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>
145 lines (108 loc) • 18.7 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _configProvider = require("../config-provider");
var _icon = _interopRequireDefault(require("../icon"));
require("./style");
var _excluded = ["children", "className", "color", "intent", "interactive", "onRemove", "removable", "round", "size", "style", "theme"];
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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 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 _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; }
var prefix = "adui-tag";
var Tag = function Tag(_ref) {
var _classNames;
var children = _ref.children,
className = _ref.className,
color = _ref.color,
intent = _ref.intent,
interactive = _ref.interactive,
onRemove = _ref.onRemove,
removableProp = _ref.removable,
round = _ref.round,
size = _ref.size,
style = _ref.style,
theme = _ref.theme,
otherProps = _objectWithoutProperties(_ref, _excluded);
var _useState = (0, _react.useState)(false),
_useState2 = _slicedToArray(_useState, 2),
removed = _useState2[0],
setRemoved = _useState2[1];
var _useContext = (0, _react.useContext)(_configProvider.ConfigContext),
sizeContext = _useContext.size;
var handleRemove = function handleRemove(e) {
setRemoved(true);
if (onRemove) {
onRemove(e);
}
};
var removable = !!onRemove || removableProp;
var classSet = (0, _classnames["default"])(className, "".concat(prefix, "-base"), color ? "" : "".concat(prefix, "-").concat(intent), "".concat(prefix, "-").concat((0, _configProvider.getComputedSize)(size, sizeContext)), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-colored"), !!color), _defineProperty(_classNames, "".concat(prefix, "-interactive"), interactive), _defineProperty(_classNames, "".concat(prefix, "-removable"), removable), _defineProperty(_classNames, "".concat(prefix, "-round"), round), _defineProperty(_classNames, "".concat(prefix, "-").concat(theme), theme), _classNames));
if (removed) {
return null;
}
var colorStyle = {};
if (color) {
colorStyle.color = color;
}
return _react["default"].createElement("div", _extends({
className: classSet,
style: _objectSpread(_objectSpread({}, colorStyle), style)
}, otherProps), _react["default"].createElement("div", {
className: "".concat(prefix, "-content")
}, children, removable && _react["default"].createElement(_icon["default"], {
icon: "cancel-circle",
className: "".concat(prefix, "-remove"),
onClick: handleRemove,
size: 16
})), _react["default"].createElement("div", {
className: "".concat(prefix, "-background")
}), !theme && _react["default"].createElement("div", {
className: "".concat(prefix, "-shadow")
}));
};
Tag.propTypes = {
children: _propTypes["default"].node.isRequired,
className: _propTypes["default"].string,
color: _propTypes["default"].string,
intent: _propTypes["default"].oneOf(["normal", "primary", "success", "warning", "danger"]),
interactive: _propTypes["default"].bool,
onRemove: _propTypes["default"].func,
removable: _propTypes["default"].bool,
round: _propTypes["default"].bool,
size: _propTypes["default"].oneOf(["mini", "small", "medium", "large"]),
style: _propTypes["default"].object,
theme: _propTypes["default"].oneOf([null, "light"])
};
Tag.defaultProps = {
className: undefined,
color: null,
intent: "normal",
interactive: false,
onRemove: null,
removable: false,
round: false,
size: "small",
style: {},
theme: null
};
var _default = Tag;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","Tag","children","className","color","intent","interactive","onRemove","removableProp","removable","round","size","style","theme","otherProps","useState","removed","setRemoved","useContext","ConfigContext","sizeContext","handleRemove","e","classSet","classNames","getComputedSize","colorStyle","propTypes","PropTypes","node","isRequired","string","oneOf","bool","func","object","defaultProps","undefined"],"sources":["../../components/tag/Tag.tsx"],"sourcesContent":["import React, { useContext, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport Icon from \"../icon\"\nimport \"./style\"\n\nconst prefix = \"adui-tag\"\n\nexport interface ITagProps {\n  [key: string]: any\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 自定义颜色\n   */\n  color?: string | null\n  /**\n   * 设置类型\n   */\n  intent?: \"normal\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n  /**\n   * 指定 Tag 是否可交互，组件将会自动加上 hover active 样式\n   */\n  interactive?: boolean\n  /**\n   * 移除时的 handler，设置此 prop 时 Tag 将会忽略 removable prop\n   */\n  onRemove?: ((e: React.MouseEvent) => void) | null\n  /**\n   * 是否可移除\n   */\n  removable?: boolean\n  /**\n   * 是否圆角\n   */\n  round?: boolean\n  /**\n   * 设置尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 附加样式\n   */\n  style?: React.CSSProperties\n  /**\n   * 主题\n   */\n  theme?: null | \"light\"\n}\n\n/**\n * 标签展现相关的独立关键词信息，方便用户快速辨别内容属性，也可进行操作。\n */\nconst Tag: React.FC<ITagProps> = ({\n  children,\n  className,\n  color,\n  intent,\n  interactive,\n  onRemove,\n  removable: removableProp,\n  round,\n  size,\n  style,\n  theme,\n  ...otherProps\n}: ITagProps) => {\n  const [removed, setRemoved] = useState(false)\n\n  const { size: sizeContext } = useContext(ConfigContext)\n\n  const handleRemove = (e: React.MouseEvent) => {\n    setRemoved(true)\n    if (onRemove) {\n      onRemove(e)\n    }\n  }\n\n  const removable = !!onRemove || removableProp\n\n  const classSet = classNames(\n    className,\n    `${prefix}-base`,\n    color ? \"\" : `${prefix}-${intent}`,\n    `${prefix}-${getComputedSize(size, sizeContext)}`,\n    {\n      [`${prefix}-colored`]: !!color,\n      [`${prefix}-interactive`]: interactive,\n      [`${prefix}-removable`]: removable,\n      [`${prefix}-round`]: round,\n      [`${prefix}-${theme}`]: theme,\n    }\n  )\n\n  if (removed) {\n    return null\n  }\n\n  const colorStyle: React.CSSProperties = {}\n\n  if (color) {\n    colorStyle.color = color\n  }\n\n  return (\n    <div\n      className={classSet}\n      style={{\n        ...colorStyle,\n        ...style,\n      }}\n      {...otherProps}\n    >\n      <div className={`${prefix}-content`}>\n        {children}\n        {removable && (\n          <Icon\n            icon=\"cancel-circle\"\n            className={`${prefix}-remove`}\n            onClick={handleRemove}\n            size={16}\n          />\n        )}\n      </div>\n      <div className={`${prefix}-background`} />\n      {!theme && <div className={`${prefix}-shadow`} />}\n    </div>\n  )\n}\n\nTag.propTypes = {\n  /**\n   * 子节点\n   */\n  children: PropTypes.node.isRequired,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 自定义颜色\n   */\n  color: PropTypes.string,\n  /**\n   * 设置类型\n   */\n  intent: PropTypes.oneOf([\n    \"normal\",\n    \"primary\",\n    \"success\",\n    \"warning\",\n    \"danger\",\n  ]),\n  /**\n   * 指定 Tag 是否可交互，组件将会自动加上 hover active 样式\n   */\n  interactive: PropTypes.bool,\n  /**\n   * 移除时的 handler，设置此 prop 时 Tag 将会忽略 removable prop\n   */\n  onRemove: PropTypes.func,\n  /**\n   * 是否可移除\n   */\n  removable: PropTypes.bool,\n  /**\n   * 是否圆角\n   */\n  round: PropTypes.bool,\n  /**\n   * 设置尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 附加样式\n   */\n  style: PropTypes.object,\n  /**\n   * 主题\n   */\n  theme: PropTypes.oneOf([null, \"light\"]),\n}\n\nTag.defaultProps = {\n  className: undefined,\n  color: null,\n  intent: \"normal\",\n  interactive: false,\n  onRemove: null,\n  removable: false,\n  round: false,\n  size: \"small\",\n  style: {},\n  theme: null,\n}\n\nexport default Tag\n"],"mappings":"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"}