ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
134 lines (133 loc) • 4.84 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _vue = require("vue");
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _Checkbox = _interopRequireDefault(require("./Checkbox"));
var _FormItemContext = require("../form/FormItemContext");
var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
var _interface = require("./interface");
var _style = _interopRequireDefault(require("./style"));
// CSSINJS
var _default = exports.default = (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: 'ACheckboxGroup',
inheritAttrs: false,
props: (0, _interface.checkboxGroupProps)(),
// emits: ['change', 'update:value'],
setup(props, _ref) {
let {
slots,
attrs,
emit,
expose
} = _ref;
const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
const {
prefixCls,
direction
} = (0, _useConfigInject.default)('checkbox', props);
const groupPrefixCls = (0, _vue.computed)(() => `${prefixCls.value}-group`);
// style
const [wrapSSR, hashId] = (0, _style.default)(groupPrefixCls);
const mergedValue = (0, _vue.ref)((props.value === undefined ? props.defaultValue : props.value) || []);
(0, _vue.watch)(() => props.value, () => {
mergedValue.value = props.value || [];
});
const options = (0, _vue.computed)(() => {
return props.options.map(option => {
if (typeof option === 'string' || typeof option === 'number') {
return {
label: option,
value: option
};
}
return option;
});
});
const triggerUpdate = (0, _vue.ref)(Symbol());
const registeredValuesMap = (0, _vue.ref)(new Map());
const cancelValue = id => {
registeredValuesMap.value.delete(id);
triggerUpdate.value = Symbol();
};
const registerValue = (id, value) => {
registeredValuesMap.value.set(id, value);
triggerUpdate.value = Symbol();
};
const registeredValues = (0, _vue.ref)(new Map());
(0, _vue.watch)(triggerUpdate, () => {
const valuseMap = new Map();
for (const value of registeredValuesMap.value.values()) {
valuseMap.set(value, true);
}
registeredValues.value = valuseMap;
});
const toggleOption = option => {
const optionIndex = mergedValue.value.indexOf(option.value);
const value = [...mergedValue.value];
if (optionIndex === -1) {
value.push(option.value);
} else {
value.splice(optionIndex, 1);
}
if (props.value === undefined) {
mergedValue.value = value;
}
const val = value.filter(val => registeredValues.value.has(val)).sort((a, b) => {
const indexA = options.value.findIndex(opt => opt.value === a);
const indexB = options.value.findIndex(opt => opt.value === b);
return indexA - indexB;
});
emit('update:value', val);
emit('change', val);
formItemContext.onFieldChange();
};
(0, _vue.provide)(_interface.CheckboxGroupContextKey, {
cancelValue,
registerValue,
toggleOption,
mergedValue,
name: (0, _vue.computed)(() => props.name),
disabled: (0, _vue.computed)(() => props.disabled)
});
expose({
mergedValue
});
return () => {
var _a;
const {
id = formItemContext.id.value
} = props;
let children = null;
if (options.value && options.value.length > 0) {
children = options.value.map(option => {
var _a;
return (0, _vue.createVNode)(_Checkbox.default, {
"prefixCls": prefixCls.value,
"key": option.value.toString(),
"disabled": 'disabled' in option ? option.disabled : props.disabled,
"indeterminate": option.indeterminate,
"value": option.value,
"checked": mergedValue.value.indexOf(option.value) !== -1,
"onChange": option.onChange,
"class": `${groupPrefixCls.value}-item`
}, {
default: () => [slots.label !== undefined ? (_a = slots.label) === null || _a === void 0 ? void 0 : _a.call(slots, option) : option.label]
});
});
}
return wrapSSR((0, _vue.createVNode)("div", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
"class": [groupPrefixCls.value, {
[`${groupPrefixCls.value}-rtl`]: direction.value === 'rtl'
}, attrs.class, hashId.value],
"id": id
}), [children || ((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots))]));
};
}
});
;