Files
vant/src/radio-group/index.tsx
2021-03-02 17:45:12 +08:00

54 lines
1.2 KiB
TypeScript

import { watch } from 'vue';
import { UnknownProp, createNamespace } from '../utils';
import { useChildren } from '@vant/use';
import { useLinkField } from '../composables/use-link-field';
import { CheckerParent } from '../checkbox/Checker';
const [createComponent, bem] = createNamespace('radio-group');
export const RADIO_KEY = 'vanRadio';
export type RadioGroupProvide = CheckerParent & {
props: {
modelValue: unknown;
};
updateModelValue: (value: unknown) => void;
};
export default createComponent({
props: {
disabled: Boolean,
iconSize: [Number, String],
direction: String,
modelValue: UnknownProp,
checkedColor: String,
},
emits: ['change', 'update:modelValue'],
setup(props, { emit, slots }) {
const { linkChildren } = useChildren(RADIO_KEY);
const updateModelValue = (value: unknown) =>
emit('update:modelValue', value);
watch(
() => props.modelValue,
(value) => emit('change', value)
);
linkChildren({
props,
updateModelValue,
});
useLinkField(() => props.modelValue);
return () => (
<div class={bem([props.direction])} role="radiogroup">
{slots.default?.()}
</div>
);
},
});