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>

117 lines 18.3 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 = ["checked", "checkedText", "className", "defaultChecked", "disabled", "onChange", "onClick", "onMouseDown", "size", "unCheckedText"]; 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 _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _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(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } 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, { useContext, useRef, useState } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import { ConfigContext, getComputedSize } from "../config-provider"; import { useActive } from "../_util/hooks/use-active"; import "./style"; var prefix = "adui-switch"; var Switch = function Switch(_ref) { var checkedProps = _ref.checked, checkedText = _ref.checkedText, className = _ref.className, defaultChecked = _ref.defaultChecked, disabled = _ref.disabled, onChange = _ref.onChange, onClick = _ref.onClick, onMouseDown = _ref.onMouseDown, size = _ref.size, unCheckedText = _ref.unCheckedText, otherProps = _objectWithoutProperties(_ref, _excluded); var _useState = useState(checkedProps !== null ? !!checkedProps : !!defaultChecked), _useState2 = _slicedToArray(_useState, 2), checked = _useState2[0], setChecked = _useState2[1]; if (checkedProps !== null && checked !== !!checkedProps) { setChecked(!!checkedProps); } var _useContext = useContext(ConfigContext), sizeContext = _useContext.size; var ref = useRef(null); var _useActive = useActive({ ref: ref, delay: 100 }), handleMouseDown = _useActive.handleMouseDown; var handleChange = function handleChange() { if (onClick) { onClick(); } if (!disabled) { if (checkedProps === null) { setChecked(!checked); } if (onChange) { onChange(!checked); } } }; var handleKeyPress = function handleKeyPress(_ref2) { var key = _ref2.key; if (key.toUpperCase() === "ENTER") { handleChange(); } }; var handleSpanMouseDown = function handleSpanMouseDown(e) { if (onMouseDown) { onMouseDown(e); } handleMouseDown(); }; var classSet = classNames(className, "".concat(prefix, "-wrapper"), "".concat(prefix, "-").concat(getComputedSize(size, sizeContext)), _defineProperty(_defineProperty({}, "".concat(prefix, "-checked"), checked), "".concat(prefix, "-disabled"), disabled)); return React.createElement("span", _extends({ "aria-checked": checked, className: classSet, onClick: handleChange, onKeyPress: handleKeyPress, onMouseDown: handleSpanMouseDown, role: "switch", ref: ref, tabIndex: 0 }, otherProps), React.createElement("span", { className: "".concat(prefix, "-base") }, React.createElement("i", { className: "".concat(prefix, "-indicator") })), !!checked && checkedText && React.createElement("span", { className: "".concat(prefix, "-text") }, checkedText), !checked && unCheckedText && React.createElement("span", { className: "".concat(prefix, "-text") }, unCheckedText)); }; Switch.propTypes = { checked: PropTypes.oneOf([null, true, false]), checkedText: PropTypes.node, className: PropTypes.string, defaultChecked: PropTypes.oneOf([null, true, false]), disabled: PropTypes.bool, onChange: PropTypes.func, onClick: PropTypes.func, size: PropTypes.oneOf(["mini", "small", "medium", "large"]), unCheckedText: PropTypes.node }; Switch.defaultProps = { checked: null, checkedText: null, className: undefined, defaultChecked: null, disabled: false, onChange: null, onClick: null, size: "small", unCheckedText: null }; export default Switch; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useContext","useRef","useState","PropTypes","classNames","ConfigContext","getComputedSize","useActive","prefix","Switch","_ref","checkedProps","checked","checkedText","className","defaultChecked","disabled","onChange","onClick","onMouseDown","size","unCheckedText","otherProps","_objectWithoutProperties","_excluded","_useState","_useState2","_slicedToArray","setChecked","_useContext","sizeContext","ref","_useActive","delay","handleMouseDown","handleChange","handleKeyPress","_ref2","key","toUpperCase","handleSpanMouseDown","e","classSet","concat","_defineProperty","createElement","_extends","onKeyPress","role","tabIndex","propTypes","oneOf","node","string","bool","func","defaultProps","undefined"],"sources":["../../components/switch/Switch.tsx"],"sourcesContent":["import React, { useContext, useRef, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport { useActive } from \"../_util/hooks/use-active\"\nimport \"./style\"\n\nconst prefix = \"adui-switch\"\n\nexport interface ISwitchProps {\n  [key: string]: any\n  /**\n   * 开关状态 - 外部控制\n   */\n  checked?: null | boolean\n  /**\n   * 开状态时的附加文字\n   */\n  checkedText?: React.ReactNode\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 默认开关状态 - 内部驱动\n   */\n  defaultChecked?: null | boolean\n  /**\n   * 是否禁用\n   */\n  disabled?: boolean\n  /**\n   * 开关状态改变时的 handler\n   */\n  onChange?: ((checked: boolean) => void) | null\n  /**\n   * 点击事件的 handler\n   */\n  onClick?: (() => void) | null\n  /**\n   * 设置尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 关状态时的附加文字\n   */\n  unCheckedText?: React.ReactNode\n}\n\n/**\n * 开关用于表示内容的开启与关闭，常用于开启或关闭某一功能、模式，也可以表示业务中的一些特殊逻辑，如广告的“投放/暂停”。\n */\nconst Switch: React.FC<ISwitchProps> = ({\n  checked: checkedProps,\n  checkedText,\n  className,\n  defaultChecked,\n  disabled,\n  onChange,\n  onClick,\n  onMouseDown,\n  size,\n  unCheckedText,\n  ...otherProps\n}: ISwitchProps) => {\n  const [checked, setChecked] = useState(\n    checkedProps !== null ? !!checkedProps : !!defaultChecked\n  )\n\n  // 相当于生命周期 getDerivedStateFromProps\n  if (checkedProps !== null && checked !== !!checkedProps) {\n    setChecked(!!checkedProps)\n  }\n\n  const { size: sizeContext } = useContext(ConfigContext)\n  const ref = useRef<HTMLSpanElement>(null)\n  const { handleMouseDown } = useActive({ ref, delay: 100 })\n\n  const handleChange = () => {\n    if (onClick) {\n      onClick()\n    }\n    if (!disabled) {\n      if (checkedProps === null) {\n        setChecked(!checked)\n      }\n      if (onChange) {\n        onChange(!checked)\n      }\n    }\n  }\n\n  const handleKeyPress = ({ key }: React.KeyboardEvent) => {\n    if (key.toUpperCase() === \"ENTER\") {\n      handleChange()\n    }\n  }\n\n  const handleSpanMouseDown = (e: React.MouseEvent) => {\n    if (onMouseDown) {\n      onMouseDown(e)\n    }\n    handleMouseDown()\n  }\n\n  const classSet = classNames(\n    className,\n    `${prefix}-wrapper`,\n    `${prefix}-${getComputedSize(size, sizeContext)}`,\n    {\n      [`${prefix}-checked`]: checked,\n      [`${prefix}-disabled`]: disabled,\n    }\n  )\n\n  return (\n    <span\n      aria-checked={checked}\n      className={classSet}\n      onClick={handleChange}\n      onKeyPress={handleKeyPress}\n      onMouseDown={handleSpanMouseDown}\n      role=\"switch\"\n      ref={ref}\n      tabIndex={0}\n      {...otherProps}\n    >\n      <span className={`${prefix}-base`}>\n        <i className={`${prefix}-indicator`} />\n      </span>\n      {!!checked && checkedText && (\n        <span className={`${prefix}-text`}>{checkedText}</span>\n      )}\n      {!checked && unCheckedText && (\n        <span className={`${prefix}-text`}>{unCheckedText}</span>\n      )}\n    </span>\n  )\n}\n\nSwitch.propTypes = {\n  /**\n   * 开关状态 - 外部控制\n   */\n  checked: PropTypes.oneOf([null, true, false]),\n  /**\n   * 开状态时的附加文字\n   */\n  checkedText: PropTypes.node,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 默认开关状态 - 内部驱动\n   */\n  defaultChecked: PropTypes.oneOf([null, true, false]),\n  /**\n   * 是否禁用\n   */\n  disabled: 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   * 关状态时的附加文字\n   */\n  unCheckedText: PropTypes.node,\n}\n\nSwitch.defaultProps = {\n  checked: null,\n  checkedText: null,\n  className: undefined,\n  defaultChecked: null,\n  disabled: false,\n  onChange: null,\n  onClick: null,\n  size: \"small\",\n  unCheckedText: null,\n}\n\nexport default Switch\n"],"mappings":";;;;;;;;;;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAC3D,OAAOC,SAAS,MAAM,YAAY;AAClC,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,aAAa,EAAEC,eAAe,QAAQ,oBAAoB;AACnE,SAASC,SAAS,QAAQ,2BAA2B;AACrD,OAAO,SAAS;AAEhB,IAAMC,MAAM,GAAG,aAAa;AA6C5B,IAAMC,MAA8B,GAAG,SAAjCA,MAA8BA,CAAAC,IAAA,EAYhB;EAAA,IAXTC,YAAY,GAAAD,IAAA,CAArBE,OAAO;IACPC,WAAW,GAAAH,IAAA,CAAXG,WAAW;IACXC,SAAS,GAAAJ,IAAA,CAATI,SAAS;IACTC,cAAc,GAAAL,IAAA,CAAdK,cAAc;IACdC,QAAQ,GAAAN,IAAA,CAARM,QAAQ;IACRC,QAAQ,GAAAP,IAAA,CAARO,QAAQ;IACRC,OAAO,GAAAR,IAAA,CAAPQ,OAAO;IACPC,WAAW,GAAAT,IAAA,CAAXS,WAAW;IACXC,IAAI,GAAAV,IAAA,CAAJU,IAAI;IACJC,aAAa,GAAAX,IAAA,CAAbW,aAAa;IACVC,UAAU,GAAAC,wBAAA,CAAAb,IAAA,EAAAc,SAAA;EAEb,IAAAC,SAAA,GAA8BvB,QAAQ,CACpCS,YAAY,KAAK,IAAI,GAAG,CAAC,CAACA,YAAY,GAAG,CAAC,CAACI,cAC7C,CAAC;IAAAW,UAAA,GAAAC,cAAA,CAAAF,SAAA;IAFMb,OAAO,GAAAc,UAAA;IAAEE,UAAU,GAAAF,UAAA;EAK1B,IAAIf,YAAY,KAAK,IAAI,IAAIC,OAAO,KAAK,CAAC,CAACD,YAAY,EAAE;IACvDiB,UAAU,CAAC,CAAC,CAACjB,YAAY,CAAC;EAC5B;EAEA,IAAAkB,WAAA,GAA8B7B,UAAU,CAACK,aAAa,CAAC;IAAzCyB,WAAW,GAAAD,WAAA,CAAjBT,IAAI;EACZ,IAAMW,GAAG,GAAG9B,MAAM,CAAkB,IAAI,CAAC;EACzC,IAAA+B,UAAA,GAA4BzB,SAAS,CAAC;MAAEwB,GAAG,EAAHA,GAAG;MAAEE,KAAK,EAAE;IAAI,CAAC,CAAC;IAAlDC,eAAe,GAAAF,UAAA,CAAfE,eAAe;EAEvB,IAAMC,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAS;IACzB,IAAIjB,OAAO,EAAE;MACXA,OAAO,CAAC,CAAC;IACX;IACA,IAAI,CAACF,QAAQ,EAAE;MACb,IAAIL,YAAY,KAAK,IAAI,EAAE;QACzBiB,UAAU,CAAC,CAAChB,OAAO,CAAC;MACtB;MACA,IAAIK,QAAQ,EAAE;QACZA,QAAQ,CAAC,CAACL,OAAO,CAAC;MACpB;IACF;EACF,CAAC;EAED,IAAMwB,cAAc,GAAG,SAAjBA,cAAcA,CAAAC,KAAA,EAAqC;IAAA,IAA/BC,GAAG,GAAAD,KAAA,CAAHC,GAAG;IAC3B,IAAIA,GAAG,CAACC,WAAW,CAAC,CAAC,KAAK,OAAO,EAAE;MACjCJ,YAAY,CAAC,CAAC;IAChB;EACF,CAAC;EAED,IAAMK,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAAIC,CAAmB,EAAK;IACnD,IAAItB,WAAW,EAAE;MACfA,WAAW,CAACsB,CAAC,CAAC;IAChB;IACAP,eAAe,CAAC,CAAC;EACnB,CAAC;EAED,IAAMQ,QAAQ,GAAGtC,UAAU,CACzBU,SAAS,KAAA6B,MAAA,CACNnC,MAAM,kBAAAmC,MAAA,CACNnC,MAAM,OAAAmC,MAAA,CAAIrC,eAAe,CAACc,IAAI,EAAEU,WAAW,CAAC,GAAAc,eAAA,CAAAA,eAAA,QAAAD,MAAA,CAEzCnC,MAAM,eAAaI,OAAO,MAAA+B,MAAA,CAC1BnC,MAAM,gBAAcQ,QAAQ,CAEpC,CAAC;EAED,OACEjB,KAAA,CAAA8C,aAAA,SAAAC,QAAA;IACE,gBAAclC,OAAQ;IACtBE,SAAS,EAAE4B,QAAS;IACpBxB,OAAO,EAAEiB,YAAa;IACtBY,UAAU,EAAEX,cAAe;IAC3BjB,WAAW,EAAEqB,mBAAoB;IACjCQ,IAAI,EAAC,QAAQ;IACbjB,GAAG,EAAEA,GAAI;IACTkB,QAAQ,EAAE;EAAE,GACR3B,UAAU,GAEdvB,KAAA,CAAA8C,aAAA;IAAM/B,SAAS,KAAA6B,MAAA,CAAKnC,MAAM;EAAQ,GAChCT,KAAA,CAAA8C,aAAA;IAAG/B,SAAS,KAAA6B,MAAA,CAAKnC,MAAM;EAAa,CAAE,CAClC,CAAC,EACN,CAAC,CAACI,OAAO,IAAIC,WAAW,IACvBd,KAAA,CAAA8C,aAAA;IAAM/B,SAAS,KAAA6B,MAAA,CAAKnC,MAAM;EAAQ,GAAEK,WAAkB,CACvD,EACA,CAACD,OAAO,IAAIS,aAAa,IACxBtB,KAAA,CAAA8C,aAAA;IAAM/B,SAAS,KAAA6B,MAAA,CAAKnC,MAAM;EAAQ,GAAEa,aAAoB,CAEtD,CAAC;AAEX,CAAC;AAEDZ,MAAM,CAACyC,SAAS,GAAG;EAIjBtC,OAAO,EAAET,SAAS,CAACgD,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;EAI7CtC,WAAW,EAAEV,SAAS,CAACiD,IAAI;EAI3BtC,SAAS,EAAEX,SAAS,CAACkD,MAAM;EAI3BtC,cAAc,EAAEZ,SAAS,CAACgD,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;EAIpDnC,QAAQ,EAAEb,SAAS,CAACmD,IAAI;EAIxBrC,QAAQ,EAAEd,SAAS,CAACoD,IAAI;EAIxBrC,OAAO,EAAEf,SAAS,CAACoD,IAAI;EAIvBnC,IAAI,EAAEjB,SAAS,CAACgD,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;EAI3D9B,aAAa,EAAElB,SAAS,CAACiD;AAC3B,CAAC;AAED3C,MAAM,CAAC+C,YAAY,GAAG;EACpB5C,OAAO,EAAE,IAAI;EACbC,WAAW,EAAE,IAAI;EACjBC,SAAS,EAAE2C,SAAS;EACpB1C,cAAc,EAAE,IAAI;EACpBC,QAAQ,EAAE,KAAK;EACfC,QAAQ,EAAE,IAAI;EACdC,OAAO,EAAE,IAAI;EACbE,IAAI,EAAE,OAAO;EACbC,aAAa,EAAE;AACjB,CAAC;AAED,eAAeZ,MAAM","ignoreList":[]}