@commercetools-uikit/localized-money-input 16.0.0 → 16.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -68,20 +68,17 @@ var messages = reactIntl.defineMessages({
68
68
  });
69
69
 
70
70
  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; }
71
-
72
71
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
73
-
74
72
  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)."; }
75
- const sequentialId = utils.createSequentialId('localized-money-input-'); // sorts the currencies with the following priority:
73
+ const sequentialId = utils.createSequentialId('localized-money-input-');
74
+
75
+ // sorts the currencies with the following priority:
76
76
  // - The selected currency is placed first (e.g EUR)
77
77
  // - All other currencies follow, sorted alphabetically as well
78
-
79
78
  const sortCurrencies = (selectedCurrency, allCurrencies) => {
80
79
  const remainingCurrencies = _filterInstanceProperty__default["default"](allCurrencies).call(allCurrencies, currency => currency !== selectedCurrency);
81
-
82
80
  return [selectedCurrency, ..._sortInstanceProperty__default["default"](remainingCurrencies).call(remainingCurrencies)];
83
81
  };
84
-
85
82
  var _ref = process.env.NODE_ENV === "production" ? {
86
83
  name: "1ktetz7",
87
84
  styles: "width:100%;position:relative;display:flex"
@@ -91,7 +88,6 @@ var _ref = process.env.NODE_ENV === "production" ? {
91
88
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAoOgB","file":"localized-money-input.tsx","sourcesContent":["import { useCallback, type ReactNode } 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 TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type 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?: (event: TCustomEvent) => void;\n  /**\n   * the currently selected currency\n   */\n  selectedCurrency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\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?: (event: TCustomEvent) => void;\n  /**\n   * Called with the event of the input.\n   */\n  currency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\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"]} */",
92
89
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
90
  };
94
-
95
91
  const LocalizedInput = props => {
96
92
  const onChange = props.onChange;
97
93
  const handleChange = react.useCallback(event => {
@@ -129,7 +125,6 @@ const LocalizedInput = props => {
129
125
  })]
130
126
  });
131
127
  };
132
-
133
128
  LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
134
129
  id: _pt__default["default"].string,
135
130
  name: _pt__default["default"].string,
@@ -147,22 +142,19 @@ LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
147
142
  warning: _pt__default["default"].node
148
143
  } : {};
149
144
  LocalizedInput.displayName = 'LocalizedInput';
150
-
151
145
  const LocalizedMoneyInput = props => {
152
146
  const intl = reactIntl.useIntl();
153
- const defaultExpansionState = props.hideCurrencyExpansionControls || props.defaultExpandCurrencies || // default to `false`, because useToggleState defaults to `true`
147
+ const defaultExpansionState = props.hideCurrencyExpansionControls || props.defaultExpandCurrencies ||
148
+ // default to `false`, because useToggleState defaults to `true`
154
149
  false;
155
-
156
150
  const _useToggleState = hooks.useToggleState(defaultExpansionState),
157
- _useToggleState2 = _slicedToArray(_useToggleState, 2),
158
- areCurrenciesExpanded = _useToggleState2[0],
159
- toggleCurrencies = _useToggleState2[1];
160
-
151
+ _useToggleState2 = _slicedToArray(_useToggleState, 2),
152
+ areCurrenciesExpanded = _useToggleState2[0],
153
+ toggleCurrencies = _useToggleState2[1];
161
154
  const onLocalizedMoneyInputToggle = react.useCallback(() => toggleCurrencies(), [toggleCurrencies]);
162
155
  const id = hooks.useFieldId(props.id, sequentialId);
163
156
  const hasErrorInRemainingCurrencies = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);
164
157
  const hasWarningInRemainingCurrencies = props.hasWarning || localizedUtils.getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);
165
-
166
158
  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {
167
159
  // this update within render replaces the old `getDerivedStateFromProps` functionality
168
160
  // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops
@@ -170,14 +162,11 @@ const LocalizedMoneyInput = props => {
170
162
  toggleCurrencies();
171
163
  }
172
164
  }
173
-
174
165
  const currencies = sortCurrencies(props.selectedCurrency, _Object$keys__default["default"](props.value));
175
166
  const shouldRenderCurrencyControl = currencies.length > 1 && !props.hideCurrencyExpansionControls;
176
-
177
167
  if (props.hideCurrencyExpansionControls) {
178
168
  process.env.NODE_ENV !== "production" ? utils.warning(typeof props.defaultExpandCurrencies !== 'boolean', 'LocalizedMoneyInput: "defaultExpandCurrencies" does not have any effect when "hideCurrencyExpansionControls" is set.') : void 0;
179
169
  }
