adui
Version:
<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>
268 lines (222 loc) • 31.5 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var ReactDOM = _interopRequireWildcard(require("react-dom"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _button = _interopRequireDefault(require("../button"));
var _icon = _interopRequireDefault(require("../icon"));
var _iconIntents = _interopRequireDefault(require("../alert/iconIntents"));
require("./style");
var _excluded = ["action", "className", "closable", "content", "duration", "getContainer", "icon", "intent", "onClose"],
_excluded2 = ["onClose", "getContainer", "intent"];
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
var prefix = "adui-message";
var INTENTS = ["normal", "primary", "success", "warning", "danger"];
var Message = (0, _react.forwardRef)(function (_ref, ref) {
var action = _ref.action,
className = _ref.className,
closable = _ref.closable,
content = _ref.content,
duration = _ref.duration,
getContainer = _ref.getContainer,
icon = _ref.icon,
intent = _ref.intent,
onClose = _ref.onClose,
otherProps = _objectWithoutProperties(_ref, _excluded);
var messageRef = (0, _react.useRef)(null);
var timer;
var clearCloseTimer = function clearCloseTimer() {
if (timer) {
clearTimeout(timer);
timer = null;
}
};
var close = function close() {
if (messageRef && messageRef.current) {
messageRef.current.style.opacity = "0";
messageRef.current.style.visibility = "hidden";
messageRef.current.style.transform = "translate3d(-50%, -56px, 0)";
messageRef.current.style.transition = "all var(--adui-motion-duration-base) var(--adui-motion-ease-base)";
}
clearCloseTimer();
if (onClose) {
onClose();
}
};
var setCloseTimer = function setCloseTimer() {
if (duration) {
timer = setTimeout(function () {
close();
}, duration * 1000);
}
};
(0, _react.useEffect)(function () {
setCloseTimer();
return clearCloseTimer;
}, []);
(0, _react.useImperativeHandle)(ref, function () {
return {
close: close,
getDomNode: function getDomNode() {
return messageRef.current;
}
};
});
var hasActions = action || closable;
return _react["default"].createElement("div", _extends({
className: (0, _classnames["default"])(className, "".concat(prefix, "-base"), "".concat(prefix, "-").concat(intent), _defineProperty({}, "".concat(prefix, "-hasActions"), hasActions)),
onMouseEnter: clearCloseTimer,
onMouseLeave: setCloseTimer,
ref: messageRef,
"data-duration": duration
}, otherProps), _react["default"].createElement(_icon["default"], {
icon: icon || _iconIntents["default"][intent],
size: 20,
className: "".concat(prefix, "-icon")
}), _react["default"].createElement("div", {
className: "".concat(prefix, "-content")
}, content), hasActions && _react["default"].createElement("div", {
className: "".concat(prefix, "-actions")
}, action && _react["default"].createElement("div", {
className: "".concat(prefix, "-action")
}, _react["default"].createElement(_button["default"], {
theme: "light",
onClick: function onClick() {
var onClick = action.onClick;
if (onClick) {
onClick();
}
}
}, action.text)), closable && _react["default"].createElement(_button["default"], {
leftIcon: "cancel",
theme: "light",
onClick: close
})));
});
Message.displayName = "Message";
Message.propTypes = {
action: _propTypes["default"].any,
className: _propTypes["default"].string,
closable: _propTypes["default"].bool,
content: _propTypes["default"].node,
duration: _propTypes["default"].number,
getContainer: _propTypes["default"].func,
icon: _propTypes["default"].any,
intent: _propTypes["default"].any,
onClose: _propTypes["default"].func
};
Message.defaultProps = {
action: null,
className: undefined,
closable: false,
content: null,
duration: 2,
getContainer: undefined,
icon: undefined,
intent: "normal",
onClose: null
};
var newInstance = function newInstance(props) {
var instances = Array.from(document.getElementsByClassName("".concat(prefix, "-wrapper")));
instances = instances.filter(function (o) {
return o.dataset.close !== "true";
});
if (instances && instances.length > 2) {
var firstInstance = instances[0];
var firstChild = firstInstance.children[0];
if (firstChild.dataset.duration !== "0") {
firstInstance.dataset.close = "true";
firstInstance.style.transform = "translate3d(0, -56px, 0)";
firstChild.style.opacity = "0";
firstChild.style.visibility = "hidden";
firstInstance.style.transition = "all var(--adui-motion-duration-base) var(--adui-motion-ease-base)";
firstChild.style.transition = "all var(--adui-motion-duration-base) var(--adui-motion-ease-base)";
}
}
var instance;
var onClose = props.onClose,
getContainer = props.getContainer,
intent = props.intent,
otherProps = _objectWithoutProperties(props, _excluded2);
var container = document.createElement("div");
container.className = "".concat(prefix, "-wrapper");
container.dataset.intent = intent;
if (getContainer) {
getContainer().appendChild(container);
} else {
document.body.appendChild(container);
}
var updateStyles = function updateStyles() {
setTimeout(function () {
var messages = Array.from(document.getElementsByClassName("".concat(prefix, "-wrapper")));
messages.forEach(function (message, index) {
if (["warning", "danger"].includes(message.dataset.intent || "")) {
message.style.transition = "all var(--adui-motion-duration-bounce) var(--adui-motion-ease-bounce)";
}
message.style.opacity = "1";
message.style.transform = "translate3d(0, ".concat(56 * (messages.length - 1 - index), "px, 0)");
});
}, 50);
};
updateStyles();
var close = function close() {
if (onClose) {
onClose();
}
setTimeout(function () {
var unmountResult = ReactDOM.unmountComponentAtNode(container);
if (unmountResult && container.parentNode) {
container.parentNode.removeChild(container);
updateStyles();
}
}, 300);
};
ReactDOM.render(_react["default"].createElement(Message, _extends({
ref: function ref(message) {
instance = message;
},
onClose: close,
intent: intent
}, otherProps)), container);
return {
destroy: function destroy() {
if (instance) {
instance.close();
}
}
};
};
INTENTS.forEach(function (intent) {
Message[intent] = function (config) {
var cnfg = {
intent: intent
};
if (typeof config === "string") {
cnfg = {
content: config,
intent: intent
};
} else {
cnfg = config;
}
return newInstance(_objectSpread(_objectSpread({}, cnfg), {}, {
intent: intent
}));
};
});
var _default = Message;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","INTENTS","Message","forwardRef","ref","action","className","closable","content","duration","getContainer","icon","intent","onClose","otherProps","messageRef","useRef","timer","clearCloseTimer","clearTimeout","close","current","style","opacity","visibility","transform","transition","setCloseTimer","setTimeout","useEffect","useImperativeHandle","getDomNode","hasActions","classNames","ICON_INTENTS","onClick","text","displayName","propTypes","PropTypes","any","string","bool","node","number","func","defaultProps","undefined","newInstance","props","instances","Array","from","document","getElementsByClassName","filter","o","dataset","length","firstInstance","firstChild","children","instance","container","createElement","appendChild","body","updateStyles","messages","forEach","message","index","includes","unmountResult","ReactDOM","unmountComponentAtNode","parentNode","removeChild","render","destroy","config","cnfg"],"sources":["../../components/message/Message.tsx"],"sourcesContent":["import React, {\n  forwardRef,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from \"react\"\nimport * as ReactDOM from \"react-dom\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Button from \"../button\"\nimport Icon, { IconNames } from \"../icon\"\nimport ICON_INTENTS from \"../alert/iconIntents\"\nimport \"./style\"\n\nconst prefix = \"adui-message\"\nconst INTENTS = [\"normal\", \"primary\", \"success\", \"warning\", \"danger\"]\n\nexport interface IMessageProps {\n  [key: string]: any\n  /**\n   * 行动按钮的配置，如：action: { text: \"解锁\", onClick: () => { message.destroy() } }\n   */\n  action?: { text: string; onClick: () => void } | null\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 是否显示关闭 Icon，如果需要只支持手动关闭，还需要传入 duration: 0\n   */\n  closable?: boolean\n  /**\n   * 内容\n   */\n  content?: React.ReactNode\n  /**\n   * 间隔多久自动关闭，单位为 s，如果传入 0，则表示不会自动消失\n   */\n  duration?: number\n  /**\n   * Message 插入到哪个元素，默认 () => document.body\n   */\n  getContainer?: () => HTMLElement\n  /**\n   * 设置图标\n   */\n  icon?: IconNames\n  /**\n   * 设置类型\n   */\n  intent: \"normal\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n  /**\n   * 关闭时的 handler\n   */\n  onClose?: (() => void) | null\n}\n\nexport interface IMessage\n  extends React.ForwardRefExoticComponent<\n    IMessageProps & React.RefAttributes<HTMLDivElement>\n  > {\n  normal: any\n  primary: any\n  success: any\n  warning: any\n  danger: any\n}\n\n/**\n * 全局提醒用于全局性地展示需要即时性关注的信息。\n */\n// @ts-ignore\nconst Message: IMessage = forwardRef(\n  (\n    {\n      action,\n      className,\n      closable,\n      content,\n      duration,\n      getContainer,\n      icon,\n      intent,\n      onClose,\n      ...otherProps\n    }: IMessageProps,\n    ref: any\n  ) => {\n    const messageRef = useRef<HTMLDivElement>(null)\n\n    let timer: null | ReturnType<typeof setTimeout>\n\n    const clearCloseTimer = () => {\n      if (timer) {\n        clearTimeout(timer)\n        timer = null\n      }\n    }\n\n    const close = () => {\n      if (messageRef && messageRef.current) {\n        messageRef.current.style.opacity = \"0\"\n        messageRef.current.style.visibility = \"hidden\"\n        messageRef.current.style.transform = \"translate3d(-50%, -56px, 0)\"\n        messageRef.current.style.transition =\n          \"all var(--adui-motion-duration-base) var(--adui-motion-ease-base)\"\n      }\n      clearCloseTimer()\n      if (onClose) {\n        onClose()\n      }\n    }\n\n    const setCloseTimer = () => {\n      if (duration) {\n        timer = setTimeout(() => {\n          close()\n        }, duration * 1000)\n      }\n    }\n\n    useEffect(() => {\n      setCloseTimer()\n      return clearCloseTimer\n    }, [])\n\n    useImperativeHandle(ref, () => ({\n      close,\n      getDomNode: () => messageRef.current,\n    }))\n\n    const hasActions = action || closable\n\n    return (\n      <div\n        className={classNames(\n          className,\n          `${prefix}-base`,\n          `${prefix}-${intent}`,\n          {\n            [`${prefix}-hasActions`]: hasActions,\n          }\n        )}\n        onMouseEnter={clearCloseTimer}\n        onMouseLeave={setCloseTimer}\n        ref={messageRef}\n        data-duration={duration}\n        {...otherProps}\n      >\n        <Icon\n          icon={icon || ICON_INTENTS[intent]}\n          size={20}\n          className={`${prefix}-icon`}\n        />\n        <div className={`${prefix}-content`}>{content}</div>\n        {hasActions && (\n          <div className={`${prefix}-actions`}>\n            {action && (\n              <div className={`${prefix}-action`}>\n                <Button\n                  theme=\"light\"\n                  onClick={() => {\n                    const { onClick } = action\n                    if (onClick) {\n                      onClick()\n                    }\n                  }}\n                >\n                  {action.text}\n                </Button>\n              </div>\n            )}\n            {closable && (\n              <Button leftIcon=\"cancel\" theme=\"light\" onClick={close} />\n            )}\n          </div>\n        )}\n      </div>\n    )\n  }\n)\n\nMessage.displayName = \"Message\"\n\nMessage.propTypes = {\n  /**\n   * 行动按钮的配置，如：action: { text: \"解锁\", onClick: () => { message.destroy() } }\n   */\n  action: PropTypes.any,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 是否显示关闭 Icon，如果需要只支持手动关闭，还需要传入 duration: 0\n   */\n  closable: PropTypes.bool,\n  /**\n   * 内容\n   */\n  content: PropTypes.node,\n  /**\n   * 间隔多久自动关闭，单位为 s，如果传入 0，则表示不会自动消失\n   */\n  duration: PropTypes.number,\n  /**\n   * Message 插入到哪个元素，默认 () => document.body\n   */\n  getContainer: PropTypes.func,\n  /**\n   * 设置图标\n   */\n  icon: PropTypes.any,\n  /**\n   * 设置类型\n   */\n  intent: PropTypes.any,\n  /**\n   * 关闭时的 handler\n   */\n  onClose: PropTypes.func,\n}\n\nMessage.defaultProps = {\n  action: null,\n  className: undefined,\n  closable: false,\n  content: null,\n  duration: 2,\n  getContainer: undefined,\n  icon: undefined,\n  intent: \"normal\",\n  onClose: null,\n}\n\nconst newInstance = (props: IMessageProps) => {\n  let instances = Array.from(\n    document.getElementsByClassName(`${prefix}-wrapper`)\n  )\n  instances = instances.filter(\n    (o: HTMLDivElement) => o.dataset.close !== \"true\"\n  )\n  if (instances && instances.length > 2) {\n    const firstInstance = instances[0] as HTMLElement\n    const firstChild = firstInstance.children[0] as HTMLElement\n    if (firstChild.dataset.duration !== \"0\") {\n      firstInstance.dataset.close = \"true\"\n      firstInstance.style.transform = \"translate3d(0, -56px, 0)\"\n      firstChild.style.opacity = \"0\"\n      firstChild.style.visibility = \"hidden\"\n\n      firstInstance.style.transition =\n        \"all var(--adui-motion-duration-base) var(--adui-motion-ease-base)\"\n      firstChild.style.transition =\n        \"all var(--adui-motion-duration-base) var(--adui-motion-ease-base)\"\n    }\n  }\n\n  let instance: any\n\n  const { onClose, getContainer, intent, ...otherProps } = props\n  const container = document.createElement(\"div\")\n  container.className = `${prefix}-wrapper`\n  container.dataset.intent = intent\n  if (getContainer) {\n    getContainer().appendChild(container)\n  } else {\n    document.body.appendChild(container)\n  }\n\n  const updateStyles = () => {\n    setTimeout(() => {\n      const messages = Array.from(\n        document.getElementsByClassName(`${prefix}-wrapper`)\n      ) as HTMLDivElement[]\n      messages.forEach((message, index) => {\n        if ([\"warning\", \"danger\"].includes(message.dataset.intent || \"\")) {\n          message.style.transition =\n            \"all var(--adui-motion-duration-bounce) var(--adui-motion-ease-bounce)\"\n        }\n        message.style.opacity = \"1\"\n        message.style.transform = `translate3d(0, ${\n          56 * (messages.length - 1 - index)\n        }px, 0)`\n      })\n    }, 50)\n  }\n\n  updateStyles()\n\n  const close = () => {\n    if (onClose) {\n      onClose()\n    }\n    setTimeout(() => {\n      const unmountResult = ReactDOM.unmountComponentAtNode(container)\n      if (unmountResult && container.parentNode) {\n        container.parentNode.removeChild(container)\n        updateStyles()\n      }\n    }, 300)\n  }\n\n  ReactDOM.render(\n    <Message\n      ref={(message) => {\n        instance = message\n      }}\n      onClose={close}\n      intent={intent}\n      {...otherProps}\n    />,\n    container\n  )\n\n  return {\n    destroy: () => {\n      if (instance) {\n        instance.close()\n      }\n    },\n  }\n}\n\nINTENTS.forEach(\n  (intent: \"normal\" | \"primary\" | \"success\" | \"warning\" | \"danger\") => {\n    Message[intent] = (config: IMessageProps | string) => {\n      let cnfg = { intent } as IMessageProps\n      if (typeof config === \"string\") {\n        cnfg = { content: config, intent }\n      } else {\n        cnfg = config\n      }\n      return newInstance({\n        ...cnfg,\n        intent,\n      })\n    }\n  }\n)\n\nexport default Message\n"],"mappings":"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"}