UNPKG

amis

Version:

一种MIS页面生成工具

246 lines (245 loc) 12.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.NavigationRenderer = exports.Navigation = void 0; var tslib_1 = require("tslib"); var react_1 = tslib_1.__importDefault(require("react")); var factory_1 = require("../factory"); var filter_schema_1 = tslib_1.__importDefault(require("../utils/filter-schema")); var tpl_1 = require("../utils/tpl"); var helper_1 = require("../utils/helper"); var Scoped_1 = require("../Scoped"); var theme_1 = require("../theme"); var icons_1 = require("../components/icons"); var icon_1 = require("../utils/icon"); var WithRemoteConfig_1 = require("../components/WithRemoteConfig"); var Spinner_1 = tslib_1.__importDefault(require("../components/Spinner")); var Navigation = /** @class */ (function (_super) { tslib_1.__extends(Navigation, _super); function Navigation() { return _super !== null && _super.apply(this, arguments) || this; } Navigation.prototype.handleClick = function (link) { var _a, _b; (_b = (_a = this.props).onSelect) === null || _b === void 0 ? void 0 : _b.call(_a, link); }; Navigation.prototype.toggleLink = function (target) { var _a, _b; (_b = (_a = this.props).onToggle) === null || _b === void 0 ? void 0 : _b.call(_a, target); }; Navigation.prototype.renderItem = function (link, index, depth) { var _this = this; var _a; if (depth === void 0) { depth = 1; } if (link.hidden === true || link.visible === false) { return null; } var isActive = !!link.active; var _b = this.props, disabled = _b.disabled, togglerClassName = _b.togglerClassName, cx = _b.classnames, indentSize = _b.indentSize; var hasSub = (link.defer && !link.loaded) || (link.children && link.children.length); return (react_1.default.createElement("li", { key: index, className: cx('Nav-item', link.className, { 'is-disabled': disabled || link.disabled || link.loading, 'is-active': isActive, 'is-unfolded': link.unfolded, 'has-sub': hasSub }) }, react_1.default.createElement("a", { onClick: this.handleClick.bind(this, link), style: { paddingLeft: depth * ((_a = parseInt(indentSize, 10)) !== null && _a !== void 0 ? _a : 24) } }, icon_1.generateIcon(cx, link.icon, 'Nav-itemIcon'), link.label), link.loading ? (react_1.default.createElement(Spinner_1.default, { size: "sm", show: true, icon: "reload", spinnerClassName: cx('Nav-spinner') })) : hasSub ? (react_1.default.createElement("span", { onClick: function () { return _this.toggleLink(link); }, className: cx('Nav-itemToggler', togglerClassName) }, react_1.default.createElement(icons_1.Icon, { icon: "caret", className: "icon" }))) : null, Array.isArray(link.children) && link.children.length ? (react_1.default.createElement("ul", { className: cx('Nav-subItems') }, link.children.map(function (link, index) { return _this.renderItem(link, index, depth + 1); }))) : null)); }; Navigation.prototype.render = function () { var _this = this; var _a = this.props, className = _a.className, stacked = _a.stacked, cx = _a.classnames, links = _a.links, loading = _a.loading; return (react_1.default.createElement("ul", { className: cx('Nav', className, stacked ? 'Nav--stacked' : 'Nav--tabs') }, Array.isArray(links) ? links.map(function (item, index) { return _this.renderItem(item, index); }) : null, react_1.default.createElement(Spinner_1.default, { show: !!loading, overlay: true, icon: "reload" }))); }; Navigation.defaultProps = { indentSize: 24 }; tslib_1.__decorate([ helper_1.autobind, tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], Navigation.prototype, "handleClick", null); tslib_1.__decorate([ helper_1.autobind, tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], Navigation.prototype, "toggleLink", null); return Navigation; }(react_1.default.Component)); exports.Navigation = Navigation; var ThemedNavigation = theme_1.themeable(Navigation); var ConditionBuilderWithRemoteOptions = WithRemoteConfig_1.withRemoteConfig({ adaptor: function (config, props) { var links = Array.isArray(config) ? config : config.links || config.options || config.items || config.rows; if (!Array.isArray(links)) { throw new Error('payload.data.options is not array.'); } return links; }, afterLoad: function (response, config, props) { if (response.value && !helper_1.someTree(config, function (item) { return item.active; })) { var env = props.env; env.jumpTo(tpl_1.filter(response.value, props.data)); } }, normalizeConfig: function (links, origin, props, motivation) { if (Array.isArray(links) && motivation !== 'toggle') { var data_1 = props.data, env_1 = props.env, unfoldedField_1 = props.unfoldedField, foldedField_1 = props.foldedField; links = helper_1.mapTree(links, function (link) { var item = tslib_1.__assign(tslib_1.__assign(tslib_1.__assign({}, link), filter_schema_1.default(link, data_1)), { active: (motivation !== 'location-change' && link.active) || (link.activeOn ? tpl_1.evalExpression(link.activeOn, data_1) : !!(link.hasOwnProperty('to') && env_1 && env_1.isCurrentUrl(tpl_1.filter(link.to, data_1)))) }); item.unfolded = helper_1.isUnfolded(item, { unfoldedField: unfoldedField_1, foldedField: foldedField_1 }) || (link.children && link.children.some(function (link) { return !!link.active; })); return item; }, 1, true); } return links; }, beforeDeferLoad: function (item, indexes, links) { return helper_1.spliceTree(links, indexes, 1, tslib_1.__assign(tslib_1.__assign({}, item), { loading: true })); }, afterDeferLoad: function (item, indexes, ret, links) { var newItem = tslib_1.__assign(tslib_1.__assign({}, item), { loading: false, loaded: true, error: ret.ok ? undefined : ret.msg }); var children = Array.isArray(ret.data) ? ret.data : ret.data.links || ret.data.options || ret.data.items || ret.data.rows; if (Array.isArray(children)) { newItem.children = children.concat(); newItem.unfolded = true; } return helper_1.spliceTree(links, indexes, 1, newItem); } })(/** @class */ (function (_super) { tslib_1.__extends(class_1, _super); function class_1(props) { var _this = _super.call(this, props) || this; _this.toggleLink = _this.toggleLink.bind(_this); _this.handleSelect = _this.handleSelect.bind(_this); return _this; } class_1.prototype.componentDidMount = function () { if (Array.isArray(this.props.links)) { this.props.updateConfig(this.props.links, 'mount'); } }; class_1.prototype.componentDidUpdate = function (prevProps) { if (this.props.location !== prevProps.location) { this.props.updateConfig(this.props.config, 'location-change'); } else if (this.props.links !== prevProps.links) { this.props.updateConfig(this.props.links, 'update'); } }; class_1.prototype.toggleLink = function (target) { var _a = this.props, config = _a.config, updateConfig = _a.updateConfig, deferLoad = _a.deferLoad; if (target.defer && !target.loaded) { deferLoad(target); } else { updateConfig(helper_1.mapTree(config, function (link) { return target === link ? tslib_1.__assign(tslib_1.__assign({}, link), { unfolded: !link.unfolded }) : link; }), 'toggle'); } }; class_1.prototype.handleSelect = function (link) { var _a = this.props, onSelect = _a.onSelect, env = _a.env, data = _a.data; if (onSelect && onSelect(link) === false) { return; } if (!link.to && ((link.children && link.children.length) || (link.defer && !link.loaded))) { this.toggleLink(link); return; } env === null || env === void 0 ? void 0 : env.jumpTo(tpl_1.filter(link.to, data), link); }; class_1.prototype.render = function () { var _a = this.props, loading = _a.loading, config = _a.config, deferLoad = _a.deferLoad, updateConfig = _a.updateConfig, rest = tslib_1.__rest(_a, ["loading", "config", "deferLoad", "updateConfig"]); return (react_1.default.createElement(ThemedNavigation, tslib_1.__assign({}, rest, { loading: loading, links: config || rest.links || [], disabled: loading, onSelect: this.handleSelect, onToggle: this.toggleLink }))); }; return class_1; }(react_1.default.Component))); exports.default = ThemedNavigation; var NavigationRenderer = /** @class */ (function (_super) { tslib_1.__extends(NavigationRenderer, _super); function NavigationRenderer() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.remoteRef = undefined; return _this; } NavigationRenderer.prototype.remoteConfigRef = function (ref) { this.remoteRef = ref; }; NavigationRenderer.prototype.componentWillMount = function () { var scoped = this.context; scoped.registerComponent(this); }; NavigationRenderer.prototype.componentWillUnmount = function () { var scoped = this.context; scoped.unRegisterComponent(this); }; NavigationRenderer.prototype.reload = function (target, query, values) { var _a; if (query) { return this.receive(query); } var _b = this.props, data = _b.data, env = _b.env, source = _b.source, __ = _b.translate; var finalData = values ? helper_1.createObject(data, values) : data; (_a = this.remoteRef) === null || _a === void 0 ? void 0 : _a.loadConfig(finalData); }; NavigationRenderer.prototype.receive = function (values) { this.reload(undefined, undefined, values); }; NavigationRenderer.prototype.render = function () { var rest = tslib_1.__rest(this.props, []); return (react_1.default.createElement(ConditionBuilderWithRemoteOptions, tslib_1.__assign({}, rest, { remoteConfigRef: this.remoteConfigRef }))); }; NavigationRenderer.contextType = Scoped_1.ScopedContext; tslib_1.__decorate([ helper_1.autobind, tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], NavigationRenderer.prototype, "remoteConfigRef", null); tslib_1.__decorate([ helper_1.autobind, tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [String, Object, Object]), tslib_1.__metadata("design:returntype", void 0) ], NavigationRenderer.prototype, "reload", null); tslib_1.__decorate([ helper_1.autobind, tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], NavigationRenderer.prototype, "receive", null); NavigationRenderer = tslib_1.__decorate([ factory_1.Renderer({ test: /(^|\/)(?:nav|navigation)$/, name: 'nav' }) ], NavigationRenderer); return NavigationRenderer; }(react_1.default.Component)); exports.NavigationRenderer = NavigationRenderer; //# sourceMappingURL=./renderers/Nav.js.map