180
-
181
170
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
182
171
  max: props.horizontalConstraint,
183
172
  children: jsxRuntime.jsxs(Stack__default["default"], {
@@ -219,7 +208,6 @@ const LocalizedMoneyInput = props => {
219
208
  })
220
209
  });
221
210
  };
222
-
223
211
  LocalizedMoneyInput.propTypes = process.env.NODE_ENV !== "production" ? {
224
212
  id: _pt__default["default"].string,
225
213
  name: _pt__default["default"].string,
@@ -245,15 +233,12 @@ LocalizedMoneyInput.getName = localizedUtils.getName;
245
233
  LocalizedMoneyInput.defaultProps = {
246
234
  horizontalConstraint: 'scale'
247
235
  };
248
-
249
236
  LocalizedMoneyInput.convertToMoneyValues = (values, locale) => {
250
237
  var _context;
251
-
252
238
  return _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](values)).call(_context, value => {
253
239
  return MoneyInput__default["default"].convertToMoneyValue(value, locale);
254
240
  });
255
241
  };
256
-
257
242
  LocalizedMoneyInput.parseMoneyValues = function () {
258
243
  let moneyValues = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
259
244
  let locale = arguments.length > 1 ? arguments[1] : undefined;
@@ -264,23 +249,18 @@ LocalizedMoneyInput.parseMoneyValues = function () {
264
249
  });
265
250
  }, {});
266
251
  };
267
-
268
252
  LocalizedMoneyInput.getHighPrecisionCurrencies = (values, locale) => {
269
253
  const typedCurrencyCodes = _Object$keys__default["default"](values);
270
-
271
254
  return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, currencyCode => MoneyInput__default["default"].isHighPrecision(values[currencyCode], locale));
272
255
  };
273
-
274
256
  LocalizedMoneyInput.getEmptyCurrencies = values => {
275
257
  const typedCurrencyCodes = _Object$keys__default["default"](values);
276
-
277
258
  return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, currencyCode => MoneyInput__default["default"].isEmpty(values[currencyCode]));
278
259
  };
279
-
280
260
  var LocalizedMoneyInput$1 = LocalizedMoneyInput;
281
261
 
282
262
  // NOTE: This string will be replaced on build time with the package version.
283
- var version = "16.0.0";
263
+ var version = "16.1.0";
284
264
 
285
265
  exports["default"] = LocalizedMoneyInput$1;
286
266
  exports.version = version;
@@ -67,23 +67,20 @@ var messages = reactIntl.defineMessages({
67
67
  });
68
68
 
69
69
  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; }
70
-
71
70
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
72
- const sequentialId = utils.createSequentialId('localized-money-input-'); // sorts the currencies with the following priority:
71
+ const sequentialId = utils.createSequentialId('localized-money-input-');
72
+
73
+ // sorts the currencies with the following priority:
73
74
  // - The selected currency is placed first (e.g EUR)
74
75
  // - All other currencies follow, sorted alphabetically as well
75
-
76
76
  const sortCurrencies = (selectedCurrency, allCurrencies) => {
77
77
  const remainingCurrencies = _filterInstanceProperty__default["default"](allCurrencies).call(allCurrencies, currency => currency !== selectedCurrency);
78
-
79
78
  return [selectedCurrency, ..._sortInstanceProperty__default["default"](remainingCurrencies).call(remainingCurrencies)];
80
79
  };
81
-
82
80
  var _ref = {
83
81
  name: "1ktetz7",
84
82
  styles: "width:100%;position:relative;display:flex"
85
83
  } ;
86
-
87
84
  const LocalizedInput = props => {
88
85
  const onChange = props.onChange;
89
86
  const handleChange = react.useCallback(event => {
@@ -121,25 +118,21 @@ const LocalizedInput = props => {
121
118
  })]
122
119
  });
123
120
  };
124
-
125
121
  LocalizedInput.propTypes = {};
126
122
  LocalizedInput.displayName = 'LocalizedInput';
