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>
182 lines (154 loc) • 24.7 kB
JavaScript
var _excluded = ["afterClose", "className", "closable", "closeText", "defaultExpanded", "expandContent", "expanded", "icon", "intent", "onClose", "onExpandChange", "size", "text", "title", "theme"];
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 _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
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, { useContext, useRef, useState } from "react";
import PropTypes from "prop-types";
import classNames from "classnames";
import Icon from "../icon";
import ICON_INTENTS from "./iconIntents";
import { ConfigContext, getComputedSize } from "../config-provider";
import "./style";
var prefix = "adui-alert";
var Alert = function Alert(_ref) {
var afterClose = _ref.afterClose,
className = _ref.className,
closable = _ref.closable,
closeText = _ref.closeText,
defaultExpanded = _ref.defaultExpanded,
expandContent = _ref.expandContent,
expandedProp = _ref.expanded,
icon = _ref.icon,
intent = _ref.intent,
onClose = _ref.onClose,
onExpandChange = _ref.onExpandChange,
size = _ref.size,
text = _ref.text,
title = _ref.title,
theme = _ref.theme,
otherProps = _objectWithoutProperties(_ref, _excluded);
var ref = useRef(null);
var _useState = useState(expandedProp !== null && expandedProp !== undefined ? expandedProp : !!defaultExpanded),
_useState2 = _slicedToArray(_useState, 2),
expanded = _useState2[0],
setExpanded = _useState2[1];
var _useState3 = useState(false),
_useState4 = _slicedToArray(_useState3, 2),
closing = _useState4[0],
setClosing = _useState4[1];
if (expandedProp !== null && expandedProp !== undefined && expanded !== expandedProp) {
setExpanded(expandedProp);
}
var _useContext = useContext(ConfigContext),
sizeContext = _useContext.size;
var computedSize = getComputedSize(size, sizeContext);
var handleClose = function handleClose() {
if (onClose) {
onClose();
}
if (ref.current) {
ref.current.style.height = "".concat(ref.current.offsetHeight, "px");
setTimeout(function () {
if (ref.current) {
ref.current.style.marginTop = "0";
ref.current.style.marginBottom = "0";
ref.current.style.paddingTop = "0";
ref.current.style.paddingBottom = "0";
ref.current.style.height = "0";
ref.current.style.opacity = "0";
}
setTimeout(function () {
setClosing(true);
if (afterClose) {
afterClose();
}
}, 300);
}, 0);
}
};
var handleExpand = function handleExpand() {
if (expandedProp === null) {
setExpanded(!expanded);
}
if (onExpandChange) {
onExpandChange(!expanded);
}
};
var classSet = classNames(className, "".concat(prefix, "-base"), "".concat(prefix, "-").concat(intent), "".concat(prefix, "-").concat(computedSize), _defineProperty({}, "".concat(prefix, "-").concat(theme), theme));
if (closing) {
return null;
}
return React.createElement("div", _extends({
ref: ref,
className: classSet
}, otherProps), React.createElement("div", {
className: "".concat(prefix, "-inner")
}, icon !== null && React.createElement(Icon, {
icon: icon || ICON_INTENTS[intent || "normal"],
size: computedSize === "mini" ? 18 : 20,
className: "".concat(prefix, "-icon")
}), React.createElement("div", {
className: "".concat(prefix, "-text")
}, !!title && React.createElement("div", {
className: "".concat(prefix, "-title")
}, title), React.createElement("div", null, text), !!expandContent && expanded && React.createElement("div", {
className: "".concat(prefix, "-expandContent")
}, " ", expandContent, " ")), closable && React.createElement("div", {
className: classNames("".concat(prefix, "-close"), _defineProperty({}, "".concat(prefix, "-close_text"), !!closeText))
}, closeText ? React.createElement("div", {
className: "".concat(prefix, "-closeText"),
onClick: handleClose,
role: "none"
}, closeText) : React.createElement(Icon, {
className: "".concat(prefix, "-closeIcon"),
icon: "cancel",
onClick: handleClose
})), !!expandContent && React.createElement("div", {
className: "".concat(prefix, "-expand"),
onClick: handleExpand,
role: "none"
}, expanded ? "收起" : "展开")));
};
Alert.displayName = "Alert";
Alert.propTypes = {
afterClose: PropTypes.func,
className: PropTypes.string,
closable: PropTypes.bool,
closeText: PropTypes.node,
defaultExpanded: PropTypes.bool,
expandContent: PropTypes.node,
expanded: PropTypes.bool,
icon: PropTypes.any,
intent: PropTypes.oneOf(["normal", "primary", "success", "info", "warning", "danger"]),
onClose: PropTypes.func,
onExpandChange: PropTypes.func,
size: PropTypes.oneOf(["mini", "small", "medium"]),
text: PropTypes.node.isRequired,
theme: PropTypes.oneOf([null, "light"]),
title: PropTypes.node
};
Alert.defaultProps = {
afterClose: function afterClose() {},
className: undefined,
closable: false,
closeText: null,
defaultExpanded: null,
expandContent: null,
expanded: null,
icon: undefined,
intent: "normal",
onClose: function onClose() {},
onExpandChange: function onExpandChange() {},
size: "small",
theme: null,
title: null
};
export default Alert;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useContext","useRef","useState","PropTypes","classNames","Icon","ICON_INTENTS","ConfigContext","getComputedSize","prefix","Alert","afterClose","className","closable","closeText","defaultExpanded","expandContent","expandedProp","expanded","icon","intent","onClose","onExpandChange","size","text","title","theme","otherProps","ref","undefined","setExpanded","closing","setClosing","sizeContext","computedSize","handleClose","current","style","height","offsetHeight","setTimeout","marginTop","marginBottom","paddingTop","paddingBottom","opacity","handleExpand","classSet","displayName","propTypes","func","string","bool","node","any","oneOf","isRequired","defaultProps"],"sources":["../../components/alert/Alert.tsx"],"sourcesContent":["import React, { useContext, useRef, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Icon, { IconNames } from \"../icon\"\nimport ICON_INTENTS from \"./iconIntents\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport \"./style\"\n\nconst prefix = \"adui-alert\"\n\nexport interface IAlertProps {\n  [key: string]: any\n  /**\n   * 关闭后的 handler，参数 node\n   */\n  afterClose?: () => void\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 是否可关闭\n   */\n  closable?: boolean\n  /**\n   * 关闭文字\n   */\n  closeText?: React.ReactNode\n  /**\n   * 是否展开，内部驱动\n   */\n  defaultExpanded?: boolean | null\n  /**\n   * 展开内容\n   */\n  expandContent?: React.ReactNode\n  /**\n   * 是否展开，外部控制\n   */\n  expanded?: boolean | null\n  /**\n   * 设置图标\n   */\n  icon?: IconNames | null\n  /**\n   * 设置类型\n   */\n  intent?: \"normal\" | \"primary\" | \"success\" | \"info\" | \"warning\" | \"danger\"\n  /**\n   * 关闭时的 handler\n   */\n  onClose?: () => void\n  /**\n   * 展开状态变化时的 handler，参数为 bool\n   */\n  onExpandChange?: (expanded: boolean) => void\n  /**\n   * 设置尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\"\n  /**\n   * 提醒内容\n   */\n  text: React.ReactNode\n  /**\n   * 设置主题\n   */\n  theme?: null | \"light\"\n  /**\n   * 提醒标题\n   */\n  title?: React.ReactNode\n}\n\n/**\n * 提醒是内容的常态、即时性提示，展示需要用户即时关注的信息。\n * 与对话框 Dialog 或气泡提示 Popover 不同，提醒 Alert 通常常驻在页面中，与页面内容有更强的关联性。\n */\nconst Alert: React.FC<IAlertProps> = ({\n  afterClose,\n  className,\n  closable,\n  closeText,\n  defaultExpanded,\n  expandContent,\n  expanded: expandedProp,\n  icon,\n  intent,\n  onClose,\n  onExpandChange,\n  size,\n  text,\n  title,\n  theme,\n  ...otherProps\n}: IAlertProps) => {\n  const ref = useRef<HTMLDivElement>(null)\n  const [expanded, setExpanded] = useState(\n    expandedProp !== null && expandedProp !== undefined\n      ? expandedProp\n      : !!defaultExpanded\n  )\n  const [closing, setClosing] = useState(false)\n\n  // 相当于生命周期 getDerivedStateFromProps\n  if (\n    expandedProp !== null &&\n    expandedProp !== undefined &&\n    expanded !== expandedProp\n  ) {\n    setExpanded(expandedProp)\n  }\n\n  const { size: sizeContext } = useContext(ConfigContext)\n  const computedSize = getComputedSize(size, sizeContext)\n\n  const handleClose = () => {\n    if (onClose) {\n      onClose()\n    }\n\n    if (ref.current) {\n      ref.current.style.height = `${ref.current.offsetHeight}px`\n\n      setTimeout(() => {\n        if (ref.current) {\n          ref.current.style.marginTop = \"0\"\n          ref.current.style.marginBottom = \"0\"\n          ref.current.style.paddingTop = \"0\"\n          ref.current.style.paddingBottom = \"0\"\n          ref.current.style.height = \"0\"\n          ref.current.style.opacity = \"0\"\n        }\n        setTimeout(() => {\n          setClosing(true)\n          if (afterClose) {\n            afterClose()\n          }\n        }, 300)\n      }, 0)\n    }\n  }\n\n  const handleExpand = () => {\n    if (expandedProp === null) {\n      setExpanded(!expanded)\n    }\n    if (onExpandChange) {\n      onExpandChange(!expanded)\n    }\n  }\n\n  const classSet = classNames(\n    className,\n    `${prefix}-base`,\n    `${prefix}-${intent}`,\n    `${prefix}-${computedSize}`,\n    {\n      [`${prefix}-${theme}`]: theme,\n    }\n  )\n\n  if (closing) {\n    return null\n  }\n\n  return (\n    <div ref={ref} className={classSet} {...otherProps}>\n      <div className={`${prefix}-inner`}>\n        {icon !== null && (\n          <Icon\n            icon={icon || ICON_INTENTS[intent || \"normal\"]}\n            size={computedSize === \"mini\" ? 18 : 20}\n            className={`${prefix}-icon`}\n          />\n        )}\n        <div className={`${prefix}-text`}>\n          {!!title && <div className={`${prefix}-title`}>{title}</div>}\n          <div>{text}</div>\n          {!!expandContent && expanded && (\n            <div className={`${prefix}-expandContent`}> {expandContent} </div>\n          )}\n        </div>\n        {closable && (\n          <div\n            className={classNames(`${prefix}-close`, {\n              [`${prefix}-close_text`]: !!closeText,\n            })}\n          >\n            {closeText ? (\n              <div\n                className={`${prefix}-closeText`}\n                onClick={handleClose}\n                role=\"none\"\n              >\n                {closeText}\n              </div>\n            ) : (\n              <Icon\n                className={`${prefix}-closeIcon`}\n                icon=\"cancel\"\n                onClick={handleClose}\n              />\n            )}\n          </div>\n        )}\n        {!!expandContent && (\n          <div\n            className={`${prefix}-expand`}\n            onClick={handleExpand}\n            role=\"none\"\n          >\n            {expanded ? \"收起\" : \"展开\"}\n          </div>\n        )}\n      </div>\n    </div>\n  )\n}\n\nAlert.displayName = \"Alert\"\n\nAlert.propTypes = {\n  /**\n   * 关闭后的 handler，参数 node\n   */\n  afterClose: PropTypes.func,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 是否可关闭\n   */\n  closable: PropTypes.bool,\n  /**\n   * 关闭文字\n   */\n  closeText: PropTypes.node,\n  /**\n   * 是否展开，内部驱动\n   */\n  defaultExpanded: PropTypes.bool,\n  /**\n   * 展开内容\n   */\n  expandContent: PropTypes.node,\n  /**\n   * 是否展开，外部控制\n   */\n  expanded: PropTypes.bool,\n  /**\n   * 设置图标\n   */\n  icon: PropTypes.any,\n  /**\n   * 设置类型\n   */\n  intent: PropTypes.oneOf([\n    \"normal\",\n    \"primary\",\n    \"success\",\n    \"info\",\n    \"warning\",\n    \"danger\",\n  ]),\n  /**\n   * 关闭时的 handler，参数 node\n   */\n  onClose: PropTypes.func,\n  /**\n   * 展开状态变化时的 handler，参数为 bool\n   */\n  onExpandChange: PropTypes.func,\n  /**\n   * 设置尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\"]),\n  /**\n   * 提醒内容\n   */\n  text: PropTypes.node.isRequired,\n  /**\n   * 设置主题\n   */\n  theme: PropTypes.oneOf([null, \"light\"]),\n  /**\n   * 提醒标题\n   */\n  title: PropTypes.node,\n}\n\nAlert.defaultProps = {\n  afterClose: () => {},\n  className: undefined,\n  closable: false,\n  closeText: null,\n  defaultExpanded: null,\n  expandContent: null,\n  expanded: null,\n  icon: undefined,\n  intent: \"normal\",\n  onClose: () => {},\n  onExpandChange: () => {},\n  size: \"small\",\n  theme: null,\n  title: null,\n}\n\nexport default Alert\n"],"mappings":"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"}