@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 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
- ```js
11
- import LocalizedMoneyInput from '@commercetools-uikit/localized-money-input';
10
+ ## Installation
12
11
 
13
- <LocalizedMoneyInput
14
- value={{
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
- ## Properties
23
-
24
- | Props | Type | Required | Values | Default | Description |
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
- Main Functions and use cases are:
20
+ Additionally install the peer dependencies (if not present)
47
21
 
48
- - Receiving localized input from user
22
+ ```
23
+ yarn add react react-dom react-intl
24
+ ```
49
25
 
50
- ## Static Properties
26
+ ```
27
+ npm --save install react react-dom react-intl
28
+ ```
51
29
 
52
- ### `LocalizedMoneyInput.convertToMoneyValue`
30
+ ## Usage
53
31
 
54
- The `convertToMoneyValue` function will turn a LocalizedMoneyInput value into a [`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.
55
- 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.
32
+ ```jsx
33
+ import LocalizedMoneyInput from '@commercetools-uikit/localized-money-input';
56
34
 
57
- Here are examples of `centPrecision` and `highPrecision` prices.
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
- ```js
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
- ```js
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
- ### `LocalizedMoneyInput.parseMoneyValue`
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&#xA;<br/>&#xA;the input doesn't accept a "currencies" prop, instead all possible&#xA;currencies have to exist (with empty or filled strings) on the value:&#xA;{ 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.&#xA;<br>&#xA;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
- The `parseMoneyValue` function will turn a [`MoneyValue`](https://docs.commercetools.com/http-api-types#money) into a value the LocalizedMoneyInput component can handle `({ amount, currencyCode })`.
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 `convertToMoneyValues` function will turn a LocalizedMoneyInput value into array 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.
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 [`MoneyValue`](https://docs.commercetools.com/http-api-types#money) into a value the LocalizedMoneyInput component can handle `({ [currencyCode]: {currencyCode, amount} })`.
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 `getEmptyCurrencies` function will return array of currencies that don't have amount .
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
- ## Example
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
  )}
@@ -0,0 +1,2 @@
1
+ export * from "./declarations/src/index";
2
+ export { default } from "./declarations/src/index";
@@ -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 _context7, _context8; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context7 = ownKeys(Object(source), !0)).call(_context7, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context8 = ownKeys(Object(source))).call(_context8, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
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: PropTypes__default["default"].string,
149
- name: PropTypes__default["default"].string,
150
- value: PropTypes__default["default"].shape({
151
- amount: PropTypes__default["default"].string.isRequired,
152
- currencyCode: PropTypes__default["default"].string.isRequired
153
- }).isRequired,
154
- onChange: PropTypes__default["default"].func,
155
- currency: PropTypes__default["default"].string.isRequired,
156
- onBlur: PropTypes__default["default"].func,
157
- onFocus: PropTypes__default["default"].func,
158
- isDisabled: PropTypes__default["default"].bool,
159
- isReadOnly: PropTypes__default["default"].bool,
160
- hasError: PropTypes__default["default"].bool,
161
- hasWarning: PropTypes__default["default"].bool,
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: toggleCurrencies,
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: PropTypes__default["default"].string,
237
- name: PropTypes__default["default"].string,
238
- // then input doesn't accept a "currencies" prop, instead all possible
239
- // currencies have to exist (with empty or filled strings) on the value:
240
- // { EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}}
241
- value: PropTypes__default["default"].objectOf(PropTypes__default["default"].shape({
242
- amount: PropTypes__default["default"].string.isRequired,
243
- currencyCode: PropTypes__default["default"].string.isRequired
244
- })).isRequired,
245
- onChange: PropTypes__default["default"].func,
246
- selectedCurrency: PropTypes__default["default"].string.isRequired,
247
- onBlur: PropTypes__default["default"].func,
248
- onFocus: PropTypes__default["default"].func,
249
- hideCurrencyExpansionControls: PropTypes__default["default"].bool,
250
- defaultExpandCurrencies: function defaultExpandCurrencies(props, propName, componentName) {
251
- var _context2;
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 _context3;
259
+ var _context2;
280
260
 
281
- return _mapInstanceProperty__default["default"](_context3 = _Object$values__default["default"](values)).call(_context3, function (value) {
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"](_context4 = _mapInstanceProperty__default["default"](moneyValues).call(moneyValues, function (value) {
292
- return MoneyInput__default["default"].parseMoneyValue(value, locale);
293
- })).call(_context4, function (pairs, value) {
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 _context5;
276
+ var typedCurrencyCodes = _Object$keys__default["default"](values);
300
277
 
301
- return _filterInstanceProperty__default["default"](_context5 = _Object$keys__default["default"](values)).call(_context5, function (currencyCode) {
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 _context6;
284
+ var typedCurrencyCodes = _Object$keys__default["default"](values);
308
285
 
309
- return _filterInstanceProperty__default["default"](_context6 = _Object$keys__default["default"](values)).call(_context6, function (currencyCode) {
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.3";
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 _context7, _context8; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context7 = ownKeys(Object(source), !0)).call(_context7, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context8 = ownKeys(Object(source))).call(_context8, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
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: toggleCurrencies,
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 _context3;
216
+ var _context2;
216
217
 
217
- return _mapInstanceProperty__default["default"](_context3 = _Object$values__default["default"](values)).call(_context3, function (value) {
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"](_context4 = _mapInstanceProperty__default["default"](moneyValues).call(moneyValues, function (value) {
228
- return MoneyInput__default["default"].parseMoneyValue(value, locale);
229
- })).call(_context4, function (pairs, value) {
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 _context5;
233
+ var typedCurrencyCodes = _Object$keys__default["default"](values);
236
234
 
237
- return _filterInstanceProperty__default["default"](_context5 = _Object$keys__default["default"](values)).call(_context5, function (currencyCode) {
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 _context6;
241
+ var typedCurrencyCodes = _Object$keys__default["default"](values);
244
242
 
245
- return _filterInstanceProperty__default["default"](_context6 = _Object$keys__default["default"](values)).call(_context6, function (currencyCode) {
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.3";
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 _context7, _context8; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context7 = ownKeys(Object(source), !0)).call(_context7, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context8 = ownKeys(Object(source))).call(_context8, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
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: PropTypes.string,
125
- name: PropTypes.string,
126
- value: PropTypes.shape({
127
- amount: PropTypes.string.isRequired,
128
- currencyCode: PropTypes.string.isRequired
129
- }).isRequired,
130
- onChange: PropTypes.func,
131
- currency: PropTypes.string.isRequired,
132
- onBlur: PropTypes.func,
133
- onFocus: PropTypes.func,
134
- isDisabled: PropTypes.bool,
135
- isReadOnly: PropTypes.bool,
136
- hasError: PropTypes.bool,
137
- hasWarning: PropTypes.bool,
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: toggleCurrencies,
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: PropTypes.string,
213
- name: PropTypes.string,
214
- // then input doesn't accept a "currencies" prop, instead all possible
215
- // currencies have to exist (with empty or filled strings) on the value:
216
- // { EUR: {amount: '12.00', currencyCode: 'EUR'}, USD: {amount: '', currencyCode: 'USD'}}
217
- value: PropTypes.objectOf(PropTypes.shape({
218
- amount: PropTypes.string.isRequired,
219
- currencyCode: PropTypes.string.isRequired
220
- })).isRequired,
221
- onChange: PropTypes.func,
222
- selectedCurrency: PropTypes.string.isRequired,
223
- onBlur: PropTypes.func,
224
- onFocus: PropTypes.func,
225
- hideCurrencyExpansionControls: PropTypes.bool,
226
- defaultExpandCurrencies: function defaultExpandCurrencies(props, propName, componentName) {
227
- var _context2;
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 _context3;
235
+ var _context2;
256
236
 
257
- return _mapInstanceProperty(_context3 = _Object$values(values)).call(_context3, function (value) {
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(_context4 = _mapInstanceProperty(moneyValues).call(moneyValues, function (value) {
268
- return MoneyInput.parseMoneyValue(value, locale);
269
- })).call(_context4, function (pairs, value) {
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 _context5;
252
+ var typedCurrencyCodes = _Object$keys(values);
276
253
 
277
- return _filterInstanceProperty(_context5 = _Object$keys(values)).call(_context5, function (currencyCode) {
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 _context6;
260
+ var typedCurrencyCodes = _Object$keys(values);
284
261
 
285
- return _filterInstanceProperty(_context6 = _Object$keys(values)).call(_context6, function (currencyCode) {
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.3";
270
+ var version = "13.0.4";
294
271
 
295
272
  export { LocalizedMoneyInput$1 as default, version };
@@ -0,0 +1,2 @@
1
+ export { default } from './localized-money-input';
2
+ export { default as version } from './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;
@@ -0,0 +1,2 @@
1
+ declare const _default: "__@UI_KIT_PACKAGE/VERSION_OF_RELEASE__";
2
+ 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.3",
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.2",
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.2",
29
+ "@commercetools-uikit/input-utils": "13.0.4",
30
30
  "@commercetools-uikit/localized-utils": "13.0.2",
31
- "@commercetools-uikit/money-input": "13.0.3",
32
- "@commercetools-uikit/select-utils": "13.0.2",
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",