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>
212 lines • 30.4 kB
JavaScript
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
var _excluded = ["action", "className", "closable", "content", "duration", "getContainer", "icon", "intent", "onClose"],
_excluded2 = ["onClose", "getContainer", "intent"];
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
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 Icon from "../icon";
import ICON_INTENTS from "../alert/iconIntents";
import "./style";
var prefix = "adui-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,
icon = _ref.icon,
intent = _ref.intent,
onClose = _ref.onClose,
otherProps = _objectWithoutProperties(_ref, _excluded);
var messageRef = 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);
}
};
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), React.createElement(Icon, {
icon: icon || ICON_INTENTS[intent],
size: 20,
className: "".concat(prefix, "-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,
icon: PropTypes.any,
intent: PropTypes.any,
onClose: PropTypes.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) {
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.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
}));
};
});
export default Message;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useEffect","useImperativeHandle","useRef","ReactDOM","PropTypes","classNames","Button","Icon","ICON_INTENTS","prefix","INTENTS","Message","_ref","ref","action","className","closable","content","duration","getContainer","icon","intent","onClose","otherProps","_objectWithoutProperties","_excluded","messageRef","timer","clearCloseTimer","clearTimeout","close","current","style","opacity","visibility","transform","transition","setCloseTimer","setTimeout","getDomNode","hasActions","createElement","_extends","concat","_defineProperty","onMouseEnter","onMouseLeave","size","theme","onClick","text","leftIcon","displayName","propTypes","any","string","bool","node","number","func","defaultProps","undefined","newInstance","props","instances","Array","from","document","getElementsByClassName","filter","o","dataset","length","firstInstance","firstChild","children","instance","_excluded2","container","appendChild","body","updateStyles","messages","forEach","message","index","unmountResult","unmountComponentAtNode","parentNode","removeChild","render","destroy","config","cnfg","_objectSpread"],"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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","ignoreList":[]}