index.js 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.switchProps = exports.default = exports.SwitchSizes = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _LoadingOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/LoadingOutlined"));
  10. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  11. var _KeyCode = _interopRequireDefault(require("../_util/KeyCode"));
  12. var _wave = _interopRequireDefault(require("../_util/wave"));
  13. var _warning = _interopRequireDefault(require("../_util/warning"));
  14. var _type = require("../_util/type");
  15. var _propsUtil = require("../_util/props-util");
  16. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  17. var _FormItemContext = require("../form/FormItemContext");
  18. var _omit = _interopRequireDefault(require("../_util/omit"));
  19. var _style = _interopRequireDefault(require("./style"));
  20. var _DisabledContext = require("../config-provider/DisabledContext");
  21. const SwitchSizes = exports.SwitchSizes = (0, _type.tuple)('small', 'default');
  22. const switchProps = () => ({
  23. id: String,
  24. prefixCls: String,
  25. size: _vueTypes.default.oneOf(SwitchSizes),
  26. disabled: {
  27. type: Boolean,
  28. default: undefined
  29. },
  30. checkedChildren: _vueTypes.default.any,
  31. unCheckedChildren: _vueTypes.default.any,
  32. tabindex: _vueTypes.default.oneOfType([_vueTypes.default.string, _vueTypes.default.number]),
  33. autofocus: {
  34. type: Boolean,
  35. default: undefined
  36. },
  37. loading: {
  38. type: Boolean,
  39. default: undefined
  40. },
  41. checked: _vueTypes.default.oneOfType([_vueTypes.default.string, _vueTypes.default.number, _vueTypes.default.looseBool]),
  42. checkedValue: _vueTypes.default.oneOfType([_vueTypes.default.string, _vueTypes.default.number, _vueTypes.default.looseBool]).def(true),
  43. unCheckedValue: _vueTypes.default.oneOfType([_vueTypes.default.string, _vueTypes.default.number, _vueTypes.default.looseBool]).def(false),
  44. onChange: {
  45. type: Function
  46. },
  47. onClick: {
  48. type: Function
  49. },
  50. onKeydown: {
  51. type: Function
  52. },
  53. onMouseup: {
  54. type: Function
  55. },
  56. 'onUpdate:checked': {
  57. type: Function
  58. },
  59. onBlur: Function,
  60. onFocus: Function
  61. });
  62. exports.switchProps = switchProps;
  63. const Switch = (0, _vue.defineComponent)({
  64. compatConfig: {
  65. MODE: 3
  66. },
  67. name: 'ASwitch',
  68. __ANT_SWITCH: true,
  69. inheritAttrs: false,
  70. props: switchProps(),
  71. slots: Object,
  72. // emits: ['update:checked', 'mouseup', 'change', 'click', 'keydown', 'blur'],
  73. setup(props, _ref) {
  74. let {
  75. attrs,
  76. slots,
  77. expose,
  78. emit
  79. } = _ref;
  80. const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
  81. const disabledContext = (0, _DisabledContext.useInjectDisabled)();
  82. const mergedDisabled = (0, _vue.computed)(() => {
  83. var _a;
  84. return (_a = props.disabled) !== null && _a !== void 0 ? _a : disabledContext.value;
  85. });
  86. (0, _vue.onBeforeMount)(() => {
  87. (0, _warning.default)(!('defaultChecked' in attrs), 'Switch', `'defaultChecked' is deprecated, please use 'v-model:checked'`);
  88. (0, _warning.default)(!('value' in attrs), 'Switch', '`value` is not validate prop, do you mean `checked`?');
  89. });
  90. const checked = (0, _vue.ref)(props.checked !== undefined ? props.checked : attrs.defaultChecked);
  91. const checkedStatus = (0, _vue.computed)(() => checked.value === props.checkedValue);
  92. (0, _vue.watch)(() => props.checked, () => {
  93. checked.value = props.checked;
  94. });
  95. const {
  96. prefixCls,
  97. direction,
  98. size
  99. } = (0, _useConfigInject.default)('switch', props);
  100. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  101. const refSwitchNode = (0, _vue.ref)();
  102. const focus = () => {
  103. var _a;
  104. (_a = refSwitchNode.value) === null || _a === void 0 ? void 0 : _a.focus();
  105. };
  106. const blur = () => {
  107. var _a;
  108. (_a = refSwitchNode.value) === null || _a === void 0 ? void 0 : _a.blur();
  109. };
  110. expose({
  111. focus,
  112. blur
  113. });
  114. (0, _vue.onMounted)(() => {
  115. (0, _vue.nextTick)(() => {
  116. if (props.autofocus && !mergedDisabled.value) {
  117. refSwitchNode.value.focus();
  118. }
  119. });
  120. });
  121. const setChecked = (check, e) => {
  122. if (mergedDisabled.value) {
  123. return;
  124. }
  125. emit('update:checked', check);
  126. emit('change', check, e);
  127. formItemContext.onFieldChange();
  128. };
  129. const handleBlur = e => {
  130. emit('blur', e);
  131. };
  132. const handleClick = e => {
  133. focus();
  134. const newChecked = checkedStatus.value ? props.unCheckedValue : props.checkedValue;
  135. setChecked(newChecked, e);
  136. emit('click', newChecked, e);
  137. };
  138. const handleKeyDown = e => {
  139. if (e.keyCode === _KeyCode.default.LEFT) {
  140. setChecked(props.unCheckedValue, e);
  141. } else if (e.keyCode === _KeyCode.default.RIGHT) {
  142. setChecked(props.checkedValue, e);
  143. }
  144. emit('keydown', e);
  145. };
  146. const handleMouseUp = e => {
  147. var _a;
  148. (_a = refSwitchNode.value) === null || _a === void 0 ? void 0 : _a.blur();
  149. emit('mouseup', e);
  150. };
  151. const classNames = (0, _vue.computed)(() => ({
  152. [`${prefixCls.value}-small`]: size.value === 'small',
  153. [`${prefixCls.value}-loading`]: props.loading,
  154. [`${prefixCls.value}-checked`]: checkedStatus.value,
  155. [`${prefixCls.value}-disabled`]: mergedDisabled.value,
  156. [prefixCls.value]: true,
  157. [`${prefixCls.value}-rtl`]: direction.value === 'rtl',
  158. [hashId.value]: true
  159. }));
  160. return () => {
  161. var _a;
  162. return wrapSSR((0, _vue.createVNode)(_wave.default, null, {
  163. default: () => [(0, _vue.createVNode)("button", (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _omit.default)(props, ['prefixCls', 'checkedChildren', 'unCheckedChildren', 'checked', 'autofocus', 'checkedValue', 'unCheckedValue', 'id', 'onChange', 'onUpdate:checked'])), attrs), {}, {
  164. "id": (_a = props.id) !== null && _a !== void 0 ? _a : formItemContext.id.value,
  165. "onKeydown": handleKeyDown,
  166. "onClick": handleClick,
  167. "onBlur": handleBlur,
  168. "onMouseup": handleMouseUp,
  169. "type": "button",
  170. "role": "switch",
  171. "aria-checked": checked.value,
  172. "disabled": mergedDisabled.value || props.loading,
  173. "class": [attrs.class, classNames.value],
  174. "ref": refSwitchNode
  175. }), [(0, _vue.createVNode)("div", {
  176. "class": `${prefixCls.value}-handle`
  177. }, [props.loading ? (0, _vue.createVNode)(_LoadingOutlined.default, {
  178. "class": `${prefixCls.value}-loading-icon`
  179. }, null) : null]), (0, _vue.createVNode)("span", {
  180. "class": `${prefixCls.value}-inner`
  181. }, [(0, _vue.createVNode)("span", {
  182. "class": `${prefixCls.value}-inner-checked`
  183. }, [(0, _propsUtil.getPropsSlot)(slots, props, 'checkedChildren')]), (0, _vue.createVNode)("span", {
  184. "class": `${prefixCls.value}-inner-unchecked`
  185. }, [(0, _propsUtil.getPropsSlot)(slots, props, 'unCheckedChildren')])])])]
  186. }));
  187. };
  188. }
  189. });
  190. var _default = exports.default = (0, _type.withInstall)(Switch);