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>

210 lines 30.8 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 = ["className", "defaultValue", "disabled", "max", "min", "onBlur", "onChange", "onFocus", "onKeyDown", "precision", "step", "value"], _excluded2 = ["leftElement", "rightElement"], _excluded3 = ["leftElement", "rightElement"]; 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, { forwardRef, useImperativeHandle, useRef, useState, memo } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import Input from "../input"; import Icon from "../icon"; import "./style"; import { isLegal, stringToNumber, getDecimalNumber } from "./core"; var prefix = "adui-numeric-input"; var NumericInput = forwardRef(function (_ref, ref) { var className = _ref.className, defaultValue = _ref.defaultValue, disabled = _ref.disabled, max = _ref.max, min = _ref.min, onBlur = _ref.onBlur, onChange = _ref.onChange, onFocus = _ref.onFocus, onKeyDown = _ref.onKeyDown, precisionProp = _ref.precision, step = _ref.step, valueProp = _ref.value, otherProps = _objectWithoutProperties(_ref, _excluded); var precision = precisionProp === undefined ? getDecimalNumber(step || 1) : precisionProp; var _useState = useState(function () { var valueState = valueProp !== null ? valueProp : defaultValue; if (typeof valueState !== "number") { valueState = ""; } return valueState; }), _useState2 = _slicedToArray(_useState, 2), value = _useState2[0], setValue = _useState2[1]; var _useState3 = useState(typeof value === "number" ? value.toFixed(precision) : ""), _useState4 = _slicedToArray(_useState3, 2), inputValue = _useState4[0], setInputValue = _useState4[1]; var inputRef = useRef(null); if (valueProp !== null && value !== valueProp) { var _inputRef$current; setValue(typeof valueProp === "number" ? valueProp : ""); if (document.activeElement !== ((_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.input)) { setInputValue(typeof valueProp === "number" ? valueProp.toFixed(precision) : ""); } } useImperativeHandle(ref, function () { return { current: inputRef.current }; }); var handleValueStepChange = function handleValueStepChange(type, stp, inputVal) { var val = stringToNumber(inputVal); var decimal = getDecimalNumber(stp); if (type === "plus") { return (val * Math.pow(10, decimal) + stp * Math.pow(10, decimal)) / Math.pow(10, decimal); } return (val * Math.pow(10, decimal) - stp * Math.pow(10, decimal)) / Math.pow(10, decimal); }; var handleButtonClick = function handleButtonClick(type) { var valueStepChanged = handleValueStepChange(type, step || 1, inputValue); if (min !== undefined && valueStepChanged < min) { valueStepChanged = min; } else if (max !== undefined && valueStepChanged > max) { valueStepChanged = max; } if (valueProp === null) { setValue(valueStepChanged); setInputValue(valueStepChanged.toFixed(precision)); } if (onChange) { onChange(valueStepChanged); } }; var handleInputChange = function handleInputChange(_ref2) { var val = _ref2.target.value; if (isLegal(step || 1, val, min, max)) { if (valueProp === null) { setValue(stringToNumber(val)); } if (onChange) { onChange(stringToNumber(val)); } } if (valueProp === null) { setInputValue(val); } }; var handleInputBlur = function handleInputBlur(e) { var val = e.target.value; if (typeof value !== "number") { setInputValue(""); } else { var valueFixed = value.toFixed(precision); if (!isLegal(step || 1, val, min, max) || val !== valueFixed) { setInputValue(valueFixed); } } if (onBlur) { onBlur(e); } }; var handleMouseDown = function handleMouseDown(type) { handleButtonClick(type); setTimeout(function () { if (inputRef.current && document.activeElement !== inputRef.current.input) { var input = inputRef.current.input; var end = input.value.length; input.setSelectionRange(end, end); input.focus(); } }, 100); }; var handleKeyDown = function handleKeyDown(e) { var key = e.key; if (key === "ArrowUp") { e.preventDefault(); e.stopPropagation(); handleButtonClick("plus"); } if (key === "ArrowDown") { e.preventDefault(); e.stopPropagation(); handleButtonClick("minus"); } }; return React.createElement(Input, _extends({ className: classNames(className, "".concat(prefix), _defineProperty({}, "".concat(prefix, "-disabled"), disabled)), cleaveOptions: { numeral: true, numeralDecimalScale: precision, delimiter: "" }, disabled: disabled, onChange: handleInputChange, onBlur: handleInputBlur, onKeyDown: handleKeyDown, value: inputValue, ref: inputRef, rightElement: React.createElement("div", { className: "".concat(prefix, "-buttons") }, React.createElement("div", { className: "".concat(prefix, "-button"), onClick: function onClick() { return handleMouseDown("plus"); }, role: "none" }, React.createElement(Icon, { icon: "arrow-up", interactive: !disabled, size: 12 })), React.createElement("div", { className: "".concat(prefix, "-button"), onClick: function onClick() { return handleMouseDown("minus"); }, role: "none" }, React.createElement(Icon, { icon: "arrow-down", interactive: !disabled, size: 12 }))) }, otherProps)); }); NumericInput.displayName = "NumericInput"; NumericInput.propTypes = { defaultValue: PropTypes.number, max: PropTypes.number, min: PropTypes.number, onChange: PropTypes.func, precision: PropTypes.number, step: PropTypes.number, value: PropTypes.number }; NumericInput.defaultProps = { defaultValue: null, max: undefined, min: undefined, onChange: function onChange() {}, precision: undefined, step: 1, value: null }; var MemoNumericInput = memo(NumericInput, function (_ref3, _ref4) { var leftElementNext = _ref4.leftElement, rightElementNext = _ref4.rightElement, nextProps = _objectWithoutProperties(_ref4, _excluded2); var leftElement = _ref3.leftElement, rightElement = _ref3.rightElement, prevProps = _objectWithoutProperties(_ref3, _excluded3); return JSON.stringify(prevProps) === JSON.stringify(nextProps); }); MemoNumericInput.displayName = "NumericInput"; export default MemoNumericInput; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useImperativeHandle","useRef","useState","memo","PropTypes","classNames","Input","Icon","isLegal","stringToNumber","getDecimalNumber","prefix","NumericInput","_ref","ref","className","defaultValue","disabled","max","min","onBlur","onChange","onFocus","onKeyDown","precisionProp","precision","step","valueProp","value","otherProps","_objectWithoutProperties","_excluded","undefined","_useState","valueState","_useState2","_slicedToArray","setValue","_useState3","toFixed","_useState4","inputValue","setInputValue","inputRef","_inputRef$current","document","activeElement","current","input","handleValueStepChange","type","stp","inputVal","val","decimal","Math","pow","handleButtonClick","valueStepChanged","handleInputChange","_ref2","target","handleInputBlur","e","valueFixed","handleMouseDown","setTimeout","end","length","setSelectionRange","focus","handleKeyDown","key","preventDefault","stopPropagation","createElement","_extends","concat","_defineProperty","cleaveOptions","numeral","numeralDecimalScale","delimiter","rightElement","onClick","role","icon","interactive","size","displayName","propTypes","number","func","defaultProps","MemoNumericInput","_ref3","_ref4","leftElementNext","leftElement","rightElementNext","nextProps","_excluded2","prevProps","_excluded3","JSON","stringify"],"sources":["../../components/numeric-input/NumericInput.tsx"],"sourcesContent":["import React, {\n  forwardRef,\n  useImperativeHandle,\n  useRef,\n  useState,\n  memo,\n} from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Input, { IInputProps, IInputRef } from \"../input\"\nimport Icon from \"../icon\"\nimport \"./style\"\nimport { isLegal, stringToNumber, getDecimalNumber } from \"./core\"\n\nconst prefix = \"adui-numeric-input\"\n\nexport interface INumericInputProps\n  extends Omit<IInputProps, \"defaultValue\" | \"onChange\" | \"value\"> {\n  [key: string]: any\n  /**\n   * 默认的初始值 - 内部驱动\n   */\n  defaultValue?: number | null\n  /**\n   * 设置最大值\n   */\n  max?: number\n  /**\n   * 设置最小值\n   */\n  min?: number\n  /**\n   * 值改变时的 handler\n   */\n  onChange?: (value?: number) => void\n  /**\n   * 设置精度\n   */\n  precision?: number\n  /**\n   * 设置增加的幅度\n   */\n  step?: number\n  /**\n   * 值 - 外部控制\n   */\n  value?: number | null\n}\n\n/**\n * 数字输入框。\n */\nconst NumericInput: React.ForwardRefExoticComponent<\n  INumericInputProps & React.RefAttributes<any>\n> = forwardRef(\n  (\n    {\n      className,\n      defaultValue,\n      disabled,\n      max,\n      min,\n      onBlur,\n      onChange,\n      onFocus,\n      onKeyDown,\n      precision: precisionProp,\n      step,\n      value: valueProp,\n      ...otherProps\n    }: INumericInputProps,\n    ref\n  ) => {\n    const precision =\n      precisionProp === undefined ? getDecimalNumber(step || 1) : precisionProp\n\n    const [value, setValue] = useState<number | string>(() => {\n      let valueState: React.ReactText | null | undefined =\n        valueProp !== null ? valueProp : defaultValue\n      if (typeof valueState !== \"number\") {\n        valueState = \"\"\n      }\n      return valueState\n    })\n    const [inputValue, setInputValue] = useState<string>(\n      typeof value === \"number\" ? value.toFixed(precision) : \"\"\n    )\n    const inputRef = useRef<IInputRef>(null)\n\n    // 相当于生命周期 getDerivedStateFromProps\n    if (valueProp !== null && value !== valueProp) {\n      setValue(typeof valueProp === \"number\" ? valueProp : \"\")\n      if (document.activeElement !== inputRef.current?.input) {\n        setInputValue(\n          typeof valueProp === \"number\" ? valueProp.toFixed(precision) : \"\"\n        )\n      }\n    }\n\n    useImperativeHandle(ref, () => ({\n      current: inputRef.current,\n    }))\n\n    const handleValueStepChange = (\n      type: \"plus\" | \"minus\",\n      stp: number,\n      inputVal?: string\n    ) => {\n      // 将 inputVal 转成数字，如果是空字符串，则认为从 0 开始加减\n      const val = stringToNumber(inputVal)\n      const decimal = getDecimalNumber(stp)\n      if (type === \"plus\") {\n        return (val * 10 ** decimal + stp * 10 ** decimal) / 10 ** decimal\n      }\n      return (val * 10 ** decimal - stp * 10 ** decimal) / 10 ** decimal\n    }\n\n    const handleButtonClick = (type: \"plus\" | \"minus\") => {\n      let valueStepChanged = handleValueStepChange(type, step || 1, inputValue)\n      if (min !== undefined && valueStepChanged < min) {\n        valueStepChanged = min\n      } else if (max !== undefined && valueStepChanged > max) {\n        valueStepChanged = max\n      }\n      if (valueProp === null) {\n        setValue(valueStepChanged)\n        setInputValue(valueStepChanged.toFixed(precision))\n      }\n      if (onChange) {\n        onChange(valueStepChanged)\n      }\n    }\n\n    const handleInputChange = ({\n      target: { value: val },\n    }: React.ChangeEvent<HTMLInputElement>) => {\n      if (isLegal(step || 1, val, min, max)) {\n        if (valueProp === null) {\n          setValue(stringToNumber(val))\n        }\n        if (onChange) {\n          onChange(stringToNumber(val))\n        }\n      }\n      if (valueProp === null) {\n        setInputValue(val)\n      }\n    }\n\n    const handleInputBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n      const {\n        target: { value: val },\n      } = e\n      if (typeof value !== \"number\") {\n        setInputValue(\"\")\n      } else {\n        const valueFixed = value.toFixed(precision)\n        if (!isLegal(step || 1, val, min, max) || val !== valueFixed) {\n          setInputValue(valueFixed)\n        }\n      }\n      if (onBlur) {\n        onBlur(e)\n      }\n    }\n\n    const handleMouseDown = (type: \"plus\" | \"minus\") => {\n      handleButtonClick(type)\n      setTimeout(() => {\n        if (\n          inputRef.current &&\n          document.activeElement !== inputRef.current.input\n        ) {\n          const { input } = inputRef.current\n          const end = input.value.length\n          input.setSelectionRange(end, end)\n          input.focus()\n        }\n      }, 100)\n    }\n\n    const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n      const { key } = e\n      if (key === \"ArrowUp\") {\n        e.preventDefault()\n        e.stopPropagation()\n        handleButtonClick(\"plus\")\n      }\n      if (key === \"ArrowDown\") {\n        e.preventDefault()\n        e.stopPropagation()\n        handleButtonClick(\"minus\")\n      }\n    }\n\n    return (\n      <Input\n        className={classNames(className, `${prefix}`, {\n          [`${prefix}-disabled`]: disabled,\n        })}\n        cleaveOptions={{\n          numeral: true,\n          numeralDecimalScale: precision,\n          delimiter: \"\",\n        }}\n        disabled={disabled}\n        onChange={handleInputChange}\n        onBlur={handleInputBlur}\n        onKeyDown={handleKeyDown}\n        value={inputValue}\n        ref={inputRef}\n        rightElement={\n          <div className={`${prefix}-buttons`}>\n            <div\n              className={`${prefix}-button`}\n              onClick={() => handleMouseDown(\"plus\")}\n              role=\"none\"\n            >\n              <Icon icon=\"arrow-up\" interactive={!disabled} size={12} />\n            </div>\n            <div\n              className={`${prefix}-button`}\n              onClick={() => handleMouseDown(\"minus\")}\n              role=\"none\"\n            >\n              <Icon icon=\"arrow-down\" interactive={!disabled} size={12} />\n            </div>\n          </div>\n        }\n        {...otherProps}\n      />\n    )\n  }\n)\n\nNumericInput.displayName = \"NumericInput\"\n\nNumericInput.propTypes = {\n  /**\n   * 默认的初始值 - 内部驱动\n   */\n  defaultValue: PropTypes.number,\n  /**\n   * 设置最大值\n   */\n  max: PropTypes.number,\n  /**\n   * 设置最小值\n   */\n  min: PropTypes.number,\n  /**\n   * 值改变时的 handler\n   */\n  onChange: PropTypes.func,\n  /**\n   * 设置精度\n   */\n  precision: PropTypes.number,\n  /**\n   * 增减的幅度\n   */\n  step: PropTypes.number,\n  /**\n   * 值 - 外部控制\n   */\n  value: PropTypes.number,\n}\n\nNumericInput.defaultProps = {\n  defaultValue: null,\n  max: undefined,\n  min: undefined,\n  onChange: () => {},\n  precision: undefined,\n  step: 1,\n  value: null,\n}\n\nconst MemoNumericInput = memo(\n  NumericInput,\n  (\n    { leftElement, rightElement, ...prevProps },\n    {\n      leftElement: leftElementNext,\n      rightElement: rightElementNext,\n      ...nextProps\n    }\n  ) => JSON.stringify(prevProps) === JSON.stringify(nextProps)\n)\n\nMemoNumericInput.displayName = \"NumericInput\"\n\nexport default MemoNumericInput\n"],"mappings":"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","ignoreList":[]}