32 lines
835 B
Vue
32 lines
835 B
Vue
|
import Radio from './Radio'
|
||
|
import Wave from '../_util/wave'
|
||
|
import { getOptionProps } from '../_util/props-util'
|
||
|
|
||
|
export default {
|
||
|
name: 'ARadioButton',
|
||
|
props: {
|
||
|
...Radio.props,
|
||
|
prefixCls: {
|
||
|
default: 'ant-radio-button',
|
||
|
type: String,
|
||
|
},
|
||
|
},
|
||
|
inject: {
|
||
|
radioGroupContext: { default: undefined },
|
||
|
},
|
||
|
render () {
|
||
|
const props = getOptionProps(this)
|
||
|
const radioProps = { props, on: { ...this.$listeners }}
|
||
|
if (this.radioGroupContext) {
|
||
|
radioProps.on.change = this.radioGroupContext.onRadioChange
|
||
|
radioProps.props.checked = props.value === this.radioGroupContext.stateValue
|
||
|
radioProps.props.disabled = props.disabled || this.radioGroupContext.disabled
|
||
|
}
|
||
|
return (
|
||
|
<Wave>
|
||
|
<Radio {...radioProps}>{this.$slots.default}</Radio>
|
||
|
</Wave>
|
||
|
)
|
||
|
},
|
||
|
}
|