@commercetools-uikit/localized-money-input 13.0.3 → 13.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +73 -77
- package/dist/commercetools-uikit-localized-money-input.cjs.d.ts +2 -0
- package/dist/commercetools-uikit-localized-money-input.cjs.dev.js +57 -80
- package/dist/commercetools-uikit-localized-money-input.cjs.prod.js +22 -24
- package/dist/commercetools-uikit-localized-money-input.esm.js +57 -80
- package/dist/declarations/src/index.d.ts +2 -0
- package/dist/declarations/src/localized-money-input.d.ts +43 -0
- package/dist/declarations/src/messages.d.ts +18 -0
- package/dist/declarations/src/version.d.ts +2 -0
- package/package.json +6 -8
package/README.md
CHANGED
|
@@ -1,85 +1,85 @@
|
|
|
1
|
+
<!-- THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. -->
|
|
2
|
+
<!-- This file is created by the `yarn generate-readme` script. -->
|
|
3
|
+
|
|
1
4
|
# LocalizedMoneyInput
|
|
2
5
|
|
|
3
6
|
## Description
|
|
4
7
|
|
|
5
|
-
A controlled input component for localized money values with validation
|
|
6
|
-
states.
|
|
7
|
-
|
|
8
|
-
## Usage
|
|
8
|
+
A controlled input component for localized money values with validation states.
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
import LocalizedMoneyInput from '@commercetools-uikit/localized-money-input';
|
|
10
|
+
## Installation
|
|
12
11
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
USD: { currencyCode: 'USD', amount: '12.22' },
|
|
16
|
-
EUR: { currencyCode: 'EUR', amount: '41.44' },
|
|
17
|
-
}}
|
|
18
|
-
onChange={(event) => alert(event.target.name, event.target.value)}
|
|
19
|
-
/>;
|
|
12
|
+
```
|
|
13
|
+
yarn add @commercetools-uikit/localized-money-input
|
|
20
14
|
```
|
|
21
15
|
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
| ------------------------------- | ---------------- | :------: | ----------------------- | ------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
26
|
-
| `id` | `string` | - | - | - | Used as prefix of HTML `id` property. Each input field id will have the currency as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en` |
|
|
27
|
-
| `name` | `string` | - | - | - | Used as HTML `name` property for each input field. Each input field name will have the currency as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en` |
|
|
28
|
-
| `value` | `object` | ✅ | - | - | Values to use. Keyed by currency, the values are the money values, e.g. `{ USD: {currencyCode: 'USD', amount: '12.22'}, EUR: {currencyCode: 'EUR', amount: '41.44'} }` |
|
|
29
|
-
| `onChange` | `function` | ✅ | - | - | Gets called when any input is changed. Is called with the change event of the changed input. |
|
|
30
|
-
| `selectedCurrency` | `string` | ✅ | - | - | Specifies which currency will be shown in case the `LocalizedMoneyInput` is collapsed. |
|
|
31
|
-
| `onBlur` | `function` | - | - | - | Called when any field is blurred. Is called with the `event` of that field. |
|
|
32
|
-
| `onFocus` | `function` | - | - | - | Called when any field is focussed. Is called with the `event` of that field. |
|
|
33
|
-
| `hideCurrencyExpansionControls` | `bool` | - | - | `false` | Will hide the currency toggle controls when set to `true`. It always shows all currencies instead. |
|
|
34
|
-
| `defaultExpandCurrencies` | `bool` | - | - | `false` | Controls whether one or all currencies are visible by default. Pass `true` to show all currencies by default. |
|
|
35
|
-
| `isDisabled` | `bool` | - | - | `false` | Disables all input fields. |
|
|
36
|
-
| `isReadOnly` | `bool` | - | - | `false` | Makes all input fields readonly. |
|
|
37
|
-
| `placeholder` | `object` | - | - | - | Placeholders for each currency. Object of the same shape as `value`. |
|
|
38
|
-
| `horizontalConstraint` | `object` | - | `m`, `l`, `xl`, `scale` | `scale` | Horizontal size limit of the input fields. |
|
|
39
|
-
| `hasError` | `bool` | - | - | - | Will apply the error state to each input without showing any error message. |
|
|
40
|
-
| `hasWarning` | `bool` | - | - | - | Indicates the input field has a warning |
|
|
41
|
-
| `errors` | `objectOf(node)` | - | - | - | Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key. |
|
|
42
|
-
| `warnings` | `objectOf(node)` | - | - | - | Used to show warnings underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the warning to show for that key. |
|
|
43
|
-
|
|
44
|
-
The component forwards all `data` attribute props. It further adds a `-${currency}` suffix to the values of the `data-test` and `data-track-component` attributes, e.g `data-test="foo"` will get added to the input for `en` as `data-test="foo-en"`.
|
|
16
|
+
```
|
|
17
|
+
npm --save install @commercetools-uikit/localized-money-input
|
|
18
|
+
```
|
|
45
19
|
|
|
46
|
-
|
|
20
|
+
Additionally install the peer dependencies (if not present)
|
|
47
21
|
|
|
48
|
-
|
|
22
|
+
```
|
|
23
|
+
yarn add react react-dom react-intl
|
|
24
|
+
```
|
|
49
25
|
|
|
50
|
-
|
|
26
|
+
```
|
|
27
|
+
npm --save install react react-dom react-intl
|
|
28
|
+
```
|
|
51
29
|
|
|
52
|
-
|
|
30
|
+
## Usage
|
|
53
31
|
|
|
54
|
-
|
|
55
|
-
|
|
32
|
+
```jsx
|
|
33
|
+
import LocalizedMoneyInput from '@commercetools-uikit/localized-money-input';
|
|
56
34
|
|
|
57
|
-
|
|
35
|
+
const Example = () => (
|
|
36
|
+
<LocalizedMoneyInput
|
|
37
|
+
value={{
|
|
38
|
+
USD: { currencyCode: 'USD', amount: '12.22' },
|
|
39
|
+
EUR: { currencyCode: 'EUR', amount: '41.44' },
|
|
40
|
+
}}
|
|
41
|
+
onChange={
|
|
42
|
+
(/** event */) => {
|
|
43
|
+
// alert(event.target.name, event.target.value)
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
/>
|
|
47
|
+
);
|
|
58
48
|
|
|
59
|
-
|
|
60
|
-
// 42.00 €
|
|
61
|
-
{
|
|
62
|
-
"type": "centPrecision",
|
|
63
|
-
"currencyCode": "EUR",
|
|
64
|
-
"centAmount": 4200,
|
|
65
|
-
"fractionDigits": 2
|
|
66
|
-
}
|
|
49
|
+
export default Example;
|
|
67
50
|
```
|
|
68
51
|
|
|
69
|
-
|
|
70
|
-
// 0.0123456 €
|
|
71
|
-
{
|
|
72
|
-
"type": "highPrecision",
|
|
73
|
-
"currencyCode": "EUR",
|
|
74
|
-
"centAmount": 1,
|
|
75
|
-
"preciseAmount": 123456,
|
|
76
|
-
"fractionDigits": 7
|
|
77
|
-
}
|
|
78
|
-
```
|
|
52
|
+
## Properties
|
|
79
53
|
|
|
80
|
-
|
|
54
|
+
| Props | Type | Required | Default | Description |
|
|
55
|
+
| ------------------------------- | ----------------------------------------------------------------------------------------------------- | :------: | --------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
56
|
+
| `id` | `string` | | | Used as HTML id property. |
|
|
57
|
+
| `name` | `string` | | | The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`). |
|
|
58
|
+
| `value` | `Record` | ✅ | | value of possible currency
<br/>
the input doesn't accept a "currencies" prop, instead all possible
currencies have to exist (with empty or filled strings) on the value:
{ EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}} |
|
|
59
|
+
| `onChange` | `ChangeEventHandler` | | | Called with the event of the input. |
|
|
60
|
+
| `selectedCurrency` | `string` | ✅ | | the currently selected currency |
|
|
61
|
+
| `onBlur` | `Function`<br/>[See signature.](#signature-onBlur) | | | Called when input is blurred |
|
|
62
|
+
| `onFocus` | `FocusEventHandler` | | | Called when input is focused |
|
|
63
|
+
| `hideCurrencyExpansionControls` | `boolean` | | | Will hide the currency expansion controls when set to `true`. All currencies will be shown when set to `true`. |
|
|
64
|
+
| `defaultExpandCurrencies` | `boolean` | | | Controls whether one or all currencirs are visible by default |
|
|
65
|
+
| `isDisabled` | `boolean` | | | Indicates that the input cannot be modified (e.g not authorized, or changes currently saving). |
|
|
66
|
+
| `isReadOnly` | `boolean` | | | Indicates that the field is displaying read-only content |
|
|
67
|
+
| `placeholder` | `Record` | | | Placeholder text for the input |
|
|
68
|
+
| `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | Horizontal size limit of the input fields. |
|
|
69
|
+
| `hasError` | `boolean` | | | Indicates that input has errors |
|
|
70
|
+
| `hasWarning` | `boolean` | | | Control to indicate on the input if there are values that are potentially invalid |
|
|
71
|
+
| `errors` | `Record` | | | A map of errors. Error messages for known errors are rendered automatically.
<br>
Unknown errors will be forwarded to `renderError` |
|
|
72
|
+
| `warnings` | `Record` | | | A map of warnings. |
|
|
73
|
+
|
|
74
|
+
## Signatures
|
|
75
|
+
|
|
76
|
+
### Signature `onBlur`
|
|
77
|
+
|
|
78
|
+
```ts
|
|
79
|
+
(event: TEvent) => void
|
|
80
|
+
```
|
|
81
81
|
|
|
82
|
-
|
|
82
|
+
## Static methods
|
|
83
83
|
|
|
84
84
|
### `LocalizedMoneyInput.getEmptyCurrencies`
|
|
85
85
|
|
|
@@ -145,8 +145,7 @@ LocalizedMoneyInput.getHighPrecisionCurrencies({
|
|
|
145
145
|
|
|
146
146
|
### `LocalizedMoneyInput.convertToMoneyValues`
|
|
147
147
|
|
|
148
|
-
The
|
|
149
|
-
If you want to forbid `highPrecision`, then the form's validation needs to add an error when it sees a `highPrecision` price. See example below.
|
|
148
|
+
The convertToMoneyValues function will turn a list of `LocalizedMoneyInput` values into a list of [`MoneyValue`](https://docs.commercetools.com/http-api-types#money) the API can handle. It automatically converts to `centPrecision` or `highPrecision` types when the number of supplied fraction digits exceeds the number of fraction digits used by the currency. If you want to forbid `highPrecision`, then the form's validation needs to add an error when it sees a `highPrecision` price. See example below.
|
|
150
149
|
|
|
151
150
|
Here are examples of `centPrecision` and `highPrecision` prices.
|
|
152
151
|
|
|
@@ -177,24 +176,29 @@ Here are examples of `centPrecision` and `highPrecision` prices.
|
|
|
177
176
|
|
|
178
177
|
### `LocalizedMoneyInput.parseMoneyValues`
|
|
179
178
|
|
|
180
|
-
The `parseMoneyValues` function will turn a
|
|
179
|
+
The `parseMoneyValues` function will turn a list of `MoneyValue` into a record of values the `LocalizedMoneyInput` component can handle.
|
|
180
|
+
|
|
181
|
+
```js
|
|
182
|
+
LocalizedMoneyInput.parseMoneyValues([{ currencyCode: 'EUR', centAmount: 10 }]);
|
|
183
|
+
|
|
184
|
+
// -> { EUR: { currencyCode: 'EUR', centAmount: 10 } }
|
|
185
|
+
```
|
|
181
186
|
|
|
182
187
|
### `LocalizedMoneyInput.getEmptyCurrencies`
|
|
183
188
|
|
|
184
|
-
The
|
|
189
|
+
The getEmptyCurrencies function will return array of currencies that don't have amount .
|
|
185
190
|
|
|
186
191
|
```js
|
|
187
192
|
LocalizedMoneyInput.getEmptyCurrencies({
|
|
188
193
|
EUR: { currencyCode: 'EUR', amount: '' },
|
|
189
194
|
USD: { currencyCode: 'USD', amount: '12.77' },
|
|
190
195
|
}); // -> ['EUR']
|
|
191
|
-
|
|
192
196
|
LocalizedMoneyInput.getEmptyCurrencies({
|
|
193
197
|
EUR: { currencyCode: 'EUR', amount: '12.77' },
|
|
194
198
|
}); // -> []
|
|
195
199
|
```
|
|
196
200
|
|
|
197
|
-
##
|
|
201
|
+
## Examples
|
|
198
202
|
|
|
199
203
|
Here's an example of how `LocalizedMoneyInput` would be used inside a form.
|
|
200
204
|
|
|
@@ -204,7 +208,6 @@ import { Formik } from 'formik';
|
|
|
204
208
|
import omitEmpty from 'omit-empty-es';
|
|
205
209
|
import { ErrorMessage } from '@commercetools-uikit/messages';
|
|
206
210
|
import LocalizedMoneyInput from '@commercetools-uikit/localized-money-input';
|
|
207
|
-
|
|
208
211
|
// the existing document, e.g. from the database
|
|
209
212
|
const doc = {
|
|
210
213
|
prices: [
|
|
@@ -218,14 +221,12 @@ const doc = {
|
|
|
218
221
|
},
|
|
219
222
|
],
|
|
220
223
|
};
|
|
221
|
-
|
|
222
224
|
// A function to convert a document to form values.
|
|
223
225
|
const docToFormValues = (doc) => ({
|
|
224
226
|
// The parseMoneyValue function will turn a MoneyValue into a
|
|
225
227
|
// value the LocalizedMoneyInput component can handle ({currency: amount})
|
|
226
228
|
prices: LocalizedMoneyInput.parseMoneyValues(doc.prices),
|
|
227
229
|
});
|
|
228
|
-
|
|
229
230
|
// a function to convert form values back to a document
|
|
230
231
|
const formValuesToDoc = (formValues) => ({
|
|
231
232
|
// The convertToMoneyValue function will convert a LocalizedMoneyInput
|
|
@@ -238,7 +239,6 @@ const formValuesToDoc = (formValues) => ({
|
|
|
238
239
|
// See example below
|
|
239
240
|
prices: LocalizedMoneyInput.convertToMoneyValues(formValues.prices),
|
|
240
241
|
});
|
|
241
|
-
|
|
242
242
|
const validate = (formValues) => {
|
|
243
243
|
const errors = { prices: {} };
|
|
244
244
|
Object.keys(formValues.prices).forEach((currency) => {
|
|
@@ -251,7 +251,6 @@ const validate = (formValues) => {
|
|
|
251
251
|
// This form doesn't accept high precision prices
|
|
252
252
|
const highPrecisionCurrencies =
|
|
253
253
|
LocalizedMoneyInput.getHighPrecisionCurrencies(formValues.prices);
|
|
254
|
-
|
|
255
254
|
// ['CAD', 'USD']
|
|
256
255
|
emptyCurrencies.forEach((emptyCurrency) => {
|
|
257
256
|
errors.prices[emptyCurrency].missing = true;
|
|
@@ -259,7 +258,6 @@ const validate = (formValues) => {
|
|
|
259
258
|
highPrecisionCurrencies.forEach((highPrecisionCurrency) => {
|
|
260
259
|
errors.prices[highPrecisionCurrency].highPrecision = true;
|
|
261
260
|
});
|
|
262
|
-
|
|
263
261
|
return omitEmpty(errors);
|
|
264
262
|
};
|
|
265
263
|
const initialValues = docToFormValues(doc);
|
|
@@ -277,7 +275,6 @@ const renderErrors = (errors) => {
|
|
|
277
275
|
};
|
|
278
276
|
});
|
|
279
277
|
};
|
|
280
|
-
|
|
281
278
|
return (
|
|
282
279
|
<Formik
|
|
283
280
|
initialValues={initialValues}
|
|
@@ -305,7 +302,6 @@ return (
|
|
|
305
302
|
errors={renderErrors(errors)}
|
|
306
303
|
horizontalConstraint={10}
|
|
307
304
|
/>
|
|
308
|
-
|
|
309
305
|
<button type="submit">Submit</button>
|
|
310
306
|
</form>
|
|
311
307
|
)}
|
|
@@ -8,10 +8,10 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
|
|
|
8
8
|
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
9
9
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
10
10
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
11
|
-
var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
12
11
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
13
12
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
13
|
var _toConsumableArray = require('@babel/runtime-corejs3/helpers/toConsumableArray');
|
|
14
|
+
var _pt = require('prop-types');
|
|
15
15
|
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
16
16
|
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
17
17
|
var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
|
|
@@ -20,8 +20,6 @@ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instan
|
|
|
20
20
|
var _Object$values = require('@babel/runtime-corejs3/core-js-stable/object/values');
|
|
21
21
|
var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
22
22
|
var react = require('react');
|
|
23
|
-
var PropTypes = require('prop-types');
|
|
24
|
-
var commonTags = require('common-tags');
|
|
25
23
|
var reactIntl = require('react-intl');
|
|
26
24
|
require('@emotion/react');
|
|
27
25
|
var hooks = require('@commercetools-uikit/hooks');
|
|
@@ -42,6 +40,7 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
|
|
|
42
40
|
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
43
41
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
44
42
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
43
|
+
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
45
44
|
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
46
45
|
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
47
46
|
var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
|
|
@@ -49,7 +48,6 @@ var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
|
49
48
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
50
49
|
var _Object$values__default = /*#__PURE__*/_interopDefault(_Object$values);
|
|
51
50
|
var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
|
|
52
|
-
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
53
51
|
var MoneyInput__default = /*#__PURE__*/_interopDefault(MoneyInput);
|
|
54
52
|
var Stack__default = /*#__PURE__*/_interopDefault(Stack);
|
|
55
53
|
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
@@ -72,11 +70,9 @@ var messages = reactIntl.defineMessages({
|
|
|
72
70
|
}
|
|
73
71
|
});
|
|
74
72
|
|
|
75
|
-
var _templateObject;
|
|
76
|
-
|
|
77
73
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
78
74
|
|
|
79
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
75
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
80
76
|
|
|
81
77
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
82
78
|
var sequentialId = utils.createSequentialId('localized-money-input-'); // sorts the currencies with the following priority:
|
|
@@ -99,7 +95,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
99
95
|
} : {
|
|
100
96
|
name: "1ysn02y-LocalizedInput",
|
|
101
97
|
styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
|
|
102
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.js"],"names":[],"mappings":"AA4DgB","file":"localized-money-input.js","sourcesContent":["import { useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport { oneLine } from 'common-tags';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { useToggleState, useFieldId } from '@commercetools-uikit/hooks';\nimport MoneyInput from '@commercetools-uikit/money-input';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { CoinsIcon } from '@commercetools-uikit/icons';\nimport {\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport messages from './messages';\n\nconst sequentialId = createSequentialId('localized-money-input-');\n\n// sorts the currencies with the following priority:\n// - The selected currency is placed first (e.g EUR)\n// - All other currencies follow, sorted alphabetically as well\nexport const sortCurrencies = (selectedCurrency, allCurrencies) => {\n  const remainingCurrencies = allCurrencies.filter(\n    (currency) => currency !== selectedCurrency\n  );\n  return [selectedCurrency, ...remainingCurrencies.sort()];\n};\n\nconst LocalizedInput = (props) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the currency to the target.\n      // That way the users  can read\n      // event.target.currency and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the currency from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.currency = props.currency;\n      onChange(event);\n    },\n    [props.currency, onChange]\n  );\n  return (\n    <Stack scale=\"xs\">\n      <div\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <MoneyInput\n          id={props.id}\n          name={props.name}\n          value={props.value}\n          onChange={handleChange}\n          onBlur={props.onBlur}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {(props.error || props.warning) && (\n        <div>{props.error ? props.error : props.warning}</div>\n      )}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nLocalizedInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  onChange: PropTypes.func,\n  currency: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n};\n\nconst LocalizedMoneyInput = (props) => {\n  const intl = useIntl();\n\n  const defaultExpansionState =\n    props.hideCurrencyExpansionControls ||\n    props.defaultExpandCurrencies ||\n    // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areCurrenciesExpanded, toggleCurrencies] = useToggleState(\n    defaultExpansionState\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingCurrencies =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);\n\n  const hasWarningInRemainingCurrencies =\n    props.hasWarning ||\n    getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);\n\n  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (!areCurrenciesExpanded) {\n      toggleCurrencies();\n    }\n  }\n\n  const currencies = sortCurrencies(\n    props.selectedCurrency,\n    Object.keys(props.value)\n  );\n\n  const shouldRenderCurrencyControl =\n    currencies.length > 1 && !props.hideCurrencyExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack scale=\"s\">\n          {currencies.map((currency, index) => {\n            const isFirstCurrency = index === 0;\n            if (!isFirstCurrency && !areCurrenciesExpanded) return null;\n\n            return (\n              <LocalizedInput\n                key={currency}\n                id={LocalizedMoneyInput.getId(id, currency)}\n                name={LocalizedMoneyInput.getName(props.name, currency)}\n                value={props.value[currency]}\n                onChange={props.onChange}\n                currency={currency}\n                placeholder={\n                  props.placeholder ? props.placeholder[currency] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[currency])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[currency])\n                )}\n                intl={intl}\n                warning={props.warnings && props.warnings[currency]}\n                error={props.errors && props.errors[currency]}\n                {...createLocalizedDataAttributes(props, currency)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderCurrencyControl && (\n          <LocalizedInputToggle\n            icon={<CoinsIcon />}\n            onClick={toggleCurrencies}\n            isOpen={areCurrenciesExpanded}\n            isDisabled={\n              areCurrenciesExpanded &&\n              Boolean(\n                hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies\n              )\n            }\n            showMessage={intl.formatMessage(messages.show, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n            hideMessage={intl.formatMessage(messages.hide, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedMoneyInput.displayName = 'LocalizedMoneyInput';\n\nLocalizedMoneyInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  // then input doesn't accept a \"currencies\" prop, instead all possible\n  // currencies have to exist (with empty or filled strings) on the value:\n  // { EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}}\n  value: PropTypes.objectOf(\n    PropTypes.shape({\n      amount: PropTypes.string.isRequired,\n      currencyCode: PropTypes.string.isRequired,\n    })\n  ).isRequired,\n  onChange: PropTypes.func,\n  selectedCurrency: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  hideCurrencyExpansionControls: PropTypes.bool,\n  defaultExpandCurrencies: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideCurrencyExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideCurrencyExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  errors: PropTypes.objectOf(PropTypes.node),\n  warnings: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedMoneyInput.getId = getId;\n\nLocalizedMoneyInput.getName = getName;\n\nLocalizedMoneyInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedMoneyInput.convertToMoneyValues = (values, locale) =>\n  Object.values(values).map((value) =>\n    MoneyInput.convertToMoneyValue(value, locale)\n  );\n\nLocalizedMoneyInput.parseMoneyValues = (moneyValues = [], locale) =>\n  moneyValues\n    .map((value) => MoneyInput.parseMoneyValue(value, locale))\n    .reduce(\n      (pairs, value) => ({\n        ...pairs,\n        [value.currencyCode]: value,\n      }),\n      {}\n    );\n\nLocalizedMoneyInput.getHighPrecisionCurrencies = (values, locale) =>\n  Object.keys(values).filter((currencyCode) =>\n    MoneyInput.isHighPrecision(values[currencyCode], locale)\n  );\n\nLocalizedMoneyInput.getEmptyCurrencies = (values) =>\n  Object.keys(values).filter((currencyCode) =>\n    MoneyInput.isEmpty(values[currencyCode])\n  );\n\nexport default LocalizedMoneyInput;\n"]} */",
|
|
98
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAwOgB","file":"localized-money-input.tsx","sourcesContent":["import {\n  useCallback,\n  type FocusEventHandler,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { useToggleState, useFieldId } from '@commercetools-uikit/hooks';\nimport MoneyInput, {\n  type TCurrencyCode,\n  type TMoneyValue,\n  type TValue,\n} from '@commercetools-uikit/money-input';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { CoinsIcon } from '@commercetools-uikit/icons';\nimport {\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport messages from './messages';\n\ntype TEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n};\n\ntype TLocalizedMoneyInputProps = {\n  /**\n   * Used as HTML id property.\n   */\n  id?: string;\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`).\n   */\n  name?: string;\n  /**\n   * value of possible currency\n   * <br/>\n   * the input doesn't accept a \"currencies\" prop, instead all possible\n   * currencies have to exist (with empty or filled strings) on the value:\n   * { EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}}\n   */\n  value: Record<string, TValue>;\n  /**\n   * Called with the event of the input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * the currently selected currency\n   */\n  selectedCurrency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Will hide the currency expansion controls when set to `true`. All currencies will be shown when set to `true`.\n   */\n  hideCurrencyExpansionControls?: boolean;\n  /**\n   * Controls whether one or all currencirs are visible by default\n   */\n  defaultExpandCurrencies?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * A map of errors. Error messages for known errors are rendered automatically.\n   * <br>\n   * Unknown errors will be forwarded to `renderError`\n   */\n  errors?: Record<string, ReactNode>;\n  /**\n   * A map of warnings.\n   */\n  warnings?: Record<string, ReactNode>;\n};\n\ntype TLocalizedInputProps = {\n  /**\n   * Used as HTML id property.\n   */\n  id?: string;\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`).\n   */\n  name?: string;\n  /**\n   * value of possible currency\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * Called with the event of the input.\n   */\n  currency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * A map of errors. Error messages for known errors are rendered automatically.\n   * <br>\n   * Unknown errors will be forwarded to `renderError`\n   */\n  error?: ReactNode;\n  /**\n   * HTML node to display warning\n   */\n  warning?: ReactNode;\n};\n\nconst sequentialId = createSequentialId('localized-money-input-');\n\n// sorts the currencies with the following priority:\n// - The selected currency is placed first (e.g EUR)\n// - All other currencies follow, sorted alphabetically as well\nexport const sortCurrencies = (\n  selectedCurrency: string,\n  allCurrencies: string[]\n) => {\n  const remainingCurrencies = allCurrencies.filter(\n    (currency) => currency !== selectedCurrency\n  );\n  return [selectedCurrency, ...remainingCurrencies.sort()];\n};\n\nconst LocalizedInput = (props: TLocalizedInputProps) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the currency to the target.\n      // That way the users  can read\n      // event.target.currency and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the currency from\n      // the input name anymore.\n      //\n      event.target.currency = props.currency;\n      onChange?.(event);\n    },\n    [props.currency, onChange]\n  );\n  return (\n    <Stack scale=\"xs\">\n      <div\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <MoneyInput\n          name={props.name}\n          value={props.value}\n          onChange={handleChange}\n          onBlur={props.onBlur}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {(props.error || props.warning) && (\n        <div>{props.error ? props.error : props.warning}</div>\n      )}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst LocalizedMoneyInput = (props: TLocalizedMoneyInputProps) => {\n  const intl = useIntl();\n\n  const defaultExpansionState =\n    props.hideCurrencyExpansionControls ||\n    props.defaultExpandCurrencies ||\n    // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areCurrenciesExpanded, toggleCurrencies] = useToggleState(\n    defaultExpansionState\n  );\n\n  const onLocalizedMoneyInputToggle = useCallback(\n    () => toggleCurrencies(),\n    [toggleCurrencies]\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingCurrencies =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);\n\n  const hasWarningInRemainingCurrencies =\n    props.hasWarning ||\n    getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);\n\n  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (!areCurrenciesExpanded) {\n      toggleCurrencies();\n    }\n  }\n\n  const currencies = sortCurrencies(\n    props.selectedCurrency,\n    Object.keys(props.value)\n  );\n\n  const shouldRenderCurrencyControl =\n    currencies.length > 1 && !props.hideCurrencyExpansionControls;\n\n  if (props.hideCurrencyExpansionControls) {\n    warning(\n      typeof props.defaultExpandCurrencies !== 'boolean',\n      'LocalizedMoneyInput: \"defaultExpandCurrencies\" does not have any effect when \"hideCurrencyExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack scale=\"s\">\n          {currencies.map((currency, index) => {\n            const isFirstCurrency = index === 0;\n            if (!isFirstCurrency && !areCurrenciesExpanded) return null;\n\n            return (\n              <LocalizedInput\n                key={currency}\n                id={LocalizedMoneyInput.getId(id, currency)}\n                name={LocalizedMoneyInput.getName(props.name, currency)}\n                value={props.value[currency]}\n                onChange={props.onChange}\n                currency={currency}\n                placeholder={\n                  props.placeholder ? props.placeholder[currency] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[currency])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[currency])\n                )}\n                warning={props.warnings && props.warnings[currency]}\n                error={props.errors && props.errors[currency]}\n                {...createLocalizedDataAttributes(props, currency)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderCurrencyControl && (\n          <LocalizedInputToggle\n            icon={<CoinsIcon />}\n            onClick={onLocalizedMoneyInputToggle}\n            isOpen={areCurrenciesExpanded}\n            isDisabled={\n              areCurrenciesExpanded &&\n              Boolean(\n                hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies\n              )\n            }\n            showMessage={intl.formatMessage(messages.show, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n            hideMessage={intl.formatMessage(messages.hide, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedMoneyInput.displayName = 'LocalizedMoneyInput';\n\nLocalizedMoneyInput.getId = getId;\n\nLocalizedMoneyInput.getName = getName;\n\nLocalizedMoneyInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedMoneyInput.convertToMoneyValues = (\n  values: TValue[],\n  locale: string\n): Array<TMoneyValue | null> =>\n  Object.values(values).map<TMoneyValue | null>((value) => {\n    return MoneyInput.convertToMoneyValue(value, locale);\n  });\n\nLocalizedMoneyInput.parseMoneyValues = (\n  moneyValues: TMoneyValue[] = [],\n  locale: string\n): Record<TCurrencyCode, TValue> =>\n  moneyValues.reduce<Record<TCurrencyCode, TValue>>((allValues, moneyValue) => {\n    const value = MoneyInput.parseMoneyValue(moneyValue, locale);\n    return {\n      ...allValues,\n      [value.currencyCode]: value,\n    };\n  }, {} as Record<TCurrencyCode, TValue>);\n\nLocalizedMoneyInput.getHighPrecisionCurrencies = (\n  values: Record<TCurrencyCode, TValue>,\n  locale: string\n): TCurrencyCode[] => {\n  const typedCurrencyCodes = Object.keys(values) as TCurrencyCode[];\n  return typedCurrencyCodes.filter((currencyCode) =>\n    MoneyInput.isHighPrecision(values[currencyCode], locale)\n  );\n};\n\nLocalizedMoneyInput.getEmptyCurrencies = (\n  values: Record<TCurrencyCode, TValue>\n): TCurrencyCode[] => {\n  const typedCurrencyCodes = Object.keys(values) as TCurrencyCode[];\n  return typedCurrencyCodes.filter((currencyCode) =>\n    MoneyInput.isEmpty(values[currencyCode])\n  );\n};\n\nexport default LocalizedMoneyInput;\n"]} */",
|
|
103
99
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
104
100
|
};
|
|
105
101
|
|
|
@@ -117,16 +113,14 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
117
113
|
// might clear it using the knob, and then we can't parse the currency from
|
|
118
114
|
// the input name anymore.
|
|
119
115
|
//
|
|
120
|
-
// eslint-disable-next-line no-param-reassign
|
|
121
116
|
event.target.currency = props.currency;
|
|
122
|
-
onChange(event);
|
|
117
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event);
|
|
123
118
|
}, [props.currency, onChange]);
|
|
124
119
|
return jsxRuntime.jsxs(Stack__default["default"], {
|
|
125
120
|
scale: "xs",
|
|
126
121
|
children: [jsxRuntime.jsx("div", {
|
|
127
122
|
css: _ref,
|
|
128
123
|
children: jsxRuntime.jsx(MoneyInput__default["default"], _objectSpread({
|
|
129
|
-
id: props.id,
|
|
130
124
|
name: props.name,
|
|
131
125
|
value: props.value,
|
|
132
126
|
onChange: handleChange,
|
|
@@ -143,26 +137,23 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
143
137
|
});
|
|
144
138
|
};
|
|
145
139
|
|
|
146
|
-
LocalizedInput.displayName = 'LocalizedInput';
|
|
147
140
|
LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
148
|
-
id:
|
|
149
|
-
name:
|
|
150
|
-
value:
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
placeholder: PropTypes__default["default"].string,
|
|
163
|
-
error: PropTypes__default["default"].node,
|
|
164
|
-
warning: PropTypes__default["default"].node
|
|
141
|
+
id: _pt__default["default"].string,
|
|
142
|
+
name: _pt__default["default"].string,
|
|
143
|
+
value: _pt__default["default"].any.isRequired,
|
|
144
|
+
onChange: _pt__default["default"].func,
|
|
145
|
+
currency: _pt__default["default"].string.isRequired,
|
|
146
|
+
onBlur: _pt__default["default"].func,
|
|
147
|
+
onFocus: _pt__default["default"].func,
|
|
148
|
+
isDisabled: _pt__default["default"].bool,
|
|
149
|
+
isReadOnly: _pt__default["default"].bool,
|
|
150
|
+
hasError: _pt__default["default"].bool,
|
|
151
|
+
hasWarning: _pt__default["default"].bool,
|
|
152
|
+
placeholder: _pt__default["default"].string,
|
|
153
|
+
error: _pt__default["default"].node,
|
|
154
|
+
warning: _pt__default["default"].node
|
|
165
155
|
} : {};
|
|
156
|
+
LocalizedInput.displayName = 'LocalizedInput';
|
|
166
157
|
|
|
167
158
|
var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
168
159
|
var intl = reactIntl.useIntl();
|
|
@@ -174,6 +165,9 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
174
165
|
areCurrenciesExpanded = _useToggleState2[0],
|
|
175
166
|
toggleCurrencies = _useToggleState2[1];
|
|
176
167
|
|
|
168
|
+
var onLocalizedMoneyInputToggle = react.useCallback(function () {
|
|
169
|
+
return toggleCurrencies();
|
|
170
|
+
}, [toggleCurrencies]);
|
|
177
171
|
var id = hooks.useFieldId(props.id, sequentialId);
|
|
178
172
|
var hasErrorInRemainingCurrencies = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);
|
|
179
173
|
var hasWarningInRemainingCurrencies = props.hasWarning || localizedUtils.getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);
|
|
@@ -188,6 +182,11 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
188
182
|
|
|
189
183
|
var currencies = sortCurrencies(props.selectedCurrency, _Object$keys__default["default"](props.value));
|
|
190
184
|
var shouldRenderCurrencyControl = currencies.length > 1 && !props.hideCurrencyExpansionControls;
|
|
185
|
+
|
|
186
|
+
if (props.hideCurrencyExpansionControls) {
|
|
187
|
+
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.defaultExpandCurrencies !== 'boolean', 'LocalizedMoneyInput: "defaultExpandCurrencies" does not have any effect when "hideCurrencyExpansionControls" is set.') : void 0;
|
|
188
|
+
}
|
|
189
|
+
|
|
191
190
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
192
191
|
max: props.horizontalConstraint,
|
|
193
192
|
children: jsxRuntime.jsxs(Stack__default["default"], {
|
|
@@ -210,14 +209,13 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
210
209
|
isReadOnly: props.isReadOnly,
|
|
211
210
|
hasError: Boolean(props.hasError || props.errors && props.errors[currency]),
|
|
212
211
|
hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[currency]),
|
|
213
|
-
intl: intl,
|
|
214
212
|
warning: props.warnings && props.warnings[currency],
|
|
215
213
|
error: props.errors && props.errors[currency]
|
|
216
214
|
}, localizedUtils.createLocalizedDataAttributes(props, currency)), currency);
|
|
217
215
|
})
|
|
218
216
|
}), shouldRenderCurrencyControl && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
|
|
219
217
|
icon: jsxRuntime.jsx(icons.CoinsIcon, {}),
|
|
220
|
-
onClick:
|
|
218
|
+
onClick: onLocalizedMoneyInputToggle,
|
|
221
219
|
isOpen: areCurrenciesExpanded,
|
|
222
220
|
isDisabled: areCurrenciesExpanded && Boolean(hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies),
|
|
223
221
|
showMessage: intl.formatMessage(messages.show, {
|
|
@@ -231,44 +229,26 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
231
229
|
});
|
|
232
230
|
};
|
|
233
231
|
|
|
234
|
-
LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
|
|
235
232
|
LocalizedMoneyInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
236
|
-
id:
|
|
237
|
-
name:
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
if (props.hideCurrencyExpansionControls && typeof props[propName] === 'boolean') {
|
|
254
|
-
throw new Error(commonTags.oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideCurrencyExpansionControls\" is set.\n "])), componentName, propName));
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
|
|
258
|
-
rest[_key - 3] = arguments[_key];
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
return PropTypes__default["default"].bool.apply(PropTypes__default["default"], _concatInstanceProperty__default["default"](_context2 = [props, propName, componentName]).call(_context2, rest));
|
|
262
|
-
},
|
|
263
|
-
isDisabled: PropTypes__default["default"].bool,
|
|
264
|
-
isReadOnly: PropTypes__default["default"].bool,
|
|
265
|
-
placeholder: PropTypes__default["default"].objectOf(PropTypes__default["default"].string),
|
|
266
|
-
horizontalConstraint: PropTypes__default["default"].oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
267
|
-
hasError: PropTypes__default["default"].bool,
|
|
268
|
-
hasWarning: PropTypes__default["default"].bool,
|
|
269
|
-
errors: PropTypes__default["default"].objectOf(PropTypes__default["default"].node),
|
|
270
|
-
warnings: PropTypes__default["default"].objectOf(PropTypes__default["default"].node)
|
|
233
|
+
id: _pt__default["default"].string,
|
|
234
|
+
name: _pt__default["default"].string,
|
|
235
|
+
value: _pt__default["default"].objectOf(_pt__default["default"].any).isRequired,
|
|
236
|
+
onChange: _pt__default["default"].func,
|
|
237
|
+
selectedCurrency: _pt__default["default"].string.isRequired,
|
|
238
|
+
onBlur: _pt__default["default"].func,
|
|
239
|
+
onFocus: _pt__default["default"].func,
|
|
240
|
+
hideCurrencyExpansionControls: _pt__default["default"].bool,
|
|
241
|
+
defaultExpandCurrencies: _pt__default["default"].bool,
|
|
242
|
+
isDisabled: _pt__default["default"].bool,
|
|
243
|
+
isReadOnly: _pt__default["default"].bool,
|
|
244
|
+
placeholder: _pt__default["default"].objectOf(_pt__default["default"].string),
|
|
245
|
+
horizontalConstraint: _pt__default["default"].oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
246
|
+
hasError: _pt__default["default"].bool,
|
|
247
|
+
hasWarning: _pt__default["default"].bool,
|
|
248
|
+
errors: _pt__default["default"].objectOf(_pt__default["default"].node),
|
|
249
|
+
warnings: _pt__default["default"].objectOf(_pt__default["default"].node)
|
|
271
250
|
} : {};
|
|
251
|
+
LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
|
|
272
252
|
LocalizedMoneyInput.getId = localizedUtils.getId;
|
|
273
253
|
LocalizedMoneyInput.getName = localizedUtils.getName;
|
|
274
254
|
LocalizedMoneyInput.defaultProps = {
|
|
@@ -276,37 +256,34 @@ LocalizedMoneyInput.defaultProps = {
|
|
|
276
256
|
};
|
|
277
257
|
|
|
278
258
|
LocalizedMoneyInput.convertToMoneyValues = function (values, locale) {
|
|
279
|
-
var
|
|
259
|
+
var _context2;
|
|
280
260
|
|
|
281
|
-
return _mapInstanceProperty__default["default"](
|
|
261
|
+
return _mapInstanceProperty__default["default"](_context2 = _Object$values__default["default"](values)).call(_context2, function (value) {
|
|
282
262
|
return MoneyInput__default["default"].convertToMoneyValue(value, locale);
|
|
283
263
|
});
|
|
284
264
|
};
|
|
285
265
|
|
|
286
266
|
LocalizedMoneyInput.parseMoneyValues = function () {
|
|
287
|
-
var _context4;
|
|
288
|
-
|
|
289
267
|
var moneyValues = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
290
268
|
var locale = arguments.length > 1 ? arguments[1] : undefined;
|
|
291
|
-
return _reduceInstanceProperty__default["default"](
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
return _objectSpread(_objectSpread({}, pairs), {}, _defineProperty({}, value.currencyCode, value));
|
|
269
|
+
return _reduceInstanceProperty__default["default"](moneyValues).call(moneyValues, function (allValues, moneyValue) {
|
|
270
|
+
var value = MoneyInput__default["default"].parseMoneyValue(moneyValue, locale);
|
|
271
|
+
return _objectSpread(_objectSpread({}, allValues), {}, _defineProperty({}, value.currencyCode, value));
|
|
295
272
|
}, {});
|
|
296
273
|
};
|
|
297
274
|
|
|
298
275
|
LocalizedMoneyInput.getHighPrecisionCurrencies = function (values, locale) {
|
|
299
|
-
var
|
|
276
|
+
var typedCurrencyCodes = _Object$keys__default["default"](values);
|
|
300
277
|
|
|
301
|
-
return _filterInstanceProperty__default["default"](
|
|
278
|
+
return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, function (currencyCode) {
|
|
302
279
|
return MoneyInput__default["default"].isHighPrecision(values[currencyCode], locale);
|
|
303
280
|
});
|
|
304
281
|
};
|
|
305
282
|
|
|
306
283
|
LocalizedMoneyInput.getEmptyCurrencies = function (values) {
|
|
307
|
-
var
|
|
284
|
+
var typedCurrencyCodes = _Object$keys__default["default"](values);
|
|
308
285
|
|
|
309
|
-
return _filterInstanceProperty__default["default"](
|
|
286
|
+
return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, function (currencyCode) {
|
|
310
287
|
return MoneyInput__default["default"].isEmpty(values[currencyCode]);
|
|
311
288
|
});
|
|
312
289
|
};
|
|
@@ -314,7 +291,7 @@ LocalizedMoneyInput.getEmptyCurrencies = function (values) {
|
|
|
314
291
|
var LocalizedMoneyInput$1 = LocalizedMoneyInput;
|
|
315
292
|
|
|
316
293
|
// NOTE: This string will be replaced on build time with the package version.
|
|
317
|
-
var version = "13.0.
|
|
294
|
+
var version = "13.0.4";
|
|
318
295
|
|
|
319
296
|
exports["default"] = LocalizedMoneyInput$1;
|
|
320
297
|
exports.version = version;
|
|
@@ -8,10 +8,10 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
|
|
|
8
8
|
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
9
9
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
10
10
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
11
|
-
require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
12
11
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
13
12
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
13
|
var _toConsumableArray = require('@babel/runtime-corejs3/helpers/toConsumableArray');
|
|
14
|
+
require('prop-types');
|
|
15
15
|
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
16
16
|
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
17
17
|
var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
|
|
@@ -20,8 +20,6 @@ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instan
|
|
|
20
20
|
var _Object$values = require('@babel/runtime-corejs3/core-js-stable/object/values');
|
|
21
21
|
var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
22
22
|
var react = require('react');
|
|
23
|
-
require('prop-types');
|
|
24
|
-
require('common-tags');
|
|
25
23
|
var reactIntl = require('react-intl');
|
|
26
24
|
require('@emotion/react');
|
|
27
25
|
var hooks = require('@commercetools-uikit/hooks');
|
|
@@ -73,7 +71,7 @@ var messages = reactIntl.defineMessages({
|
|
|
73
71
|
|
|
74
72
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
75
73
|
|
|
76
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
74
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
77
75
|
var sequentialId = utils.createSequentialId('localized-money-input-'); // sorts the currencies with the following priority:
|
|
78
76
|
// - The selected currency is placed first (e.g EUR)
|
|
79
77
|
// - All other currencies follow, sorted alphabetically as well
|
|
@@ -107,16 +105,14 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
107
105
|
// might clear it using the knob, and then we can't parse the currency from
|
|
108
106
|
// the input name anymore.
|
|
109
107
|
//
|
|
110
|
-
// eslint-disable-next-line no-param-reassign
|
|
111
108
|
event.target.currency = props.currency;
|
|
112
|
-
onChange(event);
|
|
109
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event);
|
|
113
110
|
}, [props.currency, onChange]);
|
|
114
111
|
return jsxRuntime.jsxs(Stack__default["default"], {
|
|
115
112
|
scale: "xs",
|
|
116
113
|
children: [jsxRuntime.jsx("div", {
|
|
117
114
|
css: _ref,
|
|
118
115
|
children: jsxRuntime.jsx(MoneyInput__default["default"], _objectSpread({
|
|
119
|
-
id: props.id,
|
|
120
116
|
name: props.name,
|
|
121
117
|
value: props.value,
|
|
122
118
|
onChange: handleChange,
|
|
@@ -133,8 +129,8 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
133
129
|
});
|
|
134
130
|
};
|
|
135
131
|
|
|
136
|
-
LocalizedInput.displayName = 'LocalizedInput';
|
|
137
132
|
LocalizedInput.propTypes = {};
|
|
133
|
+
LocalizedInput.displayName = 'LocalizedInput';
|
|
138
134
|
|
|
139
135
|
var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
140
136
|
var intl = reactIntl.useIntl();
|
|
@@ -146,6 +142,9 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
146
142
|
areCurrenciesExpanded = _useToggleState2[0],
|
|
147
143
|
toggleCurrencies = _useToggleState2[1];
|
|
148
144
|
|
|
145
|
+
var onLocalizedMoneyInputToggle = react.useCallback(function () {
|
|
146
|
+
return toggleCurrencies();
|
|
147
|
+
}, [toggleCurrencies]);
|
|
149
148
|
var id = hooks.useFieldId(props.id, sequentialId);
|
|
150
149
|
var hasErrorInRemainingCurrencies = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);
|
|
151
150
|
var hasWarningInRemainingCurrencies = props.hasWarning || localizedUtils.getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);
|
|
@@ -160,6 +159,9 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
160
159
|
|
|
161
160
|
var currencies = sortCurrencies(props.selectedCurrency, _Object$keys__default["default"](props.value));
|
|
162
161
|
var shouldRenderCurrencyControl = currencies.length > 1 && !props.hideCurrencyExpansionControls;
|
|
162
|
+
|
|
163
|
+
if (props.hideCurrencyExpansionControls) ;
|
|
164
|
+
|
|
163
165
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
164
166
|
max: props.horizontalConstraint,
|
|
165
167
|
children: jsxRuntime.jsxs(Stack__default["default"], {
|
|
@@ -182,14 +184,13 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
182
184
|
isReadOnly: props.isReadOnly,
|
|
183
185
|
hasError: Boolean(props.hasError || props.errors && props.errors[currency]),
|
|
184
186
|
hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[currency]),
|
|
185
|
-
intl: intl,
|
|
186
187
|
warning: props.warnings && props.warnings[currency],
|
|
187
188
|
error: props.errors && props.errors[currency]
|
|
188
189
|
}, localizedUtils.createLocalizedDataAttributes(props, currency)), currency);
|
|
189
190
|
})
|
|
190
191
|
}), shouldRenderCurrencyControl && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
|
|
191
192
|
icon: jsxRuntime.jsx(icons.CoinsIcon, {}),
|
|
192
|
-
onClick:
|
|
193
|
+
onClick: onLocalizedMoneyInputToggle,
|
|
193
194
|
isOpen: areCurrenciesExpanded,
|
|
194
195
|
isDisabled: areCurrenciesExpanded && Boolean(hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies),
|
|
195
196
|
showMessage: intl.formatMessage(messages.show, {
|
|
@@ -203,8 +204,8 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
203
204
|
});
|
|
204
205
|
};
|
|
205
206
|
|
|
206
|
-
LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
|
|
207
207
|
LocalizedMoneyInput.propTypes = {};
|
|
208
|
+
LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
|
|
208
209
|
LocalizedMoneyInput.getId = localizedUtils.getId;
|
|
209
210
|
LocalizedMoneyInput.getName = localizedUtils.getName;
|
|
210
211
|
LocalizedMoneyInput.defaultProps = {
|
|
@@ -212,37 +213,34 @@ LocalizedMoneyInput.defaultProps = {
|
|
|
212
213
|
};
|
|
213
214
|
|
|
214
215
|
LocalizedMoneyInput.convertToMoneyValues = function (values, locale) {
|
|
215
|
-
var
|
|
216
|
+
var _context2;
|
|
216
217
|
|
|
217
|
-
return _mapInstanceProperty__default["default"](
|
|
218
|
+
return _mapInstanceProperty__default["default"](_context2 = _Object$values__default["default"](values)).call(_context2, function (value) {
|
|
218
219
|
return MoneyInput__default["default"].convertToMoneyValue(value, locale);
|
|
219
220
|
});
|
|
220
221
|
};
|
|
221
222
|
|
|
222
223
|
LocalizedMoneyInput.parseMoneyValues = function () {
|
|
223
|
-
var _context4;
|
|
224
|
-
|
|
225
224
|
var moneyValues = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
226
225
|
var locale = arguments.length > 1 ? arguments[1] : undefined;
|
|
227
|
-
return _reduceInstanceProperty__default["default"](
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
return _objectSpread(_objectSpread({}, pairs), {}, _defineProperty({}, value.currencyCode, value));
|
|
226
|
+
return _reduceInstanceProperty__default["default"](moneyValues).call(moneyValues, function (allValues, moneyValue) {
|
|
227
|
+
var value = MoneyInput__default["default"].parseMoneyValue(moneyValue, locale);
|
|
228
|
+
return _objectSpread(_objectSpread({}, allValues), {}, _defineProperty({}, value.currencyCode, value));
|
|
231
229
|
}, {});
|
|
232
230
|
};
|
|
233
231
|
|
|
234
232
|
LocalizedMoneyInput.getHighPrecisionCurrencies = function (values, locale) {
|
|
235
|
-
var
|
|
233
|
+
var typedCurrencyCodes = _Object$keys__default["default"](values);
|
|
236
234
|
|
|
237
|
-
return _filterInstanceProperty__default["default"](
|
|
235
|
+
return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, function (currencyCode) {
|
|
238
236
|
return MoneyInput__default["default"].isHighPrecision(values[currencyCode], locale);
|
|
239
237
|
});
|
|
240
238
|
};
|
|
241
239
|
|
|
242
240
|
LocalizedMoneyInput.getEmptyCurrencies = function (values) {
|
|
243
|
-
var
|
|
241
|
+
var typedCurrencyCodes = _Object$keys__default["default"](values);
|
|
244
242
|
|
|
245
|
-
return _filterInstanceProperty__default["default"](
|
|
243
|
+
return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, function (currencyCode) {
|
|
246
244
|
return MoneyInput__default["default"].isEmpty(values[currencyCode]);
|
|
247
245
|
});
|
|
248
246
|
};
|
|
@@ -250,7 +248,7 @@ LocalizedMoneyInput.getEmptyCurrencies = function (values) {
|
|
|
250
248
|
var LocalizedMoneyInput$1 = LocalizedMoneyInput;
|
|
251
249
|
|
|
252
250
|
// NOTE: This string will be replaced on build time with the package version.
|
|
253
|
-
var version = "13.0.
|
|
251
|
+
var version = "13.0.4";
|
|
254
252
|
|
|
255
253
|
exports["default"] = LocalizedMoneyInput$1;
|
|
256
254
|
exports.version = version;
|
|
@@ -4,10 +4,10 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
|
|
|
4
4
|
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
5
5
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
6
6
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
7
|
-
import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
|
|
8
7
|
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
9
8
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
9
|
import _toConsumableArray from '@babel/runtime-corejs3/helpers/esm/toConsumableArray';
|
|
10
|
+
import _pt from 'prop-types';
|
|
11
11
|
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
12
12
|
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
13
13
|
import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort';
|
|
@@ -16,8 +16,6 @@ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance
|
|
|
16
16
|
import _Object$values from '@babel/runtime-corejs3/core-js-stable/object/values';
|
|
17
17
|
import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
|
|
18
18
|
import { useCallback } from 'react';
|
|
19
|
-
import PropTypes from 'prop-types';
|
|
20
|
-
import { oneLine } from 'common-tags';
|
|
21
19
|
import { defineMessages, useIntl } from 'react-intl';
|
|
22
20
|
import '@emotion/react';
|
|
23
21
|
import { useToggleState, useFieldId } from '@commercetools-uikit/hooks';
|
|
@@ -26,7 +24,7 @@ import Stack from '@commercetools-uikit/spacings-stack';
|
|
|
26
24
|
import Constraints from '@commercetools-uikit/constraints';
|
|
27
25
|
import { CoinsIcon } from '@commercetools-uikit/icons';
|
|
28
26
|
import { getHasErrorOnRemainingLanguages, getHasWarningOnRemainingLanguages, createLocalizedDataAttributes, getId, getName } from '@commercetools-uikit/localized-utils';
|
|
29
|
-
import { createSequentialId, filterDataAttributes } from '@commercetools-uikit/utils';
|
|
27
|
+
import { createSequentialId, warning, filterDataAttributes } from '@commercetools-uikit/utils';
|
|
30
28
|
import { LocalizedInputToggle } from '@commercetools-uikit/input-utils';
|
|
31
29
|
import { jsx, jsxs } from '@emotion/react/jsx-runtime';
|
|
32
30
|
|
|
@@ -48,11 +46,9 @@ var messages = defineMessages({
|
|
|
48
46
|
}
|
|
49
47
|
});
|
|
50
48
|
|
|
51
|
-
var _templateObject;
|
|
52
|
-
|
|
53
49
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
54
50
|
|
|
55
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
51
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
56
52
|
|
|
57
53
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
58
54
|
var sequentialId = createSequentialId('localized-money-input-'); // sorts the currencies with the following priority:
|
|
@@ -75,7 +71,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
75
71
|
} : {
|
|
76
72
|
name: "1ysn02y-LocalizedInput",
|
|
77
73
|
styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
|
|
78
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.js"],"names":[],"mappings":"AA4DgB","file":"localized-money-input.js","sourcesContent":["import { useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport { oneLine } from 'common-tags';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { useToggleState, useFieldId } from '@commercetools-uikit/hooks';\nimport MoneyInput from '@commercetools-uikit/money-input';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { CoinsIcon } from '@commercetools-uikit/icons';\nimport {\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport messages from './messages';\n\nconst sequentialId = createSequentialId('localized-money-input-');\n\n// sorts the currencies with the following priority:\n// - The selected currency is placed first (e.g EUR)\n// - All other currencies follow, sorted alphabetically as well\nexport const sortCurrencies = (selectedCurrency, allCurrencies) => {\n  const remainingCurrencies = allCurrencies.filter(\n    (currency) => currency !== selectedCurrency\n  );\n  return [selectedCurrency, ...remainingCurrencies.sort()];\n};\n\nconst LocalizedInput = (props) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the currency to the target.\n      // That way the users  can read\n      // event.target.currency and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the currency from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.currency = props.currency;\n      onChange(event);\n    },\n    [props.currency, onChange]\n  );\n  return (\n    <Stack scale=\"xs\">\n      <div\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <MoneyInput\n          id={props.id}\n          name={props.name}\n          value={props.value}\n          onChange={handleChange}\n          onBlur={props.onBlur}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {(props.error || props.warning) && (\n        <div>{props.error ? props.error : props.warning}</div>\n      )}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nLocalizedInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  onChange: PropTypes.func,\n  currency: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n};\n\nconst LocalizedMoneyInput = (props) => {\n  const intl = useIntl();\n\n  const defaultExpansionState =\n    props.hideCurrencyExpansionControls ||\n    props.defaultExpandCurrencies ||\n    // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areCurrenciesExpanded, toggleCurrencies] = useToggleState(\n    defaultExpansionState\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingCurrencies =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);\n\n  const hasWarningInRemainingCurrencies =\n    props.hasWarning ||\n    getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);\n\n  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (!areCurrenciesExpanded) {\n      toggleCurrencies();\n    }\n  }\n\n  const currencies = sortCurrencies(\n    props.selectedCurrency,\n    Object.keys(props.value)\n  );\n\n  const shouldRenderCurrencyControl =\n    currencies.length > 1 && !props.hideCurrencyExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack scale=\"s\">\n          {currencies.map((currency, index) => {\n            const isFirstCurrency = index === 0;\n            if (!isFirstCurrency && !areCurrenciesExpanded) return null;\n\n            return (\n              <LocalizedInput\n                key={currency}\n                id={LocalizedMoneyInput.getId(id, currency)}\n                name={LocalizedMoneyInput.getName(props.name, currency)}\n                value={props.value[currency]}\n                onChange={props.onChange}\n                currency={currency}\n                placeholder={\n                  props.placeholder ? props.placeholder[currency] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[currency])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[currency])\n                )}\n                intl={intl}\n                warning={props.warnings && props.warnings[currency]}\n                error={props.errors && props.errors[currency]}\n                {...createLocalizedDataAttributes(props, currency)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderCurrencyControl && (\n          <LocalizedInputToggle\n            icon={<CoinsIcon />}\n            onClick={toggleCurrencies}\n            isOpen={areCurrenciesExpanded}\n            isDisabled={\n              areCurrenciesExpanded &&\n              Boolean(\n                hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies\n              )\n            }\n            showMessage={intl.formatMessage(messages.show, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n            hideMessage={intl.formatMessage(messages.hide, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedMoneyInput.displayName = 'LocalizedMoneyInput';\n\nLocalizedMoneyInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  // then input doesn't accept a \"currencies\" prop, instead all possible\n  // currencies have to exist (with empty or filled strings) on the value:\n  // { EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}}\n  value: PropTypes.objectOf(\n    PropTypes.shape({\n      amount: PropTypes.string.isRequired,\n      currencyCode: PropTypes.string.isRequired,\n    })\n  ).isRequired,\n  onChange: PropTypes.func,\n  selectedCurrency: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  hideCurrencyExpansionControls: PropTypes.bool,\n  defaultExpandCurrencies: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideCurrencyExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideCurrencyExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  errors: PropTypes.objectOf(PropTypes.node),\n  warnings: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedMoneyInput.getId = getId;\n\nLocalizedMoneyInput.getName = getName;\n\nLocalizedMoneyInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedMoneyInput.convertToMoneyValues = (values, locale) =>\n  Object.values(values).map((value) =>\n    MoneyInput.convertToMoneyValue(value, locale)\n  );\n\nLocalizedMoneyInput.parseMoneyValues = (moneyValues = [], locale) =>\n  moneyValues\n    .map((value) => MoneyInput.parseMoneyValue(value, locale))\n    .reduce(\n      (pairs, value) => ({\n        ...pairs,\n        [value.currencyCode]: value,\n      }),\n      {}\n    );\n\nLocalizedMoneyInput.getHighPrecisionCurrencies = (values, locale) =>\n  Object.keys(values).filter((currencyCode) =>\n    MoneyInput.isHighPrecision(values[currencyCode], locale)\n  );\n\nLocalizedMoneyInput.getEmptyCurrencies = (values) =>\n  Object.keys(values).filter((currencyCode) =>\n    MoneyInput.isEmpty(values[currencyCode])\n  );\n\nexport default LocalizedMoneyInput;\n"]} */",
|
|
74
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAwOgB","file":"localized-money-input.tsx","sourcesContent":["import {\n  useCallback,\n  type FocusEventHandler,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { useToggleState, useFieldId } from '@commercetools-uikit/hooks';\nimport MoneyInput, {\n  type TCurrencyCode,\n  type TMoneyValue,\n  type TValue,\n} from '@commercetools-uikit/money-input';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { CoinsIcon } from '@commercetools-uikit/icons';\nimport {\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport messages from './messages';\n\ntype TEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n};\n\ntype TLocalizedMoneyInputProps = {\n  /**\n   * Used as HTML id property.\n   */\n  id?: string;\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`).\n   */\n  name?: string;\n  /**\n   * value of possible currency\n   * <br/>\n   * the input doesn't accept a \"currencies\" prop, instead all possible\n   * currencies have to exist (with empty or filled strings) on the value:\n   * { EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}}\n   */\n  value: Record<string, TValue>;\n  /**\n   * Called with the event of the input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * the currently selected currency\n   */\n  selectedCurrency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Will hide the currency expansion controls when set to `true`. All currencies will be shown when set to `true`.\n   */\n  hideCurrencyExpansionControls?: boolean;\n  /**\n   * Controls whether one or all currencirs are visible by default\n   */\n  defaultExpandCurrencies?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * A map of errors. Error messages for known errors are rendered automatically.\n   * <br>\n   * Unknown errors will be forwarded to `renderError`\n   */\n  errors?: Record<string, ReactNode>;\n  /**\n   * A map of warnings.\n   */\n  warnings?: Record<string, ReactNode>;\n};\n\ntype TLocalizedInputProps = {\n  /**\n   * Used as HTML id property.\n   */\n  id?: string;\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`).\n   */\n  name?: string;\n  /**\n   * value of possible currency\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * Called with the event of the input.\n   */\n  currency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * A map of errors. Error messages for known errors are rendered automatically.\n   * <br>\n   * Unknown errors will be forwarded to `renderError`\n   */\n  error?: ReactNode;\n  /**\n   * HTML node to display warning\n   */\n  warning?: ReactNode;\n};\n\nconst sequentialId = createSequentialId('localized-money-input-');\n\n// sorts the currencies with the following priority:\n// - The selected currency is placed first (e.g EUR)\n// - All other currencies follow, sorted alphabetically as well\nexport const sortCurrencies = (\n  selectedCurrency: string,\n  allCurrencies: string[]\n) => {\n  const remainingCurrencies = allCurrencies.filter(\n    (currency) => currency !== selectedCurrency\n  );\n  return [selectedCurrency, ...remainingCurrencies.sort()];\n};\n\nconst LocalizedInput = (props: TLocalizedInputProps) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the currency to the target.\n      // That way the users  can read\n      // event.target.currency and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the currency from\n      // the input name anymore.\n      //\n      event.target.currency = props.currency;\n      onChange?.(event);\n    },\n    [props.currency, onChange]\n  );\n  return (\n    <Stack scale=\"xs\">\n      <div\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <MoneyInput\n          name={props.name}\n          value={props.value}\n          onChange={handleChange}\n          onBlur={props.onBlur}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {(props.error || props.warning) && (\n        <div>{props.error ? props.error : props.warning}</div>\n      )}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst LocalizedMoneyInput = (props: TLocalizedMoneyInputProps) => {\n  const intl = useIntl();\n\n  const defaultExpansionState =\n    props.hideCurrencyExpansionControls ||\n    props.defaultExpandCurrencies ||\n    // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areCurrenciesExpanded, toggleCurrencies] = useToggleState(\n    defaultExpansionState\n  );\n\n  const onLocalizedMoneyInputToggle = useCallback(\n    () => toggleCurrencies(),\n    [toggleCurrencies]\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingCurrencies =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);\n\n  const hasWarningInRemainingCurrencies =\n    props.hasWarning ||\n    getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);\n\n  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (!areCurrenciesExpanded) {\n      toggleCurrencies();\n    }\n  }\n\n  const currencies = sortCurrencies(\n    props.selectedCurrency,\n    Object.keys(props.value)\n  );\n\n  const shouldRenderCurrencyControl =\n    currencies.length > 1 && !props.hideCurrencyExpansionControls;\n\n  if (props.hideCurrencyExpansionControls) {\n    warning(\n      typeof props.defaultExpandCurrencies !== 'boolean',\n      'LocalizedMoneyInput: \"defaultExpandCurrencies\" does not have any effect when \"hideCurrencyExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack scale=\"s\">\n          {currencies.map((currency, index) => {\n            const isFirstCurrency = index === 0;\n            if (!isFirstCurrency && !areCurrenciesExpanded) return null;\n\n            return (\n              <LocalizedInput\n                key={currency}\n                id={LocalizedMoneyInput.getId(id, currency)}\n                name={LocalizedMoneyInput.getName(props.name, currency)}\n                value={props.value[currency]}\n                onChange={props.onChange}\n                currency={currency}\n                placeholder={\n                  props.placeholder ? props.placeholder[currency] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[currency])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[currency])\n                )}\n                warning={props.warnings && props.warnings[currency]}\n                error={props.errors && props.errors[currency]}\n                {...createLocalizedDataAttributes(props, currency)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderCurrencyControl && (\n          <LocalizedInputToggle\n            icon={<CoinsIcon />}\n            onClick={onLocalizedMoneyInputToggle}\n            isOpen={areCurrenciesExpanded}\n            isDisabled={\n              areCurrenciesExpanded &&\n              Boolean(\n                hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies\n              )\n            }\n            showMessage={intl.formatMessage(messages.show, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n            hideMessage={intl.formatMessage(messages.hide, {\n              remainingCurrencies: currencies.length - 1,\n            })}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedMoneyInput.displayName = 'LocalizedMoneyInput';\n\nLocalizedMoneyInput.getId = getId;\n\nLocalizedMoneyInput.getName = getName;\n\nLocalizedMoneyInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedMoneyInput.convertToMoneyValues = (\n  values: TValue[],\n  locale: string\n): Array<TMoneyValue | null> =>\n  Object.values(values).map<TMoneyValue | null>((value) => {\n    return MoneyInput.convertToMoneyValue(value, locale);\n  });\n\nLocalizedMoneyInput.parseMoneyValues = (\n  moneyValues: TMoneyValue[] = [],\n  locale: string\n): Record<TCurrencyCode, TValue> =>\n  moneyValues.reduce<Record<TCurrencyCode, TValue>>((allValues, moneyValue) => {\n    const value = MoneyInput.parseMoneyValue(moneyValue, locale);\n    return {\n      ...allValues,\n      [value.currencyCode]: value,\n    };\n  }, {} as Record<TCurrencyCode, TValue>);\n\nLocalizedMoneyInput.getHighPrecisionCurrencies = (\n  values: Record<TCurrencyCode, TValue>,\n  locale: string\n): TCurrencyCode[] => {\n  const typedCurrencyCodes = Object.keys(values) as TCurrencyCode[];\n  return typedCurrencyCodes.filter((currencyCode) =>\n    MoneyInput.isHighPrecision(values[currencyCode], locale)\n  );\n};\n\nLocalizedMoneyInput.getEmptyCurrencies = (\n  values: Record<TCurrencyCode, TValue>\n): TCurrencyCode[] => {\n  const typedCurrencyCodes = Object.keys(values) as TCurrencyCode[];\n  return typedCurrencyCodes.filter((currencyCode) =>\n    MoneyInput.isEmpty(values[currencyCode])\n  );\n};\n\nexport default LocalizedMoneyInput;\n"]} */",
|
|
79
75
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
80
76
|
};
|
|
81
77
|
|
|
@@ -93,16 +89,14 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
93
89
|
// might clear it using the knob, and then we can't parse the currency from
|
|
94
90
|
// the input name anymore.
|
|
95
91
|
//
|
|
96
|
-
// eslint-disable-next-line no-param-reassign
|
|
97
92
|
event.target.currency = props.currency;
|
|
98
|
-
onChange(event);
|
|
93
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event);
|
|
99
94
|
}, [props.currency, onChange]);
|
|
100
95
|
return jsxs(Stack, {
|
|
101
96
|
scale: "xs",
|
|
102
97
|
children: [jsx("div", {
|
|
103
98
|
css: _ref,
|
|
104
99
|
children: jsx(MoneyInput, _objectSpread({
|
|
105
|
-
id: props.id,
|
|
106
100
|
name: props.name,
|
|
107
101
|
value: props.value,
|
|
108
102
|
onChange: handleChange,
|
|
@@ -119,26 +113,23 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
119
113
|
});
|
|
120
114
|
};
|
|
121
115
|
|
|
122
|
-
LocalizedInput.displayName = 'LocalizedInput';
|
|
123
116
|
LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
124
|
-
id:
|
|
125
|
-
name:
|
|
126
|
-
value:
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
placeholder: PropTypes.string,
|
|
139
|
-
error: PropTypes.node,
|
|
140
|
-
warning: PropTypes.node
|
|
117
|
+
id: _pt.string,
|
|
118
|
+
name: _pt.string,
|
|
119
|
+
value: _pt.any.isRequired,
|
|
120
|
+
onChange: _pt.func,
|
|
121
|
+
currency: _pt.string.isRequired,
|
|
122
|
+
onBlur: _pt.func,
|
|
123
|
+
onFocus: _pt.func,
|
|
124
|
+
isDisabled: _pt.bool,
|
|
125
|
+
isReadOnly: _pt.bool,
|
|
126
|
+
hasError: _pt.bool,
|
|
127
|
+
hasWarning: _pt.bool,
|
|
128
|
+
placeholder: _pt.string,
|
|
129
|
+
error: _pt.node,
|
|
130
|
+
warning: _pt.node
|
|
141
131
|
} : {};
|
|
132
|
+
LocalizedInput.displayName = 'LocalizedInput';
|
|
142
133
|
|
|
143
134
|
var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
144
135
|
var intl = useIntl();
|
|
@@ -150,6 +141,9 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
150
141
|
areCurrenciesExpanded = _useToggleState2[0],
|
|
151
142
|
toggleCurrencies = _useToggleState2[1];
|
|
152
143
|
|
|
144
|
+
var onLocalizedMoneyInputToggle = useCallback(function () {
|
|
145
|
+
return toggleCurrencies();
|
|
146
|
+
}, [toggleCurrencies]);
|
|
153
147
|
var id = useFieldId(props.id, sequentialId);
|
|
154
148
|
var hasErrorInRemainingCurrencies = props.hasError || getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);
|
|
155
149
|
var hasWarningInRemainingCurrencies = props.hasWarning || getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);
|
|
@@ -164,6 +158,11 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
164
158
|
|
|
165
159
|
var currencies = sortCurrencies(props.selectedCurrency, _Object$keys(props.value));
|
|
166
160
|
var shouldRenderCurrencyControl = currencies.length > 1 && !props.hideCurrencyExpansionControls;
|
|
161
|
+
|
|
162
|
+
if (props.hideCurrencyExpansionControls) {
|
|
163
|
+
process.env.NODE_ENV !== "production" ? warning(typeof props.defaultExpandCurrencies !== 'boolean', 'LocalizedMoneyInput: "defaultExpandCurrencies" does not have any effect when "hideCurrencyExpansionControls" is set.') : void 0;
|
|
164
|
+
}
|
|
165
|
+
|
|
167
166
|
return jsx(Constraints.Horizontal, {
|
|
168
167
|
max: props.horizontalConstraint,
|
|
169
168
|
children: jsxs(Stack, {
|
|
@@ -186,14 +185,13 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
186
185
|
isReadOnly: props.isReadOnly,
|
|
187
186
|
hasError: Boolean(props.hasError || props.errors && props.errors[currency]),
|
|
188
187
|
hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[currency]),
|
|
189
|
-
intl: intl,
|
|
190
188
|
warning: props.warnings && props.warnings[currency],
|
|
191
189
|
error: props.errors && props.errors[currency]
|
|
192
190
|
}, createLocalizedDataAttributes(props, currency)), currency);
|
|
193
191
|
})
|
|
194
192
|
}), shouldRenderCurrencyControl && jsx(LocalizedInputToggle, {
|
|
195
193
|
icon: jsx(CoinsIcon, {}),
|
|
196
|
-
onClick:
|
|
194
|
+
onClick: onLocalizedMoneyInputToggle,
|
|
197
195
|
isOpen: areCurrenciesExpanded,
|
|
198
196
|
isDisabled: areCurrenciesExpanded && Boolean(hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies),
|
|
199
197
|
showMessage: intl.formatMessage(messages.show, {
|
|
@@ -207,44 +205,26 @@ var LocalizedMoneyInput = function LocalizedMoneyInput(props) {
|
|
|
207
205
|
});
|
|
208
206
|
};
|
|
209
207
|
|
|
210
|
-
LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
|
|
211
208
|
LocalizedMoneyInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
212
|
-
id:
|
|
213
|
-
name:
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
if (props.hideCurrencyExpansionControls && typeof props[propName] === 'boolean') {
|
|
230
|
-
throw new Error(oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideCurrencyExpansionControls\" is set.\n "])), componentName, propName));
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
|
|
234
|
-
rest[_key - 3] = arguments[_key];
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
return PropTypes.bool.apply(PropTypes, _concatInstanceProperty(_context2 = [props, propName, componentName]).call(_context2, rest));
|
|
238
|
-
},
|
|
239
|
-
isDisabled: PropTypes.bool,
|
|
240
|
-
isReadOnly: PropTypes.bool,
|
|
241
|
-
placeholder: PropTypes.objectOf(PropTypes.string),
|
|
242
|
-
horizontalConstraint: PropTypes.oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
243
|
-
hasError: PropTypes.bool,
|
|
244
|
-
hasWarning: PropTypes.bool,
|
|
245
|
-
errors: PropTypes.objectOf(PropTypes.node),
|
|
246
|
-
warnings: PropTypes.objectOf(PropTypes.node)
|
|
209
|
+
id: _pt.string,
|
|
210
|
+
name: _pt.string,
|
|
211
|
+
value: _pt.objectOf(_pt.any).isRequired,
|
|
212
|
+
onChange: _pt.func,
|
|
213
|
+
selectedCurrency: _pt.string.isRequired,
|
|
214
|
+
onBlur: _pt.func,
|
|
215
|
+
onFocus: _pt.func,
|
|
216
|
+
hideCurrencyExpansionControls: _pt.bool,
|
|
217
|
+
defaultExpandCurrencies: _pt.bool,
|
|
218
|
+
isDisabled: _pt.bool,
|
|
219
|
+
isReadOnly: _pt.bool,
|
|
220
|
+
placeholder: _pt.objectOf(_pt.string),
|
|
221
|
+
horizontalConstraint: _pt.oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
222
|
+
hasError: _pt.bool,
|
|
223
|
+
hasWarning: _pt.bool,
|
|
224
|
+
errors: _pt.objectOf(_pt.node),
|
|
225
|
+
warnings: _pt.objectOf(_pt.node)
|
|
247
226
|
} : {};
|
|
227
|
+
LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
|
|
248
228
|
LocalizedMoneyInput.getId = getId;
|
|
249
229
|
LocalizedMoneyInput.getName = getName;
|
|
250
230
|
LocalizedMoneyInput.defaultProps = {
|
|
@@ -252,37 +232,34 @@ LocalizedMoneyInput.defaultProps = {
|
|
|
252
232
|
};
|
|
253
233
|
|
|
254
234
|
LocalizedMoneyInput.convertToMoneyValues = function (values, locale) {
|
|
255
|
-
var
|
|
235
|
+
var _context2;
|
|
256
236
|
|
|
257
|
-
return _mapInstanceProperty(
|
|
237
|
+
return _mapInstanceProperty(_context2 = _Object$values(values)).call(_context2, function (value) {
|
|
258
238
|
return MoneyInput.convertToMoneyValue(value, locale);
|
|
259
239
|
});
|
|
260
240
|
};
|
|
261
241
|
|
|
262
242
|
LocalizedMoneyInput.parseMoneyValues = function () {
|
|
263
|
-
var _context4;
|
|
264
|
-
|
|
265
243
|
var moneyValues = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
266
244
|
var locale = arguments.length > 1 ? arguments[1] : undefined;
|
|
267
|
-
return _reduceInstanceProperty(
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
return _objectSpread(_objectSpread({}, pairs), {}, _defineProperty({}, value.currencyCode, value));
|
|
245
|
+
return _reduceInstanceProperty(moneyValues).call(moneyValues, function (allValues, moneyValue) {
|
|
246
|
+
var value = MoneyInput.parseMoneyValue(moneyValue, locale);
|
|
247
|
+
return _objectSpread(_objectSpread({}, allValues), {}, _defineProperty({}, value.currencyCode, value));
|
|
271
248
|
}, {});
|
|
272
249
|
};
|
|
273
250
|
|
|
274
251
|
LocalizedMoneyInput.getHighPrecisionCurrencies = function (values, locale) {
|
|
275
|
-
var
|
|
252
|
+
var typedCurrencyCodes = _Object$keys(values);
|
|
276
253
|
|
|
277
|
-
return _filterInstanceProperty(
|
|
254
|
+
return _filterInstanceProperty(typedCurrencyCodes).call(typedCurrencyCodes, function (currencyCode) {
|
|
278
255
|
return MoneyInput.isHighPrecision(values[currencyCode], locale);
|
|
279
256
|
});
|
|
280
257
|
};
|
|
281
258
|
|
|
282
259
|
LocalizedMoneyInput.getEmptyCurrencies = function (values) {
|
|
283
|
-
var
|
|
260
|
+
var typedCurrencyCodes = _Object$keys(values);
|
|
284
261
|
|
|
285
|
-
return _filterInstanceProperty(
|
|
262
|
+
return _filterInstanceProperty(typedCurrencyCodes).call(typedCurrencyCodes, function (currencyCode) {
|
|
286
263
|
return MoneyInput.isEmpty(values[currencyCode]);
|
|
287
264
|
});
|
|
288
265
|
};
|
|
@@ -290,6 +267,6 @@ LocalizedMoneyInput.getEmptyCurrencies = function (values) {
|
|
|
290
267
|
var LocalizedMoneyInput$1 = LocalizedMoneyInput;
|
|
291
268
|
|
|
292
269
|
// NOTE: This string will be replaced on build time with the package version.
|
|
293
|
-
var version = "13.0.
|
|
270
|
+
var version = "13.0.4";
|
|
294
271
|
|
|
295
272
|
export { LocalizedMoneyInput$1 as default, version };
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { type FocusEventHandler, type ChangeEventHandler, type ReactNode } from 'react';
|
|
2
|
+
import { type TCurrencyCode, type TMoneyValue, type TValue } from '@commercetools-uikit/money-input';
|
|
3
|
+
declare type TEvent = {
|
|
4
|
+
target: {
|
|
5
|
+
id?: string;
|
|
6
|
+
name?: string;
|
|
7
|
+
value?: string | string[] | null;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
declare type TLocalizedMoneyInputProps = {
|
|
11
|
+
id?: string;
|
|
12
|
+
name?: string;
|
|
13
|
+
value: Record<string, TValue>;
|
|
14
|
+
onChange?: ChangeEventHandler;
|
|
15
|
+
selectedCurrency: string;
|
|
16
|
+
onBlur?: (event: TEvent) => void;
|
|
17
|
+
onFocus?: FocusEventHandler;
|
|
18
|
+
hideCurrencyExpansionControls?: boolean;
|
|
19
|
+
defaultExpandCurrencies?: boolean;
|
|
20
|
+
isDisabled?: boolean;
|
|
21
|
+
isReadOnly?: boolean;
|
|
22
|
+
placeholder?: Record<string, string>;
|
|
23
|
+
horizontalConstraint?: 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
|
|
24
|
+
hasError?: boolean;
|
|
25
|
+
hasWarning?: boolean;
|
|
26
|
+
errors?: Record<string, ReactNode>;
|
|
27
|
+
warnings?: Record<string, ReactNode>;
|
|
28
|
+
};
|
|
29
|
+
export declare const sortCurrencies: (selectedCurrency: string, allCurrencies: string[]) => string[];
|
|
30
|
+
declare const LocalizedMoneyInput: {
|
|
31
|
+
(props: TLocalizedMoneyInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
32
|
+
displayName: string;
|
|
33
|
+
getId: (idPrefix?: string | undefined, language?: string | undefined) => string | undefined;
|
|
34
|
+
getName: (namePrefix?: string | undefined, language?: string | undefined) => string | undefined;
|
|
35
|
+
defaultProps: {
|
|
36
|
+
horizontalConstraint: string;
|
|
37
|
+
};
|
|
38
|
+
convertToMoneyValues(values: TValue[], locale: string): Array<TMoneyValue | null>;
|
|
39
|
+
parseMoneyValues(moneyValues: TMoneyValue[] | undefined, locale: string): Record<TCurrencyCode, TValue>;
|
|
40
|
+
getHighPrecisionCurrencies(values: Record<TCurrencyCode, TValue>, locale: string): TCurrencyCode[];
|
|
41
|
+
getEmptyCurrencies(values: Record<TCurrencyCode, TValue>): TCurrencyCode[];
|
|
42
|
+
};
|
|
43
|
+
export default LocalizedMoneyInput;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
missingRequiredField: {
|
|
3
|
+
id: string;
|
|
4
|
+
description: string;
|
|
5
|
+
defaultMessage: string;
|
|
6
|
+
};
|
|
7
|
+
show: {
|
|
8
|
+
id: string;
|
|
9
|
+
description: string;
|
|
10
|
+
defaultMessage: string;
|
|
11
|
+
};
|
|
12
|
+
hide: {
|
|
13
|
+
id: string;
|
|
14
|
+
description: string;
|
|
15
|
+
defaultMessage: string;
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export default _default;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/localized-money-input",
|
|
3
3
|
"description": "A controlled input component for localized money values with validation states.",
|
|
4
|
-
"version": "13.0.
|
|
4
|
+
"version": "13.0.4",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -23,27 +23,25 @@
|
|
|
23
23
|
"@babel/runtime-corejs3": "7.17.2",
|
|
24
24
|
"@commercetools-uikit/constraints": "13.0.2",
|
|
25
25
|
"@commercetools-uikit/design-system": "13.0.0",
|
|
26
|
-
"@commercetools-uikit/flat-button": "13.0.
|
|
26
|
+
"@commercetools-uikit/flat-button": "13.0.4",
|
|
27
27
|
"@commercetools-uikit/hooks": "13.0.2",
|
|
28
28
|
"@commercetools-uikit/icons": "13.0.2",
|
|
29
|
-
"@commercetools-uikit/input-utils": "13.0.
|
|
29
|
+
"@commercetools-uikit/input-utils": "13.0.4",
|
|
30
30
|
"@commercetools-uikit/localized-utils": "13.0.2",
|
|
31
|
-
"@commercetools-uikit/money-input": "13.0.
|
|
32
|
-
"@commercetools-uikit/select-utils": "13.0.
|
|
31
|
+
"@commercetools-uikit/money-input": "13.0.4",
|
|
32
|
+
"@commercetools-uikit/select-utils": "13.0.4",
|
|
33
33
|
"@commercetools-uikit/spacings-stack": "13.0.2",
|
|
34
34
|
"@commercetools-uikit/tooltip": "13.0.2",
|
|
35
35
|
"@commercetools-uikit/utils": "13.0.2",
|
|
36
36
|
"@emotion/react": "^11.4.0",
|
|
37
37
|
"@emotion/styled": "^11.3.0",
|
|
38
|
-
"common-tags": "1.8.2",
|
|
39
38
|
"prop-types": "15.8.1",
|
|
40
|
-
"react-required-if": "1.0.3",
|
|
41
39
|
"react-select": "5.2.2"
|
|
42
40
|
},
|
|
43
41
|
"devDependencies": {
|
|
44
42
|
"react": "17.0.2",
|
|
45
43
|
"react-dom": "17.0.2",
|
|
46
|
-
"react-intl": "5.24.6"
|
|
44
|
+
"react-intl": "^5.24.6"
|
|
47
45
|
},
|
|
48
46
|
"peerDependencies": {
|
|
49
47
|
"react": "17.x",
|