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>

201 lines 32.4 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 = ["autoFocus", "className", "countHanzi", "defaultValue", "disabled", "id", "intent", "limit", "name", "onBlur", "onChange", "onFocus", "onKeyDown", "onPressEnter", "onScroll", "placeholder", "required", "resize", "size", "theme", "type", "value"]; 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, useContext, useImperativeHandle, useRef, useState } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import warning from "../_util/warning"; import { ConfigContext, getComputedSize } from "../config-provider"; import "./style"; var noop = function noop() {}; var prefix = "adui-channels-input"; var Textarea = forwardRef(function (_ref, ref) { var autoFocus = _ref.autoFocus, className = _ref.className, countHanzi = _ref.countHanzi, defaultValue = _ref.defaultValue, disabled = _ref.disabled, id = _ref.id, intent = _ref.intent, limit = _ref.limit, name = _ref.name, onBlur = _ref.onBlur, onChange = _ref.onChange, onFocus = _ref.onFocus, onKeyDown = _ref.onKeyDown, onPressEnter = _ref.onPressEnter, onScroll = _ref.onScroll, placeholder = _ref.placeholder, required = _ref.required, resize = _ref.resize, sizeProp = _ref.size, theme = _ref.theme, type = _ref.type, value = _ref.value, otherProps = _objectWithoutProperties(_ref, _excluded); var _useState = useState(false), _useState2 = _slicedToArray(_useState, 2), focused = _useState2[0], setFocused = _useState2[1]; var textareaRef = useRef(null); 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|\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) { setFocused(false); if (onBlur) { onBlur(e); } }; var handleFocus = function handleFocus(e) { setFocused(true); if (onFocus) { onFocus(e); } }; var fixControlledValue = function fixControlledValue(val) { if (typeof val === "undefined" || val === null) { return ""; } return val; }; 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); }; useImperativeHandle(ref, function () { return { input: textareaRef === null || textareaRef === void 0 ? void 0 : textareaRef.current, handleChange: handleChange, handleKeyDown: handleKeyDown, handleBlur: handleBlur, handleFocus: handleFocus }; }); var textareaProps = { autoFocus: autoFocus, className: "".concat(prefix, "-base"), disabled: disabled, id: id, name: name, onBlur: handleBlur, onChange: handleChange, onFocus: handleFocus, onKeyDown: handleKeyDown, onScroll: onScroll, placeholder: placeholder, ref: textareaRef, required: required, style: { resize: resize }, type: type }; if (value !== null) { textareaProps.value = fixControlledValue(value); } else { textareaProps.defaultValue = fixControlledValue(defaultValue); } var length; if (limit) { warning(resize === "none", "Input.Textarea", "不允许同时使用 prop `limit` 与 prop `resize`"); if (value) { length = countHanzi ? getFormatStrLeng(value) : value.length; } else { warning(value !== null, "Input.Textarea", "如果要限制字数,必须从外部控制 value。"); length = 0; } } var classSet = classNames(className, "".concat(prefix, "-wrapper"), "".concat(prefix, "-wrapper_textarea"), "".concat(prefix, "-").concat(size), _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "".concat(prefix, "-").concat(theme), theme), "".concat(prefix, "-disabled"), disabled), "".concat(prefix, "-limited"), !!limit), "".concat(prefix, "-normal"), intent === "normal"), "".concat(prefix, "-primary"), intent === "primary"), "".concat(prefix, "-success"), intent === "success"), "".concat(prefix, "-warning"), intent === "warning"), "".concat(prefix, "-danger"), intent === "danger" || length && limit && length > limit), "".concat(prefix, "-focused"), focused)); return React.createElement("div", _extends({ className: classSet }, otherProps), React.createElement("textarea", textareaProps), !!limit && React.createElement("div", { className: "".concat(prefix, "-limit") }, React.createElement("span", null, "".concat(length, "/").concat(limit)))); }); Textarea.propTypes = { autoFocus: PropTypes.bool, className: PropTypes.string, countHanzi: PropTypes.bool, defaultValue: PropTypes.string, disabled: PropTypes.bool, id: PropTypes.string, intent: PropTypes.oneOf(["normal", "primary", "success", "warning", "danger"]), limit: PropTypes.number, name: PropTypes.string, onBlur: PropTypes.func, onChange: PropTypes.func, onFocus: PropTypes.func, onKeyDown: PropTypes.func, onPressEnter: PropTypes.func, onScroll: PropTypes.func, placeholder: PropTypes.string, required: PropTypes.bool, resize: PropTypes.oneOf(["none", "both", "horizontal", "vertical"]), size: PropTypes.oneOf(["mini", "small", "medium", "large"]), theme: PropTypes.oneOf([null, "light"]), type: PropTypes.string, value: PropTypes.string }; Textarea.defaultProps = { autoFocus: false, className: undefined, countHanzi: true, defaultValue: null, disabled: false, id: null, intent: "normal", limit: null, name: null, onBlur: noop, onChange: noop, onFocus: noop, onKeyDown: noop, onPressEnter: noop, onScroll: noop, placeholder: "请输入", required: false, resize: "none", size: "small", theme: null, type: null, value: null }; Textarea.displayName = "Textarea"; export default Textarea; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useContext","useImperativeHandle","useRef","useState","PropTypes","classNames","warning","ConfigContext","getComputedSize","noop","prefix","Textarea","_ref","ref","autoFocus","className","countHanzi","defaultValue","disabled","id","intent","limit","name","onBlur","onChange","onFocus","onKeyDown","onPressEnter","onScroll","placeholder","required","resize","sizeProp","size","theme","type","value","otherProps","_objectWithoutProperties","_excluded","_useState","_useState2","_slicedToArray","focused","setFocused","textareaRef","_useContext","sizeContext","handleChange","e","val","target","replace","handleKeyDown","key","handleBlur","handleFocus","fixControlledValue","getFormatStrLeng","str","len","length","realLength","charCode","i","charCodeAt","Math","ceil","input","current","textareaProps","concat","style","classSet","_defineProperty","createElement","_extends","propTypes","bool","string","oneOf","number","func","defaultProps","undefined","displayName"],"sources":["../../components/channels-input/Textarea.tsx"],"sourcesContent":["import React, {\n  forwardRef,\n  useContext,\n  useImperativeHandle,\n  useRef,\n  useState,\n} from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport warning from \"../_util/warning\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\nimport \"./style\"\n\nconst noop = () => {}\n\nconst prefix = \"adui-channels-input\"\n\nexport interface ITextareaProps {\n  [key: string]: any\n  /**\n   * input 标签原生属性 - autoFocus\n   */\n  autoFocus?: boolean\n  /**\n   * 附加类名\n   */\n  className?: string\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  limit?: number | null\n  /**\n   * input 标签原生属性 - name\n   */\n  name?: string | null\n  /**\n   * blur 时的 handler\n   */\n  onBlur?: (e: React.FocusEvent<HTMLTextAreaElement>) => void\n  /**\n   * 值改变时的 handler\n   */\n  onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>, value?: string) => void\n  /**\n   * focus 时的 handler\n   */\n  onFocus?: (e: React.FocusEvent<HTMLTextAreaElement>) => void\n  /**\n   * keydown 时的 handler\n   */\n  onKeyDown?: (e: React.KeyboardEvent<HTMLTextAreaElement>) => void\n  /**\n   * enter 时的 handler\n   */\n  onPressEnter?: (e: React.KeyboardEvent<HTMLTextAreaElement>) => void\n  /**\n   * scroll 时的 handler\n   */\n  onScroll?: (e: React.UIEvent<HTMLTextAreaElement>) => void\n  /**\n   * placeholder\n   */\n  placeholder?: string\n  /**\n   * input 标签原生属性 - required\n   */\n  required?: boolean\n  /**\n   * 是否支持调整大小\n   */\n  resize?: \"none\" | \"both\" | \"horizontal\" | \"vertical\"\n  /**\n   * 设置尺寸\n   */\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\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\n/**\n * 输入区域，用于多行纯文本编辑。\n */\nconst Textarea: React.ForwardRefExoticComponent<\n  ITextareaProps & React.RefAttributes<any>\n> = forwardRef(\n  (\n    {\n      autoFocus,\n      className,\n      countHanzi,\n      defaultValue,\n      disabled,\n      id,\n      intent,\n      limit,\n      name,\n      onBlur,\n      onChange,\n      onFocus,\n      onKeyDown,\n      onPressEnter,\n      onScroll,\n      placeholder,\n      required,\n      resize,\n      size: sizeProp,\n      theme,\n      type,\n      value,\n      ...otherProps\n    }: ITextareaProps,\n    ref\n  ) => {\n    const [focused, setFocused] = useState(false)\n\n    const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n    const { size: sizeContext } = useContext(ConfigContext)\n\n    const size = getComputedSize(sizeProp, sizeContext)\n\n    const handleChange = (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n      if (!disabled && onChange) {\n        /* eslint-disable no-control-regex, max-len */\n        // 08 Backspace, 09 Tab, 0B 垂直制表符, 0C 换页, 0D 回车, A0 不间断空格,\n        // 2028/2029 分隔符, FEff 字节顺序标记。\n        const val = e.target.value.replace(\n          /\\u0008|\\u0009|\\u000B|\\u000C|\\u000D|\\u00A0|\\u2028|\\u2029|\\uFEFF/g,\n          \"\"\n        )\n        onChange(e, val)\n      }\n    }\n\n    const handleKeyDown = (e: React.KeyboardEvent<HTMLTextAreaElement>) => {\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<HTMLTextAreaElement>) => {\n      setFocused(false)\n      if (onBlur) {\n        onBlur(e)\n      }\n    }\n\n    const handleFocus = (e: React.FocusEvent<HTMLTextAreaElement>) => {\n      setFocused(true)\n      if (onFocus) {\n        onFocus(e)\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 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    useImperativeHandle(ref, () => ({\n      input: textareaRef?.current,\n      handleChange,\n      handleKeyDown,\n      handleBlur,\n      handleFocus,\n    }))\n\n    const textareaProps: { [key: string]: any } = {\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      onScroll,\n      placeholder,\n      ref: textareaRef,\n      required,\n      style: { resize },\n      type,\n    }\n\n    if (value !== null) {\n      textareaProps.value = fixControlledValue(value)\n    } else {\n      textareaProps.defaultValue = fixControlledValue(defaultValue)\n    }\n\n    let length\n    if (limit) {\n      warning(\n        resize === \"none\",\n        \"Input.Textarea\",\n        \"不允许同时使用 prop `limit` 与 prop `resize`\"\n      )\n      if (value) {\n        length = countHanzi ? getFormatStrLeng(value) : value.length\n      } else {\n        warning(\n          value !== null,\n          \"Input.Textarea\",\n          \"如果要限制字数，必须从外部控制 value。\"\n        )\n        length = 0\n      }\n    }\n\n    const classSet = classNames(\n      className,\n      `${prefix}-wrapper`,\n      `${prefix}-wrapper_textarea`,\n      `${prefix}-${size}`,\n      {\n        [`${prefix}-${theme}`]: theme,\n        [`${prefix}-disabled`]: disabled,\n        [`${prefix}-limited`]: !!limit,\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        [`${prefix}-focused`]: focused,\n      }\n    )\n\n    return (\n      <div className={classSet} {...otherProps}>\n        <textarea {...textareaProps} />\n        {!!limit && (\n          <div className={`${prefix}-limit`}>\n            <span>{`${length}/${limit}`}</span>\n          </div>\n        )}\n      </div>\n    )\n  }\n)\n\nTextarea.propTypes = {\n  /**\n   * input 标签原生属性 - autoFocus\n   */\n  autoFocus: PropTypes.bool,\n  /**\n   * 附加类名\n   */\n  className: PropTypes.string,\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  limit: PropTypes.number,\n  /**\n   * textarea 标签原生属性 - 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   * scroll 时的 handler\n   */\n  onScroll: PropTypes.func,\n  /**\n   * placeholder\n   */\n  placeholder: PropTypes.string,\n  /**\n   * input 标签原生属性 - required\n   */\n  required: PropTypes.bool,\n  /**\n   * 是否支持调整大小\n   */\n  resize: PropTypes.oneOf([\"none\", \"both\", \"horizontal\", \"vertical\"]),\n  /**\n   * 设置尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 设置主题\n   */\n  theme: PropTypes.oneOf([null, \"light\"]),\n  /**\n   * textarea 标签原生属性 - type\n   */\n  type: PropTypes.string,\n  /**\n   * 值 - 外部控制\n   */\n  value: PropTypes.string,\n}\n\nTextarea.defaultProps = {\n  autoFocus: false,\n  className: undefined,\n  countHanzi: true,\n  defaultValue: null,\n  disabled: false,\n  id: null,\n  intent: \"normal\",\n  limit: null,\n  name: null,\n  onBlur: noop,\n  onChange: noop,\n  onFocus: noop,\n  onKeyDown: noop,\n  onPressEnter: noop,\n  onScroll: noop,\n  placeholder: \"请输入\",\n  required: false,\n  resize: \"none\",\n  size: \"small\",\n  theme: null,\n  type: null,\n  value: null,\n}\n\nTextarea.displayName = \"Textarea\"\n\nexport default Textarea\n"],"mappings":"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","ignoreList":[]}