mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
86 lines
1.8 KiB
JavaScript
86 lines
1.8 KiB
JavaScript
import { createNamespace } from '../utils';
|
|
import { CheckboxMixin } from '../mixins/checkbox';
|
|
|
|
const [createComponent, bem] = createNamespace('checkbox');
|
|
|
|
export default createComponent({
|
|
mixins: [CheckboxMixin({
|
|
bem,
|
|
role: 'checkbox',
|
|
parent: 'vanCheckbox'
|
|
})],
|
|
|
|
computed: {
|
|
checked: {
|
|
get() {
|
|
return this.parent ? this.parent.value.indexOf(this.name) !== -1 : this.value;
|
|
},
|
|
|
|
set(val) {
|
|
if (this.parent) {
|
|
this.setParentValue(val);
|
|
} else {
|
|
this.$emit('input', val);
|
|
}
|
|
}
|
|
}
|
|
},
|
|
|
|
watch: {
|
|
value(val) {
|
|
this.$emit('change', val);
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
toggle() {
|
|
const checked = !this.checked;
|
|
|
|
// When toggle method is called multiple times at the same time,
|
|
// only the last call is valid.
|
|
// This is a hack for usage inside Cell.
|
|
clearTimeout(this.toggleTask);
|
|
this.toggleTask = setTimeout(() => {
|
|
this.checked = checked;
|
|
});
|
|
},
|
|
|
|
onClickIcon() {
|
|
if (!this.isDisabled) {
|
|
this.toggle();
|
|
}
|
|
},
|
|
|
|
onClickLabel() {
|
|
if (!this.isDisabled && !this.labelDisabled) {
|
|
this.toggle();
|
|
}
|
|
},
|
|
|
|
setParentValue(val) {
|
|
const { parent } = this;
|
|
const value = parent.value.slice();
|
|
|
|
if (val) {
|
|
if (parent.max && value.length >= parent.max) {
|
|
return;
|
|
}
|
|
|
|
/* istanbul ignore else */
|
|
if (value.indexOf(this.name) === -1) {
|
|
value.push(this.name);
|
|
parent.$emit('input', value);
|
|
}
|
|
} else {
|
|
const index = value.indexOf(this.name);
|
|
|
|
/* istanbul ignore else */
|
|
if (index !== -1) {
|
|
value.splice(index, 1);
|
|
parent.$emit('input', value);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
});
|