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>

160 lines (137 loc) 23.2 kB
var _excluded = ["checked", "children", "className", "disabled", "helper", "helperIcon", "helperProps", "indeterminate", "onChange", "onClick", "size", "value"]; 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, { forwardRef, useContext, useState } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import { GroupContext } from "./Context"; import Group from "./Group"; import Icon from "../icon"; import Popover from "../popover"; import { ConfigContext, getComputedSize } from "../config-provider"; import "./style"; var prefix = "adui-channels-checkbox"; var Checkbox = forwardRef(function (_ref, ref) { var _classNames; var checkedProp = _ref.checked, children = _ref.children, className = _ref.className, disabled = _ref.disabled, helper = _ref.helper, helperIcon = _ref.helperIcon, helperProps = _ref.helperProps, indeterminate = _ref.indeterminate, onChange = _ref.onChange, onClick = _ref.onClick, sizeProp = _ref.size, value = _ref.value, otherProps = _objectWithoutProperties(_ref, _excluded); var _useState = useState(!!checkedProp), _useState2 = _slicedToArray(_useState, 2), checked = _useState2[0], setChecked = _useState2[1]; var _useContext = useContext(GroupContext), disabledContext = _useContext.disabled, handleGroupValueChange = _useContext.handleGroupValueChange, sizeContext = _useContext.size, valueContext = _useContext.value; var _useContext2 = useContext(ConfigContext), sizeConfig = _useContext2.size; if (checkedProp !== null && checked !== checkedProp) { setChecked(!!checkedProp); } var size = getComputedSize(sizeProp, sizeContext, sizeConfig); var valueComputed = value !== null ? value : children === null || children === void 0 ? void 0 : children.toString(); var classSet = classNames(className, "".concat(prefix, "-base"), "".concat(prefix, "-").concat(size), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-checked"), indeterminate || (valueContext ? valueComputed && valueContext.includes(valueComputed) : checked)), _defineProperty(_classNames, "".concat(prefix, "-noChildren"), !children), _defineProperty(_classNames, "".concat(prefix, "-disabled"), disabledContext || disabled), _classNames)); var popover = helper ? React.createElement(Popover, _extends({ alignEdge: false, popup: helper }, helperProps), React.createElement(Icon, { icon: helperIcon || "help-circle", color: "var(--gray-600)", interactive: true, className: "".concat(prefix, "-helper") })) : null; var handleClick = function handleClick(e) { if (onClick) { onClick(e); } if (disabled || disabledContext) { return; } if (handleGroupValueChange && valueComputed) { handleGroupValueChange(valueComputed); } else { if (checkedProp === null) { setChecked(!checked); } if (onChange) { onChange(!checked); } } }; var handleKeyDown = function handleKeyDown(e) { if (e.key === "Enter") { handleClick(e); } }; return React.createElement("label", _extends({ "aria-checked": checked, className: classSet, onClick: handleClick, onKeyDown: handleKeyDown, ref: ref, role: "checkbox" }, otherProps), React.createElement("span", { className: "".concat(prefix, "-indicator") }, React.createElement("svg", { width: "11", height: "8", viewBox: "0 0 11 8" }, React.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M4.38909 6.86396C3.99856 7.25449 3.3654 7.25449 2.97487 6.86396L0.5 4.38909L1.20711 3.68198L3.68198 6.15685L9.33883 0.5L10.0459 1.20711L4.38909 6.86396Z", strokeLinejoin: "round" }))), !!children && React.createElement("span", null, children), popover); }); Checkbox.Group = Group; Checkbox.displayName = "Checkbox"; Checkbox.propTypes = { checked: PropTypes.oneOf([null, true, false]), children: PropTypes.node, className: PropTypes.string, disabled: PropTypes.bool, helper: PropTypes.node, helperIcon: PropTypes.any, helperProps: PropTypes.object, indeterminate: PropTypes.bool, onChange: PropTypes.func, onClick: PropTypes.func, size: PropTypes.oneOf(["mini", "small", "medium", "large"]), value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]) }; Checkbox.defaultProps = { checked: null, children: "", className: undefined, disabled: false, helper: null, helperIcon: "help-circle", helperProps: {}, indeterminate: false, onChange: null, onClick: null, size: "small", value: null }; export default Checkbox; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useContext","useState","PropTypes","classNames","GroupContext","Group","Icon","Popover","ConfigContext","getComputedSize","prefix","Checkbox","ref","checkedProp","checked","children","className","disabled","helper","helperIcon","helperProps","indeterminate","onChange","onClick","sizeProp","size","value","otherProps","setChecked","disabledContext","handleGroupValueChange","sizeContext","valueContext","sizeConfig","valueComputed","toString","classSet","includes","popover","handleClick","e","handleKeyDown","key","displayName","propTypes","oneOf","node","string","bool","any","object","func","oneOfType","number","defaultProps","undefined"],"sources":["../../components/channels-checkbox/Checkbox.tsx"],"sourcesContent":["/* eslint-disable max-len */\n/* eslint-disable jsx-a11y/no-noninteractive-element-to-interactive-role */\nimport React, { forwardRef, useContext, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { GroupContext } from \"./Context\"\nimport Group from \"./Group\"\nimport Icon, { IconNames } from \"../icon\"\nimport Popover, { IPopoverProps } from \"../popover\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport \"./style\"\n\nconst prefix = \"adui-channels-checkbox\"\n\nexport interface ICheckboxProps {\n  [key: string]: any\n  /**\n   * 是否选中\n   */\n  checked?: null | boolean\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 是否禁用\n   */\n  disabled?: boolean\n  /**\n   * 加入问号气泡提示内容\n   */\n  helper?: React.ReactNode\n  /**\n   * 自定义问号气泡的 Icon\n   */\n  helperIcon?: IconNames\n  /**\n   * 问号气泡提示的 props，会将此对象都传递给 <Popover />\n   */\n  helperProps?: IPopoverProps\n  /**\n   * 设置 indeterminate 状态，负责且仅仅负责样式控制，请在实现全选效果时使用\n   */\n  indeterminate?: boolean\n  /**\n   * 选中态发生变化时的 handler\n   */\n  onChange?: ((checked: boolean) => void) | null\n  /**\n   * 点击时的 handler\n   */\n  onClick?:\n    | ((\n        e:\n          | React.MouseEvent<HTMLLabelElement>\n          | React.KeyboardEvent<HTMLLabelElement>\n      ) => void)\n    | null\n  /**\n   * 设置尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 值，只在使用 Checkbox.Group 时会读取使用\n   */\n  value?: null | React.ReactText\n}\n\nexport interface ICheckbox\n  extends React.ForwardRefExoticComponent<\n    ICheckboxProps & React.RefAttributes<HTMLLabelElement>\n  > {\n  Group: typeof Group\n}\n\n/**\n * 勾选提供用户在多个选项中，对选项的内容进行单或多个选择。\n */\n// @ts-ignore\nconst Checkbox: ICheckbox = forwardRef(\n  (\n    {\n      checked: checkedProp,\n      children,\n      className,\n      disabled,\n      helper,\n      helperIcon,\n      helperProps,\n      indeterminate,\n      onChange,\n      onClick,\n      size: sizeProp,\n      value,\n      ...otherProps\n    }: ICheckboxProps,\n    ref\n  ) => {\n    const [checked, setChecked] = useState(!!checkedProp)\n    const {\n      disabled: disabledContext,\n      handleGroupValueChange,\n      size: sizeContext,\n      value: valueContext,\n    } = useContext(GroupContext)\n    const { size: sizeConfig } = useContext(ConfigContext)\n\n    // 相当于生命周期 getDerivedStateFromProps\n    if (checkedProp !== null && checked !== checkedProp) {\n      setChecked(!!checkedProp)\n    }\n\n    const size = getComputedSize(sizeProp, sizeContext, sizeConfig)\n\n    const valueComputed = value !== null ? value : children?.toString()\n\n    /**\n     * 当有 context context 时，使用 value：\n     * 如果存在 value prop，则直接使用 value；\n     * 如果不存在，就 string 化 children 作为 value。\n     */\n    const classSet = classNames(\n      className,\n      `${prefix}-base`,\n      `${prefix}-${size}`,\n      {\n        [`${prefix}-checked`]:\n          indeterminate ||\n          (valueContext\n            ? valueComputed && valueContext.includes(valueComputed)\n            : checked),\n        [`${prefix}-noChildren`]: !children,\n        [`${prefix}-disabled`]: disabledContext || disabled,\n      }\n    )\n\n    const popover = helper ? (\n      <Popover alignEdge={false} popup={helper} {...helperProps}>\n        <Icon\n          icon={helperIcon || \"help-circle\"}\n          color=\"var(--gray-600)\"\n          interactive\n          className={`${prefix}-helper`}\n        />\n      </Popover>\n    ) : null\n\n    const handleClick = (\n      e:\n        | React.MouseEvent<HTMLLabelElement>\n        | React.KeyboardEvent<HTMLLabelElement>\n    ) => {\n      if (onClick) {\n        onClick(e)\n      }\n      if (disabled || disabledContext) {\n        return\n      }\n      if (handleGroupValueChange && valueComputed) {\n        handleGroupValueChange(valueComputed)\n      } else {\n        if (checkedProp === null) {\n          setChecked(!checked)\n        }\n        if (onChange) {\n          onChange(!checked)\n        }\n      }\n    }\n\n    const handleKeyDown = (e: React.KeyboardEvent<HTMLLabelElement>) => {\n      if (e.key === \"Enter\") {\n        handleClick(e)\n      }\n    }\n\n    return (\n      <label\n        aria-checked={checked}\n        className={classSet}\n        onClick={handleClick}\n        onKeyDown={handleKeyDown}\n        ref={ref}\n        role=\"checkbox\"\n        {...otherProps}\n      >\n        <span className={`${prefix}-indicator`}>\n          <svg width=\"11\" height=\"8\" viewBox=\"0 0 11 8\">\n            <path\n              fillRule=\"evenodd\"\n              clipRule=\"evenodd\"\n              d=\"M4.38909 6.86396C3.99856 7.25449 3.3654 7.25449 2.97487 6.86396L0.5 4.38909L1.20711 3.68198L3.68198 6.15685L9.33883 0.5L10.0459 1.20711L4.38909 6.86396Z\"\n              // fill=\"white\"\n              // fillOpacity=\"0.9\"\n              // stroke=\"white\"\n              strokeLinejoin=\"round\"\n            />\n          </svg>\n        </span>\n        {!!children && <span>{children}</span>}\n        {popover}\n      </label>\n    )\n  }\n)\n\nCheckbox.Group = Group\n\nCheckbox.displayName = \"Checkbox\"\n\nCheckbox.propTypes = {\n  /**\n   * 是否选中\n   */\n  checked: PropTypes.oneOf([null, true, false]),\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 是否禁用\n   */\n  disabled: PropTypes.bool,\n  /**\n   * 加入问号气泡提示内容\n   */\n  helper: PropTypes.node,\n  /**\n   * 自定义问号气泡的 Icon\n   */\n  helperIcon: PropTypes.any,\n  /**\n   * 问号气泡提示的 props，会将此对象都传递给 <Popover />\n   */\n  helperProps: PropTypes.object,\n  /**\n   * 设置 indeterminate 状态，负责且仅仅负责样式控制，请在实现全选效果时使用\n   */\n  indeterminate: PropTypes.bool,\n  /**\n   * 选中态发生变化时的 handler\n   */\n  onChange: PropTypes.func,\n  /**\n   * 点击时的 handler\n   */\n  onClick: PropTypes.func,\n  /**\n   * 设置尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 值，只在使用 Checkbox.Group 时会读取使用\n   */\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n}\n\nCheckbox.defaultProps = {\n  checked: null,\n  children: \"\",\n  className: undefined,\n  disabled: false,\n  helper: null,\n  helperIcon: \"help-circle\",\n  helperProps: {},\n  indeterminate: false,\n  onChange: null,\n  onClick: null,\n  size: \"small\",\n  value: null,\n}\n\nexport default Checkbox\n"],"mappings":"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"}