fastlion-amis
Version:
一种MIS页面生成工具
91 lines (90 loc) • 7.21 kB
JavaScript
"use strict";
/**
* 关联多选框,仅支持两层关联选择。
* 左边先点选,然后右边再次点选。
* 可以满足,先从 tree 中选中一个元素,然后查出来一个列表再次勾选。
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.AssociatedCheckboxes = void 0;
var tslib_1 = require("tslib");
var react_1 = (0, tslib_1.__importDefault)(require("react"));
var Checkboxes_1 = require("./Checkboxes");
var Select_1 = require("./Select");
var helper_1 = require("../utils/helper");
var ListRadios_1 = (0, tslib_1.__importDefault)(require("./ListRadios"));
var theme_1 = require("../theme");
var uncontrollable_1 = require("uncontrollable");
var ListCheckboxes_1 = (0, tslib_1.__importDefault)(require("./ListCheckboxes"));
var TableCheckboxes_1 = (0, tslib_1.__importDefault)(require("./TableCheckboxes"));
var TreeCheckboxes_1 = (0, tslib_1.__importDefault)(require("./TreeCheckboxes"));
var ChainedCheckboxes_1 = (0, tslib_1.__importDefault)(require("./ChainedCheckboxes"));
var TreeRadios_1 = (0, tslib_1.__importDefault)(require("./TreeRadios"));
var icons_1 = require("./icons");
var locale_1 = require("../locale");
var AssociatedCheckboxes = /** @class */ (function (_super) {
(0, tslib_1.__extends)(AssociatedCheckboxes, _super);
function AssociatedCheckboxes() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.state = {
leftValue: _this.props.leftDefaultValue
};
return _this;
}
AssociatedCheckboxes.prototype.componentDidMount = function () {
var leftValue = this.state.leftValue;
var _a = this.props, options = _a.options, onDeferLoad = _a.onDeferLoad;
if (leftValue) {
var selectdOption = ListRadios_1.default.resolveSelected(leftValue, options, function (option) { return option.ref; });
if (selectdOption && onDeferLoad && selectdOption.defer) {
onDeferLoad(selectdOption);
}
}
};
AssociatedCheckboxes.prototype.leftOption2Value = function (option) {
return option.value;
};
AssociatedCheckboxes.prototype.handleLeftSelect = function (value) {
var _a = this.props, options = _a.options, onDeferLoad = _a.onDeferLoad;
this.setState({ leftValue: value });
var selectdOption = ListRadios_1.default.resolveSelected(value, options, function (option) { return option.ref; });
if (selectdOption && onDeferLoad && selectdOption.defer) {
onDeferLoad(selectdOption);
}
};
AssociatedCheckboxes.prototype.handleRetry = function (option) {
var onDeferLoad = this.props.onDeferLoad;
onDeferLoad === null || onDeferLoad === void 0 ? void 0 : onDeferLoad(option);
};
AssociatedCheckboxes.prototype.render = function () {
var _a = this.props, cx = _a.classnames, className = _a.className, leftOptions = _a.leftOptions, options = _a.options, option2value = _a.option2value, rightMode = _a.rightMode, onChange = _a.onChange, columns = _a.columns, value = _a.value, disabled = _a.disabled, leftMode = _a.leftMode, cellRender = _a.cellRender;
var selectdOption = ListRadios_1.default.resolveSelected(this.state.leftValue, options, function (option) { return option.ref; });
var __ = this.props.translate;
return (react_1.default.createElement("div", { className: cx('AssociatedCheckboxes', className) },
react_1.default.createElement("div", { className: cx('AssociatedCheckboxes-left') }, leftMode === 'tree' ? (react_1.default.createElement(TreeRadios_1.default, { option2value: this.leftOption2Value, options: leftOptions, value: this.state.leftValue, disabled: disabled, onChange: this.handleLeftSelect, showRadio: false })) : (react_1.default.createElement(ListRadios_1.default, { option2value: this.leftOption2Value, options: leftOptions, value: this.state.leftValue, disabled: disabled, onChange: this.handleLeftSelect, showRadio: false }))),
react_1.default.createElement("div", { className: cx('AssociatedCheckboxes-right') }, this.state.leftValue ? (selectdOption ? (selectdOption.defer && !selectdOption.loaded ? (react_1.default.createElement("div", { className: cx('AssociatedCheckboxes-box') },
react_1.default.createElement("div", { className: cx('AssociatedCheckboxes-reload', selectdOption.loading ? 'is-spin' : 'is-clickable'), onClick: selectdOption.loading
? undefined
: this.handleRetry.bind(this, selectdOption) },
react_1.default.createElement(icons_1.Icon, { icon: "reload", className: "icon" })),
selectdOption.loading ? (react_1.default.createElement("p", null, __('loading'))) : (react_1.default.createElement("p", null, __('Transfer.refreshIcon'))))) : rightMode === 'table' ? (react_1.default.createElement(TableCheckboxes_1.default, { columns: columns, value: value, disabled: disabled, options: selectdOption.children || [], onChange: onChange, option2value: option2value, cellRender: cellRender })) : rightMode === 'tree' ? (react_1.default.createElement(TreeCheckboxes_1.default, { value: value, disabled: disabled, options: selectdOption.children || [], onChange: onChange, option2value: option2value })) : rightMode === 'chained' ? (react_1.default.createElement(ChainedCheckboxes_1.default, { value: value, disabled: disabled, options: selectdOption.children || [], onChange: onChange, option2value: option2value })) : (react_1.default.createElement(ListCheckboxes_1.default, { value: value, disabled: disabled, options: selectdOption.children || [], onChange: onChange, option2value: option2value }))) : (react_1.default.createElement("div", { className: cx('AssociatedCheckboxes-box') }, __('Transfer.configError')))) : (react_1.default.createElement("div", { className: cx('AssociatedCheckboxes-box') }, __('Transfer.selectFromLeft'))))));
};
var _a, _b;
(0, tslib_1.__decorate)([
helper_1.autobind,
(0, tslib_1.__metadata)("design:type", Function),
(0, tslib_1.__metadata)("design:paramtypes", [typeof (_a = typeof Select_1.Option !== "undefined" && Select_1.Option) === "function" ? _a : Object]),
(0, tslib_1.__metadata)("design:returntype", void 0)
], AssociatedCheckboxes.prototype, "leftOption2Value", null);
(0, tslib_1.__decorate)([
helper_1.autobind,
(0, tslib_1.__metadata)("design:type", Function),
(0, tslib_1.__metadata)("design:paramtypes", [typeof (_b = typeof Select_1.Option !== "undefined" && Select_1.Option) === "function" ? _b : Object]),
(0, tslib_1.__metadata)("design:returntype", void 0)
], AssociatedCheckboxes.prototype, "handleLeftSelect", null);
return AssociatedCheckboxes;
}(Checkboxes_1.BaseCheckboxes));
exports.AssociatedCheckboxes = AssociatedCheckboxes;
exports.default = (0, theme_1.themeable)((0, locale_1.localeable)((0, uncontrollable_1.uncontrollable)(AssociatedCheckboxes, {
value: 'onChange'
})));
//# sourceMappingURL=./components/AssociatedCheckboxes.js.map