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>
164 lines (125 loc) • 19.1 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 _useActive2 = require("../_util/hooks/use-active");
require("./style");
var _excluded = ["checked", "checkedText", "className", "defaultChecked", "disabled", "onChange", "onClick", "onMouseDown", "size", "unCheckedText"];
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 _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-switch";
var Switch = function Switch(_ref) {
var _classNames;
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 = (0, _react.useState)(checkedProps !== null ? !!checkedProps : !!defaultChecked),
_useState2 = _slicedToArray(_useState, 2),
checked = _useState2[0],
setChecked = _useState2[1];
if (checkedProps !== null && checked !== !!checkedProps) {
setChecked(!!checkedProps);
}
var _useContext = (0, _react.useContext)(_configProvider.ConfigContext),
sizeContext = _useContext.size;
var ref = (0, _react.useRef)(null);
var _useActive = (0, _useActive2.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 = (0, _classnames["default"])(className, "".concat(prefix, "-wrapper"), "".concat(prefix, "-").concat((0, _configProvider.getComputedSize)(size, sizeContext)), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-checked"), checked), _defineProperty(_classNames, "".concat(prefix, "-disabled"), disabled), _classNames));
return _react["default"].createElement("span", _extends({
"aria-checked": checked,
className: classSet,
onClick: handleChange,
onKeyPress: handleKeyPress,
onMouseDown: handleSpanMouseDown,
role: "switch",
ref: ref,
tabIndex: 0
}, otherProps), _react["default"].createElement("span", {
className: "".concat(prefix, "-base")
}, _react["default"].createElement("i", {
className: "".concat(prefix, "-indicator")
})), !!checked && checkedText && _react["default"].createElement("span", {
className: "".concat(prefix, "-text")
}, checkedText), !checked && unCheckedText && _react["default"].createElement("span", {
className: "".concat(prefix, "-text")
}, unCheckedText));
};
Switch.propTypes = {
checked: _propTypes["default"].oneOf([null, true, false]),
checkedText: _propTypes["default"].node,
className: _propTypes["default"].string,
defaultChecked: _propTypes["default"].oneOf([null, true, false]),
disabled: _propTypes["default"].bool,
onChange: _propTypes["default"].func,
onClick: _propTypes["default"].func,
size: _propTypes["default"].oneOf(["mini", "small", "medium", "large"]),
unCheckedText: _propTypes["default"].node
};
Switch.defaultProps = {
checked: null,
checkedText: null,
className: undefined,
defaultChecked: null,
disabled: false,
onChange: null,
onClick: null,
size: "small",
unCheckedText: null
};
var _default = Switch;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","Switch","checkedProps","checked","checkedText","className","defaultChecked","disabled","onChange","onClick","onMouseDown","size","unCheckedText","otherProps","useState","setChecked","useContext","ConfigContext","sizeContext","ref","useRef","useActive","delay","handleMouseDown","handleChange","handleKeyPress","key","toUpperCase","handleSpanMouseDown","e","classSet","classNames","getComputedSize","propTypes","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":"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"}