@infomaximum/ui-kit 0.13.0 → 0.13.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/BaseSelect/BaseSelect.d.ts +1 -1
- package/dist/components/BaseSelect/BaseSelect.js +9 -23
- package/dist/components/BaseSelect/BaseSelect.styles.d.ts +6 -20
- package/dist/components/BaseSelect/BaseSelect.styles.js +7 -17
- package/dist/components/BaseSelect/BaseSelect.types.d.ts +0 -2
- package/dist/components/BaseTooltip/BaseTooltip.js +9 -4
- package/dist/components/BaseTooltip/BaseTooltip.types.d.ts +6 -0
- package/dist/components/BaseTooltip/BaseTooltip.utils.d.ts +1 -0
- package/dist/components/BaseTooltip/BaseTooltip.utils.js +2 -0
- package/dist/components/Dropdown/Dropdown.types.d.ts +3 -2
- package/dist/components/Input/Input.d.ts +2 -2
- package/dist/components/Input/Input.js +35 -10
- package/dist/components/Input/Input.styles.d.ts +7 -0
- package/dist/components/Input/Input.styles.js +9 -5
- package/dist/components/Input/Input.types.d.ts +16 -6
- package/dist/components/Input/components/InputPassword/InputPassword.d.ts +2 -1
- package/dist/components/Input/components/InputTextArea/InputTextArea.d.ts +2 -2
- package/dist/components/Input/components/InputTextArea/InputTextArea.js +27 -5
- package/dist/components/Input/components/InputTextArea/InputTextArea.types.d.ts +10 -2
- package/dist/components/Input/index.d.ts +3 -1
- package/dist/components/Popconfirm/Popconfirm.types.d.ts +1 -1
- package/dist/components/Popover/Popover.types.d.ts +1 -1
- package/dist/components/Tabs/Tabs.utils.d.ts +3 -0
- package/dist/components/Tabs/Tabs.utils.js +12 -0
- package/dist/components/Tabs/components/TabBar/TabBar.js +6 -6
- package/dist/components/Tabs/components/TabBar/TabBar.styles.d.ts +5 -2
- package/dist/components/Tabs/components/TabBar/TabBar.styles.js +5 -2
- package/dist/components/Tabs/components/TabBar/TabBar.types.d.ts +2 -0
- package/dist/components/Tabs/components/TabItem/TabItem.js +4 -4
- package/dist/components/Tabs/components/TabItem/TabItem.types.d.ts +4 -4
- package/dist/components/Tabs/hooks/useTabsDndController.d.ts +1 -1
- package/dist/components/Tabs/hooks/useTabsDndController.js +16 -3
- package/dist/components/Tooltip/Tooltip.types.d.ts +1 -1
- package/dist/index.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx, jsxs } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { forwardRef, useRef, memo, Fragment } from "react";
|
|
2
|
+
import { forwardRef, useRef, useContext, useImperativeHandle, memo, Fragment } from "react";
|
|
3
3
|
import { InputPassword } from "./components/InputPassword/InputPassword.js";
|
|
4
4
|
import { InputTextArea } from "./components/InputTextArea/InputTextArea.js";
|
|
5
5
|
import { isString } from "lodash-es";
|
|
@@ -7,7 +7,7 @@ import { CloseCircleFilled } from "@infomaximum/icons";
|
|
|
7
7
|
import { emptyString } from "../../utils/const/index.js";
|
|
8
8
|
import { prefixStyle, prefixSuffixStyle, suffixStyle, getClearIconWrapperStyle, getAddonStyle, nonStringAddonStyle, inputGroupClassName, addonWrapperStyle, getAffixWrapperStyle, affixedInputStyle, getSharedInputStyle, getBaseInputStyle } from "./Input.styles.js";
|
|
9
9
|
import { getInputTokens } from "./Input.tokens.js";
|
|
10
|
-
import {
|
|
10
|
+
import { FormItemContext } from "../Form/components/FormItem/contexts/FormItemContext.js";
|
|
11
11
|
import { useTheme } from "../../hooks/useTheme/useTheme.js";
|
|
12
12
|
import { useRemovePasswordTimeout } from "./hooks/useRemovePasswordTimeout/useRemovePasswordTimeout.js";
|
|
13
13
|
import { useKeyboardEvents } from "./hooks/useKeyboardEvents/useKeyboardEvents.js";
|
|
@@ -23,9 +23,10 @@ const InputComponent = forwardRef((props, ref) => {
|
|
|
23
23
|
allowClear,
|
|
24
24
|
addonBefore: addonBeforeProp,
|
|
25
25
|
addonAfter: addonAfterProp,
|
|
26
|
-
status,
|
|
26
|
+
status: statusProp,
|
|
27
27
|
defaultValue,
|
|
28
28
|
value: valueProp,
|
|
29
|
+
className,
|
|
29
30
|
style,
|
|
30
31
|
onChange,
|
|
31
32
|
onClear,
|
|
@@ -40,7 +41,10 @@ const InputComponent = forwardRef((props, ref) => {
|
|
|
40
41
|
const inputTokens = getInputTokens(theme);
|
|
41
42
|
const inputRef = useRef(null);
|
|
42
43
|
const affixWrapperRef = useRef(null);
|
|
43
|
-
const
|
|
44
|
+
const {
|
|
45
|
+
status: contextStatus
|
|
46
|
+
} = useContext(FormItemContext);
|
|
47
|
+
const status = statusProp || contextStatus;
|
|
44
48
|
const errorStatus = status === "error";
|
|
45
49
|
const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;
|
|
46
50
|
const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);
|
|
@@ -63,6 +67,25 @@ const InputComponent = forwardRef((props, ref) => {
|
|
|
63
67
|
onBlur: onBlurProp,
|
|
64
68
|
disabled
|
|
65
69
|
});
|
|
70
|
+
useImperativeHandle(ref, () => ({
|
|
71
|
+
focus: (options) => {
|
|
72
|
+
var _a;
|
|
73
|
+
(_a = inputRef.current) == null ? void 0 : _a.focus(options);
|
|
74
|
+
},
|
|
75
|
+
blur: () => {
|
|
76
|
+
var _a;
|
|
77
|
+
(_a = inputRef.current) == null ? void 0 : _a.blur();
|
|
78
|
+
},
|
|
79
|
+
setSelectionRange: (start, end, direction) => {
|
|
80
|
+
var _a;
|
|
81
|
+
(_a = inputRef.current) == null ? void 0 : _a.setSelectionRange(start, end, direction);
|
|
82
|
+
},
|
|
83
|
+
select: () => {
|
|
84
|
+
var _a;
|
|
85
|
+
(_a = inputRef.current) == null ? void 0 : _a.select();
|
|
86
|
+
},
|
|
87
|
+
input: inputRef.current
|
|
88
|
+
}));
|
|
66
89
|
const [value, setValue] = useMergedState(defaultValue, {
|
|
67
90
|
value: valueProp
|
|
68
91
|
});
|
|
@@ -98,13 +121,13 @@ const InputComponent = forwardRef((props, ref) => {
|
|
|
98
121
|
if (!prefixProp) {
|
|
99
122
|
return;
|
|
100
123
|
}
|
|
101
|
-
return /* @__PURE__ */ jsx("span", { css: [prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:prefix;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAgIY","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n} from \"react\";\nimport type { InputProps, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\n\nconst InputComponent = forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status,\n    defaultValue,\n    value: valueProp,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          ref={mergedRef}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<HTMLInputElement>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: prefixProp });
|
|
124
|
+
return /* @__PURE__ */ jsx("span", { css: [prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:prefix;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAoJY","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n  useContext,\n  useImperativeHandle,\n} from \"react\";\nimport type { InputProps, InputRef, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputComponent = forwardRef<InputRef, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    defaultValue,\n    value: valueProp,\n    className,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  useImperativeHandle(ref, () => ({\n    focus: (options) => {\n      inputRef.current?.focus(options);\n    },\n    blur: () => {\n      inputRef.current?.blur();\n    },\n    setSelectionRange: (start, end, direction) => {\n      inputRef.current?.setSelectionRange(start, end, direction);\n    },\n    select: () => {\n      inputRef.current?.select();\n    },\n    input: inputRef.current,\n  }));\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: className ? `${inputGroupClassName} ${className}` : inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              [\"data-error-status\"]: errorStatus ? true : undefined,\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              className: hasAddon ? undefined : className,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          data-error-status={!hasAffix && errorStatus ? true : undefined}\n          ref={inputRef}\n          className={hasAddon || hasAffix ? undefined : className}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<InputRef>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: prefixProp });
|
|
102
125
|
})();
|
|
103
126
|
const suffix = (() => {
|
|
104
127
|
if (!suffixProp) {
|
|
105
128
|
return;
|
|
106
129
|
}
|
|
107
|
-
return /* @__PURE__ */ jsx("span", { css: [suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:suffix;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AA4IY","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n} from \"react\";\nimport type { InputProps, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\n\nconst InputComponent = forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status,\n    defaultValue,\n    value: valueProp,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          ref={mergedRef}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<HTMLInputElement>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: suffixProp });
|
|
130
|
+
return /* @__PURE__ */ jsx("span", { css: [suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:suffix;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAgKY","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n  useContext,\n  useImperativeHandle,\n} from \"react\";\nimport type { InputProps, InputRef, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputComponent = forwardRef<InputRef, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    defaultValue,\n    value: valueProp,\n    className,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  useImperativeHandle(ref, () => ({\n    focus: (options) => {\n      inputRef.current?.focus(options);\n    },\n    blur: () => {\n      inputRef.current?.blur();\n    },\n    setSelectionRange: (start, end, direction) => {\n      inputRef.current?.setSelectionRange(start, end, direction);\n    },\n    select: () => {\n      inputRef.current?.select();\n    },\n    input: inputRef.current,\n  }));\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: className ? `${inputGroupClassName} ${className}` : inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              [\"data-error-status\"]: errorStatus ? true : undefined,\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              className: hasAddon ? undefined : className,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          data-error-status={!hasAffix && errorStatus ? true : undefined}\n          ref={inputRef}\n          className={hasAddon || hasAffix ? undefined : className}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<InputRef>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: suffixProp });
|
|
108
131
|
})();
|
|
109
132
|
const clearIcon = (() => {
|
|
110
133
|
if (!allowClear) {
|
|
@@ -127,28 +150,30 @@ const InputComponent = forwardRef((props, ref) => {
|
|
|
127
150
|
if (!addonBeforeProp) {
|
|
128
151
|
return;
|
|
129
152
|
}
|
|
130
|
-
return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputTokens, disabled)(theme), isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:addonBefore;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AA+KQ","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n} from \"react\";\nimport type { InputProps, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\n\nconst InputComponent = forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status,\n    defaultValue,\n    value: valueProp,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          ref={mergedRef}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<HTMLInputElement>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: addonBeforeProp });
|
|
153
|
+
return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputTokens, disabled)(theme), isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:addonBefore;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAmMQ","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n  useContext,\n  useImperativeHandle,\n} from \"react\";\nimport type { InputProps, InputRef, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputComponent = forwardRef<InputRef, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    defaultValue,\n    value: valueProp,\n    className,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  useImperativeHandle(ref, () => ({\n    focus: (options) => {\n      inputRef.current?.focus(options);\n    },\n    blur: () => {\n      inputRef.current?.blur();\n    },\n    setSelectionRange: (start, end, direction) => {\n      inputRef.current?.setSelectionRange(start, end, direction);\n    },\n    select: () => {\n      inputRef.current?.select();\n    },\n    input: inputRef.current,\n  }));\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: className ? `${inputGroupClassName} ${className}` : inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              [\"data-error-status\"]: errorStatus ? true : undefined,\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              className: hasAddon ? undefined : className,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          data-error-status={!hasAffix && errorStatus ? true : undefined}\n          ref={inputRef}\n          className={hasAddon || hasAffix ? undefined : className}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<InputRef>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: addonBeforeProp });
|
|
131
154
|
})();
|
|
132
155
|
const addonAfter = (() => {
|
|
133
156
|
if (!addonAfterProp) {
|
|
134
157
|
return;
|
|
135
158
|
}
|
|
136
|
-
return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputTokens, disabled)(theme), isString(addonAfterProp) ? {} : nonStringAddonStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:addonAfter;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAgMQ","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n} from \"react\";\nimport type { InputProps, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\n\nconst InputComponent = forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status,\n    defaultValue,\n    value: valueProp,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          ref={mergedRef}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<HTMLInputElement>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: addonAfterProp });
|
|
159
|
+
return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputTokens, disabled)(theme), isString(addonAfterProp) ? {} : nonStringAddonStyle(theme), process.env.NODE_ENV === "production" ? "" : ";label:addonAfter;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAoNQ","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n  useContext,\n  useImperativeHandle,\n} from \"react\";\nimport type { InputProps, InputRef, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputComponent = forwardRef<InputRef, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    defaultValue,\n    value: valueProp,\n    className,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  useImperativeHandle(ref, () => ({\n    focus: (options) => {\n      inputRef.current?.focus(options);\n    },\n    blur: () => {\n      inputRef.current?.blur();\n    },\n    setSelectionRange: (start, end, direction) => {\n      inputRef.current?.setSelectionRange(start, end, direction);\n    },\n    select: () => {\n      inputRef.current?.select();\n    },\n    input: inputRef.current,\n  }));\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: className ? `${inputGroupClassName} ${className}` : inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              [\"data-error-status\"]: errorStatus ? true : undefined,\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              className: hasAddon ? undefined : className,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          data-error-status={!hasAffix && errorStatus ? true : undefined}\n          ref={inputRef}\n          className={hasAddon || hasAffix ? undefined : className}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<InputRef>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"], children: addonAfterProp });
|
|
137
160
|
})();
|
|
138
161
|
return /* @__PURE__ */ jsxs(AddonWrapper, { ...hasAddon ? {
|
|
139
|
-
className: inputGroupClassName,
|
|
162
|
+
className: className ? `${inputGroupClassName} ${className}` : inputGroupClassName,
|
|
140
163
|
css: addonWrapperStyle,
|
|
141
164
|
style
|
|
142
165
|
} : {}, children: [
|
|
143
166
|
addonBefore,
|
|
144
167
|
/* @__PURE__ */ jsxs(AffixWrapper, { ...hasAffix ? {
|
|
168
|
+
["data-error-status"]: errorStatus ? true : void 0,
|
|
145
169
|
ref: affixWrapperRef,
|
|
146
170
|
css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),
|
|
147
171
|
onClick: handleAffixWrapperClick,
|
|
172
|
+
className: hasAddon ? void 0 : className,
|
|
148
173
|
style: hasAddon ? void 0 : style
|
|
149
174
|
} : {}, children: [
|
|
150
175
|
prefix,
|
|
151
|
-
/* @__PURE__ */ jsx("input", { ...restProps, ref: mergedRef, style: hasAddon || hasAffix ? void 0 : style, type, disabled, readOnly, value: formattedValue, onChange: handleChange, onFocus: handleFocus, onBlur: handleBlur, onKeyDown, onKeyUp, css: [hasAffix ? affixedInputStyle : getSharedInputStyle(inputTokens, errorStatus, disabled, theme), getBaseInputStyle(inputTokens, disabled), process.env.NODE_ENV === "production" ? "" : ";label:InputComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AA6OU","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n} from \"react\";\nimport type { InputProps, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\n\nconst InputComponent = forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status,\n    defaultValue,\n    value: valueProp,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          ref={mergedRef}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<HTMLInputElement>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"] }),
|
|
176
|
+
/* @__PURE__ */ jsx("input", { ...restProps, "data-error-status": !hasAffix && errorStatus ? true : void 0, ref: inputRef, className: hasAddon || hasAffix ? void 0 : className, style: hasAddon || hasAffix ? void 0 : style, type, disabled, readOnly, value: formattedValue, onChange: handleChange, onFocus: handleFocus, onBlur: handleBlur, onKeyDown, onKeyUp, css: [hasAffix ? affixedInputStyle : getSharedInputStyle(inputTokens, errorStatus, disabled, theme), getBaseInputStyle(inputTokens, disabled), process.env.NODE_ENV === "production" ? "" : ";label:InputComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx"],"names":[],"mappings":"AAqQU","file":"/builds/frontend/libs/ui-kit/src/components/Input/Input.tsx","sourcesContent":["import {\n  type MouseEventHandler,\n  type ChangeEventHandler,\n  memo,\n  Fragment,\n  useRef,\n  forwardRef,\n  type MemoExoticComponent,\n  type ForwardRefExoticComponent,\n  type RefAttributes,\n  type FocusEventHandler,\n  useContext,\n  useImperativeHandle,\n} from \"react\";\nimport type { InputProps, InputRef, WithPassword, WithTextArea } from \"./Input.types\";\nimport { InputPassword } from \"./components/InputPassword/InputPassword\";\nimport { InputTextArea } from \"./components/InputTextArea/InputTextArea\";\nimport { useMergedState } from \"./hooks/useMergeState\";\nimport { isString } from \"lodash-es\";\nimport { CloseCircleFilled } from \"@infomaximum/icons\";\nimport { emptyString } from \"utils\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  addonWrapperStyle,\n  affixedInputStyle,\n  getAddonStyle,\n  getAffixWrapperStyle,\n  getBaseInputStyle,\n  getClearIconWrapperStyle,\n  getSharedInputStyle,\n  inputGroupClassName,\n  nonStringAddonStyle,\n  prefixStyle,\n  prefixSuffixStyle,\n  suffixStyle,\n} from \"./Input.styles\";\nimport { getInputTokens } from \"./Input.tokens\";\nimport { useRemovePasswordTimeout } from \"./hooks/useRemovePasswordTimeout\";\nimport { resolveOnChange } from \"./utils/resolveOnChange\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputComponent = forwardRef<InputRef, InputProps>((props, ref) => {\n  const {\n    type = \"text\",\n    disabled,\n    readOnly,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    allowClear,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    defaultValue,\n    value: valueProp,\n    className,\n    style,\n    onChange,\n    onClear,\n    onFocus,\n    onBlur: onBlurProp,\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputTokens = getInputTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const affixWrapperRef = useRef<HTMLSpanElement>(null);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasAffix = Boolean(prefixProp) || Boolean(suffixProp) || allowClear;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AffixWrapper = hasAffix ? \"span\" : Fragment;\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { removePasswordTimeout } = useRemovePasswordTimeout({\n    inputRef,\n    type,\n  });\n  const { onKeyDown, onKeyUp, onBlur } = useKeyboardEvents({\n    onPressEnter,\n    onKeyDown: onKeyDownProp,\n    onKeyUp: onKeyUpProp,\n    onBlur: onBlurProp,\n    disabled,\n  });\n\n  useImperativeHandle(ref, () => ({\n    focus: (options) => {\n      inputRef.current?.focus(options);\n    },\n    blur: () => {\n      inputRef.current?.blur();\n    },\n    setSelectionRange: (start, end, direction) => {\n      inputRef.current?.setSelectionRange(start, end, direction);\n    },\n    select: () => {\n      inputRef.current?.select();\n    },\n    input: inputRef.current,\n  }));\n\n  const [value, setValue] = useMergedState(defaultValue, {\n    value: valueProp,\n  });\n  const formattedValue = value === undefined || value === null ? emptyString : value;\n\n  const handleClearIconWrapperClick: MouseEventHandler<HTMLButtonElement> = (e) => {\n    handleReset(e);\n    onClear?.();\n  };\n\n  const handleReset: MouseEventHandler<HTMLButtonElement> = (e) => {\n    setValue(emptyString);\n    resolveOnChange(inputRef.current, e, onChange);\n  };\n\n  const handleAffixWrapperClick: MouseEventHandler<HTMLSpanElement> = (e) => {\n    if (e.target instanceof Node && affixWrapperRef.current?.contains(e.target)) {\n      inputRef.current?.focus();\n    }\n  };\n\n  const handleFocus: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onFocus?.(e);\n  };\n\n  const handleBlur: FocusEventHandler<HTMLInputElement> = (e) => {\n    removePasswordTimeout();\n    onBlur(e);\n  };\n\n  const handleChange: ChangeEventHandler<HTMLInputElement> = (e) => {\n    setValue(e.target.value);\n    removePasswordTimeout();\n    resolveOnChange(inputRef.current, e, onChange, e.target.value);\n  };\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span css={[prefixStyle(theme), isString(prefixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span css={[suffixStyle(theme), isString(suffixProp) ? {} : prefixSuffixStyle(theme)]}>\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const clearIcon = (() => {\n    if (!allowClear) {\n      return;\n    }\n\n    const needClear = !disabled && !readOnly && Boolean(formattedValue);\n\n    return (\n      <button\n        type=\"button\"\n        tabIndex={-1}\n        onClick={handleClearIconWrapperClick}\n        // Do not trigger onBlur when clear input\n        // https://github.com/ant-design/ant-design/issues/31200\n        onMouseDown={(e) => e.preventDefault()}\n        css={getClearIconWrapperStyle(needClear)(theme)}\n      >\n        <CloseCircleFilled />\n      </button>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonBeforeProp}\n      </span>\n    );\n  })();\n\n  const addonAfter = (() => {\n    if (!addonAfterProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: className ? `${inputGroupClassName} ${className}` : inputGroupClassName,\n            css: addonWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <AffixWrapper\n        {...(hasAffix\n          ? {\n              [\"data-error-status\"]: errorStatus ? true : undefined,\n              ref: affixWrapperRef,\n              css: getAffixWrapperStyle(inputTokens, errorStatus, disabled)(theme),\n              onClick: handleAffixWrapperClick,\n              className: hasAddon ? undefined : className,\n              style: hasAddon ? undefined : style,\n            }\n          : {})}\n      >\n        {prefix}\n        <input\n          {...restProps}\n          data-error-status={!hasAffix && errorStatus ? true : undefined}\n          ref={inputRef}\n          className={hasAddon || hasAffix ? undefined : className}\n          style={hasAddon || hasAffix ? undefined : style}\n          type={type}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={formattedValue}\n          onChange={handleChange}\n          onFocus={handleFocus}\n          onBlur={handleBlur}\n          onKeyDown={onKeyDown}\n          onKeyUp={onKeyUp}\n          css={[\n            hasAffix\n              ? affixedInputStyle\n              : getSharedInputStyle(inputTokens, errorStatus, disabled, theme),\n            getBaseInputStyle(inputTokens, disabled),\n          ]}\n        />\n        {clearIcon}\n        {suffix}\n      </AffixWrapper>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const Input = memo(InputComponent) as MemoExoticComponent<\n  ForwardRefExoticComponent<InputProps & RefAttributes<InputRef>>\n> &\n  WithPassword &\n  WithTextArea;\n\nInput.Password = InputPassword;\nInput.TextArea = InputTextArea;\n"]} */"] }),
|
|
152
177
|
clearIcon,
|
|
153
178
|
suffix
|
|
154
179
|
] }),
|
|
@@ -6,12 +6,18 @@ export declare const prefixStyle: (theme: Theme) => {
|
|
|
6
6
|
display: string;
|
|
7
7
|
alignItems: string;
|
|
8
8
|
flex: string;
|
|
9
|
+
">:not(:last-child)": {
|
|
10
|
+
marginRight: 8;
|
|
11
|
+
};
|
|
9
12
|
};
|
|
10
13
|
export declare const suffixStyle: (theme: Theme) => {
|
|
11
14
|
marginLeft: 8;
|
|
12
15
|
display: string;
|
|
13
16
|
alignItems: string;
|
|
14
17
|
flex: string;
|
|
18
|
+
">:not(:last-child)": {
|
|
19
|
+
marginRight: 8;
|
|
20
|
+
};
|
|
15
21
|
};
|
|
16
22
|
export declare const prefixSuffixStyle: (theme: Theme) => {
|
|
17
23
|
fontSize: 16;
|
|
@@ -160,6 +166,7 @@ export declare const getAffixWrapperStyle: (inputTokens: InputTokens, errorStatu
|
|
|
160
166
|
paddingInline: number;
|
|
161
167
|
paddingBlock: number;
|
|
162
168
|
display: string;
|
|
169
|
+
verticalAlign: string;
|
|
163
170
|
};
|
|
164
171
|
export declare const affixedInputStyle: {
|
|
165
172
|
padding: number;
|
|
@@ -1,15 +1,18 @@
|
|
|
1
1
|
const inputGroupClassName = "input-group";
|
|
2
|
-
const commonAffixStyle = {
|
|
2
|
+
const commonAffixStyle = (theme) => ({
|
|
3
3
|
display: "flex",
|
|
4
4
|
alignItems: "center",
|
|
5
|
-
flex: "none"
|
|
6
|
-
|
|
5
|
+
flex: "none",
|
|
6
|
+
">:not(:last-child)": {
|
|
7
|
+
marginRight: theme.marginM
|
|
8
|
+
}
|
|
9
|
+
});
|
|
7
10
|
const prefixStyle = (theme) => ({
|
|
8
|
-
...commonAffixStyle,
|
|
11
|
+
...commonAffixStyle(theme),
|
|
9
12
|
marginRight: theme.marginXS
|
|
10
13
|
});
|
|
11
14
|
const suffixStyle = (theme) => ({
|
|
12
|
-
...commonAffixStyle,
|
|
15
|
+
...commonAffixStyle(theme),
|
|
13
16
|
marginLeft: theme.marginM
|
|
14
17
|
});
|
|
15
18
|
const prefixSuffixStyle = (theme) => ({
|
|
@@ -98,6 +101,7 @@ const getSharedInputStyle = (inputTokens, errorStatus, disabled, theme) => ({
|
|
|
98
101
|
});
|
|
99
102
|
const getAffixWrapperStyle = (inputTokens, errorStatus, disabled) => (theme) => ({
|
|
100
103
|
display: "inline-flex",
|
|
104
|
+
verticalAlign: "middle",
|
|
101
105
|
...getSharedInputStyle(inputTokens, errorStatus, disabled, theme)
|
|
102
106
|
});
|
|
103
107
|
const affixedInputStyle = {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
export interface InputProps extends Pick<InputHTMLAttributes<HTMLInputElement>, "autoFocus" | "placeholder" | "disabled" | "readOnly" | "type" | "name" | "defaultValue" | "value" | "onChange" | "maxLength" | "id" | "style" | "onFocus" | "onBlur" | "onKeyDown" | "onKeyUp"> {
|
|
1
|
+
import { InputHTMLAttributes, KeyboardEventHandler, ReactNode, RefObject } from 'react';
|
|
2
|
+
import { InputPassword } from './components/InputPassword/InputPassword';
|
|
3
|
+
import { InputTextArea } from './components/InputTextArea/InputTextArea';
|
|
4
|
+
export interface InputProps extends Pick<InputHTMLAttributes<HTMLInputElement>, "autoFocus" | "placeholder" | "required" | "disabled" | "readOnly" | "type" | "name" | "defaultValue" | "value" | "onChange" | "maxLength" | "spellCheck" | "id" | "style" | "className" | "autoComplete" | "onFocus" | "onBlur" | "onKeyDown" | "onKeyUp" | "onClick" | "onInput" | "onSelect"> {
|
|
5
5
|
prefix?: ReactNode;
|
|
6
6
|
suffix?: ReactNode;
|
|
7
7
|
allowClear?: boolean;
|
|
@@ -12,8 +12,18 @@ export interface InputProps extends Pick<InputHTMLAttributes<HTMLInputElement>,
|
|
|
12
12
|
onPressEnter?: KeyboardEventHandler<HTMLInputElement>;
|
|
13
13
|
}
|
|
14
14
|
export interface WithPassword {
|
|
15
|
-
Password:
|
|
15
|
+
Password: typeof InputPassword;
|
|
16
16
|
}
|
|
17
17
|
export interface WithTextArea {
|
|
18
|
-
TextArea:
|
|
18
|
+
TextArea: typeof InputTextArea;
|
|
19
19
|
}
|
|
20
|
+
type CurrentRefInput = RefObject<HTMLInputElement>["current"];
|
|
21
|
+
type Input = NonNullable<CurrentRefInput>;
|
|
22
|
+
export interface InputRef {
|
|
23
|
+
focus: Input["focus"];
|
|
24
|
+
blur: Input["blur"];
|
|
25
|
+
setSelectionRange: Input["setSelectionRange"];
|
|
26
|
+
select: Input["select"];
|
|
27
|
+
input: CurrentRefInput;
|
|
28
|
+
}
|
|
29
|
+
export {};
|
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { InputPasswordProps } from './InputPassword.types';
|
|
2
|
-
|
|
2
|
+
import { InputRef } from '../../Input.types';
|
|
3
|
+
export declare const InputPassword: import('react').MemoExoticComponent<import('react').ForwardRefExoticComponent<InputPasswordProps & import('react').RefAttributes<InputRef>>>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { InputTextAreaProps } from './InputTextArea.types';
|
|
2
|
-
export declare const InputTextArea: import('react').MemoExoticComponent<import('react').ForwardRefExoticComponent<InputTextAreaProps & import('react').RefAttributes<
|
|
1
|
+
import { InputTextAreaProps, TextAreaRef } from './InputTextArea.types';
|
|
2
|
+
export declare const InputTextArea: import('react').MemoExoticComponent<import('react').ForwardRefExoticComponent<InputTextAreaProps & import('react').RefAttributes<TextAreaRef>>>;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import { forwardRef, useRef, useState, useEffect, useMemo, useLayoutEffect, memo } from "react";
|
|
2
|
+
import { forwardRef, useRef, useContext, useImperativeHandle, useState, useEffect, useMemo, useLayoutEffect, memo } from "react";
|
|
3
3
|
import calculateAutoSizeStyle from "./InputTextArea.utils.js";
|
|
4
4
|
import { getTextareaStyle } from "./InputTextArea.styles.js";
|
|
5
5
|
import { getInputTokens } from "../../Input.tokens.js";
|
|
6
|
-
import {
|
|
6
|
+
import { FormItemContext } from "../../../Form/components/FormItem/contexts/FormItemContext.js";
|
|
7
7
|
import { useTheme } from "../../../../hooks/useTheme/useTheme.js";
|
|
8
8
|
import { useMergedState } from "../../hooks/useMergeState/useMergeState.js";
|
|
9
9
|
const RESIZE_START = 0;
|
|
@@ -13,19 +13,35 @@ const InputTextAreaComponent = forwardRef((props, ref) => {
|
|
|
13
13
|
const {
|
|
14
14
|
defaultValue,
|
|
15
15
|
value: valueProp,
|
|
16
|
-
status,
|
|
16
|
+
status: statusProp,
|
|
17
17
|
disabled,
|
|
18
18
|
autoSize,
|
|
19
19
|
style,
|
|
20
20
|
onChange,
|
|
21
|
+
onPressEnter,
|
|
22
|
+
onKeyDown,
|
|
21
23
|
...restProps
|
|
22
24
|
} = props;
|
|
23
25
|
const theme = useTheme();
|
|
24
26
|
const inputTokens = getInputTokens(theme);
|
|
25
27
|
const textAreaRef = useRef(null);
|
|
26
|
-
const
|
|
28
|
+
const {
|
|
29
|
+
status: contextStatus
|
|
30
|
+
} = useContext(FormItemContext);
|
|
31
|
+
const status = statusProp || contextStatus;
|
|
27
32
|
const errorStatus = status === "error";
|
|
28
33
|
const needAutoSize = !!autoSize;
|
|
34
|
+
useImperativeHandle(ref, () => ({
|
|
35
|
+
focus: (options) => {
|
|
36
|
+
var _a;
|
|
37
|
+
(_a = textAreaRef.current) == null ? void 0 : _a.focus(options);
|
|
38
|
+
},
|
|
39
|
+
blur: () => {
|
|
40
|
+
var _a;
|
|
41
|
+
(_a = textAreaRef.current) == null ? void 0 : _a.blur();
|
|
42
|
+
},
|
|
43
|
+
textArea: textAreaRef.current
|
|
44
|
+
}));
|
|
29
45
|
const [value, setValue] = useMergedState(defaultValue, {
|
|
30
46
|
value: valueProp
|
|
31
47
|
});
|
|
@@ -72,6 +88,12 @@ const InputTextAreaComponent = forwardRef((props, ref) => {
|
|
|
72
88
|
setValue(e.target.value);
|
|
73
89
|
onChange == null ? void 0 : onChange(e);
|
|
74
90
|
};
|
|
91
|
+
const handleKeyDown = (e) => {
|
|
92
|
+
if (e.key === "Enter" && onPressEnter) {
|
|
93
|
+
onPressEnter(e);
|
|
94
|
+
}
|
|
95
|
+
onKeyDown == null ? void 0 : onKeyDown(e);
|
|
96
|
+
};
|
|
75
97
|
const mergedAutoSizeStyle = needAutoSize ? autoSizeStyle : null;
|
|
76
98
|
const mergedStyle = {
|
|
77
99
|
...style,
|
|
@@ -81,7 +103,7 @@ const InputTextAreaComponent = forwardRef((props, ref) => {
|
|
|
81
103
|
mergedStyle.overflowY = "hidden";
|
|
82
104
|
mergedStyle.overflowX = "hidden";
|
|
83
105
|
}
|
|
84
|
-
return /* @__PURE__ */ jsx("textarea", { ...restProps, ref:
|
|
106
|
+
return /* @__PURE__ */ jsx("textarea", { ...restProps, ref: textAreaRef, style: mergedStyle, value, disabled, onChange: handleChange, onKeyDown: handleKeyDown, css: getTextareaStyle(inputTokens, errorStatus, disabled)(theme) });
|
|
85
107
|
});
|
|
86
108
|
const InputTextArea = memo(InputTextAreaComponent);
|
|
87
109
|
export {
|
|
@@ -1,10 +1,18 @@
|
|
|
1
|
-
import { TextareaHTMLAttributes } from 'react';
|
|
1
|
+
import { KeyboardEventHandler, RefObject, TextareaHTMLAttributes } from 'react';
|
|
2
2
|
interface AutoSizeType {
|
|
3
3
|
minRows?: number;
|
|
4
4
|
maxRows?: number;
|
|
5
5
|
}
|
|
6
|
-
export interface InputTextAreaProps extends Pick<TextareaHTMLAttributes<HTMLTextAreaElement>, "id" | "name" | "autoFocus" | "placeholder" | "cols" | "rows" | "maxLength" | "disabled" | "readOnly" | "defaultValue" | "value" | "style" | "onChange" | "onBlur" | "onFocus"> {
|
|
6
|
+
export interface InputTextAreaProps extends Pick<TextareaHTMLAttributes<HTMLTextAreaElement>, "id" | "name" | "autoFocus" | "placeholder" | "cols" | "rows" | "maxLength" | "disabled" | "readOnly" | "defaultValue" | "value" | "style" | "className" | "onChange" | "onBlur" | "onFocus" | "onInput" | "onKeyDown"> {
|
|
7
7
|
status?: "error";
|
|
8
8
|
autoSize?: boolean | AutoSizeType;
|
|
9
|
+
onPressEnter?: KeyboardEventHandler<HTMLTextAreaElement>;
|
|
10
|
+
}
|
|
11
|
+
type CurrentRefTextArea = RefObject<HTMLTextAreaElement>["current"];
|
|
12
|
+
type TextArea = NonNullable<CurrentRefTextArea>;
|
|
13
|
+
export interface TextAreaRef {
|
|
14
|
+
focus: TextArea["focus"];
|
|
15
|
+
blur: TextArea["blur"];
|
|
16
|
+
textArea: CurrentRefTextArea;
|
|
9
17
|
}
|
|
10
18
|
export {};
|
|
@@ -1,2 +1,4 @@
|
|
|
1
1
|
export { Input } from './Input';
|
|
2
|
-
export type { InputProps } from './Input.types';
|
|
2
|
+
export type { InputProps, InputRef } from './Input.types';
|
|
3
|
+
export type { InputTextAreaProps as TextAreaProps, TextAreaRef, } from './components/InputTextArea/InputTextArea.types';
|
|
4
|
+
export type { InputPasswordProps as PasswordProps } from './components/InputPassword/InputPassword.types';
|
|
@@ -3,7 +3,7 @@ import { BaseTooltipProps } from '../BaseTooltip/BaseTooltip.types';
|
|
|
3
3
|
import { ButtonProps } from 'components/Button';
|
|
4
4
|
import { MouseEvent, ReactNode } from 'react';
|
|
5
5
|
import { Theme } from '../../themes';
|
|
6
|
-
export interface PopconfirmProps extends Omit<BaseTooltipProps, "floatingElement" | "arrowColor"> {
|
|
6
|
+
export interface PopconfirmProps extends Omit<BaseTooltipProps, "floatingElement" | "arrowColor" | "styles"> {
|
|
7
7
|
okButtonProps?: ButtonProps;
|
|
8
8
|
okText?: ReactNode;
|
|
9
9
|
cancelButtonProps?: ButtonProps;
|
|
@@ -2,7 +2,7 @@ import { Interpolation } from '@emotion/react';
|
|
|
2
2
|
import { BaseTooltipProps, BaseTooltipTriggerType } from '../BaseTooltip/BaseTooltip.types';
|
|
3
3
|
import { ReactNode } from 'react';
|
|
4
4
|
import { Theme } from '../../themes';
|
|
5
|
-
export interface PopoverProps extends Omit<BaseTooltipProps, "floatingElement" | "arrowColor" | "trigger"> {
|
|
5
|
+
export interface PopoverProps extends Omit<BaseTooltipProps, "floatingElement" | "arrowColor" | "trigger" | "styles"> {
|
|
6
6
|
title?: ReactNode | (() => ReactNode);
|
|
7
7
|
content?: ReactNode | (() => ReactNode);
|
|
8
8
|
trigger?: Exclude<BaseTooltipTriggerType, "contextMenu">;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
const getTabKeysWithoutOrdering = (items) => items.map((item) => item.key);
|
|
2
|
+
const getOrderedTabKeys = (currentOrderedTabKeys, newTabKeys) => {
|
|
3
|
+
const updatedPrev = currentOrderedTabKeys.reduce((acc, key) => {
|
|
4
|
+
return newTabKeys.includes(key) ? [...acc, key] : acc;
|
|
5
|
+
}, []);
|
|
6
|
+
const uniqueKeys = /* @__PURE__ */ new Set([...updatedPrev, ...newTabKeys]);
|
|
7
|
+
return Array.from(uniqueKeys);
|
|
8
|
+
};
|
|
9
|
+
export {
|
|
10
|
+
getOrderedTabKeys,
|
|
11
|
+
getTabKeysWithoutOrdering
|
|
12
|
+
};
|