127
-
128
123
  const LocalizedMoneyInput = props => {
129
124
  const intl = reactIntl.useIntl();
130
- const defaultExpansionState = props.hideCurrencyExpansionControls || props.defaultExpandCurrencies || // default to `false`, because useToggleState defaults to `true`
125
+ const defaultExpansionState = props.hideCurrencyExpansionControls || props.defaultExpandCurrencies ||
126
+ // default to `false`, because useToggleState defaults to `true`
131
127
  false;
132
-
133
128
  const _useToggleState = hooks.useToggleState(defaultExpansionState),
134
- _useToggleState2 = _slicedToArray(_useToggleState, 2),
135
- areCurrenciesExpanded = _useToggleState2[0],
136
- toggleCurrencies = _useToggleState2[1];
137
-
129
+ _useToggleState2 = _slicedToArray(_useToggleState, 2),
130
+ areCurrenciesExpanded = _useToggleState2[0],
131
+ toggleCurrencies = _useToggleState2[1];
138
132
  const onLocalizedMoneyInputToggle = react.useCallback(() => toggleCurrencies(), [toggleCurrencies]);
139
133
  const id = hooks.useFieldId(props.id, sequentialId);
140
134
  const hasErrorInRemainingCurrencies = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);
141
135
  const hasWarningInRemainingCurrencies = props.hasWarning || localizedUtils.getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);
142
-
143
136
  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {
144
137
  // this update within render replaces the old `getDerivedStateFromProps` functionality
145
138
  // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops
@@ -147,12 +140,9 @@ const LocalizedMoneyInput = props => {
147
140
  toggleCurrencies();
148
141
  }
149
142
  }
150
-
151
143
  const currencies = sortCurrencies(props.selectedCurrency, _Object$keys__default["default"](props.value));
152
144
  const shouldRenderCurrencyControl = currencies.length > 1 && !props.hideCurrencyExpansionControls;
153
-
154
145
  if (props.hideCurrencyExpansionControls) ;
155
-
156
146
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
157
147
  max: props.horizontalConstraint,
158
148
  children: jsxRuntime.jsxs(Stack__default["default"], {
@@ -194,7 +184,6 @@ const LocalizedMoneyInput = props => {
194
184
  })
195
185
  });
196
186
  };
197
-
198
187
  LocalizedMoneyInput.propTypes = {};
199
188
  LocalizedMoneyInput.displayName = 'LocalizedMoneyInput';
200
189
  LocalizedMoneyInput.getId = localizedUtils.getId;
@@ -202,15 +191,12 @@ LocalizedMoneyInput.getName = localizedUtils.getName;
202
191
  LocalizedMoneyInput.defaultProps = {
203
192
  horizontalConstraint: 'scale'
204
193
  };
205
-
206
194
  LocalizedMoneyInput.convertToMoneyValues = (values, locale) => {
207
195
  var _context;
208
-
209
196
  return _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](values)).call(_context, value => {
210
197
  return MoneyInput__default["default"].convertToMoneyValue(value, locale);
211
198
  });
212
199
  };
213
-
214
200
  LocalizedMoneyInput.parseMoneyValues = function () {
215
201
  let moneyValues = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
216
202
  let locale = arguments.length > 1 ? arguments[1] : undefined;
@@ -221,23 +207,18 @@ LocalizedMoneyInput.parseMoneyValues = function () {
221
207
  });
222
208
  }, {});
223
209
  };
224
-
225
210
  LocalizedMoneyInput.getHighPrecisionCurrencies = (values, locale) => {
226
211
  const typedCurrencyCodes = _Object$keys__default["default"](values);
227
-
228
212
  return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, currencyCode => MoneyInput__default["default"].isHighPrecision(values[currencyCode], locale));
229
213
  };
230
-
231
214
  LocalizedMoneyInput.getEmptyCurrencies = values => {
232
215
  const typedCurrencyCodes = _Object$keys__default["default"](values);
233
-
234
216
  return _filterInstanceProperty__default["default"](typedCurrencyCodes).call(typedCurrencyCodes, currencyCode => MoneyInput__default["default"].isEmpty(values[currencyCode]));
235
217
  };
236
-
237
218
  var LocalizedMoneyInput$1 = LocalizedMoneyInput;
238
219
 
239
220
  // NOTE: This string will be replaced on build time with the package version.
240
- var version = "16.0.0";
221
+ var version = "16.1.0";
241
222
 
242
223
  exports["default"] = LocalizedMoneyInput$1;
243
224
  exports.version = version;
@@ -45,20 +45,17 @@ var messages = defineMessages({
45
45
  });
46
46
 
47
47
  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; }
48
-
49
48
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
50
-
51
49
  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)."; }
