fastlion-amis
Version:
一种MIS页面生成工具
344 lines (343 loc) • 23.5 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.ListItemRenderer = exports.LionListRenderer = exports.LionList = void 0;
var tslib_1 = require("tslib");
var react_1 = (0, tslib_1.__importDefault)(require("react"));
var factory_1 = require("../../../factory");
var List_1 = tslib_1.__importStar(require("../../../renderers/List"));
var list_1 = require("../../../store/list");
var react_dom_1 = require("react-dom");
var offset_1 = (0, tslib_1.__importDefault)(require("../../../utils/offset"));
var dom_1 = require("../../../utils/dom");
var Button_1 = (0, tslib_1.__importDefault)(require("../../../components/Button"));
var Checkbox_1 = (0, tslib_1.__importDefault)(require("../../../components/Checkbox"));
require("./index.css");
var InfinteSroll_1 = (0, tslib_1.__importDefault)(require("../components/InfinteSroll"));
var helper_1 = require("../../../utils/helper");
var tpl_1 = require("../../../utils/tpl");
var tpl_builtin_1 = require("../../../utils/tpl-builtin");
var errImg = '';
var LionList = /** @class */ (function (_super) {
(0, tslib_1.__extends)(LionList, _super);
function LionList(props) {
var _this = _super.call(this, props) || this;
_this.state = {
morePopVisible: false
};
_this.pullUpRefresh = function (e) {
var target = e.target;
var scrollHeight = target === null || target === void 0 ? void 0 : target.scrollHeight;
var scrollTop = target === null || target === void 0 ? void 0 : target.scrollTop;
var clientHeight = target === null || target === void 0 ? void 0 : target.clientHeight;
if (Math.ceil(scrollTop + clientHeight) >= scrollHeight && !_this.xhrTimer) {
_this.xhrTimer = setTimeout(function () { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
var res, _a;
return (0, tslib_1.__generator)(this, function (_b) {
switch (_b.label) {
case 0:
clearTimeout(this.xhrTimer);
this.xhrTimer = null;
_a = this.props.onPullUpRequest;
if (!_a) return [3 /*break*/, 2];
return [4 /*yield*/, this.props.onPullUpRequest({})];
case 1:
_a = (_b.sent());
_b.label = 2;
case 2:
res = _a;
return [2 /*return*/];
}
});
}); }, 100);
}
};
// 移动端默认隐藏勾选框
if (_this.getMobileUI() && props.hideCheckToggler === void 0) {
props.store.update({ hideCheckToggler: true });
}
return _this;
}
LionList.prototype.componentDidMount = function () {
this.calcAutoFillHeight();
};
LionList.prototype.calcAutoFillHeight = function () {
var _a = this.props, _b = _a.autoFillHeight, autoFillHeight = _b === void 0 ? true : _b, footerToolbar = _a.footerToolbar, ns = _a.classPrefix;
if (!autoFillHeight) {
return;
}
var dom = (0, react_dom_1.findDOMNode)(this);
var top = (0, offset_1.default)(dom).top;
var viewportHeight = window.innerHeight;
var allParentPaddingButtom = 0;
var parentNode = dom.parentElement;
while (parentNode) {
var paddingButtom = (0, dom_1.getStyleNumber)(parentNode, 'padding-bottom');
var borderBottom = (0, dom_1.getStyleNumber)(parentNode, 'border-bottom-width');
allParentPaddingButtom =
allParentPaddingButtom + paddingButtom + borderBottom;
parentNode = parentNode.parentElement;
}
var n = viewportHeight - top - allParentPaddingButtom;
dom.style.height = n + 'px';
};
LionList.prototype.getMobileUI = function () {
return (0, helper_1.isMobile)() && this.props.useMobileUI;
};
LionList.prototype.renderHeader = function () {
var _a = this.props, header = _a.header, headerClassName = _a.headerClassName, headerToolbar = _a.headerToolbar, headerToolbarRender = _a.headerToolbarRender, render = _a.render, showHeader = _a.showHeader, store = _a.store, cx = _a.classnames;
if (showHeader === false) {
return null;
}
var child = headerToolbarRender
? headerToolbarRender((0, tslib_1.__assign)((0, tslib_1.__assign)({}, this.props), { selectedItems: store.selectedItems.map(function (item) { return item.data; }), items: store.items.map(function (item) { return item.data; }), unSelectedItems: store.unSelectedItems.map(function (item) { return item.data; }) }), this.renderToolbar)
: null;
var actions = this.renderActions('header');
var toolbarNode = actions || child ? (react_1.default.createElement("div", { className: cx('List-toolbar', headerClassName), key: "header-toolbar" },
actions,
child)) : null;
var headerNode = header && (!Array.isArray(header) || header.length) ? (react_1.default.createElement("div", { className: cx('List-header', headerClassName), key: "header" }, render('header', header))) : null;
return headerNode && toolbarNode
? [headerNode, toolbarNode]
: headerNode || toolbarNode || null;
};
LionList.prototype.renderFooter = function () {
var _a = this.props, footer = _a.footer, footerClassName = _a.footerClassName, footerToolbar = _a.footerToolbar, headerToolbar = _a.headerToolbar, footerToolbarRender = _a.footerToolbarRender, render = _a.render, showFooter = _a.showFooter, store = _a.store, cx = _a.classnames;
if (showFooter === false) {
return null;
}
var _footer = footerToolbar || [];
if (this.getMobileUI()) {
// 勾选批量状态时
if (!store.hideCheckToggler) {
_footer = ["bulkActions"];
}
else {
if (headerToolbar) {
// 移动端将所有操作统一放在在底部
_footer = _footer.concat(headerToolbar);
}
// 非勾选状态补渲染不批量操作
_footer = _footer.filter(function (item) {
var type = item.type || item;
return !['bulk-actions', 'bulkActions'].includes(type);
});
}
}
var child = footerToolbarRender
? footerToolbarRender((0, tslib_1.__assign)((0, tslib_1.__assign)({}, this.props), { selectedItems: store.selectedItems.map(function (item) { return item.data; }), items: store.items.map(function (item) { return item.data; }), unSelectedItems: store.unSelectedItems.map(function (item) { return item.data; }) }), this.renderToolbar,
// PC端始终显示foottoolbar, 移动端勾选状态显示 批量
_footer)
: null;
var actions = this.renderActions('footer');
var toolbarNode = actions || child ? (react_1.default.createElement("div", { className: cx('List-toolbar', 'List-footer', footerClassName), key: "footer-toolbar" },
actions,
child)) : null;
var footerNode = footer && (!Array.isArray(footer) || footer.length) ? (react_1.default.createElement("div", { className: cx('List-footer', footerClassName), key: "footer" }, render('footer', footer))) : null;
return footerNode && toolbarNode
? [toolbarNode, footerNode]
: footerNode || toolbarNode || null;
};
LionList.prototype.renderCheckAll = function () {
var _a = this.props, store = _a.store, multiple = _a.multiple, selectable = _a.selectable, cx = _a.classnames, ns = _a.classPrefix, __ = _a.translate;
if (!store.selectable ||
!multiple ||
!selectable ||
store.dragging ||
!store.items.length) {
return null;
}
return (this.getMobileUI() ? react_1.default.createElement("div", { key: "checkall", className: cx('Mobile-checkall') },
react_1.default.createElement(Checkbox_1.default, { classPrefix: ns, type: multiple ? 'checkbox' : 'radio', checked: store.allChecked, onChange: this.handleCheckAll, inline: true }),
react_1.default.createElement("span", null, __('Select.checkAll'))) :
react_1.default.createElement(Button_1.default, { key: "checkall",
// tooltip="切换全选"
onClick: this.handleCheckAll, size: "sm", level: store.allChecked ? 'info' : 'default' }, __('Select.checkAll')));
};
LionList.prototype.renderActions = function (region) {
var _this = this;
var _a = this.props, actions = _a.actions, render = _a.render, store = _a.store, multiple = _a.multiple, selectable = _a.selectable, env = _a.env, ns = _a.classPrefix, cx = _a.classnames;
var btn;
actions = Array.isArray(actions) ? actions.concat() : [];
if (!~this.renderedToolbars.indexOf('check-all') &&
!store.hideCheckToggler &&
this.getMobileUI() &&
(btn = this.renderCheckAll())) {
actions.unshift({
type: 'button',
children: btn
});
}
return Array.isArray(actions) && actions.length ? (react_1.default.createElement("div", { className: cx('List-actions') }, actions.map(function (action, key) {
return render("action/" + key, (0, tslib_1.__assign)({ type: 'button' }, action), {
onAction: _this.handleAction,
key: key,
btnDisabled: store.dragging
});
}))) : null;
};
LionList.prototype.renderHeaderContent = function () {
var _a = this.props, render = _a.render, cx = _a.classnames, __ = _a.translate, getModalContainer = _a.env.getModalContainer, filterRender = _a.filterRender, store = _a.store;
if (this.getMobileUI()) {
{ /* 搜索 */ }
var filterNode = filterRender && filterRender();
{ /* 批量 */ }
var checkAll = !~this.renderedToolbars.indexOf('check-all') && this.renderCheckAll() ?
react_1.default.createElement("span", { className: cx('Mobile-batch-manage', { 'is-active': !store.hideCheckToggler }), onClick: function (e) {
e.preventDefault();
store.toggableHideCheck();
} }, store.hideCheckToggler ? react_1.default.createElement("i", { className: 'fa fa-tasks batch-manage-icon' }) : __('Wizard.finish')) : null;
return filterNode || checkAll ? (react_1.default.createElement("div", { className: cx('Mobile-header-toolbar-wrapper') },
filterNode,
checkAll)) : null;
}
var heading = this.renderHeading();
var header = this.renderHeader();
return react_1.default.createElement(react_1.default.Fragment, null,
header,
heading);
};
LionList.prototype.render = function () {
var _a;
var _this = this;
var _b = this.props, className = _b.className, itemClassName = _b.itemClassName, store = _b.store, render = _b.render, multiple = _b.multiple, listItem = _b.listItem, onAction = _b.onAction, checkOnItemClick = _b.checkOnItemClick, itemAction = _b.itemAction, cx = _b.classnames, size = _b.size, __ = _b.translate, onLoadMore = _b.onLoadMore, loadHasMore = _b.loadHasMore, infinteLoad = _b.infinteLoad;
this.renderedToolbars = [];
var header = this.renderHeaderContent();
var footer = this.renderFooter();
return (react_1.default.createElement("div", { className: cx('List', 'LionList', className, (_a = {},
_a["List--" + size] = size,
_a['List--unsaved'] = !!store.modified || !!store.moved,
_a['is-mobile'] = this.getMobileUI(),
_a)), ref: this.bodyRef },
header,
react_1.default.createElement("div", { className: cx('List-content', {
'hasHeader': header,
'hasFooter': footer,
}) },
store.items.length ? (react_1.default.createElement("div", { className: cx('List-items') }, store.items.map(function (item, index) {
return render("" + index, (0, tslib_1.__assign)({ type: 'lion-list-item' }, listItem), {
key: item.index,
className: cx(itemClassName, {
'is-checked': item.checked,
'is-modified': item.modified,
'is-moved': item.moved
}),
selectable: store.selectable,
checkable: item.checkable,
multiple: multiple,
item: item,
itemIndex: item.index,
hideCheckToggler: store.hideCheckToggler,
checkOnItemClick: checkOnItemClick,
itemAction: itemAction,
selected: item.checked,
onCheck: _this.handleCheck,
dragging: store.dragging,
onAction: onAction,
data: item.locals,
onQuickChange: store.dragging ? null : _this.handleQuickChange,
popOverContainer: _this.getPopOverContainer
});
}))) : null,
infinteLoad && react_1.default.createElement(InfinteSroll_1.default, { loadMore: onLoadMore, hasMore: loadHasMore })),
footer));
};
LionList.defaultProps = {
hideCheckToggler: (0, helper_1.isMobile)()
};
return LionList;
}(List_1.default));
exports.LionList = LionList;
var LionListRenderer = /** @class */ (function (_super) {
(0, tslib_1.__extends)(LionListRenderer, _super);
function LionListRenderer() {
return _super !== null && _super.apply(this, arguments) || this;
}
LionListRenderer = (0, tslib_1.__decorate)([
(0, factory_1.Renderer)({
type: 'lion-list',
storeType: list_1.ListStore.name
})
], LionListRenderer);
return LionListRenderer;
}(LionList));
exports.LionListRenderer = LionListRenderer;
var ListItemRenderer = /** @class */ (function (_super) {
(0, tslib_1.__extends)(ListItemRenderer, _super);
function ListItemRenderer(props) {
return _super.call(this, props) || this;
}
ListItemRenderer.prototype.getValue = function (name, data) {
var rest = [];
for (var _i = 2; _i < arguments.length; _i++) {
rest[_i - 2] = arguments[_i];
}
return (0, tpl_builtin_1.isPureVariable)(name) ? tpl_1.filter.apply(void 0, (0, tslib_1.__spreadArray)([name, data], rest, false)) : data[name];
};
ListItemRenderer.prototype.render = function () {
var _this = this;
var _a, _b;
var _c = this.props, className = _c.className, data = _c.data, avatar = _c.avatar, title = _c.title, titleClassName = _c.titleClassName, subTitle = _c.subTitle, desc = _c.desc, avatarClassName = _c.avatarClassName, checkOnItemClick = _c.checkOnItemClick, render = _c.render, checkable = _c.checkable, cx = _c.classnames, actionsPosition = _c.actionsPosition, itemAction = _c.itemAction, $schema = _c.$schema, env = _c.env,
// Jay
footable = _c.footable, footBody = _c.footBody;
var avaterImg = this.getValue(avatar, data, '| raw');
if (avaterImg) {
var baseUrl = ((_b = (_a = env === null || env === void 0 ? void 0 : env.axiosInstance) === null || _a === void 0 ? void 0 : _a.defaults) === null || _b === void 0 ? void 0 : _b.baseURL) || (env === null || env === void 0 ? void 0 : env.ajaxApi) || '';
avaterImg = baseUrl + avaterImg;
}
return (
// Jay
react_1.default.createElement("div", { className: cx('ListItem-wapper') },
react_1.default.createElement("div", { className: cx("ListItem ListItem--actions-at-" + (actionsPosition || 'right'), {
'ListItem--hasItemAction': itemAction
}, className,
// Jay
typeof (footable) === 'object' && footable.expand === 'all' && 'expand'),
// Jay
onTouchStart: function () {
footable && (_this.touchStartTime = +new Date());
},
// 这里不能用onTouchEnd,否则会有一些bug
onClick: function (e) {
if (footable && (+new Date() - _this.touchStartTime < 300)) {
if (/expand/.test(e.currentTarget.className)) {
e.currentTarget.classList.remove('expand');
}
else {
e.currentTarget.classList.add('expand');
}
}
((checkOnItemClick && checkable) || itemAction)
&& _this.handleClick(e);
} },
this.renderLeft(),
$schema.avatar ? (react_1.default.createElement("span", { className: cx('ListItem-avatar', avatarClassName) },
react_1.default.createElement("img", { src: avaterImg || errImg, alt: "..." }))) : null,
react_1.default.createElement("div", { className: cx('ListItem-content') },
title ? (react_1.default.createElement("p", { className: cx('ListItem-title', titleClassName) }, this.getValue(title, data))) : null,
subTitle ? (react_1.default.createElement("div", null,
react_1.default.createElement("small", { className: cx('ListItem-subtitle') }, this.getValue(subTitle, data)))) : null,
desc ? react_1.default.createElement("small", { className: cx('ListItem-subtitle') }, this.getValue(desc, data)) : null,
this.renderBody()),
this.renderRight()),
footable && (footBody === null || footBody === void 0 ? void 0 : footBody.length) &&
react_1.default.createElement("div", { className: cx('ListItem-footable', 'flex-wrap') }, footBody === null || footBody === void 0 ? void 0 : footBody.map(function (column, index) {
return react_1.default.createElement("div", { key: index, className: 'footItem flex items-center' },
react_1.default.createElement("span", { className: "label" },
column.label,
" :"),
react_1.default.createElement("span", { className: "value" }, column.type ? render("field", column, { key: index, data: data }) : (data[column.name] || '-')));
}))));
};
var _a;
ListItemRenderer.propsList = (0, tslib_1.__spreadArray)(['multiple'], List_1.ListItem.propsList, true);
ListItemRenderer = (0, tslib_1.__decorate)([
(0, factory_1.Renderer)({
test: /(^|\/)(?:lion-list|lion-list-group)\/(?:.*\/)?lion-list-item$/,
name: 'lion-list-item'
}),
(0, tslib_1.__metadata)("design:paramtypes", [typeof (_a = typeof List_1.ListItemProps !== "undefined" && List_1.ListItemProps) === "function" ? _a : Object])
], ListItemRenderer);
return ListItemRenderer;
}(List_1.ListItem));
exports.ListItemRenderer = ListItemRenderer;
//# sourceMappingURL=./renderers/Lion/List/index.js.map