@1money/react-ui 1.7.0 → 1.7.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.
@@ -20,6 +20,8 @@ export var InputAmount = function InputAmount(props) {
20
20
  wrapperCls = props.wrapperCls,
21
21
  _props$prefixCls = props.prefixCls,
22
22
  prefixCls = _props$prefixCls === void 0 ? 'input-amount' : _props$prefixCls,
23
+ messageCls = props.messageCls,
24
+ footnoteCls = props.footnoteCls,
23
25
  invalid = props.invalid,
24
26
  _props$placeholder = props.placeholder,
25
27
  placeholder = _props$placeholder === void 0 ? '0' : _props$placeholder,
@@ -29,10 +31,15 @@ export var InputAmount = function InputAmount(props) {
29
31
  message = props.message,
30
32
  footnote = props.footnote,
31
33
  onChange = props.onChange,
32
- rest = __rest(props, ["value", "children", "className", "wrapperCls", "prefixCls", "invalid", "placeholder", "prefix", "currency", "suffix", "message", "footnote", "onChange"]);
34
+ _onClick = props.onClick,
35
+ rest = __rest(props, ["value", "children", "className", "wrapperCls", "prefixCls", "messageCls", "footnoteCls", "invalid", "placeholder", "prefix", "currency", "suffix", "message", "footnote", "onChange", "onClick"]);
33
36
  var classes = classnames(prefixCls);
34
37
  var inputRef = useRef(null);
35
38
  var fakeEleRef = useRef(null);
39
+ var prefixRef = useRef(null);
40
+ var suffixRef = useRef(null);
41
+ var currencyRef = useRef(null);
42
+ var containerRef = useRef(null);
36
43
  var _useState = useState(null),
37
44
  _useState2 = _slicedToArray(_useState, 2),
38
45
  _value = _useState2[0],
@@ -41,6 +48,10 @@ export var InputAmount = function InputAmount(props) {
41
48
  _useState4 = _slicedToArray(_useState3, 2),
42
49
  _width = _useState4[0],
43
50
  setWidth = _useState4[1];
51
+ var _useState5 = useState(false),
52
+ _useState6 = _slicedToArray(_useState5, 2),
53
+ isMaxWidth = _useState6[0],
54
+ setIsMaxWidth = _useState6[1];
44
55
  var handleChange = useCallback(function (e) {
45
56
  setValue(e.value);
46
57
  onChange === null || onChange === void 0 ? void 0 : onChange(e);
@@ -67,8 +78,16 @@ export var InputAmount = function InputAmount(props) {
67
78
  }
68
79
  }, [_value]);
69
80
  useEffect(function () {
70
- var _a;
71
- setWidth(((_a = fakeEleRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || MIN_INPUT_WIDTH);
81
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
82
+ var containerWidth = (_b = (_a = containerRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) !== null && _b !== void 0 ? _b : MIN_INPUT_WIDTH;
83
+ var prefixWidth = (_d = (_c = prefixRef.current) === null || _c === void 0 ? void 0 : _c.offsetWidth) !== null && _d !== void 0 ? _d : 0;
84
+ var suffixWidth = (_f = (_e = suffixRef.current) === null || _e === void 0 ? void 0 : _e.offsetWidth) !== null && _f !== void 0 ? _f : 0;
85
+ var currencyWidth = (_h = (_g = currencyRef.current) === null || _g === void 0 ? void 0 : _g.offsetWidth) !== null && _h !== void 0 ? _h : 0;
86
+ var fakeWidth = (_k = (_j = fakeEleRef.current) === null || _j === void 0 ? void 0 : _j.offsetWidth) !== null && _k !== void 0 ? _k : 0;
87
+ var gapWidth = prefixWidth && suffixWidth && currencyWidth ? 24 : prefixWidth && suffixWidth || prefixWidth && currencyWidth || suffixWidth && currencyWidth ? 16 : prefixWidth || suffixWidth || currencyWidth ? 8 : 0;
88
+ var maxWidth = containerWidth - prefixWidth - suffixWidth - currencyWidth - gapWidth;
89
+ setWidth(Math.min(maxWidth, Math.max(fakeWidth, MIN_INPUT_WIDTH)));
90
+ setIsMaxWidth(fakeWidth >= maxWidth);
72
91
  }, [_value]);
73
92
  useEffect(function () {
74
93
  return setValue(value !== null && value !== void 0 ? value : null);
@@ -76,8 +95,10 @@ export var InputAmount = function InputAmount(props) {
76
95
  return _jsxs("div", {
77
96
  className: classes('wrapper', [wrapperCls, invalid ? classes('invalid') : undefined].join(' ').trim()),
78
97
  children: [_jsxs("div", {
98
+ ref: containerRef,
79
99
  className: classes(void 0, className),
80
100
  children: [prefix && _jsx("span", {
101
+ ref: prefixRef,
81
102
  className: classes('prefix'),
82
103
  onClick: function onClick() {
83
104
  var _a;
@@ -89,13 +110,31 @@ export var InputAmount = function InputAmount(props) {
89
110
  ref: inputRef,
90
111
  value: value,
91
112
  placeholder: placeholder,
92
- className: classes('element'),
113
+ className: classes('element', isMaxWidth ? classes('element-max') : ''),
93
114
  onChange: handleChange,
94
115
  onKeyDown: handleKeyDown,
95
116
  style: {
96
117
  '--input-width': "".concat(_width, "px")
118
+ },
119
+ onClick: function onClick(e) {
120
+ var _a, _b;
121
+ var target = e.target;
122
+ if (!(target instanceof HTMLInputElement)) {
123
+ var input = (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.getInput();
124
+ if (!input) return;
125
+ // @ts-expect-error
126
+ var len = (_b = input.value) === null || _b === void 0 ? void 0 : _b.length;
127
+ // @ts-expect-error
128
+ input.setSelectionRange(len, len);
129
+ // @ts-expect-error
130
+ input.scrollLeft = input.scrollWidth;
131
+ // @ts-expect-error
132
+ input.focus();
133
+ }
134
+ _onClick === null || _onClick === void 0 ? void 0 : _onClick(e);
97
135
  }
98
136
  })), currency && _jsx("span", {
137
+ ref: currencyRef,
99
138
  className: classes('currency'),
100
139
  onClick: function onClick() {
101
140
  var _a;
@@ -103,6 +142,7 @@ export var InputAmount = function InputAmount(props) {
103
142
  },
104
143
  children: currency
105
144
  }), suffix && _jsx("span", {
145
+ ref: suffixRef,
106
146
  className: classes('suffix'),
107
147
  children: suffix
108
148
  }), _jsx("span", {
@@ -117,15 +157,15 @@ export var InputAmount = function InputAmount(props) {
117
157
  })]
118
158
  }), (message || footnote) && _jsxs("div", {
119
159
  className: classes('extra'),
120
- children: [message && _jsx("span", {
121
- className: classes('message'),
160
+ children: [message && _jsx("div", {
161
+ className: classes('message', messageCls),
122
162
  children: message
123
- }), footnote && _jsx("span", {
124
- className: classes('footnote'),
163
+ }), footnote && _jsx("div", {
164
+ className: classes('footnote', footnoteCls),
125
165
  children: footnote
126
166
  })]
127
167
  })]
128
168
  });
129
169
  };
130
170
  export default /*#__PURE__*/memo(InputAmount);
131
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/InputAmount/InputAmount.js","components/src/components/InputAmount/InputAmount.tsx"],"names":["__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","jsx","_jsx","jsxs","_jsxs","memo","useState","useCallback","useRef","useEffect","InputNumber","numericFormatter","classnames","MIN_INPUT_WIDTH","InputAmount","props","value","children","className","wrapperCls","_props$prefixCls","prefixCls","invalid","_props$placeholder","placeholder","prefix","currency","suffix","message","footnote","onChange","rest","classes","inputRef","fakeEleRef","_useState","_useState2","_slicedToArray","_value","setValue","_useState3","_useState4","_width","setWidth","handleChange","handleKeyDown","key","prev","concat","str","toString","setTimeout","slice","_a","current","offsetWidth","undefined","join","trim","onClick","focus","assign","mode","ref","onKeyDown","style","stopPropagation","thousandSeparator"],"mappings":"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","file":"components/InputAmount/InputAmount.js","sourcesContent":["var __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { memo, useState, useCallback, useRef, useEffect } from 'react';\nimport { InputNumber } from 'primereact/inputnumber';\nimport { numericFormatter } from 'react-number-format';\nimport classnames from '../../utils/classnames';\nconst MIN_INPUT_WIDTH = 33;\nexport const InputAmount = props => {\n    const { value, children, className, wrapperCls, prefixCls = 'input-amount', invalid, placeholder = '0', prefix, currency, suffix, message, footnote, onChange } = props, rest = __rest(props, [\"value\", \"children\", \"className\", \"wrapperCls\", \"prefixCls\", \"invalid\", \"placeholder\", \"prefix\", \"currency\", \"suffix\", \"message\", \"footnote\", \"onChange\"]);\n    const classes = classnames(prefixCls);\n    const inputRef = useRef(null);\n    const fakeEleRef = useRef(null);\n    const [_value, setValue] = useState(null);\n    const [_width, setWidth] = useState(MIN_INPUT_WIDTH);\n    const handleChange = useCallback((e) => {\n        setValue(e.value);\n        onChange === null || onChange === void 0 ? void 0 : onChange(e);\n    }, [onChange]);\n    const handleKeyDown = useCallback((e) => {\n        switch (e.key) {\n            case '.':\n                setValue(prev => `${prev}.`);\n                break;\n            case 'Backspace':\n                if (_value == null)\n                    return;\n                // eslint-disable-next-line no-case-declarations\n                const str = _value.toString();\n                if (str[str.length - 2] === '.') {\n                    setTimeout(() => {\n                        setValue(`${str.slice(0, -1)}`);\n                    }, 0);\n                }\n                break;\n            default:\n                break;\n        }\n    }, [_value]);\n    useEffect(() => {\n        var _a;\n        setWidth(((_a = fakeEleRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || MIN_INPUT_WIDTH);\n    }, [_value]);\n    useEffect(() => setValue(value !== null && value !== void 0 ? value : null), [value]);\n    return _jsxs(\"div\", { className: classes('wrapper', [wrapperCls, invalid ? classes('invalid') : undefined].join(' ').trim()), children: [_jsxs(\"div\", { className: classes(void 0, className), children: [prefix && _jsx(\"span\", { className: classes('prefix'), onClick: () => { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, children: prefix }), _jsx(InputNumber, Object.assign({}, rest, { mode: 'decimal', ref: inputRef, value: value, placeholder: placeholder, className: classes('element'), onChange: handleChange, onKeyDown: handleKeyDown, style: { '--input-width': `${_width}px` } })), currency && _jsx(\"span\", { className: classes('currency'), onClick: () => { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, children: currency }), suffix && _jsx(\"span\", { className: classes('suffix'), children: suffix }), _jsx(\"span\", { ref: fakeEleRef, className: classes('fake'), onClick: e => e.stopPropagation(), children: numericFormatter('' + (_value == null ? '' : _value), {\n                            thousandSeparator: true,\n                        }) })] }), (message || footnote) && _jsxs(\"div\", { className: classes('extra'), children: [message && _jsx(\"span\", { className: classes('message'), children: message }), footnote && _jsx(\"span\", { className: classes('footnote'), children: footnote })] })] });\n};\nexport default memo(InputAmount);",null],"sourceRoot":"../../../../../../../../../src"}
171
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/InputAmount/InputAmount.js","components/src/components/InputAmount/InputAmount.tsx"],"names":["__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","jsx","_jsx","jsxs","_jsxs","memo","useState","useCallback","useRef","useEffect","InputNumber","numericFormatter","classnames","MIN_INPUT_WIDTH","InputAmount","props","value","children","className","wrapperCls","_props$prefixCls","prefixCls","messageCls","footnoteCls","invalid","_props$placeholder","placeholder","prefix","currency","suffix","message","footnote","onChange","onClick","rest","classes","inputRef","fakeEleRef","prefixRef","suffixRef","currencyRef","containerRef","_useState","_useState2","_slicedToArray","_value","setValue","_useState3","_useState4","_width","setWidth","_useState5","_useState6","isMaxWidth","setIsMaxWidth","handleChange","handleKeyDown","key","prev","concat","str","toString","setTimeout","slice","_a","_b","_c","_d","_e","_f","_g","_h","_j","_k","containerWidth","current","offsetWidth","prefixWidth","suffixWidth","currencyWidth","fakeWidth","gapWidth","maxWidth","Math","min","max","undefined","join","trim","ref","focus","assign","mode","onKeyDown","style","target","HTMLInputElement","input","getInput","len","setSelectionRange","scrollLeft","scrollWidth","stopPropagation","thousandSeparator"],"mappings":"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","file":"components/InputAmount/InputAmount.js","sourcesContent":["var __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { memo, useState, useCallback, useRef, useEffect } from 'react';\nimport { InputNumber } from 'primereact/inputnumber';\nimport { numericFormatter } from 'react-number-format';\nimport classnames from '../../utils/classnames';\nconst MIN_INPUT_WIDTH = 33;\nexport const InputAmount = props => {\n    const { value, children, className, wrapperCls, prefixCls = 'input-amount', messageCls, footnoteCls, invalid, placeholder = '0', prefix, currency, suffix, message, footnote, onChange, onClick } = props, rest = __rest(props, [\"value\", \"children\", \"className\", \"wrapperCls\", \"prefixCls\", \"messageCls\", \"footnoteCls\", \"invalid\", \"placeholder\", \"prefix\", \"currency\", \"suffix\", \"message\", \"footnote\", \"onChange\", \"onClick\"]);\n    const classes = classnames(prefixCls);\n    const inputRef = useRef(null);\n    const fakeEleRef = useRef(null);\n    const prefixRef = useRef(null);\n    const suffixRef = useRef(null);\n    const currencyRef = useRef(null);\n    const containerRef = useRef(null);\n    const [_value, setValue] = useState(null);\n    const [_width, setWidth] = useState(MIN_INPUT_WIDTH);\n    const [isMaxWidth, setIsMaxWidth] = useState(false);\n    const handleChange = useCallback((e) => {\n        setValue(e.value);\n        onChange === null || onChange === void 0 ? void 0 : onChange(e);\n    }, [onChange]);\n    const handleKeyDown = useCallback((e) => {\n        switch (e.key) {\n            case '.':\n                setValue(prev => `${prev}.`);\n                break;\n            case 'Backspace':\n                if (_value == null)\n                    return;\n                // eslint-disable-next-line no-case-declarations\n                const str = _value.toString();\n                if (str[str.length - 2] === '.') {\n                    setTimeout(() => {\n                        setValue(`${str.slice(0, -1)}`);\n                    }, 0);\n                }\n                break;\n            default:\n                break;\n        }\n    }, [_value]);\n    useEffect(() => {\n        var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;\n        const containerWidth = (_b = (_a = containerRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) !== null && _b !== void 0 ? _b : MIN_INPUT_WIDTH;\n        const prefixWidth = (_d = (_c = prefixRef.current) === null || _c === void 0 ? void 0 : _c.offsetWidth) !== null && _d !== void 0 ? _d : 0;\n        const suffixWidth = (_f = (_e = suffixRef.current) === null || _e === void 0 ? void 0 : _e.offsetWidth) !== null && _f !== void 0 ? _f : 0;\n        const currencyWidth = (_h = (_g = currencyRef.current) === null || _g === void 0 ? void 0 : _g.offsetWidth) !== null && _h !== void 0 ? _h : 0;\n        const fakeWidth = (_k = (_j = fakeEleRef.current) === null || _j === void 0 ? void 0 : _j.offsetWidth) !== null && _k !== void 0 ? _k : 0;\n        const gapWidth = prefixWidth && suffixWidth && currencyWidth\n            ? 24\n            : (prefixWidth && suffixWidth) || (prefixWidth && currencyWidth) || (suffixWidth && currencyWidth)\n                ? 16\n                : prefixWidth || suffixWidth || currencyWidth\n                    ? 8\n                    : 0;\n        const maxWidth = containerWidth - prefixWidth - suffixWidth - currencyWidth - gapWidth;\n        setWidth(Math.min(maxWidth, Math.max(fakeWidth, MIN_INPUT_WIDTH)));\n        setIsMaxWidth(fakeWidth >= maxWidth);\n    }, [_value]);\n    useEffect(() => setValue(value !== null && value !== void 0 ? value : null), [value]);\n    return _jsxs(\"div\", { className: classes('wrapper', [wrapperCls, invalid ? classes('invalid') : undefined].join(' ').trim()), children: [_jsxs(\"div\", { ref: containerRef, className: classes(void 0, className), children: [prefix && _jsx(\"span\", { ref: prefixRef, className: classes('prefix'), onClick: () => { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, children: prefix }), _jsx(InputNumber, Object.assign({}, rest, { mode: 'decimal', ref: inputRef, value: value, placeholder: placeholder, className: classes('element', isMaxWidth ? classes('element-max') : ''), onChange: handleChange, onKeyDown: handleKeyDown, style: { '--input-width': `${_width}px` }, onClick: (e) => {\n                            var _a, _b;\n                            const target = e.target;\n                            if (!(target instanceof HTMLInputElement)) {\n                                const input = (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.getInput();\n                                if (!input)\n                                    return;\n                                // @ts-expect-error\n                                const len = (_b = input.value) === null || _b === void 0 ? void 0 : _b.length;\n                                // @ts-expect-error\n                                input.setSelectionRange(len, len);\n                                // @ts-expect-error\n                                input.scrollLeft = input.scrollWidth;\n                                // @ts-expect-error\n                                input.focus();\n                            }\n                            onClick === null || onClick === void 0 ? void 0 : onClick(e);\n                        } })), currency && _jsx(\"span\", { ref: currencyRef, className: classes('currency'), onClick: () => { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, children: currency }), suffix && _jsx(\"span\", { ref: suffixRef, className: classes('suffix'), children: suffix }), _jsx(\"span\", { ref: fakeEleRef, className: classes('fake'), onClick: e => e.stopPropagation(), children: numericFormatter('' + (_value == null ? '' : _value), {\n                            thousandSeparator: true,\n                        }) })] }), (message || footnote) && _jsxs(\"div\", { className: classes('extra'), children: [message && _jsx(\"div\", { className: classes('message', messageCls), children: message }), footnote && _jsx(\"div\", { className: classes('footnote', footnoteCls), children: footnote })] })] });\n};\nexport default memo(InputAmount);",null],"sourceRoot":"../../../../../../../../../src"}
@@ -5,6 +5,8 @@ export interface InputAmountProps extends Omit<InputNumberProps, 'prefix' | 'suf
5
5
  className?: string;
6
6
  prefixCls?: string;
7
7
  wrapperCls?: string;
8
+ messageCls?: string;
9
+ footnoteCls?: string;
8
10
  invalid?: boolean;
9
11
  prefix?: ReactNode;
10
12
  currency?: ReactNode;
@@ -1 +1 @@
1
- .om-react-ui-input-amount{display:inline-flex;gap:8px;align-items:center;justify-content:start;width:100%;padding-bottom:16px;border-bottom:1px solid #d1d2d2}.om-react-ui-input-amount-wrapper{display:inline-flex;flex-direction:column;gap:16px;width:100%}.om-react-ui-input-amount:has(.p-inputwrapper-focus:not(.p-invalid)){border-bottom-color:#073387}.om-react-ui-input-amount-element{display:inline-flex;flex-grow:0;color:#073387;font-weight:500;font-size:52px;font-family:var(--font-aeonik),Aeonik;line-height:56px;letter-spacing:-.25px}.om-react-ui-input-amount-element input{position:relative;width:var(--input-width);padding:0;color:inherit;font-weight:inherit;font-size:inherit;font-family:inherit;line-height:inherit;letter-spacing:inherit;border:none;border-radius:0;box-shadow:none}.om-react-ui-input-amount-element input::placeholder{color:inherit}.om-react-ui-input-amount-fake{position:absolute;top:0;left:-9999px;z-index:-1;display:inline-block;font-weight:500;font-size:52px;font-family:var(--font-aeonik),Aeonik;line-height:56px;letter-spacing:-.25px;white-space:pre;visibility:hidden;opacity:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;inset-block-start:0;inset-inline-start:0}.om-react-ui-input-amount-currency,.om-react-ui-input-amount-prefix,.om-react-ui-input-amount-suffix{display:inline-flex;flex-grow:0;flex-shrink:0;align-items:center}.om-react-ui-input-amount-prefix{color:#073387}.om-react-ui-input-amount-currency,.om-react-ui-input-amount-prefix{font-weight:500;font-size:52px;font-family:var(--font-aeonik),Aeonik;line-height:56px;letter-spacing:-.25px}.om-react-ui-input-amount-currency{color:#e3e4e4}.om-react-ui-input-amount-suffix{margin-left:auto}.om-react-ui-input-amount-extra{display:inline-flex;flex-direction:column;gap:16px}.om-react-ui-input-amount-message{color:#131313;font-weight:400;font-size:12px;font-family:var(--font-inter),Inter;line-height:140%}.om-react-ui-input-amount-footnote{color:#073387;font-weight:500;font-size:16px;font-family:var(--font-inter),Inter;line-height:140%}.om-react-ui-input-amount-invalid .om-react-ui-input-amount{border-bottom-color:#ae0000}.om-react-ui-input-amount-invalid .om-react-ui-input-amount-element,.om-react-ui-input-amount-invalid .om-react-ui-input-amount-message,.om-react-ui-input-amount-invalid .om-react-ui-input-amount-prefix{color:#ae0000}
1
+ .om-react-ui-input-amount{display:inline-flex;gap:8px;align-items:center;justify-content:start;width:100%;padding-bottom:16px;border-bottom:1px solid #d1d2d2}.om-react-ui-input-amount:has(.p-inputwrapper-focus:not(.p-invalid)){border-bottom-color:#073387}.om-react-ui-input-amount-element{position:relative;display:inline-flex;flex-grow:0;color:#073387;font-weight:500;font-size:52px;font-family:var(--font-aeonik),Aeonik;line-height:56px;letter-spacing:-.25px}.om-react-ui-input-amount-element input{position:relative;width:var(--input-width);max-width:100%;padding:0;color:inherit;font-weight:inherit;font-size:inherit;font-family:inherit;line-height:inherit;letter-spacing:inherit;border:none;border-radius:0;box-shadow:none}.om-react-ui-input-amount-element input::placeholder{color:inherit}.om-react-ui-input-amount-element-max:after{position:absolute;top:0;right:0;width:98px;height:100%;background:linear-gradient(90deg,hsla(0,0%,100%,0),hsla(0,0%,100%,.51) 37.98%,#fff 84.13%);cursor:text;content:""}.om-react-ui-input-amount-fake{position:absolute;top:0;left:-9999px;z-index:-1;display:inline-block;color:#073387;font-weight:500;font-size:52px;font-family:var(--font-aeonik),Aeonik;line-height:56px;letter-spacing:-.25px;white-space:pre;visibility:hidden;opacity:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;inset-block-start:0;inset-inline-start:0}.om-react-ui-input-amount-currency,.om-react-ui-input-amount-prefix,.om-react-ui-input-amount-suffix{display:inline-flex;flex-grow:0;flex-shrink:0;align-items:center}.om-react-ui-input-amount-prefix{color:#073387}.om-react-ui-input-amount-currency,.om-react-ui-input-amount-prefix{font-weight:500;font-size:52px;font-family:var(--font-aeonik),Aeonik;line-height:56px;letter-spacing:-.25px}.om-react-ui-input-amount-currency{color:#e3e4e4}.om-react-ui-input-amount-suffix{margin-left:auto}.om-react-ui-input-amount-extra{display:inline-flex;flex-direction:column;gap:16px}.om-react-ui-input-amount-message{color:#131313;font-weight:400;font-size:12px;font-family:var(--font-inter),Inter;line-height:140%}.om-react-ui-input-amount-footnote{text-align:left}.om-react-ui-input-amount-invalid .om-react-ui-input-amount{border-bottom-color:#ae0000}.om-react-ui-input-amount-invalid .om-react-ui-input-amount-element,.om-react-ui-input-amount-invalid .om-react-ui-input-amount-message,.om-react-ui-input-amount-invalid .om-react-ui-input-amount-prefix{color:#ae0000}.om-react-ui-input-amount-wrapper{display:inline-flex;flex-direction:column;gap:16px;width:100%}
@@ -3,39 +3,41 @@
3
3
  $component: 'input-amount';
4
4
  $cls: #{$prefix}-#{$component};
5
5
 
6
+ @mixin input-amount-font($color: $color-primary) {
7
+ color: $color;
8
+ font-weight: 500;
9
+ font-size: 52px;
10
+ font-family: var(--font-aeonik), Aeonik;
11
+ line-height: 56px;
12
+ letter-spacing: -0.25px;
13
+ }
14
+
6
15
  .#{$cls} {
7
- &-wrapper {
16
+ & {
8
17
  display: inline-flex;
9
- flex-direction: column;
10
- gap: 16px;
18
+ gap: 8px;
19
+ align-items: center;
20
+ justify-content: start;
11
21
  width: 100%;
22
+ padding-bottom: 16px;
23
+ border-bottom: 1px solid $color-grey-bold;
12
24
  }
13
25
 
14
- display: inline-flex;
15
- gap: 8px;
16
- align-items: center;
17
- justify-content: start;
18
- width: 100%;
19
- padding-bottom: 16px;
20
- border-bottom: 1px solid $color-grey-bold;
21
-
22
26
  &:has(.p-inputwrapper-focus:not(.p-invalid)) {
23
27
  border-bottom-color: $color-primary;
24
28
  }
25
29
 
26
30
  &-element {
31
+ position: relative;
27
32
  display: inline-flex;
28
33
  flex-grow: 0;
29
- color: $color-primary;
30
- font-weight: 500;
31
- font-size: 52px;
32
- font-family: var(--font-aeonik), Aeonik;
33
- line-height: 56px;
34
- letter-spacing: -0.25px;
34
+
35
+ @include input-amount-font;
35
36
 
36
37
  input {
37
38
  position: relative;
38
39
  width: var(--input-width);
40
+ max-width: 100%;
39
41
  padding: 0;
40
42
  color: inherit;
41
43
  font-weight: inherit;
@@ -51,6 +53,19 @@ $cls: #{$prefix}-#{$component};
51
53
  color: inherit;
52
54
  }
53
55
  }
56
+
57
+ &-max {
58
+ &::after {
59
+ position: absolute;
60
+ top: 0;
61
+ right: 0;
62
+ width: 98px;
63
+ height: 100%;
64
+ background: linear-gradient(90deg, rgba(254, 254, 254, 0%) 0%, rgba(255, 255, 255, 51%) 37.98%, #FFF 84.13%);
65
+ cursor: text;
66
+ content: '';
67
+ }
68
+ }
54
69
  }
55
70
 
56
71
  &-fake {
@@ -59,11 +74,9 @@ $cls: #{$prefix}-#{$component};
59
74
  left: -9999px;
60
75
  z-index: -1;
61
76
  display: inline-block;
62
- font-weight: 500;
63
- font-size: 52px;
64
- font-family: var(--font-aeonik), Aeonik;
65
- line-height: 56px;
66
- letter-spacing: -0.25px;
77
+
78
+ @include input-amount-font;
79
+
67
80
  white-space: pre;
68
81
  visibility: hidden;
69
82
  opacity: 0;
@@ -83,21 +96,11 @@ $cls: #{$prefix}-#{$component};
83
96
  }
84
97
 
85
98
  &-prefix {
86
- color: $color-primary;
87
- font-weight: 500;
88
- font-size: 52px;
89
- font-family: var(--font-aeonik), Aeonik;
90
- line-height: 56px;
91
- letter-spacing: -0.25px;
99
+ @include input-amount-font;
92
100
  }
93
101
 
94
102
  &-currency {
95
- color: $color-grey-deep;
96
- font-weight: 500;
97
- font-size: 52px;
98
- font-family: var(--font-aeonik), Aeonik;
99
- line-height: 56px;
100
- letter-spacing: -0.25px;
103
+ @include input-amount-font($color-grey-deep);
101
104
  }
102
105
 
103
106
  &-suffix {
@@ -119,11 +122,7 @@ $cls: #{$prefix}-#{$component};
119
122
  }
120
123
 
121
124
  &-footnote {
122
- color: $color-primary;
123
- font-weight: 500;
124
- font-size: 16px;
125
- font-family: var(--font-inter), Inter;
126
- line-height: 140%;
125
+ text-align: left;
127
126
  }
128
127
 
129
128
  &-invalid {
@@ -137,4 +136,11 @@ $cls: #{$prefix}-#{$component};
137
136
  color: $color-negative;
138
137
  }
139
138
  }
139
+ }
140
+
141
+ .#{$cls}-wrapper {
142
+ display: inline-flex;
143
+ flex-direction: column;
144
+ gap: 16px;
145
+ width: 100%;
140
146
  }