oak-frontend-base/lib/miniprogram_npm/lin-ui/checkbox-group/index.js

121 lines
2.9 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import eventBus from '../core/utils/event-bus';
import rules from '../behaviors/rules';
Component({
behaviors: ['wx://form-field',rules],
externalClasses: ['l-class', 'l-error-text', 'l-error-text-class'],
relations: {
'../checkbox/index': {
type: 'child',
linked(target) {
this.init(target);
},
linkChanged() {
},
unlinked() {
// this.init(target);
}
}
},
properties: {
// 选项的排列方式 一行显示 or 多行显示
placement: {
type: String,
value: 'column', //column row
},
// 最多选中值
maxSelected: {
type: Number,
value: null
},
minSelected: {
type: Number,
value: null
},
},
data: {
},
attached() {
let { minSelected, maxSelected} = this.properties;
this.checkMax(minSelected, maxSelected);
},
methods: {
init(target) {
if(this._keys === undefined) this._keys = {};
if(this._selected === undefined) this._selected = {};
this.checkDefaultItem(target);
this.checkedKeyRepeat(target);
},
checkedKeyRepeat(target) {
let { key } = target.properties;
if(this._keys[key]) {
throw new Error(`keys有重复元素, checkbox的key属性不能重复${key}`);
} else {
this._keys[key] = true;
}
},
checkDefaultItem(target) {
const { key, checked, cell } = target.properties;
if(checked) {
this._selected[key] = {...cell,checked:true, value: key};
}
},
checkMax(min, max) {
if(min !== null && min < 0) {
throw new Error('最小选择个数必须大于等于0');
}
if(max !== null && max < 0) {
throw new Error('最多选择个数必须大于0');
}
if(max !== null && min !== null && min >= max) {
throw new Error('最多选择个数必须大于最小选择个数');
}
},
onEmitEventHandle(currentItem) {
currentItem.checked ? this.addSelect (currentItem):this.removeSelect(currentItem.key);
this.validatorData({
[this.data.name]: Object.values(this._selected)
});
this.triggerEvent('linchange', currentItem, {
bubbles: true,
composed: true
});
eventBus.emit(`lin-form-change-${this.id}`,this.id);
},
onEmitOverflowHandle(data){
this.triggerEvent('linout', data, {
bubbles: true,
composed: true
});
},
removeSelect(key) {
delete this._selected[key];
},
addSelect(currentItem) {
let {key, ...obj} = currentItem;
this._selected[key] = {...obj, value: key};
},
getValues() {
return Object.values(this._selected);
},
reset() {
this._selected = {};
const list = this.getRelationNodes('../checkbox/index');
return list.forEach(item => {
return item.setData({
checked: false
});
});
}
}
});