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>
244 lines (212 loc) • 29.6 kB
JavaScript
var _excluded = ["action", "className", "closable", "content", "duration", "getContainer", "icon", "intent", "onClose"],
_excluded2 = ["onClose", "getContainer", "intent"];
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 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) {
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.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","action","className","closable","content","duration","getContainer","icon","intent","onClose","otherProps","messageRef","timer","clearCloseTimer","clearTimeout","close","current","style","opacity","visibility","transform","transition","setCloseTimer","setTimeout","getDomNode","hasActions","onClick","text","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","container","createElement","appendChild","body","updateStyles","messages","forEach","message","index","includes","unmountResult","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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"}