fastlion-amis
Version:
一种MIS页面生成工具
255 lines (254 loc) • 15.8 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.MultiSelectControlRenderer = exports.SelectControlRenderer = void 0;
var tslib_1 = require("tslib");
var react_1 = (0, tslib_1.__importDefault)(require("react"));
var classnames_1 = (0, tslib_1.__importDefault)(require("classnames"));
var Options_1 = require("./Options");
var Select_1 = tslib_1.__importStar(require("../../components/Select"));
var find_1 = (0, tslib_1.__importDefault)(require("lodash/find"));
var debounce_1 = (0, tslib_1.__importDefault)(require("lodash/debounce"));
var api_1 = require("../../utils/api");
var helper_1 = require("../../utils/helper");
var Transfer_1 = require("./Transfer");
var TransferDropDown_1 = (0, tslib_1.__importDefault)(require("../../components/TransferDropDown"));
var SelectControl = /** @class */ (function (_super) {
(0, tslib_1.__extends)(SelectControl, _super);
function SelectControl(props) {
var _this = _super.call(this, props) || this;
_this.changeValue = _this.changeValue.bind(_this);
_this.lazyloadRemote = (0, debounce_1.default)(_this.loadRemote.bind(_this), 250, {
trailing: true,
leading: false
});
_this.inputRef = _this.inputRef.bind(_this);
return _this;
}
SelectControl.prototype.componentWillUnmount = function () {
this.unHook && this.unHook();
};
SelectControl.prototype.inputRef = function (ref) {
this.input = ref;
};
SelectControl.prototype.foucs = function () {
this.input && this.input.focus();
};
SelectControl.prototype.changeValue = function (value) {
var _a = this.props, joinValues = _a.joinValues, extractValue = _a.extractValue, delimiter = _a.delimiter, multiple = _a.multiple, type = _a.type, valueField = _a.valueField, onChange = _a.onChange, setOptions = _a.setOptions, options = _a.options, name = _a.name;
var newValue = value;
var additonalOptions = [];
(Array.isArray(value) ? value : value ? [value] : []).forEach(function (option) {
var resolved = (0, find_1.default)(options, function (item) {
return item[valueField || 'value'] == option[valueField || 'value'];
});
resolved || additonalOptions.push(option);
});
if (joinValues) {
if (multiple) {
newValue = Array.isArray(value)
? value
.map(function (item) { return item[valueField || 'value']; })
.join(delimiter)
: value
? value[valueField || 'value']
: '';
}
else {
newValue = newValue ? newValue[valueField || 'value'] : '';
}
}
else if (extractValue) {
if (multiple) {
newValue = Array.isArray(value)
? value.map(function (item) { return item[valueField || 'value']; })
: value
? [value[valueField || 'value']]
: [''];
}
else {
newValue = newValue ? newValue[valueField || 'value'] : '';
}
}
// 不设置没法回显
additonalOptions.length && setOptions(options.concat(additonalOptions));
onChange(newValue);
};
SelectControl.prototype.loadRemote = function (input) {
return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
var _a, autoComplete, env, data, setOptions, setLoading, formInited, addHook, ctx, ret, options, combinedOptions;
return (0, tslib_1.__generator)(this, function (_b) {
switch (_b.label) {
case 0:
_a = this.props, autoComplete = _a.autoComplete, env = _a.env, data = _a.data, setOptions = _a.setOptions, setLoading = _a.setLoading, formInited = _a.formInited, addHook = _a.addHook;
if (!env || !env.fetcher) {
throw new Error('fetcher is required');
}
if (!formInited) {
this.unHook && this.unHook();
return [2 /*return*/, (this.unHook = addHook(this.loadRemote.bind(this, input), 'init'))];
}
ctx = (0, helper_1.createObject)(data, {
term: input,
value: input
});
if (!(0, api_1.isEffectiveApi)(autoComplete, ctx)) {
return [2 /*return*/, Promise.resolve({
options: []
})];
}
setLoading(true);
_b.label = 1;
case 1:
_b.trys.push([1, , 3, 4]);
return [4 /*yield*/, env.fetcher(autoComplete, ctx)];
case 2:
ret = _b.sent();
options = (ret.data && ret.data.options) || ret.data || [];
combinedOptions = this.mergeOptions(options);
setOptions(combinedOptions);
return [2 /*return*/, {
options: combinedOptions
}];
case 3:
setLoading(false);
return [7 /*endfinally*/];
case 4: return [2 /*return*/];
}
});
});
};
SelectControl.prototype.mergeOptions = function (options) {
var _a = this.props, selectedOptions = _a.selectedOptions, _b = _a.valueField, valueField = _b === void 0 ? 'value' : _b;
var combinedOptions = (0, Select_1.normalizeOptions)(options, undefined, valueField).concat();
if (Array.isArray(selectedOptions) && selectedOptions.length) {
selectedOptions.forEach(function (option) {
if (!(0, find_1.default)(combinedOptions, function (item) { return item.value == option.value; })) {
combinedOptions.push((0, tslib_1.__assign)((0, tslib_1.__assign)({}, option), { hidden: true }));
}
});
}
return combinedOptions;
};
SelectControl.prototype.renderMenu = function (option, state) {
var _a = this.props, menuTpl = _a.menuTpl, render = _a.render, data = _a.data;
return render("menu/" + state.index, menuTpl, {
data: (0, helper_1.createObject)((0, helper_1.createObject)(data, state), option)
});
};
SelectControl.prototype.reload = function () {
var reload = this.props.reloadOptions;
reload && reload();
};
SelectControl.prototype.option2value = function () { };
SelectControl.prototype.renderOtherMode = function () {
var _a = this.props, selectMode = _a.selectMode, env = _a.env, rest = (0, tslib_1.__rest)(_a, ["selectMode", "env"]);
return (react_1.default.createElement(TransferDropdownRenderer, (0, tslib_1.__assign)({}, rest, { popOverContainer: env.getModalContainer, env: env, selectMode: selectMode === 'group' ? 'list' : selectMode })));
};
SelectControl.prototype.render = function () {
var _a = this.props, autoComplete = _a.autoComplete, searchable = _a.searchable, options = _a.options, className = _a.className, loading = _a.loading, value = _a.value, selectedOptions = _a.selectedOptions, multi = _a.multi, multiple = _a.multiple, placeholder = _a.placeholder, id = _a.id, classPrefix = _a.classPrefix, classnames = _a.classnames, creatable = _a.creatable, inline = _a.inline, noResultsText = _a.noResultsText, render = _a.render, menuTpl = _a.menuTpl, borderMode = _a.borderMode, selectMode = _a.selectMode, env = _a.env, useMobileUI = _a.useMobileUI, rest = (0, tslib_1.__rest)(_a, ["autoComplete", "searchable", "options", "className", "loading", "value", "selectedOptions", "multi", "multiple", "placeholder", "id", "classPrefix", "classnames", "creatable", "inline", "noResultsText", "render", "menuTpl", "borderMode", "selectMode", "env", "useMobileUI"]);
if (noResultsText) {
noResultsText = render('noResultText', noResultsText);
}
var mobileUI = useMobileUI && (0, helper_1.isMobile)();
// Jay
// disabledFormItem 禁用某些表单选项,例如checkboxex,radio,select目前用到的场景是根据input-table-dynamic的原始数据已有值来禁用
var _b = this.props, store = _b.store, name = _b.name;
var clearable = rest.clearable;
var disabled = rest.disabled;
if (name && (store === null || store === void 0 ? void 0 : store.disabledFormItem[name])) {
if (multiple) {
options.forEach(function (option) {
var _a;
if (((_a = store === null || store === void 0 ? void 0 : store.disabledFormItem[name]) === null || _a === void 0 ? void 0 : _a.indexOf(option.value)) > -1) {
option.disabled = true;
clearable = false;
}
});
}
else {
disabled = options.some(function (option) { var _a; return ((_a = store === null || store === void 0 ? void 0 : store.disabledFormItem[name]) === null || _a === void 0 ? void 0 : _a.indexOf(option.value)) > -1; });
clearable = !disabled;
}
}
return (react_1.default.createElement("div", { className: (0, classnames_1.default)(classPrefix + "SelectControl", className) }, ['table', 'list', 'group', 'tree', 'chained', 'associated', 'select'].includes(selectMode) ? (this.renderOtherMode()) : (react_1.default.createElement(Select_1.default, (0, tslib_1.__assign)({}, rest, { useMobileUI: useMobileUI, popOverContainer: mobileUI && env && env.getModalContainer
? env.getModalContainer
: rest.popOverContainer, borderMode: borderMode, placeholder: placeholder, multiple: multiple || multi, ref: this.inputRef, value: selectedOptions, options: options, loadOptions: (0, api_1.isEffectiveApi)(autoComplete) ? this.lazyloadRemote : undefined, creatable: creatable, searchable: searchable || !!autoComplete, onChange: this.changeValue, loading: loading, noResultsText: noResultsText, renderMenu: menuTpl ? this.renderMenu : undefined,
// Jay
clearable: clearable, disabled: disabled })))));
};
var _a;
SelectControl.defaultProps = {
clearable: false,
searchable: false,
multiple: false
};
(0, tslib_1.__decorate)([
helper_1.autobind,
(0, tslib_1.__metadata)("design:type", Function),
(0, tslib_1.__metadata)("design:paramtypes", [typeof (_a = typeof Options_1.Option !== "undefined" && Options_1.Option) === "function" ? _a : Object, Object]),
(0, tslib_1.__metadata)("design:returntype", void 0)
], SelectControl.prototype, "renderMenu", null);
return SelectControl;
}(react_1.default.Component));
exports.default = SelectControl;
var TransferDropdownRenderer = /** @class */ (function (_super) {
(0, tslib_1.__extends)(TransferDropdownRenderer, _super);
function TransferDropdownRenderer() {
return _super !== null && _super.apply(this, arguments) || this;
}
TransferDropdownRenderer.prototype.render = function () {
var _a;
var _b = this.props, className = _b.className, cx = _b.classnames, selectedOptions = _b.selectedOptions, sortable = _b.sortable, loading = _b.loading, searchable = _b.searchable, searchResultMode = _b.searchResultMode, showArrow = _b.showArrow, deferLoad = _b.deferLoad, disabled = _b.disabled, selectTitle = _b.selectTitle, selectMode = _b.selectMode, multiple = _b.multiple, columns = _b.columns, leftMode = _b.leftMode, borderMode = _b.borderMode, useMobileUI = _b.useMobileUI, clearable = _b.clearable, // Aug
// Jay
placeholder = _b.placeholder, showCount = _b.showCount, render = _b.render, label = _b.label, domicile = _b.domicile, popOverContainer = _b.popOverContainer;
// 目前 LeftOptions 没有接口可以动态加载
// 为了方便可以快速实现动态化,让选项的第一个成员携带
// LeftOptions 信息
var _c = this.props, options = _c.options, leftOptions = _c.leftOptions, leftDefaultValue = _c.leftDefaultValue, labelTpl = _c.labelTpl;
if (selectMode === 'associated' &&
options &&
options.length === 1 &&
options[0].leftOptions &&
Array.isArray(options[0].children)) {
leftOptions = options[0].leftOptions;
leftDefaultValue = (_a = options[0].leftDefaultValue) !== null && _a !== void 0 ? _a : leftDefaultValue;
options = options[0].children;
}
// ((selectMode === 'associated' && !multiple) || (selectMode === 'group' && !multiple) || (selectMode === 'table' && !multiple) || (selectMode === 'tree' && !multiple) || (selectMode === 'chained' && !multiple) || (selectMode === 'associated' && !multiple)) ? false : true
return (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement(TransferDropDown_1.default, { selectMode: selectMode, popOverContainer: popOverContainer, className: className, value: selectedOptions, disabled: disabled, options: options, onChange: this.handleChange, option2value: this.option2value, sortable: sortable, searchResultMode: searchResultMode, onSearch: searchable ? this.handleSearch : undefined, showArrow: showArrow, onDeferLoad: deferLoad, selectTitle: selectTitle, multiple: multiple, columns: selectMode === 'table' ? this.props.$schema.columns : columns, leftMode: leftMode, leftOptions: leftOptions, borderMode: borderMode, useMobileUI: useMobileUI, clearable: clearable, labelTpl: labelTpl,
// Jay
placeholder: placeholder, showCount: showCount, render: render, loading: loading, label: label, domicile: domicile })));
};
return TransferDropdownRenderer;
}(Transfer_1.BaseTransferRenderer));
var SelectControlRenderer = /** @class */ (function (_super) {
(0, tslib_1.__extends)(SelectControlRenderer, _super);
function SelectControlRenderer() {
return _super !== null && _super.apply(this, arguments) || this;
}
SelectControlRenderer = (0, tslib_1.__decorate)([
(0, Options_1.OptionsControl)({
type: 'select'
})
], SelectControlRenderer);
return SelectControlRenderer;
}(SelectControl));
exports.SelectControlRenderer = SelectControlRenderer;
var MultiSelectControlRenderer = /** @class */ (function (_super) {
(0, tslib_1.__extends)(MultiSelectControlRenderer, _super);
function MultiSelectControlRenderer() {
return _super !== null && _super.apply(this, arguments) || this;
}
MultiSelectControlRenderer.defaultProps = {
multiple: true
};
MultiSelectControlRenderer = (0, tslib_1.__decorate)([
(0, Options_1.OptionsControl)({
type: 'multi-select'
})
], MultiSelectControlRenderer);
return MultiSelectControlRenderer;
}(SelectControl));
exports.MultiSelectControlRenderer = MultiSelectControlRenderer;
//# sourceMappingURL=./renderers/Form/Select.js.map