| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _vue = require("vue");
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
- var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
- var _Checkbox = _interopRequireDefault(require("./Checkbox"));
- var _FormItemContext = require("../form/FormItemContext");
- var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
- var _interface = require("./interface");
- var _default2 = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'ACheckboxGroup',
- props: (0, _interface.checkboxGroupProps)(),
- // emits: ['change', 'update:value'],
- setup: function setup(props, _ref) {
- var slots = _ref.slots,
- emit = _ref.emit,
- expose = _ref.expose;
- var formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
- var _useConfigInject = (0, _useConfigInject2.default)('checkbox', props),
- prefixCls = _useConfigInject.prefixCls,
- direction = _useConfigInject.direction;
- var mergedValue = (0, _vue.ref)((props.value === undefined ? props.defaultValue : props.value) || []);
- (0, _vue.watch)(function () {
- return props.value;
- }, function () {
- mergedValue.value = props.value || [];
- });
- var options = (0, _vue.computed)(function () {
- return props.options.map(function (option) {
- if (typeof option === 'string' || typeof option === 'number') {
- return {
- label: option,
- value: option
- };
- }
- return option;
- });
- });
- var triggerUpdate = (0, _vue.ref)(Symbol());
- var registeredValuesMap = (0, _vue.ref)(new Map());
- var cancelValue = function cancelValue(id) {
- registeredValuesMap.value.delete(id);
- triggerUpdate.value = Symbol();
- };
- var registerValue = function registerValue(id, value) {
- registeredValuesMap.value.set(id, value);
- triggerUpdate.value = Symbol();
- };
- var registeredValues = (0, _vue.ref)(new Map());
- (0, _vue.watch)(triggerUpdate, function () {
- var valuseMap = new Map();
- var _iterator = (0, _createForOfIteratorHelper2.default)(registeredValuesMap.value.values()),
- _step;
- try {
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
- var value = _step.value;
- valuseMap.set(value, true);
- }
- } catch (err) {
- _iterator.e(err);
- } finally {
- _iterator.f();
- }
- registeredValues.value = valuseMap;
- });
- var toggleOption = function toggleOption(option) {
- var optionIndex = mergedValue.value.indexOf(option.value);
- var value = (0, _toConsumableArray2.default)(mergedValue.value);
- if (optionIndex === -1) {
- value.push(option.value);
- } else {
- value.splice(optionIndex, 1);
- }
- if (props.value === undefined) {
- mergedValue.value = value;
- }
- var val = value.filter(function (val) {
- return registeredValues.value.has(val);
- }).sort(function (a, b) {
- var indexA = options.value.findIndex(function (opt) {
- return opt.value === a;
- });
- var indexB = options.value.findIndex(function (opt) {
- return opt.value === b;
- });
- return indexA - indexB;
- });
- emit('update:value', val);
- emit('change', val);
- formItemContext.onFieldChange();
- };
- (0, _vue.provide)(_interface.CheckboxGroupContextKey, {
- cancelValue: cancelValue,
- registerValue: registerValue,
- toggleOption: toggleOption,
- mergedValue: mergedValue,
- name: (0, _vue.computed)(function () {
- return props.name;
- }),
- disabled: (0, _vue.computed)(function () {
- return props.disabled;
- })
- });
- expose({
- mergedValue: mergedValue
- });
- return function () {
- var _slots$default;
- var _props$id = props.id,
- id = _props$id === void 0 ? formItemContext.id.value : _props$id;
- var children = null;
- var groupPrefixCls = "".concat(prefixCls.value, "-group");
- if (options.value && options.value.length > 0) {
- children = options.value.map(function (option) {
- var _slots$label;
- 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": "".concat(groupPrefixCls, "-item")
- }, {
- default: function _default() {
- return [option.label === undefined ? (_slots$label = slots.label) === null || _slots$label === void 0 ? void 0 : _slots$label.call(slots, option) : option.label];
- }
- });
- });
- }
- return (0, _vue.createVNode)("div", {
- "class": [groupPrefixCls, (0, _defineProperty2.default)({}, "".concat(groupPrefixCls, "-rtl"), direction.value === 'rtl')],
- "id": id
- }, [children || ((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots))]);
- };
- }
- });
- exports.default = _default2;
|