@1money/react-ui 1.6.4 → 1.7.0

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.
Files changed (37) hide show
  1. package/es/components/Icons/Icons.d.ts +1 -0
  2. package/es/components/Icons/Icons.js +3 -2
  3. package/es/components/Icons/SVGs.d.ts +1 -0
  4. package/es/components/Icons/SVGs.js +8 -1
  5. package/es/components/InputAmount/InputAmount.d.ts +5 -0
  6. package/es/components/InputAmount/InputAmount.js +131 -0
  7. package/es/components/InputAmount/index.d.ts +4 -0
  8. package/es/components/InputAmount/index.js +5 -0
  9. package/es/components/InputAmount/interface.d.ts +14 -0
  10. package/es/components/InputAmount/interface.js +2 -0
  11. package/es/components/InputAmount/style/InputAmount.css +1 -0
  12. package/es/components/InputAmount/style/InputAmount.scss +140 -0
  13. package/es/components/InputAmount/style/css.js +2 -0
  14. package/es/components/InputAmount/style/index.d.ts +1 -0
  15. package/es/components/InputAmount/style/index.js +2 -0
  16. package/es/index.css +1 -1
  17. package/es/index.d.ts +2 -0
  18. package/es/index.js +4 -1
  19. package/lib/components/Icons/Icons.d.ts +1 -0
  20. package/lib/components/Icons/Icons.js +2 -1
  21. package/lib/components/Icons/SVGs.d.ts +1 -0
  22. package/lib/components/Icons/SVGs.js +10 -3
  23. package/lib/components/InputAmount/InputAmount.d.ts +5 -0
  24. package/lib/components/InputAmount/InputAmount.js +138 -0
  25. package/lib/components/InputAmount/index.d.ts +4 -0
  26. package/lib/components/InputAmount/index.js +33 -0
  27. package/lib/components/InputAmount/interface.d.ts +14 -0
  28. package/lib/components/InputAmount/interface.js +6 -0
  29. package/lib/components/InputAmount/style/InputAmount.css +1 -0
  30. package/lib/components/InputAmount/style/InputAmount.scss +140 -0
  31. package/lib/components/InputAmount/style/css.js +4 -0
  32. package/lib/components/InputAmount/style/index.d.ts +1 -0
  33. package/lib/components/InputAmount/style/index.js +4 -0
  34. package/lib/index.css +1 -1
  35. package/lib/index.d.ts +2 -0
  36. package/lib/index.js +9 -1
  37. package/package.json +7 -1
