import type { ExtractPropTypes, PropType } from 'vue'; import { defineComponent, computed } from 'vue'; import classNames from '../_util/classNames'; import useConfigInject from '../_util/hooks/useConfigInject'; const checkableTagProps = () => ({ prefixCls: String, checked: { type: Boolean, default: undefined }, onChange: { type: Function as PropType<(checked: boolean) => void>, }, onClick: { type: Function as PropType<(e: MouseEvent) => void>, }, 'onUpdate:checked': Function as PropType<(checked: boolean) => void>, }); export type CheckableTagProps = Partial>>; const CheckableTag = defineComponent({ name: 'ACheckableTag', props: checkableTagProps(), // emits: ['update:checked', 'change', 'click'], setup(props, { slots, emit }) { const { prefixCls } = useConfigInject('tag', props); const handleClick = (e: MouseEvent) => { const { checked } = props; emit('update:checked', !checked); emit('change', !checked); emit('click', e); }; const cls = computed(() => classNames(prefixCls.value, { [`${prefixCls.value}-checkable`]: true, [`${prefixCls.value}-checkable-checked`]: props.checked, }), ); return () => { return ( {slots.default?.()} ); }; }, }); export default CheckableTag;