UNPKG

vxe-table-demonic

Version:

一个基于 vue 的 PC 端表单/表格组件,支持增删改查、虚拟列表、虚拟树、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、弹窗、自定义模板、渲染器、JSON 配置式...

97 lines (96 loc) 3.01 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _vue = require("vue"); var _conf = _interopRequireDefault(require("../../v-x-e-table/src/conf")); var _xeUtils = _interopRequireDefault(require("xe-utils")); var _size = require("../../hooks/size"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var _default = (0, _vue.defineComponent)({ name: 'VxeCheckboxGroup', props: { modelValue: Array, disabled: Boolean, max: { type: [String, Number], default: null }, size: { type: String, default: function () { return _conf.default.checkbox.size || _conf.default.size; } } }, emits: ['update:modelValue', 'change'], setup: function (props, context) { var slots = context.slots, emit = context.emit; var $xeform = (0, _vue.inject)('$xeform', null); var $xeformiteminfo = (0, _vue.inject)('$xeformiteminfo', null); var xID = _xeUtils.default.uniqueId(); var computeIsMaximize = (0, _vue.computed)(function () { var modelValue = props.modelValue, max = props.max; if (max) { return (modelValue ? modelValue.length : 0) >= _xeUtils.default.toNumber(max); } return false; }); var computeMaps = { computeIsMaximize: computeIsMaximize }; var $xecheckboxgroup = { xID: xID, props: props, context: context, getComputeMaps: function () { return computeMaps; } }; (0, _size.useSize)(props); var checkboxGroupMethods = { dispatchEvent: function (type, params, evnt) { emit(type, Object.assign({ $checkboxGroup: $xecheckboxgroup, $event: evnt }, params)); } }; var checkboxGroupPrivateMethods = { handleChecked: function (params, evnt) { var checked = params.checked, label = params.label; var checklist = props.modelValue || []; var checkIndex = checklist.indexOf(label); if (checked) { if (checkIndex === -1) { checklist.push(label); } } else { checklist.splice(checkIndex, 1); } emit('update:modelValue', checklist); $xecheckboxgroup.dispatchEvent('change', Object.assign({ checklist: checklist }, params), evnt); // 自动更新校验状态 if ($xeform && $xeformiteminfo) { $xeform.triggerItemEvent(evnt, $xeformiteminfo.itemConfig.field, checklist); } } }; Object.assign($xecheckboxgroup, checkboxGroupMethods, checkboxGroupPrivateMethods); var renderVN = function () { return (0, _vue.h)('div', { class: 'vxe-checkbox-group' }, slots.default ? slots.default({}) : []); }; $xecheckboxgroup.renderVN = renderVN; (0, _vue.provide)('$xecheckboxgroup', $xecheckboxgroup); return renderVN; } }); exports.default = _default;