Group.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.radioGroupProps = exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  10. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  11. var _Radio = _interopRequireDefault(require("./Radio"));
  12. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  13. var _type = require("../_util/type");
  14. var _FormItemContext = require("../form/FormItemContext");
  15. var _context = require("./context");
  16. var _style = _interopRequireDefault(require("./style"));
  17. // CSSINJS
  18. const RadioGroupSizeTypes = ['large', 'default', 'small'];
  19. const radioGroupProps = () => ({
  20. prefixCls: String,
  21. value: _vueTypes.default.any,
  22. size: (0, _type.stringType)(),
  23. options: (0, _type.arrayType)(),
  24. disabled: (0, _type.booleanType)(),
  25. name: String,
  26. buttonStyle: (0, _type.stringType)('outline'),
  27. id: String,
  28. optionType: (0, _type.stringType)('default'),
  29. onChange: (0, _type.functionType)(),
  30. 'onUpdate:value': (0, _type.functionType)()
  31. });
  32. exports.radioGroupProps = radioGroupProps;
  33. var _default = exports.default = (0, _vue.defineComponent)({
  34. compatConfig: {
  35. MODE: 3
  36. },
  37. name: 'ARadioGroup',
  38. inheritAttrs: false,
  39. props: radioGroupProps(),
  40. // emits: ['update:value', 'change'],
  41. setup(props, _ref) {
  42. let {
  43. slots,
  44. emit,
  45. attrs
  46. } = _ref;
  47. const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
  48. const {
  49. prefixCls,
  50. direction,
  51. size
  52. } = (0, _useConfigInject.default)('radio', props);
  53. // Style
  54. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  55. const stateValue = (0, _vue.ref)(props.value);
  56. const updatingValue = (0, _vue.ref)(false);
  57. (0, _vue.watch)(() => props.value, val => {
  58. stateValue.value = val;
  59. updatingValue.value = false;
  60. });
  61. const onRadioChange = ev => {
  62. const lastValue = stateValue.value;
  63. const {
  64. value
  65. } = ev.target;
  66. if (!('value' in props)) {
  67. stateValue.value = value;
  68. }
  69. // nextTick for https://github.com/vueComponent/ant-design-vue/issues/1280
  70. if (!updatingValue.value && value !== lastValue) {
  71. updatingValue.value = true;
  72. emit('update:value', value);
  73. emit('change', ev);
  74. formItemContext.onFieldChange();
  75. }
  76. (0, _vue.nextTick)(() => {
  77. updatingValue.value = false;
  78. });
  79. };
  80. (0, _context.useProvideRadioGroupContext)({
  81. onChange: onRadioChange,
  82. value: stateValue,
  83. disabled: (0, _vue.computed)(() => props.disabled),
  84. name: (0, _vue.computed)(() => props.name),
  85. optionType: (0, _vue.computed)(() => props.optionType)
  86. });
  87. return () => {
  88. var _a;
  89. const {
  90. options,
  91. buttonStyle,
  92. id = formItemContext.id.value
  93. } = props;
  94. const groupPrefixCls = `${prefixCls.value}-group`;
  95. const classString = (0, _classNames.default)(groupPrefixCls, `${groupPrefixCls}-${buttonStyle}`, {
  96. [`${groupPrefixCls}-${size.value}`]: size.value,
  97. [`${groupPrefixCls}-rtl`]: direction.value === 'rtl'
  98. }, attrs.class, hashId.value);
  99. let children = null;
  100. if (options && options.length > 0) {
  101. children = options.map(option => {
  102. if (typeof option === 'string' || typeof option === 'number') {
  103. return (0, _vue.createVNode)(_Radio.default, {
  104. "key": option,
  105. "prefixCls": prefixCls.value,
  106. "disabled": props.disabled,
  107. "value": option,
  108. "checked": stateValue.value === option
  109. }, {
  110. default: () => [option]
  111. });
  112. }
  113. const {
  114. value,
  115. disabled,
  116. label
  117. } = option;
  118. return (0, _vue.createVNode)(_Radio.default, {
  119. "key": `radio-group-value-options-${value}`,
  120. "prefixCls": prefixCls.value,
  121. "disabled": disabled || props.disabled,
  122. "value": value,
  123. "checked": stateValue.value === value
  124. }, {
  125. default: () => [label]
  126. });
  127. });
  128. } else {
  129. children = (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots);
  130. }
  131. return wrapSSR((0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
  132. "class": classString,
  133. "id": id
  134. }), [children]));
  135. };
  136. }
  137. });