52
- const sequentialId = createSequentialId('localized-money-input-'); // sorts the currencies with the following priority:
50
+ const sequentialId = createSequentialId('localized-money-input-');
51
+
52
+ // sorts the currencies with the following priority:
53
53
  // - The selected currency is placed first (e.g EUR)
54
54
  // - All other currencies follow, sorted alphabetically as well
55
-
56
55
  const sortCurrencies = (selectedCurrency, allCurrencies) => {
57
56
  const remainingCurrencies = _filterInstanceProperty(allCurrencies).call(allCurrencies, currency => currency !== selectedCurrency);
58
-
59
57
  return [selectedCurrency, ..._sortInstanceProperty(remainingCurrencies).call(remainingCurrencies)];
60
58
  };
61
-
62
59
  var _ref = process.env.NODE_ENV === "production" ? {
63
60
  name: "1ktetz7",
64
61
  styles: "width:100%;position:relative;display:flex"
@@ -68,7 +65,6 @@ var _ref = process.env.NODE_ENV === "production" ? {
68
65
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAoOgB","file":"localized-money-input.tsx","sourcesContent":["import { useCallback, type ReactNode } 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 TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type 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?: (event: TCustomEvent) => void;\n  /**\n   * the currently selected currency\n   */\n  selectedCurrency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\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?: (event: TCustomEvent) => void;\n  /**\n   * Called with the event of the input.\n   */\n  currency: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\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"]} */",
69
66
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70
67
  };
71
-
72
68
  const LocalizedInput = props => {
73
69
  const onChange = props.onChange;
74
70
  const handleChange = useCallback(event => {
@@ -106,7 +102,6 @@ const LocalizedInput = props => {
106
102
  })]
107
103
  });
108
104
  };
109
-
110
105
  LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
111
106
  id: _pt.string,
112
107
  name: _pt.string,
@@ -124,22 +119,19 @@ LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
124
119
  warning: _pt.node
125
120
  } : {};
126
121
  LocalizedInput.displayName = 'LocalizedInput';
127
-
128
122
  const LocalizedMoneyInput = props => {
129
123
  const intl = useIntl();
130
- const defaultExpansionState = props.hideCurrencyExpansionControls || props.defaultExpandCurrencies || // default to `false`, because useToggleState defaults to `true`
124
+ const defaultExpansionState = props.hideCurrencyExpansionControls || props.defaultExpandCurrencies ||
125
+ // default to `false`, because useToggleState defaults to `true`
131
126
  false;
132
-
133
127
  const _useToggleState = useToggleState(defaultExpansionState),
134
- _useToggleState2 = _slicedToArray(_useToggleState, 2),
135
- areCurrenciesExpanded = _useToggleState2[0],
136
- toggleCurrencies = _useToggleState2[1];
137
-
128
+ _useToggleState2 = _slicedToArray(_useToggleState, 2),
129
+ areCurrenciesExpanded = _useToggleState2[0],
130
+ toggleCurrencies = _useToggleState2[1];
138
131
  const onLocalizedMoneyInputToggle = useCallback(() => toggleCurrencies(), [toggleCurrencies]);
139
132
  const id = useFieldId(props.id, sequentialId);
140
133
  const hasErrorInRemainingCurrencies = props.hasError || getHasErrorOnRemainingLanguages(props.errors, props.selectedCurrency);
141
134
  const hasWarningInRemainingCurrencies = props.hasWarning || getHasWarningOnRemainingLanguages(props.warnings, props.selectedCurrency);
142
-
143
135
  if (hasErrorInRemainingCurrencies || hasWarningInRemainingCurrencies) {
144
136
  // this update within render replaces the old `getDerivedStateFromProps` functionality
145
137
  // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops
@@ -147,14 +139,11 @@ const LocalizedMoneyInput = props => {
147
139
  toggleCurrencies();
148
140
  }
149
141
  }
150
-
151
142
  const currencies = sortCurrencies(props.selectedCurrency, _Object$keys(props.value));
152
143
  const shouldRenderCurrencyControl = currencies.length > 1 && !props.hideCurrencyExpansionControls;
153
-
154
144
  if (props.hideCurrencyExpansionControls) {
155
145
  process.env.NODE_ENV !== "production" ? warning(typeof props.defaultExpandCurrencies !== 'boolean', 'LocalizedMoneyInput: "defaultExpandCurrencies" does not have any effect when "hideCurrencyExpansionControls" is set.') : void 0;
156
146
  }
157
-
158
147
  return jsx(Constraints.Horizontal, {
159
148
  max: props.horizontalConstraint,
160
149
  children: jsxs(Stack, {
@@ -196,7 +185,6 @@ const LocalizedMoneyInput = props => {
196
185
  })
197
186
  });
198
187
  };
199
-
200
188
  LocalizedMoneyInput.propTypes = process.env.NODE_ENV !== "production" ? {
201
189
  id: _pt.string,
202
190
  name: _pt.string,
@@ -222,15 +210,12 @@ LocalizedMoneyInput.getName = getName;
222
210
  LocalizedMoneyInput.defaultProps = {
223
211
  horizontalConstraint: 'scale'
224
212
  };
225
-
226
213
  LocalizedMoneyInput.convertToMoneyValues = (values, locale) => {
227
214
  var _context;
228
-
229
215
  return _mapInstanceProperty(_context = _Object$values(values)).call(_context, value => {
230
216
  return MoneyInput.convertToMoneyValue(value, locale);
231
217
  });
232
218
  };
233
-
234
219
  LocalizedMoneyInput.parseMoneyValues = function () {
235
220
  let moneyValues = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
236
221
  let locale = arguments.length > 1 ? arguments[1] : undefined;
@@ -241,22 +226,17 @@ LocalizedMoneyInput.parseMoneyValues = function () {
241
226
  });
242
227
  }, {});
