import classNames from 'classnames'; import PropTypes from '../_util/vue-types'; import Radio from './Radio'; import { getOptionProps, filterEmpty, hasProp } from '../_util/props-util'; import { ConfigConsumerProps } from '../config-provider'; function noop() {} export default { name: 'ARadioGroup', model: { prop: 'value', }, props: { prefixCls: PropTypes.string, defaultValue: PropTypes.any, value: PropTypes.any, size: { default: 'default', validator(value) { return ['large', 'default', 'small'].includes(value); }, }, options: { default: () => [], type: Array, }, disabled: Boolean, name: String, buttonStyle: PropTypes.string.def('outline'), }, data() { const { value, defaultValue } = this; return { stateValue: value === undefined ? defaultValue : value, }; }, provide() { return { radioGroupContext: this, }; }, inject: { configProvider: { default: () => ConfigConsumerProps }, }, computed: { radioOptions() { const { disabled } = this; return this.options.map(option => { return typeof option === 'string' ? { label: option, value: option } : { ...option, disabled: option.disabled === undefined ? disabled : option.disabled }; }); }, classes() { const { prefixCls, size } = this; return { [`${prefixCls}`]: true, [`${prefixCls}-${size}`]: size, }; }, }, watch: { value(val) { this.stateValue = val; }, }, methods: { onRadioChange(ev) { const lastValue = this.stateValue; const { value } = ev.target; if (!hasProp(this, 'value')) { this.stateValue = value; } if (value !== lastValue) { this.$emit('input', value); this.$emit('change', ev); } }, }, render() { const { mouseenter = noop, mouseleave = noop } = this.$listeners; const props = getOptionProps(this); const { prefixCls: customizePrefixCls, options, buttonStyle } = props; const getPrefixCls = this.configProvider.getPrefixCls; const prefixCls = getPrefixCls('radio', customizePrefixCls); const groupPrefixCls = `${prefixCls}-group`; const classString = classNames(groupPrefixCls, `${groupPrefixCls}-${buttonStyle}`, { [`${groupPrefixCls}-${props.size}`]: props.size, }); let children = filterEmpty(this.$slots.default); // 如果存在 options, 优先使用 if (options && options.length > 0) { children = options.map((option, index) => { if (typeof option === 'string') { return ( {option} ); } else { return ( {option.label} ); } }); } return (
{children}
); }, };