@commercetools-uikit/localized-money-input 19.22.1 → 19.22.3

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.
@@ -87,8 +87,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
87
87
  styles: "width:100%;position:relative;display:flex"
88
88
  } : {
89
89
  name: "1ysn02y-LocalizedInput",
90
- styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
91
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAqPgB","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 { ErrorMessage, WarningMessage } from '@commercetools-uikit/messages';\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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          isCondensed={props.isCondensed}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          hasHighPrecisionBadge={props.hasHighPrecisionBadge}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {props.error && <ErrorMessage>{props.error}</ErrorMessage>}\n      {props.warning && <WarningMessage>{props.warning}</WarningMessage>}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst LocalizedMoneyInput = ({\n  horizontalConstraint = 'scale',\n  ...props\n}: 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={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                isCondensed={props.isCondensed}\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(\n                  {\n                    horizontalConstraint,\n                    ...props,\n                  },\n                  currency\n                )}\n                hasHighPrecisionBadge={props.hasHighPrecisionBadge}\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.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"]} */",
90
+ styles: "width:100%;position:relative;display:flex;label:LocalizedInput;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAqPgB","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 { ErrorMessage, WarningMessage } from '@commercetools-uikit/messages';\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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          isCondensed={props.isCondensed}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          hasHighPrecisionBadge={props.hasHighPrecisionBadge}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {props.error && <ErrorMessage>{props.error}</ErrorMessage>}\n      {props.warning && <WarningMessage>{props.warning}</WarningMessage>}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst LocalizedMoneyInput = ({\n  horizontalConstraint = 'scale',\n  ...props\n}: 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={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                isCondensed={props.isCondensed}\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(\n                  {\n                    horizontalConstraint,\n                    ...props,\n                  },\n                  currency\n                )}\n                hasHighPrecisionBadge={props.hasHighPrecisionBadge}\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.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
91
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
92
  };
94
93
  const LocalizedInput = props => {
@@ -276,7 +275,7 @@ LocalizedMoneyInput.getEmptyCurrencies = values => {
276
275
  var LocalizedMoneyInput$1 = LocalizedMoneyInput;
277
276
 
278
277
  // NOTE: This string will be replaced on build time with the package version.
279
- var version = "19.22.1";
278
+ var version = "19.22.3";
280
279
 
281
280
  exports["default"] = LocalizedMoneyInput$1;
282
281
  exports.version = version;
@@ -230,7 +230,7 @@ LocalizedMoneyInput.getEmptyCurrencies = values => {
230
230
  var LocalizedMoneyInput$1 = LocalizedMoneyInput;
231
231
 
232
232
  // NOTE: This string will be replaced on build time with the package version.
233
- var version = "19.22.1";
233
+ var version = "19.22.3";
234
234
 
235
235
  exports["default"] = LocalizedMoneyInput$1;
236
236
  exports.version = version;
@@ -64,8 +64,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
64
64
  styles: "width:100%;position:relative;display:flex"
65
65
  } : {
66
66
  name: "1ysn02y-LocalizedInput",
67
- styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
68
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAqPgB","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 { ErrorMessage, WarningMessage } from '@commercetools-uikit/messages';\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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          isCondensed={props.isCondensed}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          hasHighPrecisionBadge={props.hasHighPrecisionBadge}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {props.error && <ErrorMessage>{props.error}</ErrorMessage>}\n      {props.warning && <WarningMessage>{props.warning}</WarningMessage>}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst LocalizedMoneyInput = ({\n  horizontalConstraint = 'scale',\n  ...props\n}: 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={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                isCondensed={props.isCondensed}\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(\n                  {\n                    horizontalConstraint,\n                    ...props,\n                  },\n                  currency\n                )}\n                hasHighPrecisionBadge={props.hasHighPrecisionBadge}\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.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"]} */",
67
+ styles: "width:100%;position:relative;display:flex;label:LocalizedInput;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-money-input.tsx"],"names":[],"mappings":"AAqPgB","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 { ErrorMessage, WarningMessage } from '@commercetools-uikit/messages';\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * 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   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge?: boolean;\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          isCondensed={props.isCondensed}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          placeholder={props.placeholder}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          hasHighPrecisionBadge={props.hasHighPrecisionBadge}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      {props.error && <ErrorMessage>{props.error}</ErrorMessage>}\n      {props.warning && <WarningMessage>{props.warning}</WarningMessage>}\n    </Stack>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst LocalizedMoneyInput = ({\n  horizontalConstraint = 'scale',\n  ...props\n}: 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={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                isCondensed={props.isCondensed}\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(\n                  {\n                    horizontalConstraint,\n                    ...props,\n                  },\n                  currency\n                )}\n                hasHighPrecisionBadge={props.hasHighPrecisionBadge}\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.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
68
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70
69
  };
71
70
  const LocalizedInput = props => {
@@ -253,6 +252,6 @@ LocalizedMoneyInput.getEmptyCurrencies = values => {
253
252
  var LocalizedMoneyInput$1 = LocalizedMoneyInput;
254
253
 
255
254
  // NOTE: This string will be replaced on build time with the package version.
256
- var version = "19.22.1";
255
+ var version = "19.22.3";
257
256
 
258
257
  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": "19.22.1",
4
+ "version": "19.22.3",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,19 +21,19 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "19.22.1",
25
- "@commercetools-uikit/design-system": "19.22.1",
26
- "@commercetools-uikit/flat-button": "19.22.1",
27
- "@commercetools-uikit/hooks": "19.22.1",
28
- "@commercetools-uikit/icons": "19.22.1",
29
- "@commercetools-uikit/input-utils": "19.22.1",
30
- "@commercetools-uikit/localized-utils": "19.22.1",
31
- "@commercetools-uikit/messages": "19.22.1",
32
- "@commercetools-uikit/money-input": "19.22.1",
33
- "@commercetools-uikit/select-utils": "19.22.1",
34
- "@commercetools-uikit/spacings-stack": "19.22.1",
35
- "@commercetools-uikit/tooltip": "19.22.1",
36
- "@commercetools-uikit/utils": "19.22.1",
24
+ "@commercetools-uikit/constraints": "19.22.3",
25
+ "@commercetools-uikit/design-system": "19.22.3",
26
+ "@commercetools-uikit/flat-button": "19.22.3",
27
+ "@commercetools-uikit/hooks": "19.22.3",
28
+ "@commercetools-uikit/icons": "19.22.3",
29
+ "@commercetools-uikit/input-utils": "19.22.3",
30
+ "@commercetools-uikit/localized-utils": "19.22.3",
31
+ "@commercetools-uikit/messages": "19.22.3",
32
+ "@commercetools-uikit/money-input": "19.22.3",
33
+ "@commercetools-uikit/select-utils": "19.22.3",
34
+ "@commercetools-uikit/spacings-stack": "19.22.3",
35
+ "@commercetools-uikit/tooltip": "19.22.3",
36
+ "@commercetools-uikit/utils": "19.22.3",
37
37
  "@emotion/react": "^11.10.5",
38
38
  "@emotion/styled": "^11.10.5",
39
39
  "prop-types": "15.8.1",