UNPKG

fastlion-amis

Version:

一种MIS页面生成工具

141 lines (140 loc) 9.4 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CheckboxesControlRenderer = void 0; var tslib_1 = require("tslib"); var react_1 = (0, tslib_1.__importDefault)(require("react")); var Options_1 = require("./Options"); var Checkbox_1 = (0, tslib_1.__importDefault)(require("../../components/Checkbox")); var chunk_1 = (0, tslib_1.__importDefault)(require("lodash/chunk")); var icons_1 = require("../../components/icons"); var helper_1 = require("../../utils/helper"); var CheckboxesControl = /** @class */ (function (_super) { (0, tslib_1.__extends)(CheckboxesControl, _super); function CheckboxesControl() { return _super !== null && _super.apply(this, arguments) || this; } CheckboxesControl.prototype.reload = function () { var reload = this.props.reloadOptions; reload && reload(); }; CheckboxesControl.prototype.handleAddClick = function () { var onAdd = this.props.onAdd; onAdd && onAdd(); }; CheckboxesControl.prototype.handleEditClick = function (e, item) { var onEdit = this.props.onEdit; e.preventDefault(); e.stopPropagation(); onEdit && onEdit(item); }; CheckboxesControl.prototype.handleDeleteClick = function (e, item) { var onDelete = this.props.onDelete; e.preventDefault(); e.stopPropagation(); onDelete && onDelete(item); }; CheckboxesControl.prototype.renderGroup = function (option, index) { var _this = this; var _a; var _b = this.props, cx = _b.classnames, labelField = _b.labelField; if (!((_a = option.children) === null || _a === void 0 ? void 0 : _a.length)) { return null; } return (react_1.default.createElement("div", { key: index, className: cx('CheckboxesControl-group', option.className) }, react_1.default.createElement("label", { className: cx('CheckboxesControl-groupLabel', option.labelClassName) }, option[labelField || 'label']), option.children.map(function (option, index) { return _this.renderItem(option, index); }))); }; CheckboxesControl.prototype.renderItem = function (option, index) { var _this = this; var _a; if (option.children) { return this.renderGroup(option, index); } var _b = this.props, itemClassName = _b.itemClassName, onToggle = _b.onToggle, selectedOptions = _b.selectedOptions, disabled = _b.disabled, inline = _b.inline, labelClassName = _b.labelClassName, labelField = _b.labelField, removable = _b.removable, editable = _b.editable, __ = _b.translate, store = _b.store, name = _b.name; return (react_1.default.createElement(Checkbox_1.default, { className: itemClassName, key: index, onChange: function () { return onToggle(option); }, checked: !!~selectedOptions.indexOf(option), // Jay // disabledFormItem 禁用某些表单选项,例如checkboxex,radio,select目前用到的场景是根据input-table-dynamic的原始数据已有值来禁用 disabled: disabled || option.disabled || (name ? ((_a = store === null || store === void 0 ? void 0 : store.disabledFormItem[name]) === null || _a === void 0 ? void 0 : _a.indexOf(option.value)) > -1 : undefined), inline: inline, labelClassName: labelClassName, description: option.description }, String(option[labelField || 'label']), removable && (0, helper_1.hasAbility)(option, 'removable') ? (react_1.default.createElement("a", { "data-tooltip": __('Select.clear'), "data-position": "left" }, react_1.default.createElement(icons_1.Icon, { icon: "minus", className: "icon", onClick: function (e) { return _this.handleDeleteClick(e, option); } }))) : null, editable && (0, helper_1.hasAbility)(option, 'editable') ? (react_1.default.createElement("a", { "data-tooltip": "\u7F16\u8F91", "data-position": "left" }, react_1.default.createElement(icons_1.Icon, { icon: "pencil", className: "icon", onClick: function (e) { return _this.handleEditClick(e, option); } }))) : null)); }; CheckboxesControl.prototype.renderUnlimit = function () { var _this = this; var _a = this.props, showUnLimited = _a.showUnLimited, selectedOptions = _a.selectedOptions, cx = _a.classnames; var limitChecked = selectedOptions.length == 0; if (showUnLimited) { return (react_1.default.createElement("span", { className: cx('Checkbox-unlimited'), style: { color: limitChecked ? 'white' : undefined, background: limitChecked ? '#3574ee' : undefined }, onClick: function () { var _a, _b; _this.setState({ limitChecked: true }); (_b = (_a = _this.props).onChange) === null || _b === void 0 ? void 0 : _b.call(_a, undefined); } }, "\u4E0D\u9650\u5236")); } return null; }; CheckboxesControl.prototype.render = function () { var _this = this; var _a = this.props, className = _a.className, disabled = _a.disabled, placeholder = _a.placeholder, options = _a.options, inline = _a.inline, columnsCount = _a.columnsCount, selectedOptions = _a.selectedOptions, onToggle = _a.onToggle, onToggleAll = _a.onToggleAll, checkAll = _a.checkAll, cx = _a.classnames, itemClassName = _a.itemClassName, labelClassName = _a.labelClassName, creatable = _a.creatable, addApi = _a.addApi, createBtnLabel = _a.createBtnLabel, __ = _a.translate; var body = []; if (options && options.length) { body = options.map(function (option, key) { return _this.renderItem(option, key); }); } if (checkAll && body.length) { body.unshift(react_1.default.createElement(Checkbox_1.default, { key: "checkall", className: itemClassName, onChange: onToggleAll, checked: !!selectedOptions.length, partial: !!(selectedOptions.length && selectedOptions.length !== options.length), disabled: disabled, inline: inline, labelClassName: labelClassName }, __('Checkboxes.selectAll'))); } if (columnsCount > 0) { var weight = 12 / columnsCount; var cellClassName_1 = "Grid-col--sm" + (weight === Math.round(weight) ? weight : ''); body = (0, chunk_1.default)(body, columnsCount).map(function (group, groupIndex) { return (react_1.default.createElement("div", { className: cx('Grid'), key: groupIndex }, Array.from({ length: columnsCount }).map(function (_, index) { return (react_1.default.createElement("div", { key: index, className: cx(cellClassName_1) }, group[index])); }))); }); } return (react_1.default.createElement("div", { className: cx("CheckboxesControl", className) }, this.renderUnlimit(), body && body.length ? (body) : (react_1.default.createElement("span", { className: "Form-placeholder", style: { color: '#999' } }, __(placeholder))), (creatable || addApi) && !disabled ? (react_1.default.createElement("a", { className: cx('Checkboxes-addBtn'), onClick: this.handleAddClick }, react_1.default.createElement(icons_1.Icon, { icon: "plus", className: "icon" }), __(createBtnLabel))) : null)); }; var _a, _b; CheckboxesControl.defaultProps = { columnsCount: 0, multiple: true, placeholder: 'placeholder.noOption', creatable: false, inline: true, createBtnLabel: 'Select.createLabel' }; (0, tslib_1.__decorate)([ helper_1.autobind, (0, tslib_1.__metadata)("design:type", Function), (0, tslib_1.__metadata)("design:paramtypes", []), (0, tslib_1.__metadata)("design:returntype", void 0) ], CheckboxesControl.prototype, "handleAddClick", null); (0, tslib_1.__decorate)([ helper_1.autobind, (0, tslib_1.__metadata)("design:type", Function), (0, tslib_1.__metadata)("design:paramtypes", [typeof (_a = typeof Event !== "undefined" && Event) === "function" ? _a : Object, Object]), (0, tslib_1.__metadata)("design:returntype", void 0) ], CheckboxesControl.prototype, "handleEditClick", null); (0, tslib_1.__decorate)([ helper_1.autobind, (0, tslib_1.__metadata)("design:type", Function), (0, tslib_1.__metadata)("design:paramtypes", [typeof (_b = typeof Event !== "undefined" && Event) === "function" ? _b : Object, Object]), (0, tslib_1.__metadata)("design:returntype", void 0) ], CheckboxesControl.prototype, "handleDeleteClick", null); return CheckboxesControl; }(react_1.default.Component)); exports.default = CheckboxesControl; var CheckboxesControlRenderer = /** @class */ (function (_super) { (0, tslib_1.__extends)(CheckboxesControlRenderer, _super); function CheckboxesControlRenderer() { return _super !== null && _super.apply(this, arguments) || this; } CheckboxesControlRenderer = (0, tslib_1.__decorate)([ (0, Options_1.OptionsControl)({ type: 'checkboxes', sizeMutable: false }) ], CheckboxesControlRenderer); return CheckboxesControlRenderer; }(CheckboxesControl)); exports.CheckboxesControlRenderer = CheckboxesControlRenderer; //# sourceMappingURL=./renderers/Form/Checkboxes.js.map