@@ -0,0 +1,5 @@
1
+ import type { FC, PropsWithChildren } from 'react';
2
+ import type { InputAmountProps } from './interface';
3
+ export declare const InputAmount: FC<PropsWithChildren<InputAmountProps>>;
4
+ declare const _default: import("react").NamedExoticComponent<PropsWithChildren<InputAmountProps>>;
5
+ export default _default;
@@ -0,0 +1,131 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
+ var __rest = this && this.__rest || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
6
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
7
+ }
8
+ return t;
9
+ };
10
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
+ import { memo, useState, useCallback, useRef, useEffect } from 'react';
12
+ import { InputNumber } from 'primereact/inputnumber';
13
+ import { numericFormatter } from 'react-number-format';
14
+ import classnames from '../../utils/classnames';
15
+ var MIN_INPUT_WIDTH = 33;
16
+ export var InputAmount = function InputAmount(props) {
17
+ var value = props.value,
18
+ children = props.children,
19
+ className = props.className,
20
+ wrapperCls = props.wrapperCls,
21
+ _props$prefixCls = props.prefixCls,
22
+ prefixCls = _props$prefixCls === void 0 ? 'input-amount' : _props$prefixCls,
23
+ invalid = props.invalid,
24
+ _props$placeholder = props.placeholder,
25
+ placeholder = _props$placeholder === void 0 ? '0' : _props$placeholder,
26
+ prefix = props.prefix,
27
+ currency = props.currency,
28
+ suffix = props.suffix,
29
+ message = props.message,
30
+ footnote = props.footnote,
31
+ onChange = props.onChange,
32
+ rest = __rest(props, ["value", "children", "className", "wrapperCls", "prefixCls", "invalid", "placeholder", "prefix", "currency", "suffix", "message", "footnote", "onChange"]);
33
+ var classes = classnames(prefixCls);
34
+ var inputRef = useRef(null);
35
+ var fakeEleRef = useRef(null);
36
+ var _useState = useState(null),
37
+ _useState2 = _slicedToArray(_useState, 2),
38
+ _value = _useState2[0],
39
+ setValue = _useState2[1];
40
+ var _useState3 = useState(MIN_INPUT_WIDTH),
41
+ _useState4 = _slicedToArray(_useState3, 2),
42
+ _width = _useState4[0],
43
+ setWidth = _useState4[1];
44
+ var handleChange = useCallback(function (e) {
45
+ setValue(e.value);
46
+ onChange === null || onChange === void 0 ? void 0 : onChange(e);
47
+ }, [onChange]);
48
+ var handleKeyDown = useCallback(function (e) {
49
+ switch (e.key) {
50
+ case '.':
51
+ setValue(function (prev) {
52
+ return "".concat(prev, ".");
53
+ });
54
+ break;
55
+ case 'Backspace':
56
+ if (_value == null) return;
57
+ // eslint-disable-next-line no-case-declarations
58
+ var str = _value.toString();
59
+ if (str[str.length - 2] === '.') {
60
+ setTimeout(function () {
61
+ setValue("".concat(str.slice(0, -1)));
62
+ }, 0);
63
+ }
64
+ break;
65
+ default:
66
+ break;
67
+ }
68
+ }, [_value]);
69
+ useEffect(function () {
70
+ var _a;
71
+ setWidth(((_a = fakeEleRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || MIN_INPUT_WIDTH);
72
+ }, [_value]);
73
+ useEffect(function () {
74
+ return setValue(value !== null && value !== void 0 ? value : null);
75
+ }, [value]);
76
+ return _jsxs("div", {
77
+ className: classes('wrapper', [wrapperCls, invalid ? classes('invalid') : undefined].join(' ').trim()),
78
+ children: [_jsxs("div", {
79
+ className: classes(void 0, className),
80
+ children: [prefix && _jsx("span", {
81
+ className: classes('prefix'),
82
+ onClick: function onClick() {
83
+ var _a;
84
+ return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
85
+ },
86
+ children: prefix
87
+ }), _jsx(InputNumber, Object.assign({}, rest, {
88
+ mode: 'decimal',
89
+ ref: inputRef,
90
+ value: value,
91
+ placeholder: placeholder,
92
+ className: classes('element'),
93
+ onChange: handleChange,
94
+ onKeyDown: handleKeyDown,
95
+ style: {
96
+ '--input-width': "".concat(_width, "px")
97
+ }
98
+ })), currency && _jsx("span", {
99
+ className: classes('currency'),
100
+ onClick: function onClick() {
101
+ var _a;
102
+ return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
103
+ },
104
+ children: currency
105
+ }), suffix && _jsx("span", {
106
+ className: classes('suffix'),
107
+ children: suffix
108
+ }), _jsx("span", {
109
+ ref: fakeEleRef,
110
+ className: classes('fake'),
111
+ onClick: function onClick(e) {
112
+ return e.stopPropagation();
113
+ },
114
+ children: numericFormatter('' + (_value == null ? '' : _value), {
115
+ thousandSeparator: true
116
+ })
117
+ })]
118
+ }), (message || footnote) && _jsxs("div", {
119
+ className: classes('extra'),
120
+ children: [message && _jsx("span", {
121
+ className: classes('message'),
122
+ children: message
123
+ }), footnote && _jsx("span", {
124
+ className: classes('footnote'),
125
+ children: footnote
126
+ })]
127
+ })]
128
+ });
129
+ };
130
+ 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"}
@@ -0,0 +1,4 @@
1
+ import InputAmount from './InputAmount';
2
+ export { InputAmount } from './InputAmount';
3
+ export default InputAmount;
4
+ export * from './interface';
@@ -0,0 +1,5 @@
1
+ import InputAmount from './InputAmount';
2
+ export { InputAmount } from './InputAmount';
3
+ export default InputAmount;
4
+ export * from './interface';
5
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvSW5wdXRBbW91bnQvaW5kZXgudHMiXSwibmFtZXMiOlsiSW5wdXRBbW91bnQiXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLFdBQVcsTUFBTSxlQUFlO0FBRXZDLFNBQVNBLFdBQVcsUUFBUSxlQUFlO0FBRTNDLGVBQWVBLFdBQVc7QUFFMUIsY0FBYyxhQUFhIiwiZmlsZSI6ImNvbXBvbmVudHMvSW5wdXRBbW91bnQvaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6W251bGxdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -0,0 +1,14 @@
1
+ import type { RefObject, ReactNode } from 'react';
2
+ import type { InputNumberProps, InputNumber } from 'primereact/inputnumber';
3
+ export interface InputAmountProps extends Omit<InputNumberProps, 'prefix' | 'suffix' | 'currency'> {
4
+ ref?: RefObject<InputNumber | null>;
5
+ className?: string;
6
+ prefixCls?: string;
7
+ wrapperCls?: string;
8
+ invalid?: boolean;
9
+ prefix?: ReactNode;
10
+ currency?: ReactNode;
11
+ suffix?: ReactNode;
12
+ message?: ReactNode;
13
+ footnote?: ReactNode;
14
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy9JbnB1dEFtb3VudC9pbnRlcmZhY2UuanMiLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMiLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvSW5wdXRBbW91bnQvaW50ZXJmYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7fTsiXSwibWFwcGluZ3MiOiJBQUFBIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +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}
@@ -0,0 +1,140 @@
1
+ @use '../../../variable.scss'as *;
2
+
3
+ $component: 'input-amount';
4
+ $cls: #{$prefix}-#{$component};
5
+
6
+ .#{$cls} {
7
+ &-wrapper {
8
+ display: inline-flex;
9
+ flex-direction: column;
10
+ gap: 16px;
11
+ width: 100%;
12
+ }
13
+
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
+ &:has(.p-inputwrapper-focus:not(.p-invalid)) {
23
+ border-bottom-color: $color-primary;
24
+ }
25
+
26
+ &-element {
27
+ display: inline-flex;
28
+ 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;
35
+
36
+ input {
37
+ position: relative;
38
+ width: var(--input-width);
39
+ padding: 0;
40
+ color: inherit;
41
+ font-weight: inherit;
42
+ font-size: inherit;
43
+ font-family: inherit;
44
+ line-height: inherit;
45
+ letter-spacing: inherit;
46
+ border: none;
47
+ border-radius: 0;
48
+ box-shadow: none;
49
+
50
+ &::placeholder {
51
+ color: inherit;
52
+ }
53
+ }
54
+ }
55
+
56
+ &-fake {
57
+ position: absolute;
58
+ top: 0;
59
+ left: -9999px;
60
+ z-index: -1;
61
+ 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;
67
+ white-space: pre;
68
+ visibility: hidden;
69
+ opacity: 0;
70
+ user-select: none;
71
+ pointer-events: none;
72
+ inset-block-start: 0;
73
+ inset-inline-start: 0;
74
+ }
75
+
76
+ &-prefix,
77
+ &-currency,
78
+ &-suffix {
79
+ display: inline-flex;
80
+ flex-grow: 0;
81
+ flex-shrink: 0;
82
+ align-items: center;
83
+ }
84
+
85
+ &-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;
92
+ }
93
+
94
+ &-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;
101
+ }
102
+
103
+ &-suffix {
104
+ margin-left: auto;
105
+ }
106
+
107
+ &-extra {
108
+ display: inline-flex;
109
+ flex-direction: column;
110
+ gap: 16px;
111
+ }
112
+
113
+ &-message {
114
+ color: $color-primary-black;
115
+ font-weight: 400;
116
+ font-size: 12px;
117
+ font-family: var(--font-inter), Inter;
118
+ line-height: 140%;
119
+ }
120
+
121
+ &-footnote {
122
+ color: $color-primary;
123
+ font-weight: 500;
124
+ font-size: 16px;
125
+ font-family: var(--font-inter), Inter;
126
+ line-height: 140%;
127
+ }
128
+
129
+ &-invalid {
130
+ .#{$cls} {
131
+ border-bottom-color: $color-negative;
132
+ }
133
+
134
+ .#{$cls}-prefix,
135
+ .#{$cls}-element,
136
+ .#{$cls}-message {
137
+ color: $color-negative;
138
+ }
139
+ }
140
+ }
@@ -0,0 +1,2 @@
1
+ import './InputAmount.css';
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvSW5wdXRBbW91bnQvc3JjL2NvbXBvbmVudHMvSW5wdXRBbW91bnQvc3R5bGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxvQkFBb0IiLCJmaWxlIjoiY29tcG9uZW50cy9JbnB1dEFtb3VudC9zdHlsZS9jc3MuanMiLCJzb3VyY2VzQ29udGVudCI6W251bGxdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -0,0 +1 @@
1
+ import './InputAmount.scss';
@@ -0,0 +1,2 @@
1
+ import './InputAmount.scss';
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvSW5wdXRBbW91bnQvc3JjL2NvbXBvbmVudHMvSW5wdXRBbW91bnQvc3R5bGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxvQkFBb0IiLCJmaWxlIjoiY29tcG9uZW50cy9JbnB1dEFtb3VudC9zdHlsZS9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==