243
228
  };
244
-
245
229
  LocalizedMoneyInput.getHighPrecisionCurrencies = (values, locale) => {
246
230
  const typedCurrencyCodes = _Object$keys(values);
247
-
248
231
  return _filterInstanceProperty(typedCurrencyCodes).call(typedCurrencyCodes, currencyCode => MoneyInput.isHighPrecision(values[currencyCode], locale));
249
232
  };
250
-
251
233
  LocalizedMoneyInput.getEmptyCurrencies = values => {
252
234
  const typedCurrencyCodes = _Object$keys(values);
253
-
254
235
  return _filterInstanceProperty(typedCurrencyCodes).call(typedCurrencyCodes, currencyCode => MoneyInput.isEmpty(values[currencyCode]));
255
236
  };
256
-
257
237
  var LocalizedMoneyInput$1 = LocalizedMoneyInput;
258
238
 
259
239
  // NOTE: This string will be replaced on build time with the package version.
260
- var version = "16.0.0";
240
+ var version = "16.1.0";
261
241
 
262
242
  export { LocalizedMoneyInput$1 as default, version };
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": "16.0.0",
4
+ "version": "16.1.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,22 +21,22 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "16.0.0",
25
- "@commercetools-uikit/design-system": "16.0.0",
26
- "@commercetools-uikit/flat-button": "16.0.0",
27
- "@commercetools-uikit/hooks": "16.0.0",
28
- "@commercetools-uikit/icons": "16.0.0",
29
- "@commercetools-uikit/input-utils": "16.0.0",
30
- "@commercetools-uikit/localized-utils": "16.0.0",
31
- "@commercetools-uikit/money-input": "16.0.0",
32
- "@commercetools-uikit/select-utils": "16.0.0",
33
- "@commercetools-uikit/spacings-stack": "16.0.0",
34
- "@commercetools-uikit/tooltip": "16.0.0",
35
- "@commercetools-uikit/utils": "16.0.0",
24
+ "@commercetools-uikit/constraints": "16.1.0",
25
+ "@commercetools-uikit/design-system": "16.1.0",
26
+ "@commercetools-uikit/flat-button": "16.1.0",
27
+ "@commercetools-uikit/hooks": "16.1.0",
28
+ "@commercetools-uikit/icons": "16.1.0",
29
+ "@commercetools-uikit/input-utils": "16.1.0",
30
+ "@commercetools-uikit/localized-utils": "16.1.0",
31
+ "@commercetools-uikit/money-input": "16.1.0",
32
+ "@commercetools-uikit/select-utils": "16.1.0",
33
+ "@commercetools-uikit/spacings-stack": "16.1.0",
34
+ "@commercetools-uikit/tooltip": "16.1.0",
35
+ "@commercetools-uikit/utils": "16.1.0",
36
36
  "@emotion/react": "^11.10.5",
37
37
  "@emotion/styled": "^11.10.5",
38
38
  "prop-types": "15.8.1",
39
- "react-select": "5.7.2"
39
+ "react-select": "5.7.3"
40
40
  },
41
41
  "devDependencies": {
42
42
  "react": "17.0.2",