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>
289 lines (253 loc) • 35.8 kB
JavaScript
var _excluded = ["action", "className", "closable", "content", "duration", "getContainer", "intent", "onClose"],
_excluded2 = ["onClose", "getContainer"];
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; }
import React, { forwardRef, useEffect, useImperativeHandle, useRef } from "react";
import * as ReactDOM from "react-dom";
import PropTypes from "prop-types";
import classNames from "classnames";
import Button from "../button";
import "./style";
var prefix = "adui-channels-message";
var INTENTS = ["normal", "primary", "success", "warning", "danger"];
var Message = forwardRef(function (_ref, ref) {
var action = _ref.action,
className = _ref.className,
closable = _ref.closable,
content = _ref.content,
duration = _ref.duration,
getContainer = _ref.getContainer,
intent = _ref.intent,
onClose = _ref.onClose,
otherProps = _objectWithoutProperties(_ref, _excluded);
var messageRef = useRef(null);
var icon = React.createElement("svg", {
className: "".concat(prefix, "-icon"),
width: "20",
height: "20",
viewBox: "0 0 20 20",
fill: "none"
}, React.createElement("path", {
fillRule: "evenodd",
clipRule: "evenodd",
d: "M1.66663 10C1.66663 14.6024 5.39759 18.3333 9.99996 18.3333C14.6023 18.3333 18.3333 14.6024 18.3333 10C18.3333 5.39763 14.6023 1.66667 9.99996 1.66667C5.39759 1.66667 1.66663 5.39763 1.66663 10ZM13.6856 7.11667L9.01949 11.7828L6.71457 9.47785L5.83329 10.3591L8.31438 12.842C8.70481 13.2327 9.33806 13.2329 9.72871 12.8424L14.571 8.00211L13.6856 7.11667Z",
fill: "#07C160",
fillOpacity: "0.9"
}));
switch (intent) {
case "normal":
icon = React.createElement("svg", {
className: "".concat(prefix, "-icon"),
width: "20",
height: "20",
viewBox: "0 0 20 20",
fill: "none"
}, React.createElement("path", {
fillRule: "evenodd",
clipRule: "evenodd",
d: "M9.99996 18.3333C5.39759 18.3333 1.66663 14.6024 1.66663 10C1.66663 5.39762 5.39759 1.66666 9.99996 1.66666C14.6023 1.66666 18.3333 5.39762 18.3333 10C18.3333 14.6024 14.6023 18.3333 9.99996 18.3333ZM10.625 8.33333V14.1667H9.37496V8.33333H10.625ZM9.99996 7.5C10.4602 7.5 10.8333 7.1269 10.8333 6.66666C10.8333 6.20643 10.4602 5.83333 9.99996 5.83333C9.53972 5.83333 9.16663 6.20643 9.16663 6.66666C9.16663 7.1269 9.53972 7.5 9.99996 7.5Z",
fill: "#10AEFF"
}));
break;
case "warning":
icon = React.createElement("svg", {
className: "".concat(prefix, "-icon"),
width: "20",
height: "20",
viewBox: "0 0 20 20",
fill: "none"
}, React.createElement("path", {
fillRule: "evenodd",
clipRule: "evenodd",
d: "M18.3005 16.0439C18.6855 16.7105 18.2044 17.5439 17.4346 17.5439L2.5653 17.5452C1.79551 17.5452 1.31431 16.712 1.69913 16.0453L9.13254 3.16683C9.51738 2.5001 10.4797 2.50002 10.8646 3.16667L18.3005 16.0439ZM9.37253 7.9541H10.6274L10.5298 12.6758H9.47019L9.37253 7.9541ZM9.28952 14.4043C9.28952 14.79 9.60202 15.0977 9.99753 15.0977C10.3979 15.0977 10.7104 14.79 10.7104 14.4043C10.7104 14.0185 10.3979 13.7158 9.99753 13.7158C9.60202 13.7158 9.28952 14.0185 9.28952 14.4043Z",
fill: "#FA9D3B"
}));
break;
case "danger":
icon = React.createElement("svg", {
className: "".concat(prefix, "-icon"),
width: "20",
height: "20",
viewBox: "0 0 20 20",
fill: "none"
}, React.createElement("path", {
fillRule: "evenodd",
clipRule: "evenodd",
d: "M9.99996 18.3333C5.39759 18.3333 1.66663 14.6024 1.66663 10C1.66663 5.39763 5.39759 1.66667 9.99996 1.66667C14.6023 1.66667 18.3333 5.39763 18.3333 10C18.3333 14.6024 14.6023 18.3333 9.99996 18.3333ZM9.36389 5.11312H10.6342L10.5431 11.4437H9.45504L9.36389 5.11312ZM9.24996 13.5173C9.24996 13.9331 9.58036 14.2521 9.99622 14.2521C10.4235 14.2521 10.7482 13.9331 10.7482 13.5173C10.7482 13.1014 10.4235 12.7824 9.99622 12.7824C9.58036 12.7824 9.24996 13.1014 9.24996 13.5173Z",
fill: "#FA5151"
}));
break;
default:
break;
}
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.filter = "blur(4px)";
}
clearCloseTimer();
if (onClose) {
onClose();
}
};
var setCloseTimer = function setCloseTimer() {
if (duration) {
timer = setTimeout(function () {
close();
}, duration * 1000);
}
};
useEffect(function () {
setCloseTimer();
return clearCloseTimer;
}, []);
useImperativeHandle(ref, function () {
return {
close: close,
getDomNode: function getDomNode() {
return messageRef.current;
}
};
});
var hasActions = action || closable;
return React.createElement("div", _extends({
className: classNames(className, "".concat(prefix, "-base"), "".concat(prefix, "-").concat(intent), _defineProperty({}, "".concat(prefix, "-hasActions"), hasActions)),
onMouseEnter: clearCloseTimer,
onMouseLeave: setCloseTimer,
ref: messageRef,
"data-duration": duration
}, otherProps), icon, React.createElement("div", {
className: "".concat(prefix, "-content")
}, content), hasActions && React.createElement("div", {
className: "".concat(prefix, "-actions")
}, action && React.createElement("div", {
className: "".concat(prefix, "-action")
}, React.createElement(Button, {
theme: "light",
onClick: function onClick() {
var onClick = action.onClick;
if (onClick) {
onClick();
}
}
}, action.text)), closable && React.createElement(Button, {
leftIcon: "cancel",
theme: "light",
onClick: close
})));
});
Message.displayName = "Message";
Message.propTypes = {
action: PropTypes.any,
className: PropTypes.string,
closable: PropTypes.bool,
content: PropTypes.node,
duration: PropTypes.number,
getContainer: PropTypes.func,
intent: PropTypes.any,
onClose: PropTypes.func
};
Message.defaultProps = {
action: null,
className: undefined,
closable: false,
content: null,
duration: 2,
getContainer: 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";
firstChild.style.opacity = "0";
firstChild.style.visibility = "hidden";
firstChild.style.filter = "blur(4px)";
}
}
var instance;
var onClose = props.onClose,
getContainer = props.getContainer,
otherProps = _objectWithoutProperties(props, _excluded2);
var container = document.createElement("div");
container.className = "".concat(prefix, "-wrapper");
if (getContainer) {
getContainer().appendChild(container);
} else {
document.body.appendChild(container);
}
var updateStyles = function updateStyles() {
setTimeout(function () {
var messages = document.getElementsByClassName("".concat(prefix, "-wrapper"));
Array.prototype.forEach.call(messages, function (message, index) {
message.style.opacity = "1";
message.style.transform = "\n translate3d(var(--message-offset-x),\n calc(".concat(56 * (messages.length - 1 - index), "px + var(--message-offset-y)), 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.createElement(Message, _extends({
ref: function ref(message) {
instance = message;
},
onClose: close
}, 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
}));
};
});
export default Message;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useEffect","useImperativeHandle","useRef","ReactDOM","PropTypes","classNames","Button","prefix","INTENTS","Message","ref","action","className","closable","content","duration","getContainer","intent","onClose","otherProps","messageRef","icon","timer","clearCloseTimer","clearTimeout","close","current","style","opacity","visibility","filter","setCloseTimer","setTimeout","getDomNode","hasActions","onClick","text","displayName","propTypes","any","string","bool","node","number","func","defaultProps","undefined","newInstance","props","instances","Array","from","document","getElementsByClassName","o","dataset","length","firstInstance","firstChild","children","instance","container","createElement","appendChild","body","updateStyles","messages","prototype","forEach","call","message","index","transform","unmountResult","unmountComponentAtNode","parentNode","removeChild","render","destroy","config","cnfg"],"sources":["../../components/channels-message/Message.tsx"],"sourcesContent":["/* eslint-disable max-len */\nimport 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 \"./style\"\n\nconst prefix = \"adui-channels-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  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      intent,\n      onClose,\n      ...otherProps\n    }: IMessageProps,\n    ref: any\n  ) => {\n    const messageRef = useRef<HTMLDivElement>(null)\n\n    let icon = (\n      <svg\n        className={`${prefix}-icon`}\n        width=\"20\"\n        height=\"20\"\n        viewBox=\"0 0 20 20\"\n        fill=\"none\"\n      >\n        <path\n          fillRule=\"evenodd\"\n          clipRule=\"evenodd\"\n          d=\"M1.66663 10C1.66663 14.6024 5.39759 18.3333 9.99996 18.3333C14.6023 18.3333 18.3333 14.6024 18.3333 10C18.3333 5.39763 14.6023 1.66667 9.99996 1.66667C5.39759 1.66667 1.66663 5.39763 1.66663 10ZM13.6856 7.11667L9.01949 11.7828L6.71457 9.47785L5.83329 10.3591L8.31438 12.842C8.70481 13.2327 9.33806 13.2329 9.72871 12.8424L14.571 8.00211L13.6856 7.11667Z\"\n          fill=\"#07C160\"\n          fillOpacity=\"0.9\"\n        />\n      </svg>\n    )\n\n    switch (intent) {\n      case \"normal\":\n        icon = (\n          <svg\n            className={`${prefix}-icon`}\n            width=\"20\"\n            height=\"20\"\n            viewBox=\"0 0 20 20\"\n            fill=\"none\"\n          >\n            <path\n              fillRule=\"evenodd\"\n              clipRule=\"evenodd\"\n              d=\"M9.99996 18.3333C5.39759 18.3333 1.66663 14.6024 1.66663 10C1.66663 5.39762 5.39759 1.66666 9.99996 1.66666C14.6023 1.66666 18.3333 5.39762 18.3333 10C18.3333 14.6024 14.6023 18.3333 9.99996 18.3333ZM10.625 8.33333V14.1667H9.37496V8.33333H10.625ZM9.99996 7.5C10.4602 7.5 10.8333 7.1269 10.8333 6.66666C10.8333 6.20643 10.4602 5.83333 9.99996 5.83333C9.53972 5.83333 9.16663 6.20643 9.16663 6.66666C9.16663 7.1269 9.53972 7.5 9.99996 7.5Z\"\n              fill=\"#10AEFF\"\n            />\n          </svg>\n        )\n        break\n      case \"warning\":\n        icon = (\n          <svg\n            className={`${prefix}-icon`}\n            width=\"20\"\n            height=\"20\"\n            viewBox=\"0 0 20 20\"\n            fill=\"none\"\n          >\n            <path\n              fillRule=\"evenodd\"\n              clipRule=\"evenodd\"\n              d=\"M18.3005 16.0439C18.6855 16.7105 18.2044 17.5439 17.4346 17.5439L2.5653 17.5452C1.79551 17.5452 1.31431 16.712 1.69913 16.0453L9.13254 3.16683C9.51738 2.5001 10.4797 2.50002 10.8646 3.16667L18.3005 16.0439ZM9.37253 7.9541H10.6274L10.5298 12.6758H9.47019L9.37253 7.9541ZM9.28952 14.4043C9.28952 14.79 9.60202 15.0977 9.99753 15.0977C10.3979 15.0977 10.7104 14.79 10.7104 14.4043C10.7104 14.0185 10.3979 13.7158 9.99753 13.7158C9.60202 13.7158 9.28952 14.0185 9.28952 14.4043Z\"\n              fill=\"#FA9D3B\"\n            />\n          </svg>\n        )\n        break\n      case \"danger\":\n        icon = (\n          <svg\n            className={`${prefix}-icon`}\n            width=\"20\"\n            height=\"20\"\n            viewBox=\"0 0 20 20\"\n            fill=\"none\"\n          >\n            <path\n              fillRule=\"evenodd\"\n              clipRule=\"evenodd\"\n              d=\"M9.99996 18.3333C5.39759 18.3333 1.66663 14.6024 1.66663 10C1.66663 5.39763 5.39759 1.66667 9.99996 1.66667C14.6023 1.66667 18.3333 5.39763 18.3333 10C18.3333 14.6024 14.6023 18.3333 9.99996 18.3333ZM9.36389 5.11312H10.6342L10.5431 11.4437H9.45504L9.36389 5.11312ZM9.24996 13.5173C9.24996 13.9331 9.58036 14.2521 9.99622 14.2521C10.4235 14.2521 10.7482 13.9331 10.7482 13.5173C10.7482 13.1014 10.4235 12.7824 9.99622 12.7824C9.58036 12.7824 9.24996 13.1014 9.24996 13.5173Z\"\n              fill=\"#FA5151\"\n            />\n          </svg>\n        )\n        break\n      default:\n        break\n    }\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.filter = \"blur(4px)\"\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        <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  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  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      firstChild.style.opacity = \"0\"\n      firstChild.style.visibility = \"hidden\"\n      firstChild.style.filter = \"blur(4px)\"\n    }\n  }\n\n  let instance: any\n\n  const { onClose, getContainer, ...otherProps } = props\n  const container = document.createElement(\"div\")\n  container.className = `${prefix}-wrapper`\n  if (getContainer) {\n    getContainer().appendChild(container)\n  } else {\n    document.body.appendChild(container)\n  }\n\n  const updateStyles = () => {\n    setTimeout(() => {\n      const messages = document.getElementsByClassName(`${prefix}-wrapper`)\n      Array.prototype.forEach.call(\n        messages,\n        (message: HTMLDivElement, index: number) => {\n          message.style.opacity = \"1\"\n          message.style.transform = `\n          translate3d(var(--message-offset-x),\n          calc(${\n            56 * (messages.length - 1 - index)\n          }px + var(--message-offset-y)), 0)`\n        }\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      {...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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"}