UNPKG

linkmore-design

Version:

🌈 πŸš€lmη»„δ»ΆεΊ“γ€‚πŸš€

236 lines (233 loc) β€’ 7.35 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.attachTypeApi = attachTypeApi; exports.getInstance = exports.default = void 0; exports.getKeyThenIncreaseKey = getKeyThenIncreaseKey; exports.typeList = void 0; var _CheckCircleFilled = _interopRequireDefault(require("@ant-design/icons/CheckCircleFilled")); var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons/CloseCircleFilled")); var _ExclamationCircleFilled = _interopRequireDefault(require("@ant-design/icons/ExclamationCircleFilled")); var _InfoCircleFilled = _interopRequireDefault(require("@ant-design/icons/InfoCircleFilled")); var _LoadingOutlined = _interopRequireDefault(require("@ant-design/icons/LoadingOutlined")); var _classnames = _interopRequireDefault(require("classnames")); var _rcNotification = _interopRequireDefault(require("rc-notification")); var React = _interopRequireWildcard(require("react")); var _configProvider = _interopRequireWildcard(require("../config-provider")); var _useMessage = _interopRequireDefault(require("./hooks/useMessage")); let messageInstance; let defaultDuration = 3; let defaultTop; let key = 1; let localPrefixCls = ''; let transitionName = 'move-up'; let hasTransitionName = false; let getContainer; let maxCount; let rtl = false; function getKeyThenIncreaseKey() { return key++; } function setMessageConfig(options) { if (options.top !== undefined) { defaultTop = options.top; messageInstance = null; // delete messageInstance for new defaultTop } if (options.duration !== undefined) { defaultDuration = options.duration; } if (options.prefixCls !== undefined) { localPrefixCls = options.prefixCls; } if (options.getContainer !== undefined) { getContainer = options.getContainer; messageInstance = null; // delete messageInstance for new getContainer } if (options.transitionName !== undefined) { transitionName = options.transitionName; messageInstance = null; // delete messageInstance for new transitionName hasTransitionName = true; } if (options.maxCount !== undefined) { maxCount = options.maxCount; messageInstance = null; } if (options.rtl !== undefined) { rtl = options.rtl; } } function getRCNotificationInstance(args, callback) { const { prefixCls: customizePrefixCls, getPopupContainer: getContextPopupContainer } = args; const { getPrefixCls, getRootPrefixCls, getIconPrefixCls } = (0, _configProvider.globalConfig)(); const prefixCls = getPrefixCls('message', customizePrefixCls || localPrefixCls); const rootPrefixCls = getRootPrefixCls(args.rootPrefixCls, prefixCls); const iconPrefixCls = getIconPrefixCls(); if (messageInstance) { callback({ prefixCls, rootPrefixCls, iconPrefixCls, instance: messageInstance }); return; } const instanceConfig = { prefixCls, transitionName: hasTransitionName ? transitionName : `${rootPrefixCls}-${transitionName}`, style: { top: defaultTop }, // θ¦†η›–εŽŸζ₯ηš„ζ ·εΌ getContainer: getContainer || getContextPopupContainer, maxCount }; _rcNotification.default.newInstance(instanceConfig, instance => { if (messageInstance) { callback({ prefixCls, rootPrefixCls, iconPrefixCls, instance: messageInstance }); return; } messageInstance = instance; if (process.env.NODE_ENV === 'test') { messageInstance.config = instanceConfig; } callback({ prefixCls, rootPrefixCls, iconPrefixCls, instance }); }); } const typeToIcon = { info: _InfoCircleFilled.default, success: _CheckCircleFilled.default, error: _CloseCircleFilled.default, warning: _ExclamationCircleFilled.default, loading: _LoadingOutlined.default }; const typeList = Object.keys(typeToIcon); exports.typeList = typeList; function getRCNoticeProps(args, prefixCls, iconPrefixCls) { const duration = args.duration !== undefined ? args.duration : defaultDuration; const progress = args.progress === false ? false : true; const IconComponent = typeToIcon[args.type]; const messageClass = (0, _classnames.default)(`${prefixCls}-custom-content`, { [`${prefixCls}-${args.type}`]: args.type, [`${prefixCls}-rtl`]: rtl === true }); return { key: args.key, duration, style: args.style || {}, className: (0, _classnames.default)(args.className, 'lm_message'), content: /*#__PURE__*/React.createElement(_configProvider.default, { iconPrefixCls: iconPrefixCls }, /*#__PURE__*/React.createElement("div", { className: messageClass }, args.icon || IconComponent && /*#__PURE__*/React.createElement(IconComponent, null), /*#__PURE__*/React.createElement("span", null, args.content), progress && duration > 0 && /*#__PURE__*/React.createElement("div", { className: "message_progress", style: { animationDuration: `${duration}s` } }))), onClose: args.onClose, onClick: args.onClick }; } function notice(args) { const target = args.key || getKeyThenIncreaseKey(); const closePromise = new Promise(resolve => { const callback = () => { if (typeof args.onClose === 'function') { args.onClose(); } return resolve(true); }; getRCNotificationInstance(args, ({ prefixCls, iconPrefixCls, instance }) => { instance.notice(getRCNoticeProps({ ...args, key: target, onClose: callback }, prefixCls, iconPrefixCls)); }); }); const result = () => { if (messageInstance) { messageInstance.removeNotice(target); args.onClose?.(); } }; result.then = (filled, rejected) => closePromise.then(filled, rejected); result.promise = closePromise; return result; } function isArgsProps(content) { return Object.prototype.toString.call(content) === '[object Object]' && !!content.content; } const api = { open: notice, config: setMessageConfig, destroy(messageKey) { if (messageInstance) { if (messageKey) { const { removeNotice } = messageInstance; removeNotice(messageKey); } else { const { destroy } = messageInstance; destroy(); messageInstance = null; } } } }; function attachTypeApi(originalApi, type) { originalApi[type] = (content, duration, onClose) => { if (isArgsProps(content)) { return originalApi.open({ ...content, type }); } if (typeof duration === 'function') { onClose = duration; duration = undefined; } return originalApi.open({ content, duration, type, onClose }); }; } typeList.forEach(type => attachTypeApi(api, type)); api.warn = api.warning; api.useMessage = (0, _useMessage.default)(getRCNotificationInstance, getRCNoticeProps); /** @internal test Only function. Not work on production */ const getInstance = () => process.env.NODE_ENV === 'test' ? messageInstance : null; exports.getInstance = getInstance; var _default = api; exports.default = _default;