amis
Version:
一种MIS页面生成工具
104 lines (103 loc) • 5.66 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
var react_1 = tslib_1.__importDefault(require("react"));
var factory_1 = require("../factory");
var react_overlays_1 = require("react-overlays");
var Overlay_1 = tslib_1.__importDefault(require("../components/Overlay"));
var PopOver_1 = tslib_1.__importDefault(require("../components/PopOver"));
var helper_1 = require("../utils/helper");
var tpl_1 = require("../utils/tpl");
var DropDownButton = /** @class */ (function (_super) {
tslib_1.__extends(DropDownButton, _super);
function DropDownButton(props) {
var _this = _super.call(this, props) || this;
_this.state = {
isOpened: _this.props.defaultIsOpened || false
};
_this.open = _this.open.bind(_this);
_this.close = _this.close.bind(_this);
_this.toogle = _this.toogle.bind(_this);
_this.domRef = _this.domRef.bind(_this);
return _this;
}
DropDownButton.prototype.domRef = function (ref) {
this.target = ref;
};
DropDownButton.prototype.toogle = function (e) {
e.preventDefault();
this.setState({
isOpened: !this.state.isOpened
});
};
DropDownButton.prototype.open = function () {
this.setState({
isOpened: true
});
};
DropDownButton.prototype.close = function () {
this.setState({
isOpened: false
});
};
DropDownButton.prototype.renderOuter = function () {
var _this = this;
var _a = this.props, render = _a.render, buttons = _a.buttons, data = _a.data, popOverContainer = _a.popOverContainer, cx = _a.classnames, ns = _a.classPrefix, children = _a.children, align = _a.align, closeOnClick = _a.closeOnClick, closeOnOutside = _a.closeOnOutside;
var body = (react_1.default.createElement(react_overlays_1.RootCloseWrapper, { disabled: !this.state.isOpened, onRootClose: closeOnOutside !== false ? this.close : helper_1.noop },
react_1.default.createElement("ul", { className: cx('DropDown-menu'), onClick: closeOnClick ? this.close : helper_1.noop }, children
? children
: Array.isArray(buttons)
? buttons.map(function (button, index) {
if (!helper_1.isVisible(button, data)) {
return null;
}
else if (button === 'divider' || button.type === 'divider') {
return react_1.default.createElement("li", { key: index, className: cx('DropDown-divider') });
}
return (react_1.default.createElement("li", { key: index }, render("button/" + index, tslib_1.__assign(tslib_1.__assign({ type: 'button' }, button), { isMenuItem: true }))));
})
: null)));
if (popOverContainer) {
return (react_1.default.createElement(Overlay_1.default, { container: popOverContainer, placement: align === 'right' ? 'right-bottom-right-top' : 'left-bottom-left-top', target: function () { return _this.target; }, show: true },
react_1.default.createElement(PopOver_1.default, { overlay: true, onHide: this.close, classPrefix: ns, className: cx('DropDown-popover'), style: { minWidth: this.target.offsetWidth } }, body)));
}
return body;
};
DropDownButton.prototype.render = function () {
var _a = this.props, block = _a.block, disabled = _a.disabled, btnDisabled = _a.btnDisabled, size = _a.size, label = _a.label, level = _a.level, primary = _a.primary, className = _a.className, cx = _a.classnames, caretIcon = _a.caretIcon, align = _a.align, iconOnly = _a.iconOnly, icon = _a.icon, data = _a.data;
return (react_1.default.createElement("div", { className: cx('DropDown ', {
'DropDown--block': block,
'DropDown--alignRight': align === 'right',
'is-opened': this.state.isOpened
}), ref: this.domRef },
react_1.default.createElement("button", { onClick: this.toogle, disabled: disabled || btnDisabled, className: cx('Button', className, typeof level === 'undefined' ? 'Button--default' : level ? "Button--" + level : '', {
'Button--block': block,
'Button--primary': primary,
'Button--iconOnly': iconOnly
}, size ? "Button--" + size : '') },
icon ? react_1.default.createElement("i", { className: cx(icon, 'm-r-xs') }) : null,
typeof label === 'string' ? tpl_1.filter(label, data) : label,
react_1.default.createElement("i", { className: cx('DropDown-caret', caretIcon) })),
this.state.isOpened ? this.renderOuter() : null));
};
DropDownButton.defaultProps = {
caretIcon: 'fa fa-angle-down'
};
return DropDownButton;
}(react_1.default.Component));
exports.default = DropDownButton;
var DropDownButtonRenderer = /** @class */ (function (_super) {
tslib_1.__extends(DropDownButtonRenderer, _super);
function DropDownButtonRenderer() {
return _super !== null && _super.apply(this, arguments) || this;
}
DropDownButtonRenderer = tslib_1.__decorate([
factory_1.Renderer({
test: /(^|\/)dropdown-button$/,
name: 'dropdown-button'
})
], DropDownButtonRenderer);
return DropDownButtonRenderer;
}(DropDownButton));
exports.DropDownButtonRenderer = DropDownButtonRenderer;
//# sourceMappingURL=./renderers/DropDownButton.js.map