fastlion-amis
Version:
一种MIS页面生成工具
161 lines (160 loc) • 9.73 kB
JavaScript
"use strict";
/**
* @file scoped.jsx.
* @author fex
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.HocPopOver = void 0;
var tslib_1 = require("tslib");
var react_1 = tslib_1.__importDefault(require("react"));
var react_dom_1 = require("react-dom");
var hoist_non_react_statics_1 = tslib_1.__importDefault(require("hoist-non-react-statics"));
var PopOver_1 = tslib_1.__importDefault(require("../components/PopOver"));
var Overlay_1 = tslib_1.__importDefault(require("../components/Overlay"));
var icons_1 = require("../components/icons");
var RootClose_1 = require("../utils/RootClose");
var HocPopOver = function (config) {
if (config === void 0) { config = {}; }
return function (Component) {
var lastOpenedInstance = null;
var PopOverComponent = /** @class */ (function (_super) {
tslib_1.__extends(PopOverComponent, _super);
function PopOverComponent(props) {
var _this = _super.call(this, props) || this;
_this.openPopOver = _this.openPopOver.bind(_this);
_this.closePopOver = _this.closePopOver.bind(_this);
_this.closePopOverLater = _this.closePopOverLater.bind(_this);
_this.clearCloseTimer = _this.clearCloseTimer.bind(_this);
_this.targetRef = _this.targetRef.bind(_this);
// this.handleClickOutside = this.handleClickOutside.bind(this);
_this.state = {
isOpened: false
};
return _this;
}
PopOverComponent.prototype.targetRef = function (ref) {
this.target = ref;
};
PopOverComponent.prototype.openPopOver = function () {
var _this = this;
var onPopOverOpened = this.props.onPopOverOpened;
lastOpenedInstance === null || lastOpenedInstance === void 0 ? void 0 : lastOpenedInstance.closePopOver();
lastOpenedInstance = this;
this.setState({
isOpened: true
}, function () { return onPopOverOpened && onPopOverOpened(_this.props.popOver); });
};
PopOverComponent.prototype.closePopOver = function () {
var _this = this;
clearTimeout(this.timer);
if (!this.state.isOpened) {
return;
}
lastOpenedInstance = null;
var onPopOverClosed = this.props.onPopOverClosed;
this.setState({
isOpened: false
}, function () { return onPopOverClosed && onPopOverClosed(_this.props.popOver); });
};
PopOverComponent.prototype.closePopOverLater = function () {
// 5s 后自动关闭。
this.timer = setTimeout(this.closePopOver, 2000);
};
PopOverComponent.prototype.clearCloseTimer = function () {
clearTimeout(this.timer);
};
PopOverComponent.prototype.buildSchema = function () {
var _a = this.props, popOver = _a.popOver, name = _a.name, label = _a.label, __ = _a.translate;
var schema;
if (popOver === true) {
schema = {
type: 'panel',
body: '${name}'
};
}
else if (popOver &&
(popOver.mode === 'dialog' || popOver.mode === 'drawer')) {
schema = tslib_1.__assign({ type: popOver.mode, actions: [
{
label: __('Dialog.close'),
type: 'button',
actionType: 'cancel'
}
] }, popOver);
}
else if (popOver) {
schema = tslib_1.__assign({ type: 'panel' }, popOver);
}
return schema || 'error';
};
PopOverComponent.prototype.renderPopOver = function () {
var _this = this;
var _a = this.props, popOver = _a.popOver, render = _a.render, popOverContainer = _a.popOverContainer, cx = _a.classnames, ns = _a.classPrefix;
if (popOver &&
(popOver.mode === 'dialog' ||
popOver.mode === 'drawer')) {
return render('popover-detail', this.buildSchema(), {
show: true,
onClose: this.closePopOver,
onConfirm: this.closePopOver
});
}
var content = render('popover-detail', this.buildSchema(), {
className: cx(popOver.className)
});
if (!popOverContainer) {
popOverContainer = function () { return (0, react_dom_1.findDOMNode)(_this); };
}
var position = (popOver && popOver.position) || '';
var isFixed = /^fixed\-/.test(position);
return isFixed ? (react_1.default.createElement(RootClose_1.RootClose, { disabled: !this.state.isOpened, onRootClose: this.closePopOver }, function (ref) {
return (react_1.default.createElement("div", { className: cx("PopOverAble--fixed PopOverAble--".concat(position)), onMouseLeave: (popOver === null || popOver === void 0 ? void 0 : popOver.trigger) === 'hover'
? _this.closePopOver
: undefined, onMouseEnter: (popOver === null || popOver === void 0 ? void 0 : popOver.trigger) === 'hover'
? _this.clearCloseTimer
: undefined, ref: ref }, content));
})) : (react_1.default.createElement(Overlay_1.default, { container: function () { return (0, react_dom_1.findDOMNode)(_this); }, placement: position || config.position || 'center', target: function () { return _this.target; }, onHide: this.closePopOver, rootClose: true, show: true },
react_1.default.createElement(PopOver_1.default, { classPrefix: ns, className: cx('PopOverAble-popover', popOver.popOverClassName), offset: popOver.offset, onMouseLeave: (popOver === null || popOver === void 0 ? void 0 : popOver.trigger) === 'hover'
? this.closePopOver
: undefined, onMouseEnter: (popOver === null || popOver === void 0 ? void 0 : popOver.trigger) === 'hover'
? this.clearCloseTimer
: undefined }, content)));
};
PopOverComponent.prototype.render = function () {
var _a = this.props, popOver = _a.popOver, popOverEnabled = _a.popOverEnabled, popOverEnable = _a.popOverEnable, className = _a.className, noHoc = _a.noHoc, cx = _a.classnames, showIcon = _a.showIcon;
if (!popOver ||
popOverEnabled === false ||
noHoc ||
popOverEnable === false) {
return react_1.default.createElement(Component, tslib_1.__assign({}, this.props));
}
var triggerProps = {};
var trigger = popOver === null || popOver === void 0 ? void 0 : popOver.trigger;
if (trigger === 'hover') {
triggerProps.onMouseEnter = this.openPopOver;
triggerProps.onMouseLeave = this.closePopOverLater;
}
else {
triggerProps.onClick = this.openPopOver;
}
return (react_1.default.createElement(Component, tslib_1.__assign({}, this.props, { className: cx("Field--popOverAble", className, {
in: this.state.isOpened
}), ref: config.targetOutter ? this.targetRef : undefined }), (popOver === null || popOver === void 0 ? void 0 : popOver.showIcon) !== false ? (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement(Component, tslib_1.__assign({}, this.props, { wrapperComponent: '', noHoc: true })),
react_1.default.createElement("span", tslib_1.__assign({ key: "popover-btn", className: cx('Field-popOverBtn') }, triggerProps, { ref: config.targetOutter ? undefined : this.targetRef }),
react_1.default.createElement(icons_1.Icon, { icon: "zoom-in", className: "icon" })),
this.state.isOpened ? this.renderPopOver() : null)) : (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement("div", tslib_1.__assign({ className: cx('Field-popOverWrap') }, triggerProps, { ref: config.targetOutter ? undefined : this.targetRef }),
react_1.default.createElement(Component, tslib_1.__assign({}, this.props, { wrapperComponent: '', noHoc: true }))),
this.state.isOpened ? this.renderPopOver() : null))));
};
PopOverComponent.ComposedComponent = Component;
return PopOverComponent;
}(react_1.default.Component));
(0, hoist_non_react_statics_1.default)(PopOverComponent, Component);
return PopOverComponent;
};
};
exports.HocPopOver = HocPopOver;
exports.default = exports.HocPopOver;
//# sourceMappingURL=./renderers/PopOver.js.map