index.js 7.8 KB

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