mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-05 10:22:44 +08:00
56 lines
1.0 KiB
TypeScript
56 lines
1.0 KiB
TypeScript
import { VantComponent } from '../common/component';
|
|
import { Weapp } from 'definitions/weapp';
|
|
|
|
VantComponent({
|
|
field: true,
|
|
|
|
relation: {
|
|
name: 'radio-group',
|
|
type: 'ancestor',
|
|
linked(target) {
|
|
this.parent = target;
|
|
},
|
|
unlinked() {
|
|
this.parent = null;
|
|
}
|
|
},
|
|
|
|
classes: ['icon-class', 'label-class'],
|
|
|
|
props: {
|
|
value: null,
|
|
disabled: Boolean,
|
|
useIconSlot: Boolean,
|
|
checkedColor: String,
|
|
labelPosition: {
|
|
type: String,
|
|
value: 'right'
|
|
},
|
|
labelDisabled: Boolean,
|
|
shape: {
|
|
type: String,
|
|
value: 'round'
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
emitChange(value: boolean) {
|
|
const instance = this.parent || this;
|
|
instance.$emit('input', value);
|
|
instance.$emit('change', value);
|
|
},
|
|
|
|
onChange(event: Weapp.Event) {
|
|
console.log(event);
|
|
this.emitChange(this.data.name);
|
|
},
|
|
|
|
onClickLabel() {
|
|
const { disabled, labelDisabled, name } = this.data;
|
|
if (!disabled && !labelDisabled) {
|
|
this.emitChange(name);
|
|
}
|
|
}
|
|
}
|
|
});
|