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>

99 lines (85 loc) 14 kB
var _excluded = ["className", "color", "icon", "interactive", "onClick", "paths", "size"]; 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, { 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 _classNames; 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"), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-interactive"), interactive), _defineProperty(_classNames, "".concat(prefix, "-interactive_level_0"), interactive && lightness < 0.35), _defineProperty(_classNames, "".concat(prefix, "-interactive_level_1"), interactive && lightness < 0.45 && lightness >= 0.35), _defineProperty(_classNames, "".concat(prefix, "-interactive_level_2"), interactive && lightness < 0.65 && lightness >= 0.45), _defineProperty(_classNames, "".concat(prefix, "-interactive_level_3"), interactive && lightness < 1 && lightness >= 0.65), _defineProperty(_classNames, "".concat(prefix, "-interactive_level_white"), interactive && lightness === 1), _classNames)); 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","className","color","icon","interactiveProp","interactive","onClick","paths","size","otherProps","length","lightness","colorProp","includes","documentStyle","getComputedStyle","document","documentElement","getPropertyValue","slice","l","data","finalPaths","map","d","classSet","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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"}