You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
969 B
36 lines
969 B
import { useChildren } from '../common/relation'; |
|
import { VantComponent } from '../common/component'; |
|
VantComponent({ |
|
field: true, |
|
relation: useChildren('checkbox', function (target) { |
|
this.updateChild(target); |
|
}), |
|
props: { |
|
max: Number, |
|
value: { |
|
type: Array, |
|
observer: 'updateChildren', |
|
}, |
|
disabled: { |
|
type: Boolean, |
|
observer: 'updateChildren', |
|
}, |
|
direction: { |
|
type: String, |
|
value: 'vertical', |
|
}, |
|
}, |
|
methods: { |
|
updateChildren() { |
|
this.children.forEach((child) => this.updateChild(child)); |
|
}, |
|
updateChild(child) { |
|
const { value, disabled, direction } = this.data; |
|
child.setData({ |
|
value: value.indexOf(child.data.name) !== -1, |
|
parentDisabled: disabled, |
|
direction, |
|
}); |
|
}, |
|
}, |
|
});
|
|
|