@infomaximum/ui-kit 0.14.5 → 0.14.6

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.
@@ -160,25 +160,25 @@ const InputNumberComponent = forwardRef((props, ref) => {
160
160
  if (!prefixProp) {
161
161
  return;
162
162
  }
163
- return /* @__PURE__ */ jsx("span", { css: [prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AAkJQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: prefixProp });
163
+ return /* @__PURE__ */ jsx("span", { css: [prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AAkJQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          role=\"spinbutton\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: prefixProp });
164
164
  })();
165
165
  const suffix = (() => {
166
166
  if (!suffixProp) {
167
167
  return;
168
168
  }
169
- return /* @__PURE__ */ jsx("span", { css: [suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AAgKQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: suffixProp });
169
+ return /* @__PURE__ */ jsx("span", { css: [suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AAgKQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          role=\"spinbutton\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: suffixProp });
170
170
  })();
171
171
  const addonBefore = (() => {
172
172
  if (!addonBeforeProp) {
173
173
  return;
174
174
  }
175
- return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputNumberTokens, disabled)(theme), isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AA8KQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: addonBeforeProp });
175
+ return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputNumberTokens, disabled)(theme), isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AA8KQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          role=\"spinbutton\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: addonBeforeProp });
176
176
  })();
177
177
  const addonAfter = (() => {
178
178
  if (!addonAfterProp) {
179
179
  return;
180
180
  }
181
- return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputNumberTokens, disabled)(theme), isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AA+LQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: addonAfterProp });
181
+ return /* @__PURE__ */ jsx("span", { css: [getAddonStyle(inputNumberTokens, disabled)(theme), isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AA+LQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          role=\"spinbutton\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: addonAfterProp });
182
182
  })();
183
183
  return /* @__PURE__ */ jsxs(AddonWrapper, { ...hasAddon ? {
184
184
  className: inputNumberWrapperClassName,
@@ -186,9 +186,9 @@ const InputNumberComponent = forwardRef((props, ref) => {
186
186
  style
187
187
  } : {}, children: [
188
188
  addonBefore,
189
- /* @__PURE__ */ jsxs("div", { ref: inputNumberRef, onClick: onInputNumberClick, className: inputNumberClassName, onFocus, onBlur, onKeyDown, onKeyUp, style: hasAddon ? void 0 : style, css: [getInputWrapperStyle(inputNumberTokens, disabled, hasAffix, hasSuffix, errorStatus, controls)(theme), (_a = styles == null ? void 0 : styles.inputNumber) == null ? void 0 : _a.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:InputNumberComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AA6NQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: [
189
+ /* @__PURE__ */ jsxs("div", { ref: inputNumberRef, onClick: onInputNumberClick, className: inputNumberClassName, onFocus, onBlur, onKeyDown, onKeyUp, style: hasAddon ? void 0 : style, css: [getInputWrapperStyle(inputNumberTokens, disabled, hasAffix, hasSuffix, errorStatus, controls)(theme), (_a = styles == null ? void 0 : styles.inputNumber) == null ? void 0 : _a.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:InputNumberComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx"],"names":[],"mappings":"AA6NQ","file":"/builds/frontend/libs/ui-kit/src/components/InputNumber/InputNumber.tsx","sourcesContent":["import { forwardRef, Fragment, memo, useContext, useRef, useState } from \"react\";\nimport type { InputNumberProps } from \"./InputNumber.types\";\nimport { StepController } from \"./components/StepController/StepController\";\nimport { isNull, isString } from \"lodash-es\";\nimport { getInputNumberTokens } from \"./InputNumber.tokens\";\nimport { useTheme } from \"hooks/useTheme\";\nimport {\n  getAddonStyle,\n  getInputStyle,\n  getInputWrapperStyle,\n  inputNumberClassName,\n  inputNumberWrapperClassName,\n  inputNumberWrapperStyle,\n  nonStringAddonStyle,\n  nonStringPrefixSuffixStyle,\n  prefixStyle,\n  suffixStyle,\n} from \"./InputNumber.styles\";\nimport { getMiniDecimal, type DecimalClass } from \"./utils\";\nimport { useMergeRefs } from \"@floating-ui/react\";\nimport { useStep } from \"./hooks/useStep\";\nimport { useKeyboardEvents } from \"./hooks/useKeyboardEvents\";\nimport { useWheelEvents } from \"./hooks/useWheelEvents\";\nimport { useFocusBlurEvents } from \"./hooks/useFocusBlurEvents\";\nimport { useRange } from \"./hooks/useRange\";\nimport { useDecimalTools } from \"./hooks/useDecimalTools\";\nimport { emptyString } from \"utils\";\nimport { useChangeValue } from \"./hooks/useChangeValue\";\nimport { FormItemContext } from \"../Form/components/FormItem/contexts/FormItemContext\";\n\nconst InputNumberComponent = forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => {\n  const {\n    style,\n    styles,\n    prefix: prefixProp,\n    suffix: suffixProp,\n    addonBefore: addonBeforeProp,\n    addonAfter: addonAfterProp,\n    status: statusProp,\n    min,\n    max,\n    step = 1,\n    controls = true,\n    keyboard = true,\n    changeOnWheel = false,\n    changeOnBlur = true,\n    stringMode = false,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    onChange: onChangeProp,\n    onInput,\n    onPressEnter,\n    onStep: onStepProp,\n    ...restProps\n  } = props;\n  const theme = useTheme();\n  const inputNumberTokens = getInputNumberTokens(theme);\n  const inputRef = useRef<HTMLInputElement>(null);\n  const mergedRef = useMergeRefs([inputRef, ref]);\n  const shiftKeyRef = useRef(false);\n  const inputValueRef = useRef<string | number | undefined>(emptyString);\n  const userTypingRef = useRef(false);\n  const { status: contextStatus } = useContext(FormItemContext);\n  const status = statusProp || contextStatus;\n  const errorStatus = status === \"error\";\n  const hasSuffix = Boolean(suffixProp);\n  const hasAffix = Boolean(prefixProp) || hasSuffix;\n  const hasAddon = Boolean(addonBeforeProp) || Boolean(addonAfterProp);\n  const AddonWrapper = hasAddon ? \"span\" : Fragment;\n  const { getPrecision, mergedParser, mergedFormatter } = useDecimalTools({\n    inputValueRef,\n    parser,\n    formatter,\n    precision,\n    decimalSeparator,\n    step,\n  });\n\n  const [decimalValue, setDecimalValue] = useState<DecimalClass>(() =>\n    getMiniDecimal(value ?? defaultValue)\n  );\n\n  const { outOfRange, maxDecimal, minDecimal, getRangeValue, isInRange } = useRange({\n    decimalValue,\n    max,\n    min,\n  });\n  const { inputValue, triggerValueUpdate, flushInputValue, onChange } = useChangeValue({\n    decimalValue,\n    getPrecision,\n    mergedParser,\n    mergedFormatter,\n    setDecimalValue,\n    getRangeValue,\n    isInRange,\n    inputValueRef,\n    userTypingRef,\n    defaultValue,\n    value,\n    disabled,\n    readOnly,\n    stringMode,\n    onInput,\n    onChange: onChangeProp,\n  });\n  const { onStep, upDisabled, downDisabled } = useStep({\n    decimalValue,\n    maxDecimal,\n    minDecimal,\n    step,\n    stringMode,\n    inputRef,\n    shiftKeyRef,\n    userTypingRef,\n    triggerValueUpdate,\n    onStep: onStepProp,\n  });\n  const { onKeyDown, onKeyUp } = useKeyboardEvents({\n    keyboard,\n    shiftKeyRef,\n    userTypingRef,\n    flushInputValue,\n    onStep,\n    onPressEnter,\n  });\n  const { focus, inputNumberRef, onFocus, onBlur, onInputNumberClick } = useFocusBlurEvents({\n    changeOnBlur,\n    inputRef,\n    userTypingRef,\n    flushInputValue,\n  });\n  useWheelEvents({ focus, changeOnWheel, inputRef, onStep });\n\n  const prefix = (() => {\n    if (!prefixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[prefixStyle(theme), isString(prefixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {prefixProp}\n      </span>\n    );\n  })();\n\n  const suffix = (() => {\n    if (!suffixProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[suffixStyle(theme), isString(suffixProp) ? {} : nonStringPrefixSuffixStyle(theme)]}\n      >\n        {suffixProp}\n      </span>\n    );\n  })();\n\n  const addonBefore = (() => {\n    if (!addonBeforeProp) {\n      return;\n    }\n\n    return (\n      <span\n        css={[\n          getAddonStyle(inputNumberTokens, disabled)(theme),\n          isString(addonBeforeProp) ? {} : nonStringAddonStyle(inputNumberTokens)(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(inputNumberTokens, disabled)(theme),\n          isString(addonAfterProp) ? {} : nonStringAddonStyle(inputNumberTokens)(theme),\n        ]}\n      >\n        {addonAfterProp}\n      </span>\n    );\n  })();\n\n  return (\n    <AddonWrapper\n      {...(hasAddon\n        ? {\n            className: inputNumberWrapperClassName,\n            css: inputNumberWrapperStyle,\n            style,\n          }\n        : {})}\n    >\n      {addonBefore}\n      <div\n        ref={inputNumberRef}\n        onClick={onInputNumberClick}\n        className={inputNumberClassName}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        onKeyDown={onKeyDown}\n        onKeyUp={onKeyUp}\n        style={hasAddon ? undefined : style}\n        css={[\n          getInputWrapperStyle(\n            inputNumberTokens,\n            disabled,\n            hasAffix,\n            hasSuffix,\n            errorStatus,\n            controls\n          )(theme),\n          styles?.inputNumber?.(theme),\n        ]}\n      >\n        {prefix}\n        <input\n          autoComplete=\"off\"\n          role=\"spinbutton\"\n          {...restProps}\n          ref={mergedRef}\n          aria-valuemin={min ? Number(min) : undefined}\n          aria-valuemax={max ? Number(max) : undefined}\n          step={step}\n          disabled={disabled}\n          readOnly={readOnly}\n          value={isNull(inputValue) ? undefined : inputValue}\n          onChange={onChange}\n          css={getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme)}\n        />\n        {suffix}\n        {controls && !disabled && (\n          <StepController upDisabled={upDisabled} downDisabled={downDisabled} onStep={onStep} />\n        )}\n      </div>\n      {addonAfter}\n    </AddonWrapper>\n  );\n});\n\nexport const InputNumber = memo(InputNumberComponent);\n"]} */"], children: [
190
190
  prefix,
191
- /* @__PURE__ */ jsx("input", { autoComplete: "off", ...restProps, ref: mergedRef, "aria-valuemin": min ? Number(min) : void 0, "aria-valuemax": max ? Number(max) : void 0, step, disabled, readOnly, value: isNull(inputValue) ? void 0 : inputValue, onChange, css: getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme) }),
191
+ /* @__PURE__ */ jsx("input", { autoComplete: "off", role: "spinbutton", ...restProps, ref: mergedRef, "aria-valuemin": min ? Number(min) : void 0, "aria-valuemax": max ? Number(max) : void 0, step, disabled, readOnly, value: isNull(inputValue) ? void 0 : inputValue, onChange, css: getInputStyle(inputNumberTokens, disabled, hasAffix, outOfRange)(theme) }),
192
192
  suffix,
193
193
  controls && !disabled && /* @__PURE__ */ jsx(StepController, { upDisabled, downDisabled, onStep })
194
194
  ] }),
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@infomaximum/ui-kit",
3
3
  "license": "Apache-2.0",
4
- "version": "0.14.5",
4
+ "version": "0.14.6",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
7
7
  "module": "dist/index.js",