UNPKG

deer-ui

Version:

React.js UI components for PC Web

190 lines (160 loc) 7.89 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _reactDom = _interopRequireDefault(require("react-dom")); var _classnames = _interopRequireDefault(require("classnames")); var _icon = require("../icon"); function _createSuper(Derived) { return function () { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (_isNativeReflectConstruct()) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } var Message = /*#__PURE__*/function (_PureComponent) { (0, _inherits2.default)(Message, _PureComponent); var _super = _createSuper(Message); function Message(props) { var _this; (0, _classCallCheck2.default)(this, Message); _this = _super.call(this, props); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", { visible: true }); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "animationTime", 500); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_containerRef", null); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "_currentNodeRef", null); (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "destroy", function () { if (_this._containerRef) { _reactDom.default.unmountComponentAtNode(_this._containerRef); } if (_this._currentNodeRef) { _this._currentNodeRef.remove(); } }); _this.typeConfig = { info: "info", success: "success", error: "error", warning: "warning", primary: "primary" }; return _this; } (0, _createClass2.default)(Message, [{ key: "componentDidMount", value: function componentDidMount() { var _this2 = this; var _this$props = this.props, duration = _this$props.duration, onClose = _this$props.onClose; this.timer = setTimeout(function () { _this2.setState({ visible: false }, function () { setTimeout(function () { _this2.destroy(); }, _this2.animationTime); onClose(); }); }, duration * 1000); } }, { key: "componentWillUnmount", value: function componentWillUnmount() { this.destroy(); clearTimeout(this.timer); } }, { key: "render", value: function render() { var visible = this.state.visible; var typeConfig = this.typeConfig; var _this$props2 = this.props, title = _this$props2.title, type = _this$props2.type, className = _this$props2.className, darkTheme = _this$props2.darkTheme, prefixCls = _this$props2.prefixCls, attr = (0, _objectWithoutProperties2.default)(_this$props2, ["title", "type", "className", "darkTheme", "prefixCls"]); var messageCss = visible ? 'message-open' : 'message-close'; return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({ className: (0, _classnames.default)("".concat(prefixCls), className, (0, _defineProperty2.default)({}, "".concat(prefixCls, "-").concat(type), type), (0, _defineProperty2.default)({}, "".concat(prefixCls, "-theme-dark"), darkTheme), ["".concat(messageCss)]) }, attr), /*#__PURE__*/_react.default.createElement("span", { className: "".concat(prefixCls, "-icon") }, type === typeConfig['info'] ? /*#__PURE__*/_react.default.createElement(_icon.InfoIcon, null) : null, type === typeConfig['success'] ? /*#__PURE__*/_react.default.createElement(_icon.SuccessIcon, null) : null, type === typeConfig['warning'] ? /*#__PURE__*/_react.default.createElement(_icon.WarningIcon, null) : null, type === typeConfig['error'] ? /*#__PURE__*/_react.default.createElement(_icon.ErrorIcon, null) : null, type === typeConfig['primary'] ? /*#__PURE__*/_react.default.createElement(_icon.LoadingIcon, null) : null), /*#__PURE__*/_react.default.createElement("span", null, title)); } }], [{ key: "success", value: function success(title, onClose, duration, darkTheme) { return this.renderElement("success", title, onClose, duration, darkTheme); } }, { key: "error", value: function error(title, onClose, duration, darkTheme) { return this.renderElement("error", title, onClose, duration, darkTheme); } }, { key: "warning", value: function warning(title, onClose, duration, darkTheme) { return this.renderElement("warning", title, onClose, duration, darkTheme); } }, { key: "info", value: function info(title, onClose, duration, darkTheme) { return this.renderElement("info", title, onClose, duration, darkTheme); } }, { key: "primary", value: function primary(title, onClose, duration, darkTheme) { return this.renderElement("primary", title, onClose, duration, darkTheme); } }]); return Message; }(_react.PureComponent); (0, _defineProperty2.default)(Message, "propTypes", { prefixCls: _propTypes.default.string.isRequired, title: _propTypes.default.oneOfType([_propTypes.default.element, _propTypes.default.string, _propTypes.default.object]).isRequired, duration: _propTypes.default.number, onClose: _propTypes.default.func, darkTheme: _propTypes.default.bool }); (0, _defineProperty2.default)(Message, "defaultProps", { duration: 2, prefixCls: "deer-ui-message", darkTheme: false, onClose: function onClose() {} }); (0, _defineProperty2.default)(Message, "renderElement", function (type, title, onClose, duration, darkTheme) { var container = document.createElement("div"); var currentNode = document.body.appendChild(container); var _message = _reactDom.default.render( /*#__PURE__*/_react.default.createElement(Message, { type: type, title: title, duration: duration, darkTheme: darkTheme, onClose: onClose }), container); if (_message) { _message._containerRef = container; _message._currentNodeRef = currentNode; return { destroy: _message.destroy }; } return { destroy: function destroy() {} }; }); var _default = Message; exports.default = _default;