import { inject } from 'vue'; import LoadingOutlined from '@ant-design/icons-vue/LoadingOutlined'; import PropTypes from '../_util/vue-types'; import hasProp, { getOptionProps, getComponent } from '../_util/props-util'; import VcSwitch from '../vc-switch'; import Wave from '../_util/wave'; import { ConfigConsumerProps } from '../config-provider'; import warning from '../_util/warning'; const Switch = { name: 'ASwitch', __ANT_SWITCH: true, inheritAttrs: false, props: { prefixCls: PropTypes.string, // size=default and size=large are the same size: PropTypes.oneOf(['small', 'default', 'large']), disabled: PropTypes.bool, checkedChildren: PropTypes.any, unCheckedChildren: PropTypes.any, tabindex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]), checked: PropTypes.bool, defaultChecked: PropTypes.bool, autofocus: PropTypes.bool, loading: PropTypes.bool, }, setup() { return { configProvider: inject('configProvider', ConfigConsumerProps), }; }, methods: { focus() { this.refSwitchNode?.focus(); }, blur() { this.refSwitchNode?.blur(); }, saveRef(c) { this.refSwitchNode = c; }, }, created() { warning( hasProp(this, 'checked') || !('value' in this.$attrs), 'Switch', '`value` is not validate prop, do you mean `checked`?', ); }, render() { const { prefixCls: customizePrefixCls, size, loading, disabled, ...restProps } = getOptionProps( this, ); const getPrefixCls = this.configProvider.getPrefixCls; const prefixCls = getPrefixCls('switch', customizePrefixCls); const { $attrs } = this; const classes = { [$attrs.class]: $attrs.class, [`${prefixCls}-small`]: size === 'small', [`${prefixCls}-loading`]: loading, }; const loadingIcon = loading ? : null; const switchProps = { ...restProps, prefixCls, loadingIcon, checkedChildren: getComponent(this, 'checkedChildren'), unCheckedChildren: getComponent(this, 'unCheckedChildren'), disabled: disabled || loading, ...$attrs, class: classes, ref: this.saveRef, }; const comp = ; return {comp}; }, }; /* istanbul ignore next */ Switch.install = function(app) { app.component(Switch.name, Switch); }; export default Switch;