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>

377 lines (325 loc) 55.7 kB
var _excluded = ["autoComplete", "autoFocus", "className", "cleaveOptions", "contentJustify", "countHanzi", "defaultValue", "disabled", "id", "intent", "leftElement", "limit", "name", "onBlur", "onChange", "onFocus", "onKeyDown", "onPressEnter", "placeholder", "required", "rightElement", "size", "style", "theme", "type", "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 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 _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, useImperativeHandle, useEffect, useRef, useState } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import Cleave from "cleave.js/react"; import warning from "../_util/warning"; import { ConfigContext, getComputedSize } from "../config-provider"; import Textarea from "./Textarea"; import "./style"; var prefix = "adui-channels-input"; var Input = forwardRef(function (_ref, ref) { var _cleaveRef$current, _classNames, _classNames2, _classNames3; var autoComplete = _ref.autoComplete, autoFocus = _ref.autoFocus, className = _ref.className, cleaveOptions = _ref.cleaveOptions, contentJustify = _ref.contentJustify, countHanzi = _ref.countHanzi, defaultValue = _ref.defaultValue, disabled = _ref.disabled, id = _ref.id, intent = _ref.intent, leftElement = _ref.leftElement, limit = _ref.limit, name = _ref.name, onBlur = _ref.onBlur, onChange = _ref.onChange, onFocus = _ref.onFocus, onKeyDown = _ref.onKeyDown, onPressEnter = _ref.onPressEnter, placeholder = _ref.placeholder, required = _ref.required, rightElement = _ref.rightElement, sizeProp = _ref.size, style = _ref.style, theme = _ref.theme, type = _ref.type, value = _ref.value, otherProps = _objectWithoutProperties(_ref, _excluded); var _useState = useState(null), _useState2 = _slicedToArray(_useState, 2), leftElementWidth = _useState2[0], setLeftElementWidth = _useState2[1]; var _useState3 = useState(null), _useState4 = _slicedToArray(_useState3, 2), rightElementWidth = _useState4[0], setRightElementWidth = _useState4[1]; var inputRef = useRef(null); var wrapperElementRef = useRef(null); var leftElementRef = useRef(null); var rightElementRef = useRef(null); var justifyElementRef = useRef(null); var cleaveRef = useRef(null); var inputElement = (inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) || (cleaveRef === null || cleaveRef === void 0 ? void 0 : (_cleaveRef$current = cleaveRef.current) === null || _cleaveRef$current === void 0 ? void 0 : _cleaveRef$current.element); var _useContext = useContext(ConfigContext), sizeContext = _useContext.size; var size = getComputedSize(sizeProp, sizeContext); var handleChange = function handleChange(e) { if (!disabled && onChange) { var val = e.target.value.replace(/\u0008|\u0009|\u000A|\u000B|\u000C|\u000D|\u00A0|\u2028|\u2029|\uFEFF/g, ""); onChange(e, val); } }; var handleKeyDown = function handleKeyDown(e) { if (e.key === "Enter" && onPressEnter) { onPressEnter(e); } if (onKeyDown) { onKeyDown(e); } }; var handleBlur = function handleBlur(e) { if (onBlur) { onBlur(e); } }; var handleFocus = function handleFocus(e) { if (onFocus) { onFocus(e); } }; var handleAttachedElementClick = function handleAttachedElementClick(position) { if (position === "left" && leftElement && leftElement.type && leftElement.type.name === "Icon") { inputElement.focus(); inputElement.select(); } if (position === "right" && rightElement && rightElement.type && rightElement.type.name === "Icon") { inputElement.focus(); inputElement.select(); } }; var fixControlledValue = function fixControlledValue(val) { if (typeof val === "undefined" || val === null) { return ""; } return val; }; var updateElementsWidth = function updateElementsWidth() { if (leftElementRef !== null && leftElementRef !== void 0 && leftElementRef.current) { var clientWidth = leftElementRef.current.clientWidth; if (Math.abs(clientWidth - (leftElementWidth || 0)) > 2) { setLeftElementWidth(clientWidth); } } else if (leftElementWidth) { setLeftElementWidth(null); } if (rightElementRef !== null && rightElementRef !== void 0 && rightElementRef.current) { var _clientWidth = rightElementRef.current.clientWidth; if (Math.abs(_clientWidth - (rightElementWidth || 0)) > 2) { setRightElementWidth(_clientWidth); } } else if (rightElementWidth) { setRightElementWidth(null); } if (justifyElementRef !== null && justifyElementRef !== void 0 && justifyElementRef.current) { var scrollWidth = justifyElementRef.current.scrollWidth; if (wrapperElementRef.current && Math.ceil(scrollWidth) !== wrapperElementRef.current.clientWidth) { wrapperElementRef.current.style.width = "".concat(Math.ceil(scrollWidth), "px"); } } }; var getFormatStrLeng = function getFormatStrLeng(str) { var len = str.length; var realLength = 0; var charCode = -1; for (var i = 0; i < len; i += 1) { charCode = str.charCodeAt(i); if (charCode >= 0 && charCode <= 128) { realLength += 0.5; } else { realLength += 1; } } return Math.ceil(realLength); }; useEffect(function () { updateElementsWidth(); if (cleaveRef !== null && cleaveRef !== void 0 && cleaveRef.current) { var el = cleaveRef.current.element; if (cleaveRef.current.lastInputValue !== value) { cleaveRef.current.lastInputValue = value; } if (cleaveRef.current.state.value !== value) { cleaveRef.current.state.value = value; } if (cleaveRef.current.properties.result !== value) { cleaveRef.current.properties.result = value; } if (el && el.value !== value && value) { el.value = value; } } }); useImperativeHandle(ref, function () { var _cleaveRef$current2; var realRef = (inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) || (cleaveRef === null || cleaveRef === void 0 ? void 0 : (_cleaveRef$current2 = cleaveRef.current) === null || _cleaveRef$current2 === void 0 ? void 0 : _cleaveRef$current2.element); return { cleave: cleaveRef === null || cleaveRef === void 0 ? void 0 : cleaveRef.current, input: realRef, leftElement: leftElementRef === null || leftElementRef === void 0 ? void 0 : leftElementRef.current, rightElement: rightElementRef === null || rightElementRef === void 0 ? void 0 : rightElementRef.current, updateElementsWidth: updateElementsWidth, handleChange: handleChange, handleKeyDown: handleKeyDown, handleBlur: handleBlur, handleFocus: handleFocus, handleAttachedElementClick: handleAttachedElementClick, focus: function focus() { return realRef.focus(); }, blur: function blur() { return realRef.blur(); } }; }); var inputProps = { autoComplete: autoComplete, autoFocus: autoFocus, className: "".concat(prefix, "-base"), disabled: disabled, id: id, name: name, onBlur: handleBlur, onChange: handleChange, onFocus: handleFocus, onKeyDown: handleKeyDown, placeholder: placeholder, ref: inputRef, required: required, style: { paddingLeft: leftElementWidth ? "".concat(leftElementWidth, "px") : undefined, paddingRight: rightElementWidth ? "".concat(rightElementWidth, "px") : undefined }, type: type }; var cleaveInputProps = _objectSpread({}, inputProps); if (value !== null) { inputProps.value = fixControlledValue(value); } else { inputProps.defaultValue = fixControlledValue(defaultValue); } cleaveInputProps.value = value || defaultValue || ""; var input = !cleaveOptions || Object.keys(cleaveOptions).length === 0 ? React.createElement("input", inputProps) : React.createElement(Cleave, _extends({ options: cleaveOptions }, cleaveInputProps, { ref: cleaveRef })); var length; if (limit) { warning(!rightElement, "Input", "不允许同时使用 prop `limit` 与 prop `rightElement`"); if (value) { length = countHanzi ? getFormatStrLeng(value) : value.length; } else { warning(value !== null, "Input", "如果要使用 limit Prop,必须从外部控制 value。"); length = 0; } } if (contentJustify) { warning(value !== null, "Input", "如果使用 contentJusfity Prop,必须从外部控制 value。"); } var classSet = classNames(className, "".concat(prefix, "-wrapper"), "".concat(prefix, "-").concat(size), (_classNames = {}, _defineProperty(_classNames, "".concat(prefix, "-").concat(theme), theme), _defineProperty(_classNames, "".concat(prefix, "-disabled"), disabled), _defineProperty(_classNames, "".concat(prefix, "-limited"), limit), _defineProperty(_classNames, "".concat(prefix, "-limited_digit-over-2"), limit && limit.toString().length > 2), _defineProperty(_classNames, "".concat(prefix, "-normal"), intent === "normal"), _defineProperty(_classNames, "".concat(prefix, "-primary"), intent === "primary"), _defineProperty(_classNames, "".concat(prefix, "-success"), intent === "success"), _defineProperty(_classNames, "".concat(prefix, "-warning"), intent === "warning"), _defineProperty(_classNames, "".concat(prefix, "-danger"), intent === "danger" || length && limit && length > limit), _classNames)); var leftType = leftElement && leftElement.type ? leftElement.type.type : ""; var rightType = rightElement && rightElement.type ? rightElement.type.type : ""; return React.createElement("div", _extends({ ref: wrapperElementRef, className: classSet, style: style }, otherProps), !!leftElement && React.createElement("div", { ref: leftElementRef, onClick: function onClick() { return handleAttachedElementClick("left"); }, role: "none", className: classNames("".concat(prefix, "-left"), (_classNames2 = {}, _defineProperty(_classNames2, "".concat(prefix, "-left_button"), leftType === "Button"), _defineProperty(_classNames2, "".concat(prefix, "-left_icon"), leftType === "Icon"), _defineProperty(_classNames2, "".concat(prefix, "-left_select"), leftType === "Select"), _classNames2)) }, leftElement), input, !!rightElement && React.createElement("div", { ref: rightElementRef, onClick: function onClick() { return handleAttachedElementClick("right"); }, role: "none", className: classNames("".concat(prefix, "-right"), (_classNames3 = {}, _defineProperty(_classNames3, "".concat(prefix, "-right_button"), rightType === "Button"), _defineProperty(_classNames3, "".concat(prefix, "-right_icon"), rightType === "Icon"), _defineProperty(_classNames3, "".concat(prefix, "-right_select"), rightType === "Select"), _classNames3)) }, rightElement), limit && React.createElement("div", { className: "".concat(prefix, "-limit") }, React.createElement("span", null, "".concat(length, "/").concat(limit))), contentJustify && React.createElement("div", { className: "".concat(prefix, "-justify"), ref: justifyElementRef, style: { paddingLeft: leftElementWidth ? "".concat(leftElementWidth, "px") : undefined, paddingRight: rightElementWidth ? "".concat(rightElementWidth, "px") : undefined, minWidth: style === null || style === void 0 ? void 0 : style.minWidth } }, fixControlledValue(value))); }); Input.Textarea = Textarea; Input.displayName = "Input"; Input.propTypes = { autoComplete: PropTypes.oneOf(["on", "off"]), autoFocus: PropTypes.bool, className: PropTypes.string, cleaveOptions: PropTypes.object, contentJustify: PropTypes.bool, countHanzi: PropTypes.bool, defaultValue: PropTypes.string, disabled: PropTypes.bool, id: PropTypes.string, intent: PropTypes.oneOf(["normal", "primary", "success", "warning", "danger"]), leftElement: PropTypes.any, limit: PropTypes.number, name: PropTypes.string, onBlur: PropTypes.func, onChange: PropTypes.func, onFocus: PropTypes.func, onKeyDown: PropTypes.func, onPressEnter: PropTypes.func, placeholder: PropTypes.string, required: PropTypes.bool, rightElement: PropTypes.any, size: PropTypes.oneOf(["mini", "small", "medium", "large"]), style: PropTypes.object, theme: PropTypes.oneOf([null, "light"]), type: PropTypes.string, value: PropTypes.string }; Input.defaultProps = { autoComplete: "off", autoFocus: false, className: undefined, cleaveOptions: {}, contentJustify: false, countHanzi: true, defaultValue: null, disabled: false, id: null, intent: "normal", leftElement: undefined, limit: null, name: null, onBlur: function onBlur() {}, onChange: function onChange() {}, onFocus: function onFocus() {}, onKeyDown: function onKeyDown() {}, onPressEnter: function onPressEnter() {}, placeholder: "请输入", required: false, rightElement: undefined, size: "small", style: {}, theme: null, type: null, value: null }; export default Input; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useContext","useImperativeHandle","useEffect","useRef","useState","PropTypes","classNames","Cleave","warning","ConfigContext","getComputedSize","Textarea","prefix","Input","ref","autoComplete","autoFocus","className","cleaveOptions","contentJustify","countHanzi","defaultValue","disabled","id","intent","leftElement","limit","name","onBlur","onChange","onFocus","onKeyDown","onPressEnter","placeholder","required","rightElement","sizeProp","size","style","theme","type","value","otherProps","leftElementWidth","setLeftElementWidth","rightElementWidth","setRightElementWidth","inputRef","wrapperElementRef","leftElementRef","rightElementRef","justifyElementRef","cleaveRef","inputElement","current","element","sizeContext","handleChange","e","val","target","replace","handleKeyDown","key","handleBlur","handleFocus","handleAttachedElementClick","position","focus","select","fixControlledValue","updateElementsWidth","clientWidth","Math","abs","scrollWidth","ceil","width","getFormatStrLeng","str","len","length","realLength","charCode","i","charCodeAt","el","lastInputValue","state","properties","result","realRef","cleave","input","blur","inputProps","paddingLeft","undefined","paddingRight","cleaveInputProps","Object","keys","classSet","toString","leftType","rightType","minWidth","displayName","propTypes","oneOf","bool","string","object","any","number","func","defaultProps"],"sources":["../../components/channels-input/Input.tsx"],"sourcesContent":["import React, {\n  forwardRef,\n  useContext,\n  useImperativeHandle,\n  useEffect,\n  useRef,\n  useState,\n} from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Cleave from \"cleave.js/react\"\nimport warning from \"../_util/warning\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport Textarea from \"./Textarea\"\nimport \"./style\"\n\nconst prefix = \"adui-channels-input\"\n\nexport interface IInputProps {\n  [key: string]: any\n  /**\n   * input 标签原生属性 - autoComplete\n   */\n  autoComplete?: \"on\" | \"off\"\n  /**\n   * input 标签原生属性 - autoFocus\n   */\n  autoFocus?: boolean\n  /**\n   * 附加类名\n   */\n  className?: string\n  /**\n   * 实现手机号、日期、数字及自定义格式，可查看[示例](http://wxad.design/adui/components/input)。\n   */\n  cleaveOptions?: object\n  /**\n   * 宽度是否与内容宽度对齐\n   */\n  contentJustify?: boolean\n  /**\n   * 是否按照一个汉字算 2 字数的方式限制长度\n   */\n  countHanzi?: boolean\n  /**\n   * 默认值 - 内部驱动\n   */\n  defaultValue?: string | null\n  /**\n   * 是否禁用\n   */\n  disabled?: boolean\n  /**\n   * 输入框的 id\n   */\n  id?: string | null\n  /**\n   * 类型\n   */\n  intent?: \"normal\" | \"primary\" | \"success\" | \"warning\" | \"danger\"\n  /**\n   * 前置元素\n   */\n  leftElement?: JSX.Element\n  /**\n   * 限制长度\n   */\n  limit?: number | null\n  /**\n   * input 标签原生属性 - name\n   */\n  name?: string | null\n  /**\n   * blur 时的 handler\n   */\n  onBlur?: (e: React.FocusEvent<HTMLInputElement>) => void\n  /**\n   * 值改变时的 handler\n   */\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>, value?: string) => void\n  /**\n   * focus 时的 handler\n   */\n  onFocus?: (e: React.FocusEvent<HTMLInputElement>) => void\n  /**\n   * keydown 时的 handler\n   */\n  onKeyDown?: (e: React.KeyboardEvent<HTMLInputElement>) => void\n  /**\n   * enter 时的 handler\n   */\n  onPressEnter?: (e: React.KeyboardEvent<HTMLInputElement>) => void\n  /**\n   * placeholder\n   */\n  placeholder?: string\n  /**\n   * input 标签原生属性 - required\n   */\n  required?: boolean\n  /**\n   * 后置元素\n   */\n  rightElement?: JSX.Element\n  /**\n   * 设置尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  /**\n   * 附加样式\n   */\n  style?: React.CSSProperties\n  /**\n   * 设置主题\n   */\n  theme?: null | \"light\"\n  /**\n   * input 标签原生属性 - type\n   */\n  type?: string | null\n  /**\n   * 值 - 外部控制\n   */\n  value?: string | null\n}\n\nexport interface IInput\n  extends React.ForwardRefExoticComponent<\n    IInputProps & React.RefAttributes<any>\n  > {\n  Textarea: typeof Textarea\n}\n\n/**\n * 输入框用于文本输入的区域，可结合图标、按钮、选择器等组件使用。\n */\n// @ts-ignore\nconst Input: IInput = forwardRef(\n  (\n    {\n      autoComplete,\n      autoFocus,\n      className,\n      cleaveOptions,\n      contentJustify,\n      countHanzi,\n      defaultValue,\n      disabled,\n      id,\n      intent,\n      leftElement,\n      limit,\n      name,\n      onBlur,\n      onChange,\n      onFocus,\n      onKeyDown,\n      onPressEnter,\n      placeholder,\n      required,\n      rightElement,\n      size: sizeProp,\n      style,\n      theme,\n      type,\n      value,\n      ...otherProps\n    }: IInputProps,\n    ref\n  ) => {\n    const [leftElementWidth, setLeftElementWidth] = useState<null | number>(\n      null\n    )\n    const [rightElementWidth, setRightElementWidth] = useState<null | number>(\n      null\n    )\n    const inputRef = useRef<any>(null)\n    const wrapperElementRef = useRef<HTMLDivElement>(null)\n    const leftElementRef = useRef<HTMLDivElement>(null)\n    const rightElementRef = useRef<HTMLDivElement>(null)\n    const justifyElementRef = useRef<HTMLDivElement>(null)\n    const cleaveRef = useRef<any>(null)\n\n    const inputElement = inputRef?.current || cleaveRef?.current?.element\n\n    const { size: sizeContext } = useContext(ConfigContext)\n\n    const size = getComputedSize(sizeProp, sizeContext)\n\n    const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n      if (!disabled && onChange) {\n        /* eslint-disable no-control-regex, max-len */\n        // 08 Backspace, 09 Tab, 0A 换行符, 0B 垂直制表符, 0C 换页, 0D 回车, A0 不间断空格,\n        // 2028/2029 分隔符, FEff 字节顺序标记。\n        const val = e.target.value.replace(\n          /\\u0008|\\u0009|\\u000A|\\u000B|\\u000C|\\u000D|\\u00A0|\\u2028|\\u2029|\\uFEFF/g,\n          \"\"\n        )\n        onChange(e, val)\n      }\n    }\n\n    const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n      if (e.key === \"Enter\" && onPressEnter) {\n        onPressEnter(e)\n      }\n      if (onKeyDown) {\n        onKeyDown(e)\n      }\n    }\n\n    const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n      if (onBlur) {\n        onBlur(e)\n      }\n    }\n\n    const handleFocus = (e: React.FocusEvent<HTMLInputElement>) => {\n      if (onFocus) {\n        onFocus(e)\n      }\n    }\n\n    const handleAttachedElementClick = (position: \"left\" | \"right\") => {\n      if (\n        position === \"left\" &&\n        leftElement &&\n        leftElement.type &&\n        leftElement.type.name === \"Icon\"\n      ) {\n        inputElement.focus()\n        inputElement.select()\n      }\n      if (\n        position === \"right\" &&\n        rightElement &&\n        rightElement.type &&\n        rightElement.type.name === \"Icon\"\n      ) {\n        inputElement.focus()\n        inputElement.select()\n      }\n    }\n\n    const fixControlledValue = (val?: string | null) => {\n      if (typeof val === \"undefined\" || val === null) {\n        return \"\"\n      }\n      return val\n    }\n\n    const updateElementsWidth = () => {\n      /**\n       * 这个方法会在 didUpdate 和 didMount 时去 setState\n       * 一定要避免造成循环。\n       */\n      if (leftElementRef?.current) {\n        const { clientWidth } = leftElementRef.current\n\n        // 防止循环\n        if (Math.abs(clientWidth - (leftElementWidth || 0)) > 2) {\n          setLeftElementWidth(clientWidth)\n        }\n      } else if (leftElementWidth) {\n        setLeftElementWidth(null)\n      }\n\n      if (rightElementRef?.current) {\n        const { clientWidth } = rightElementRef.current\n\n        // 防止循环\n        if (Math.abs(clientWidth - (rightElementWidth || 0)) > 2) {\n          setRightElementWidth(clientWidth)\n        }\n      } else if (rightElementWidth) {\n        setRightElementWidth(null)\n      }\n\n      if (justifyElementRef?.current) {\n        const { scrollWidth } = justifyElementRef.current\n        if (\n          wrapperElementRef.current &&\n          Math.ceil(scrollWidth) !== wrapperElementRef.current.clientWidth\n        ) {\n          wrapperElementRef.current.style.width = `${Math.ceil(scrollWidth)}px`\n        }\n      }\n    }\n\n    const getFormatStrLeng = (str: string) => {\n      const len = str.length\n      let realLength = 0\n      let charCode = -1\n      for (let i = 0; i < len; i += 1) {\n        charCode = str.charCodeAt(i)\n        if (charCode >= 0 && charCode <= 128) {\n          realLength += 0.5\n        } else {\n          realLength += 1\n        }\n      }\n      return Math.ceil(realLength)\n    }\n\n    useEffect(() => {\n      updateElementsWidth()\n      if (cleaveRef?.current) {\n        const el = cleaveRef.current.element\n        /**\n         * 修复 cleave.1.4.7 bug:\n         */\n        if (cleaveRef.current.lastInputValue !== value) {\n          cleaveRef.current.lastInputValue = value\n        }\n        if (cleaveRef.current.state.value !== value) {\n          cleaveRef.current.state.value = value\n        }\n        if (cleaveRef.current.properties.result !== value) {\n          cleaveRef.current.properties.result = value\n        }\n        if (el && el.value !== value && value) {\n          el.value = value\n        }\n      }\n    })\n\n    useImperativeHandle(ref, () => {\n      const realRef = inputRef?.current || cleaveRef?.current?.element\n      return {\n        cleave: cleaveRef?.current,\n        input: realRef,\n        leftElement: leftElementRef?.current,\n        rightElement: rightElementRef?.current,\n        updateElementsWidth,\n        handleChange,\n        handleKeyDown,\n        handleBlur,\n        handleFocus,\n        handleAttachedElementClick,\n        focus: () => realRef.focus(),\n        blur: () => realRef.blur(),\n      }\n    })\n\n    const inputProps: { [key: string]: any } = {\n      autoComplete,\n      autoFocus,\n      className: `${prefix}-base`,\n      disabled,\n      id,\n      name,\n      onBlur: handleBlur,\n      onChange: handleChange,\n      onFocus: handleFocus,\n      onKeyDown: handleKeyDown,\n      placeholder,\n      ref: inputRef,\n      required,\n      style: {\n        paddingLeft: leftElementWidth ? `${leftElementWidth}px` : undefined,\n        paddingRight: rightElementWidth ? `${rightElementWidth}px` : undefined,\n      },\n      type,\n    }\n\n    const cleaveInputProps = { ...inputProps }\n\n    if (value !== null) {\n      inputProps.value = fixControlledValue(value)\n    } else {\n      inputProps.defaultValue = fixControlledValue(defaultValue)\n    }\n\n    /**\n     * cleave 不接收原生的 defaultValue，必须传入 value prop 来实现 defaultValue 的作用\n     * https://github.com/nosir/cleave.js/blob/master/doc/reactjs-component-usage.md#how-to-pass-default-value\n     */\n    cleaveInputProps.value = value || defaultValue || \"\"\n\n    const input =\n      !cleaveOptions || Object.keys(cleaveOptions).length === 0 ? (\n        <input {...inputProps} />\n      ) : (\n        <Cleave options={cleaveOptions} {...cleaveInputProps} ref={cleaveRef} />\n      )\n\n    let length\n    if (limit) {\n      warning(\n        !rightElement,\n        \"Input\",\n        \"不允许同时使用 prop `limit` 与 prop `rightElement`\"\n      )\n      if (value) {\n        length = countHanzi ? getFormatStrLeng(value) : value.length\n      } else {\n        warning(\n          value !== null,\n          \"Input\",\n          \"如果要使用 limit Prop，必须从外部控制 value。\"\n        )\n        length = 0\n      }\n    }\n    if (contentJustify) {\n      warning(\n        value !== null,\n        \"Input\",\n        \"如果使用 contentJusfity Prop，必须从外部控制 value。\"\n      )\n    }\n\n    const classSet = classNames(\n      className,\n      `${prefix}-wrapper`,\n      `${prefix}-${size}`,\n      {\n        [`${prefix}-${theme}`]: theme,\n        [`${prefix}-disabled`]: disabled,\n        [`${prefix}-limited`]: limit,\n        [`${prefix}-limited_digit-over-2`]:\n          limit && limit.toString().length > 2,\n        [`${prefix}-normal`]: intent === \"normal\",\n        [`${prefix}-primary`]: intent === \"primary\",\n        [`${prefix}-success`]: intent === \"success\",\n        [`${prefix}-warning`]: intent === \"warning\",\n        [`${prefix}-danger`]:\n          intent === \"danger\" || (length && limit && length > limit),\n      }\n    )\n\n    const leftType =\n      leftElement && leftElement.type ? leftElement.type.type : \"\"\n    const rightType =\n      rightElement && rightElement.type ? rightElement.type.type : \"\"\n\n    return (\n      <div\n        ref={wrapperElementRef}\n        className={classSet}\n        style={style}\n        {...otherProps}\n      >\n        {!!leftElement && (\n          <div\n            ref={leftElementRef}\n            onClick={() => handleAttachedElementClick(\"left\")}\n            role=\"none\"\n            className={classNames(`${prefix}-left`, {\n              [`${prefix}-left_button`]: leftType === \"Button\",\n              [`${prefix}-left_icon`]: leftType === \"Icon\",\n              [`${prefix}-left_select`]: leftType === \"Select\",\n            })}\n          >\n            {leftElement}\n          </div>\n        )}\n        {input}\n        {!!rightElement && (\n          <div\n            ref={rightElementRef}\n            onClick={() => handleAttachedElementClick(\"right\")}\n            role=\"none\"\n            className={classNames(`${prefix}-right`, {\n              [`${prefix}-right_button`]: rightType === \"Button\",\n              [`${prefix}-right_icon`]: rightType === \"Icon\",\n              [`${prefix}-right_select`]: rightType === \"Select\",\n            })}\n          >\n            {rightElement}\n          </div>\n        )}\n        {limit && (\n          <div className={`${prefix}-limit`}>\n            <span>{`${length}/${limit}`}</span>\n          </div>\n        )}\n        {contentJustify && (\n          <div\n            className={`${prefix}-justify`}\n            ref={justifyElementRef}\n            style={{\n              paddingLeft: leftElementWidth\n                ? `${leftElementWidth}px`\n                : undefined,\n              paddingRight: rightElementWidth\n                ? `${rightElementWidth}px`\n                : undefined,\n              minWidth: style?.minWidth,\n            }}\n          >\n            {fixControlledValue(value)}\n          </div>\n        )}\n      </div>\n    )\n  }\n)\n\nInput.Textarea = Textarea\n\nInput.displayName = \"Input\"\n\nInput.propTypes = {\n  /**\n   * input 标签原生属性 - autoComplete\n   */\n  autoComplete: PropTypes.oneOf([\"on\", \"off\"]),\n  /**\n   * input 标签原生属性 - autoFocus\n   */\n  autoFocus: PropTypes.bool,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\n  /**\n   * 实现手机号、日期、数字及自定义格式，可查看[示例](http://wxad.design/adui/components/input)。\n   */\n  cleaveOptions: PropTypes.object,\n  /**\n   * 宽度是否与内容宽度对齐\n   */\n  contentJustify: PropTypes.bool,\n  /**\n   * 是否按照一个汉字算 2 字数的方式限制长度\n   */\n  countHanzi: PropTypes.bool,\n  /**\n   * 默认值 - 内部驱动\n   */\n  defaultValue: PropTypes.string,\n  /**\n   * 是否禁用\n   */\n  disabled: PropTypes.bool,\n  /**\n   * 输入框的 id\n   */\n  id: PropTypes.string,\n  /**\n   * 类型\n   */\n  intent: PropTypes.oneOf([\n    \"normal\",\n    \"primary\",\n    \"success\",\n    \"warning\",\n    \"danger\",\n  ]),\n  /**\n   * 前置元素\n   */\n  leftElement: PropTypes.any,\n  /**\n   * 限制长度\n   */\n  limit: PropTypes.number,\n  /**\n   * input 标签原生属性 - name\n   */\n  name: PropTypes.string,\n  /**\n   * blur 时的 handler\n   */\n  onBlur: PropTypes.func,\n  /**\n   * 值改变时的 handler\n   */\n  onChange: PropTypes.func,\n  /**\n   * focus 时的 handler\n   */\n  onFocus: PropTypes.func,\n  /**\n   * keydown 时的 handler\n   */\n  onKeyDown: PropTypes.func,\n  /**\n   * enter 时的 handler\n   */\n  onPressEnter: PropTypes.func,\n  /**\n   * placeholder\n   */\n  placeholder: PropTypes.string,\n  /**\n   * input 标签原生属性 - required\n   */\n  required: PropTypes.bool,\n  /**\n   * 后置元素\n   */\n  rightElement: PropTypes.any,\n  /**\n   * 设置尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 附加样式\n   */\n  style: PropTypes.object,\n  /**\n   * 设置主题\n   */\n  theme: PropTypes.oneOf([null, \"light\"]),\n  /**\n   * input 标签原生属性 - type\n   */\n  type: PropTypes.string,\n  /**\n   * 值 - 外部控制\n   */\n  value: PropTypes.string,\n}\n\nInput.defaultProps = {\n  autoComplete: \"off\",\n  autoFocus: false,\n  className: undefined,\n  cleaveOptions: {},\n  contentJustify: false,\n  countHanzi: true,\n  defaultValue: null,\n  disabled: false,\n  id: null,\n  intent: \"normal\",\n  leftElement: undefined,\n  limit: null,\n  name: null,\n  onBlur: () => {},\n  onChange: () => {},\n  onFocus: () => {},\n  onKeyDown: () => {},\n  onPressEnter: () => {},\n  placeholder: \"请输入\",\n  required: false,\n  rightElement: undefined,\n  size: \"small\",\n  style: {},\n  theme: null,\n  type: null,\n  value: null,\n}\n\nexport default Input\n"],"mappings":"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