UNPKG

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>

87 lines 14.8 kB
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 = ["className", "color", "icon", "interactive", "onClick", "paths", "size"]; 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, { useMemo } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import { color2hsl } from "../_util/color"; import IconSvgPaths from "./IconSvgPaths"; import "./style"; var prefix = "adui-icon"; var Icon = function Icon(_ref) { var className = _ref.className, color = _ref.color, icon = _ref.icon, interactiveProp = _ref.interactive, _onClick = _ref.onClick, paths = _ref.paths, size = _ref.size, otherProps = _objectWithoutProperties(_ref, _excluded); if (!icon && !(paths !== null && paths !== void 0 && paths.length)) { return null; } var lightness = useMemo(function () { var colorProp = color; if (colorProp && colorProp.includes("var")) { var documentStyle = getComputedStyle(document.documentElement); if (documentStyle) { colorProp = documentStyle.getPropertyValue(colorProp.slice(4, colorProp.length - 1)); } colorProp = "#a3a3a3"; } return color2hsl(colorProp).l; }, [color]); var data = IconSvgPaths[icon] || []; var finalPaths = (paths || data).map(function (d) { return React.createElement("path", { d: d, key: d, fillRule: "evenodd" }); }); var interactive = interactiveProp || !!_onClick; var classSet = classNames(className, "".concat(prefix, "-base"), _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "".concat(prefix, "-interactive"), interactive), "".concat(prefix, "-interactive_level_0"), interactive && lightness < 0.35), "".concat(prefix, "-interactive_level_1"), interactive && lightness < 0.45 && lightness >= 0.35), "".concat(prefix, "-interactive_level_2"), interactive && lightness < 0.65 && lightness >= 0.45), "".concat(prefix, "-interactive_level_3"), interactive && lightness < 1 && lightness >= 0.65), "".concat(prefix, "-interactive_level_white"), interactive && lightness === 1)); return React.createElement("svg", _extends({ className: classSet, width: size, height: size, viewBox: "0 0 18 18", fill: color, "data-interactive": interactive, "data-icon": icon, onClick: function onClick(e) { if (_onClick) { _onClick(e); } } }, otherProps), finalPaths, interactive && lightness !== 1 && React.createElement("g", { className: "".concat(prefix, "-interactive-cover"), fill: "#000" }, finalPaths)); }; Icon.propTypes = { className: PropTypes.string, color: PropTypes.string, icon: PropTypes.any, interactive: PropTypes.bool, onClick: PropTypes.func, paths: PropTypes.array, size: PropTypes.number }; Icon.defaultProps = { className: undefined, color: "var(--gray-700)", icon: undefined, interactive: false, onClick: null, paths: undefined, size: 18 }; Icon.type = "Icon"; export default Icon; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useMemo","PropTypes","classNames","color2hsl","IconSvgPaths","prefix","Icon","_ref","className","color","icon","interactiveProp","interactive","onClick","paths","size","otherProps","_objectWithoutProperties","_excluded","length","lightness","colorProp","includes","documentStyle","getComputedStyle","document","documentElement","getPropertyValue","slice","l","data","finalPaths","map","d","createElement","key","fillRule","classSet","concat","_defineProperty","_extends","width","height","viewBox","fill","e","propTypes","string","any","bool","func","array","number","defaultProps","undefined","type"],"sources":["../../components/icon/Icon.tsx"],"sourcesContent":["import React, { useMemo } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { color2hsl } from \"../_util/color\"\nimport IconSvgPaths from \"./IconSvgPaths\"\nimport { IIconNames } from \"./IconNames\"\nimport \"./style\"\n\nconst prefix = \"adui-icon\"\n\nexport type IconNames = keyof IIconNames\n\nexport interface IIconProps {\n  [key: string]: any\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 颜色值，支持 rgb(a?), hex 以及 css variable\n   */\n  color?: string\n  /**\n   * 图标名称\n   */\n  icon: IconNames\n  /**\n   * 是否可交互，组件内部将会根据当前颜色，为其加上 hover active 样式\n   */\n  interactive?: boolean\n  /**\n   * 点击事件的 handler\n   */\n  onClick?: ((e: React.MouseEvent<SVGSVGElement, MouseEvent>) => void) | null\n  /**\n   * 自定义图标 path 路径\n   */\n  paths?: string[]\n  /**\n   * 尺寸\n   */\n  size?: number\n}\n\n/**\n * 语义化的矢量图形，分为导航、反馈、编辑、工具、图表和生活五种类型。\n */\nconst Icon: React.FC<IIconProps> & {\n  type: string\n} = ({\n  className,\n  color,\n  icon,\n  interactive: interactiveProp,\n  onClick,\n  paths,\n  size,\n  ...otherProps\n}: IIconProps) => {\n  if (!icon && !paths?.length) {\n    return null\n  }\n\n  const lightness = useMemo(() => {\n    let colorProp = color\n    if (colorProp && colorProp.includes(\"var\")) {\n      const documentStyle = getComputedStyle(document.documentElement)\n      if (documentStyle) {\n        colorProp = documentStyle.getPropertyValue(\n          colorProp.slice(4, colorProp.length - 1)\n        )\n      }\n      colorProp = \"#a3a3a3\"\n    }\n    return color2hsl(colorProp).l\n  }, [color])\n\n  const data = IconSvgPaths[icon] || []\n  const finalPaths = (paths || data).map((d: string) => (\n    <path d={d} key={d} fillRule=\"evenodd\" />\n  ))\n  const interactive = interactiveProp || !!onClick\n  const classSet = classNames(className, `${prefix}-base`, {\n    [`${prefix}-interactive`]: interactive,\n    [`${prefix}-interactive_level_0`]: interactive && lightness < 0.35,\n    [`${prefix}-interactive_level_1`]:\n      interactive && lightness < 0.45 && lightness >= 0.35,\n    [`${prefix}-interactive_level_2`]:\n      interactive && lightness < 0.65 && lightness >= 0.45,\n    [`${prefix}-interactive_level_3`]:\n      interactive && lightness < 1 && lightness >= 0.65,\n    [`${prefix}-interactive_level_white`]: interactive && lightness === 1,\n  })\n\n  return (\n    <svg\n      className={classSet}\n      width={size}\n      height={size}\n      viewBox=\"0 0 18 18\"\n      fill={color}\n      data-interactive={interactive}\n      data-icon={icon}\n      onClick={(e) => {\n        if (onClick) {\n          onClick(e)\n        }\n      }}\n      {...otherProps}\n    >\n      {finalPaths}\n      {interactive && lightness !== 1 && (\n        <g className={`${prefix}-interactive-cover`} fill=\"#000\">\n          {finalPaths}\n        </g>\n      )}\n    </svg>\n  )\n}\n\nIcon.propTypes = {\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 颜色值，支持 rgb(a?), hex 以及 css variable\n   */\n  color: PropTypes.string,\n  /**\n   * 图标名称\n   */\n  icon: PropTypes.any,\n  /**\n   * 是否可交互，组件内部将会根据当前颜色，为其加上 hover active 样式\n   */\n  interactive: PropTypes.bool,\n  /**\n   * 点击事件的 handler\n   */\n  onClick: PropTypes.func,\n  /**\n   * 自定义图标 path 路径\n   */\n  paths: PropTypes.array,\n  /**\n   * 尺寸\n   */\n  size: PropTypes.number,\n}\n\nIcon.defaultProps = {\n  className: undefined,\n  color: \"var(--gray-700)\",\n  icon: undefined,\n  interactive: false,\n  onClick: null,\n  paths: undefined,\n  size: 18,\n}\n\nIcon.type = \"Icon\"\n\nexport default Icon\n"],"mappings":"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","ignoreList":[]}