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>

129 lines (113 loc) 20 kB
var _excluded = ["active", "children", "className", "disabled", "href", "leftIcon", "rightIcon", "intent", "loading", "onClick", "size", "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 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 _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, useContext } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import Icon from "../icon"; import Spinner from "../spinner"; import Group from "./Group"; import { ConfigContext, getComputedSize } from "../config-provider"; import { ButtonGroupContext } from "./Context"; import "./style"; var prefix = "adui-channels-button"; var Button = forwardRef(function (_ref, ref) { var _classNames; var active = _ref.active, children = _ref.children, className = _ref.className, disabledProp = _ref.disabled, href = _ref.href, leftIcon = _ref.leftIcon, rightIcon = _ref.rightIcon, intentProp = _ref.intent, loading = _ref.loading, onClick = _ref.onClick, sizeProp = _ref.size, themeProp = _ref.theme, otherProps = _objectWithoutProperties(_ref, _excluded); var _useContext = useContext(ButtonGroupContext), disabledContext = _useContext.disabled, intentContext = _useContext.intent, sizeContext = _useContext.size, themeContext = _useContext.theme; var _useContext2 = useContext(ConfigContext), sizeConfigContext = _useContext2.size; var disabled = disabledProp === null ? disabledContext : disabledProp; var intent = intentProp === null ? intentContext : intentProp; var size = getComputedSize(sizeProp, sizeContext, sizeConfigContext); var theme = themeProp === null ? themeContext : themeProp; var classSet = classNames(className, "".concat(prefix, "-base"), "".concat(prefix, "-").concat(intent), "".concat(prefix, "-").concat(size), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-").concat(theme), theme), _defineProperty(_classNames, "".concat(prefix, "-active"), active), _defineProperty(_classNames, "".concat(prefix, "-hasLeftIcon"), !!leftIcon || !children), _defineProperty(_classNames, "".concat(prefix, "-hasRightIcon"), !!rightIcon || !children), _defineProperty(_classNames, "".concat(prefix, "-disabled"), disabled && !loading), _defineProperty(_classNames, "".concat(prefix, "-loading"), loading), _classNames)); var handleClick = function handleClick(e) { if (!disabled && !loading && onClick) { onClick(e); } }; var tagProps = _objectSpread({ className: classSet, disabled: !!disabled, href: href, onClick: handleClick, ref: ref, target: href && "_blank" }, otherProps); var tagChildren = React.createElement(React.Fragment, null, !!leftIcon && React.createElement(Icon, { size: 18, className: "".concat(prefix, "-leftIcon"), icon: leftIcon }), !!children && React.createElement("span", { className: "".concat(prefix, "-content") }, children), !!rightIcon && React.createElement(Icon, { size: 18, className: "".concat(prefix, "-rightIcon"), icon: rightIcon }), loading && React.createElement("div", { className: "".concat(prefix, "-spinner") }, React.createElement(Spinner, { color: theme === "light" || intent === "normal" ? null : "#fff", intent: theme === "light" ? intent : "normal" }))); if (href) { return React.createElement("a", tagProps, tagChildren); } return React.createElement("button", _extends({ type: "button" }, tagProps), tagChildren); }); Button.type = "Button"; Button.Group = Group; Button.displayName = "Button"; Button.propTypes = { active: PropTypes.bool, children: PropTypes.node, className: PropTypes.string, disabled: PropTypes.bool, href: PropTypes.string, intent: PropTypes.oneOf(["normal", "primary", "success", "warning", "danger"]), leftIcon: PropTypes.any, loading: PropTypes.bool, onClick: PropTypes.func, rightIcon: PropTypes.any, size: PropTypes.oneOf(["mini", "small", "medium", "large"]), theme: PropTypes.oneOf([null, "light"]) }; Button.defaultProps = { active: false, children: "", className: undefined, disabled: null, href: undefined, intent: "primary", leftIcon: undefined, loading: false, onClick: null, rightIcon: undefined, size: "small", theme: null }; export default Button; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useContext","PropTypes","classNames","Icon","Spinner","Group","ConfigContext","getComputedSize","ButtonGroupContext","prefix","Button","ref","active","children","className","disabledProp","disabled","href","leftIcon","rightIcon","intentProp","intent","loading","onClick","sizeProp","size","themeProp","theme","otherProps","disabledContext","intentContext","sizeContext","themeContext","sizeConfigContext","classSet","handleClick","e","tagProps","target","tagChildren","type","displayName","propTypes","bool","node","string","oneOf","any","func","defaultProps","undefined"],"sources":["../../components/channels-button/Button.tsx"],"sourcesContent":["import React, { forwardRef, useContext } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Icon, { IconNames } from \"../icon\"\nimport Spinner from \"../spinner\"\nimport Group from \"./Group\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport { ButtonGroupContext } from \"./Context\"\nimport \"./style\"\n\nconst prefix = \"adui-channels-button\"\n\nexport interface IButtonProps {\n  [key: string]: any\n  /**\n   * active 状态，用于 Button.Group 中\n   */\n  active?: boolean\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 是否禁用\n   */\n  disabled?: boolean | null\n  /**\n   * 使用 href，将 <button /> 转化为 <a /> 标签，这时候也可以传入 target=\"_blank\" 等 <a /> 标签的属性\n   */\n  href?: string\n  /**\n   * 类型\n   */\n  intent?: \"normal\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n  /**\n   * 左图标\n   */\n  leftIcon?: IconNames\n  /**\n   * 是否加载\n   */\n  loading?: boolean\n  /**\n   * 点击事件的 handler\n   */\n  onClick?:\n    | null\n    | ((e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>) => void)\n  /**\n   * 右图标\n   */\n  rightIcon?: IconNames\n  /**\n   * 尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 主题\n   */\n  theme?: null | \"light\"\n}\n\nexport interface IButton\n  extends React.ForwardRefExoticComponent<\n    IButtonProps & React.RefAttributes<any>\n  > {\n  Group: typeof Group\n  type: string\n}\n\n/**\n * 按钮用于触发一个新任务、新流程等的即时行动。\n */\n// @ts-ignore\nconst Button: IButton = forwardRef(\n  (\n    {\n      active,\n      children,\n      className,\n      disabled: disabledProp,\n      href,\n      leftIcon,\n      rightIcon,\n      intent: intentProp,\n      loading,\n      onClick,\n      size: sizeProp,\n      theme: themeProp,\n      ...otherProps\n    }: IButtonProps,\n    ref\n  ) => {\n    const {\n      disabled: disabledContext,\n      intent: intentContext,\n      size: sizeContext,\n      theme: themeContext,\n    } = useContext(ButtonGroupContext)\n    const { size: sizeConfigContext } = useContext(ConfigContext)\n\n    const disabled = disabledProp === null ? disabledContext : disabledProp\n    const intent = intentProp === null ? intentContext : intentProp\n    const size = getComputedSize(sizeProp, sizeContext, sizeConfigContext)\n    const theme = themeProp === null ? themeContext : themeProp\n\n    const classSet = classNames(\n      className,\n      `${prefix}-base`,\n      `${prefix}-${intent}`,\n      `${prefix}-${size}`,\n      {\n        [`${prefix}-${theme}`]: theme,\n        [`${prefix}-active`]: active,\n        [`${prefix}-hasLeftIcon`]: !!leftIcon || !children,\n        [`${prefix}-hasRightIcon`]: !!rightIcon || !children,\n        [`${prefix}-disabled`]: disabled && !loading,\n        [`${prefix}-loading`]: loading,\n      }\n    )\n\n    const handleClick = (\n      e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n    ) => {\n      if (!disabled && !loading && onClick) {\n        onClick(e)\n      }\n    }\n\n    const tagProps = {\n      className: classSet,\n      disabled: !!disabled,\n      href,\n      onClick: handleClick,\n      ref,\n      target: href && \"_blank\",\n      ...otherProps,\n    }\n\n    const tagChildren = (\n      <>\n        {!!leftIcon && (\n          <Icon size={18} className={`${prefix}-leftIcon`} icon={leftIcon} />\n        )}\n        {!!children && <span className={`${prefix}-content`}>{children}</span>}\n        {!!rightIcon && (\n          <Icon size={18} className={`${prefix}-rightIcon`} icon={rightIcon} />\n        )}\n        {loading && (\n          <div className={`${prefix}-spinner`}>\n            <Spinner\n              color={theme === \"light\" || intent === \"normal\" ? null : \"#fff\"}\n              intent={theme === \"light\" ? intent : \"normal\"}\n            />\n          </div>\n        )}\n      </>\n    )\n\n    if (href) {\n      return <a {...tagProps}>{tagChildren}</a>\n    }\n    return (\n      <button type=\"button\" {...tagProps}>\n        {tagChildren}\n      </button>\n    )\n  }\n)\n\nButton.type = \"Button\"\n\nButton.Group = Group\n\nButton.displayName = \"Button\"\n\nButton.propTypes = {\n  /**\n   * active 状态，用于 Button.Group 中\n   */\n  active: PropTypes.bool,\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 是否禁用\n   */\n  disabled: PropTypes.bool,\n  /**\n   * 使用 href，将 <button /> 转化为 <a /> 标签，这时候也可以传入 target=\"_blank\" 等 <a /> 标签的属性\n   */\n  href: PropTypes.string,\n  /**\n   * 类型\n   */\n  intent: PropTypes.oneOf([\n    \"normal\",\n    \"primary\",\n    \"success\",\n    \"warning\",\n    \"danger\",\n  ]),\n  /**\n   * 左图标\n   */\n  leftIcon: PropTypes.any,\n  /**\n   * 是否加载\n   */\n  loading: PropTypes.bool,\n  /**\n   * 点击事件的 handler\n   */\n  onClick: PropTypes.func,\n  /**\n   * 右图标\n   */\n  rightIcon: PropTypes.any,\n  /**\n   * 尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 主题\n   */\n  theme: PropTypes.oneOf([null, \"light\"]),\n}\n\nButton.defaultProps = {\n  active: false,\n  children: \"\",\n  className: undefined,\n  disabled: null,\n  href: undefined,\n  intent: \"primary\",\n  leftIcon: undefined,\n  loading: false,\n  onClick: null,\n  rightIcon: undefined,\n  size: \"small\",\n  theme: null,\n}\n\nexport default Button\n"],"mappings":"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"}