@commercetools-uikit/money-input 12.2.2 → 12.2.6

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.
@@ -11,7 +11,6 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
11
11
  var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
12
12
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
13
13
  var _typeof = require('@babel/runtime-corejs3/helpers/typeof');
14
- var _extends = require('@babel/runtime-corejs3/helpers/extends');
15
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
16
15
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
17
16
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
@@ -25,7 +24,7 @@ var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/insta
25
24
  var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
26
25
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
27
26
  var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
28
- var React = require('react');
27
+ var react$1 = require('react');
29
28
  var ReactDOM = require('react-dom');
30
29
  var PropTypes = require('prop-types');
31
30
  var has = require('lodash/has');
@@ -41,6 +40,7 @@ var icons = require('@commercetools-uikit/icons');
41
40
  var Constraints = require('@commercetools-uikit/constraints');
42
41
  var hooks = require('@commercetools-uikit/hooks');
43
42
  var inputUtils = require('@commercetools-uikit/input-utils');
43
+ var jsxRuntime = require('@emotion/react/jsx-runtime');
44
44
 
45
45
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
46
46
 
@@ -62,7 +62,6 @@ var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceP
62
62
  var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
63
63
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
64
64
  var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
65
- var React__default = /*#__PURE__*/_interopDefault(React);
66
65
  var ReactDOM__default = /*#__PURE__*/_interopDefault(ReactDOM);
67
66
  var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
68
67
  var has__default = /*#__PURE__*/_interopDefault(has);
@@ -735,16 +734,16 @@ var currencies = {
735
734
  };
736
735
 
737
736
  var getCurrencyLabelStyles = function getCurrencyLabelStyles() {
738
- return /*#__PURE__*/react.css("display:flex;color:", designSystem.customProperties.fontColorForInputWhenDisabled, ";background-color:", designSystem.customProperties.backgroundColorForInputWhenDisabled, ";border-top-left-radius:", designSystem.customProperties.borderRadiusForInput, ";border-bottom-left-radius:", designSystem.customProperties.borderRadiusForInput, ";border:1px ", designSystem.customProperties.borderColorForInputWhenDisabled, " solid;border-right:0;padding:0 ", designSystem.customProperties.spacingS, ";align-items:center;font-size:", designSystem.customProperties.fontSizeForInput, ";box-sizing:border-box;" + (process.env.NODE_ENV === "production" ? "" : ";label:getCurrencyLabelStyles;"));
737
+ return /*#__PURE__*/react.css("display:flex;color:", designSystem.customProperties.fontColorForInputWhenDisabled, ";background-color:", designSystem.customProperties.backgroundColorForInputWhenDisabled, ";border-top-left-radius:", designSystem.customProperties.borderRadiusForInput, ";border-bottom-left-radius:", designSystem.customProperties.borderRadiusForInput, ";border:1px ", designSystem.customProperties.borderColorForInputWhenDisabled, " solid;border-right:0;padding:0 ", designSystem.customProperties.spacingS, ";align-items:center;font-size:", designSystem.customProperties.fontSizeForInput, ";box-sizing:border-box;" + (process.env.NODE_ENV === "production" ? "" : ";label:getCurrencyLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vbmV5LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJd0MiLCJmaWxlIjoibW9uZXktaW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBnZXRJbnB1dFN0eWxlcyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2lucHV0LXV0aWxzJztcblxuY29uc3QgZ2V0Q3VycmVuY3lMYWJlbFN0eWxlcyA9ICgpID0+IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgY29sb3I6ICR7dmFycy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7dmFycy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH07XG4gIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7dmFycy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7dmFycy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlcjogMXB4ICR7dmFycy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkfSBzb2xpZDtcbiAgYm9yZGVyLXJpZ2h0OiAwO1xuICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtc2l6ZTogJHt2YXJzLmZvbnRTaXplRm9ySW5wdXR9O1xuICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuYDtcblxuY29uc3QgZ2V0QW1vdW50SW5wdXRTdHlsZXMgPSAocHJvcHMpID0+IFtcbiAgZ2V0SW5wdXRTdHlsZXMocHJvcHMpLFxuICBjc3NgXG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwO1xuICAgIG1hcmdpbi1sZWZ0OiAwO1xuXG4gICAgJjo6cGxhY2Vob2xkZXIge1xuICAgICAgY29sb3I6ICR7dmFycy5wbGFjZWhvbGRlckZvbnRDb2xvckZvcklucHV0fTtcbiAgICB9XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRIaWdoUHJlY2lzaW9uV3JhcHBlclN0eWxlcyA9ICh7IGlzRGlzYWJsZWQgfSkgPT4gY3NzYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgcmlnaHQ6IDA7XG4gIG1hcmdpbi1yaWdodDogJHt2YXJzLnNwYWNpbmdYc307XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgY3Vyc29yOiAke2lzRGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ2RlZmF1bHQnfTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5gO1xuXG5leHBvcnQge1xuICBnZXRIaWdoUHJlY2lzaW9uV3JhcHBlclN0eWxlcyxcbiAgZ2V0Q3VycmVuY3lMYWJlbFN0eWxlcyxcbiAgZ2V0QW1vdW50SW5wdXRTdHlsZXMsXG59O1xuIl19 */");
739
738
  };
740
739
 
741
740
  var getAmountInputStyles = function getAmountInputStyles(props) {
742
- return [inputUtils.getInputStyles(props), /*#__PURE__*/react.css("border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;&::placeholder{color:", designSystem.customProperties.placeholderFontColorForInput, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getAmountInputStyles;"))];
741
+ return [inputUtils.getInputStyles(props), /*#__PURE__*/react.css("border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;&::placeholder{color:", designSystem.customProperties.placeholderFontColorForInput, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getAmountInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vbmV5LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQksiLCJmaWxlIjoibW9uZXktaW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBnZXRJbnB1dFN0eWxlcyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2lucHV0LXV0aWxzJztcblxuY29uc3QgZ2V0Q3VycmVuY3lMYWJlbFN0eWxlcyA9ICgpID0+IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgY29sb3I6ICR7dmFycy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7dmFycy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH07XG4gIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7dmFycy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7dmFycy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlcjogMXB4ICR7dmFycy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkfSBzb2xpZDtcbiAgYm9yZGVyLXJpZ2h0OiAwO1xuICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtc2l6ZTogJHt2YXJzLmZvbnRTaXplRm9ySW5wdXR9O1xuICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuYDtcblxuY29uc3QgZ2V0QW1vdW50SW5wdXRTdHlsZXMgPSAocHJvcHMpID0+IFtcbiAgZ2V0SW5wdXRTdHlsZXMocHJvcHMpLFxuICBjc3NgXG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwO1xuICAgIG1hcmdpbi1sZWZ0OiAwO1xuXG4gICAgJjo6cGxhY2Vob2xkZXIge1xuICAgICAgY29sb3I6ICR7dmFycy5wbGFjZWhvbGRlckZvbnRDb2xvckZvcklucHV0fTtcbiAgICB9XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRIaWdoUHJlY2lzaW9uV3JhcHBlclN0eWxlcyA9ICh7IGlzRGlzYWJsZWQgfSkgPT4gY3NzYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgcmlnaHQ6IDA7XG4gIG1hcmdpbi1yaWdodDogJHt2YXJzLnNwYWNpbmdYc307XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgY3Vyc29yOiAke2lzRGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ2RlZmF1bHQnfTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5gO1xuXG5leHBvcnQge1xuICBnZXRIaWdoUHJlY2lzaW9uV3JhcHBlclN0eWxlcyxcbiAgZ2V0Q3VycmVuY3lMYWJlbFN0eWxlcyxcbiAgZ2V0QW1vdW50SW5wdXRTdHlsZXMsXG59O1xuIl19 */")];
743
742
  };
744
743
 
745
744
  var getHighPrecisionWrapperStyles = function getHighPrecisionWrapperStyles(_ref) {
746
745
  var isDisabled = _ref.isDisabled;
747
- return /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-right:", designSystem.customProperties.spacingXs, ";height:100%;display:flex;align-items:center;cursor:", isDisabled ? 'not-allowed' : 'default', ";justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:getHighPrecisionWrapperStyles;"));
746
+ return /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-right:", designSystem.customProperties.spacingXs, ";height:100%;display:flex;align-items:center;cursor:", isDisabled ? 'not-allowed' : 'default', ";justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:getHighPrecisionWrapperStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vbmV5LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQjZEIiwiZmlsZSI6Im1vbmV5LWlucHV0LnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgYXMgdmFycyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHsgZ2V0SW5wdXRTdHlsZXMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pbnB1dC11dGlscyc7XG5cbmNvbnN0IGdldEN1cnJlbmN5TGFiZWxTdHlsZXMgPSAoKSA9PiBjc3NgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGNvbG9yOiAke3ZhcnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWR9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWR9O1xuICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke3ZhcnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke3ZhcnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICBib3JkZXI6IDFweCAke3ZhcnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH0gc29saWQ7XG4gIGJvcmRlci1yaWdodDogMDtcbiAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmb250LXNpemU6ICR7dmFycy5mb250U2l6ZUZvcklucHV0fTtcbiAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbmA7XG5cbmNvbnN0IGdldEFtb3VudElucHV0U3R5bGVzID0gKHByb3BzKSA9PiBbXG4gIGdldElucHV0U3R5bGVzKHByb3BzKSxcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBtYXJnaW4tbGVmdDogMDtcblxuICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke3ZhcnMucGxhY2Vob2xkZXJGb250Q29sb3JGb3JJbnB1dH07XG4gICAgfVxuICBgLFxuXTtcblxuY29uc3QgZ2V0SGlnaFByZWNpc2lvbldyYXBwZXJTdHlsZXMgPSAoeyBpc0Rpc2FibGVkIH0pID0+IGNzc2BcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDA7XG4gIHJpZ2h0OiAwO1xuICBtYXJnaW4tcmlnaHQ6ICR7dmFycy5zcGFjaW5nWHN9O1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGN1cnNvcjogJHtpc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuYDtcblxuZXhwb3J0IHtcbiAgZ2V0SGlnaFByZWNpc2lvbldyYXBwZXJTdHlsZXMsXG4gIGdldEN1cnJlbmN5TGFiZWxTdHlsZXMsXG4gIGdldEFtb3VudElucHV0U3R5bGVzLFxufTtcbiJdfQ== */");
748
747
  };
749
748
 
750
749
  var messages = reactIntl.defineMessages({
@@ -757,13 +756,13 @@ var messages = reactIntl.defineMessages({
757
756
 
758
757
  var _excluded = ["id"];
759
758
 
760
- function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default['default'](object); if (_Object$getOwnPropertySymbols__default['default']) { var symbols = _Object$getOwnPropertySymbols__default['default'](object); if (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; }
759
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (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; }
761
760
 
762
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context14; _forEachInstanceProperty__default['default'](_context14 = ownKeys(Object(source), true)).call(_context14, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default['default']) { _Object$defineProperties__default['default'](target, _Object$getOwnPropertyDescriptors__default['default'](source)); } else { var _context15; _forEachInstanceProperty__default['default'](_context15 = ownKeys(Object(source))).call(_context15, function (key) { _Object$defineProperty__default['default'](target, key, _Object$getOwnPropertyDescriptor__default['default'](source, key)); }); } } return target; }
761
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context14; _forEachInstanceProperty__default["default"](_context14 = ownKeys(Object(source), true)).call(_context14, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context15; _forEachInstanceProperty__default["default"](_context15 = ownKeys(Object(source))).call(_context15, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
763
762
 
764
763
  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)."; }
765
764
 
766
- var TooltipWrapper = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
765
+ var TooltipWrapper = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
767
766
  target: "elvjg270"
768
767
  } : {
769
768
  target: "elvjg270",
@@ -774,6 +773,7 @@ var TooltipWrapper = _styled__default['default']("div", process.env.NODE_ENV ===
774
773
  } : {
775
774
  name: "zjik7",
776
775
  styles: "display:flex",
776
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["money-input.js"],"names":[],"mappings":"AAgCiC","file":"money-input.js","sourcesContent":["import { useRef, useCallback } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport has from 'lodash/has';\nimport requiredIf from 'react-required-if';\nimport Select, { components } from 'react-select';\nimport { useIntl } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport {\n  warning,\n  isNumberish,\n  SafeHTMLElement,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  DropdownIndicator,\n  createSelectStyles,\n} from '@commercetools-uikit/select-utils';\nimport { FractionDigitsIcon } from '@commercetools-uikit/icons';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport currencies from './currencies.json';\nimport {\n  getHighPrecisionWrapperStyles,\n  getCurrencyLabelStyles,\n  getAmountInputStyles,\n} from './money-input.styles';\nimport messages from './messages';\n\nconst TooltipWrapper = styled.div`\n  display: flex;\n`;\n\nconst getPortalId = (id) => `portal-${id}`;\nconst getPortalNode = (id) => document.querySelector(`#${getPortalId(id)}`);\n\nconst Portal = (props) => {\n  const domNode = getPortalNode(props.id);\n  return ReactDOM.createPortal(props.children, domNode);\n};\n\nconst CurrencyLabel = (props) => (\n  <label htmlFor={props.id} css={getCurrencyLabelStyles()}>\n    {props.children}\n  </label>\n);\n\nCurrencyLabel.displayName = 'CurrencyLabel';\n\nCurrencyLabel.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\nconst SingleValue = ({ id, ...props }) => (\n  <components.SingleValue {...props}>\n    <label htmlFor={id}>{props.children}</label>\n  </components.SingleValue>\n);\n\nSingleValue.displayName = 'SingleValue';\n\nSingleValue.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\n// overwrite styles of createSelectStyles\nconst createCurrencySelectStyles = (\n  { hasWarning, hasError, isDisabled, isReadOnly, hasFocus, menuPortalZIndex },\n  theme\n) => {\n  const selectStyles = createSelectStyles(\n    {\n      hasWarning,\n      hasError,\n      menuPortalZIndex,\n    },\n    theme\n  );\n  return {\n    ...selectStyles,\n    control: (base, state) => ({\n      ...selectStyles.control(base, state),\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      minWidth: '72px',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${vars.borderColorForInputWhenDisabled} !important`;\n        if (hasError) return vars.borderColorForInputWhenError;\n        if (hasWarning) return vars.borderColorForInputWhenWarning;\n        if (hasFocus) return vars.borderColorForInputWhenFocused;\n        if (isReadOnly)\n          return `${vars.borderColorForInputWhenReadonly} !important`;\n        return vars.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: (() => {\n        if (isReadOnly) return vars.backgroundColorForInput;\n        return base.backgroundColor;\n      })(),\n    }),\n    singleValue: (base) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: (() => {\n        if (isDisabled) return vars.fontColorForInputWhenDisabled;\n        if (hasError) return vars.fontColorForInputWhenError;\n        if (hasWarning) return vars.fontColorForInputWhenWarning;\n        if (isReadOnly) return vars.fontColorForInputWhenReadonly;\n        return base.color;\n      })(),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly ? vars.fontColorForInputWhenReadonly : '',\n    }),\n  };\n};\n\n// The MoneyInput component always operates on a value consisting of:\n//   { amount: String, currencyCode: String }\n//\n// The amount may only use a dot as the decimal separator.\n// The currencyCode must be supported by the API.\n//\n// The MoneyInput does not do any validation on its own. It only serves as a way\n// to get the amount and currencyCode input from the user. Validation is always\n// up to the parent.\n//\n// The CTP API supports prices two types of prices: centPrecision and\n// highPrecision. The MoneyInput itself does not know about these. However,\n// it has two static methods defined (convertToMoneyValue and parseMoneyValue),\n// which can be used to convert between MoneyInput value and the MoneyValue\n// supported by the API.\n// Some places in the API do not support highPrecision prices, but the\n// convertToMoneyValue will always return either a centPrecision or a\n// highPrecision price. It's up the MoneyInput's parent to show a validation\n// error in case a highPrecision price is used.\n//\n// A value is considered as to have highPrecision when the number of supplied\n// fraction digits exceed the number of fraction digits the currency uses. For\n// example, 42.00 € is always a centPrecision price, while 42.001 € is always a\n// highPrecision price. It is not possible to hae 42.00 € as a highPrecision\n// price.\n//\n// The first time the component renders, we want to try to show the centAmount\n// as a formatted number. To achieve this, the parseMoneyValue function can\n// be used to turn the API value into a value the MoneyInput understands.\n// During this transformation, the money value will get formatted into \"amount\".\n//\n// When the user changes the value, we don't want to format again. We only format\n// in case the user blurs the field. This avoids many edge cases where the\n// formatting would mess with the user's input.\n//\n//\n// A full example of an MoneyValue with centPrecision would be\n// {\n//   \"type\": \"centPrecision\",\n//   \"currencyCode\": \"EUR\",\n//   \"centAmount\": 4200,\n//   \"fractionDigits\": 2\n// }\n// which equals 42.00 €\n//\n// A full example of an MoneyValue with highPrecision would be\n// {\n//  \"type\": \"highPrecision\",\n//  \"currencyCode\": \"EUR\",\n//  \"centAmount\": 1,\n//  \"preciseAmount\": 123456,\n//  \"fractionDigits\": 7\n// }\n// which equals 0.0123456 €\n\n// Parsing\n// Since most users are not careful about how they enter values, we will parse\n// both `.` and `,` as decimal separators.\n// When a value is `1.000,00` we parse it as `1000`.\n// When a value is `1,000.00` we also parse it as `1000`.\n//\n// This means the highest amount always wins. We do this by comparing the last\n// position of `.` and `,`. Whatever occurs later is used as the decimal\n// separator.\nexport const parseRawAmountToNumber = (rawAmount, locale) => {\n  let fractionsSeparator;\n\n  if (locale) {\n    fractionsSeparator = (2.5) // we need any number with fractions, so that we know what is the fraction\n      .toLocaleString(locale) // \"symbol\" for the provided locale\n      .replace(/\\d/g, ''); // then we remove the numbers and keep the \"symbol\"\n  } else {\n    const lastDot = String(rawAmount).lastIndexOf('.');\n    const lastComma = String(rawAmount).lastIndexOf(',');\n    fractionsSeparator = lastComma > lastDot ? ',' : '.';\n  }\n\n  fractionsSeparator = fractionsSeparator === '.' ? '\\\\.' : fractionsSeparator; // here we escape the '.' to use it as regex\n  // The raw amount with only one sparator\n  const normalizedAmount = String(rawAmount)\n    .replace(new RegExp(`[^0-9${fractionsSeparator}]`, 'g'), '') // we just keep the numbers and the fraction symbol\n    .replace(fractionsSeparator, '.'); // then we change whatever `fractionsSeparator` was to `.` so we can parse it as float\n\n  return parseFloat(normalizedAmount, 10);\n};\n\n// Turns the user input into a value the MoneyInput can pass up through onChange\n// In case the number of fraction digits contained in \"amount\" exceeds the\n// number of fraction digits the currency uses, it will emit a price of\n// type \"highPrecision\" instead of the regular \"centPrecision\".\n// It will return \"null\" in case an invalid value is entered.\n// The value is invalid when\n//  - no amount was entered\n//  - an invalid amount was entered\n//  - no currency was selected\n//\n// This function expects the \"amount\" to be a trimmed value.\nexport const createMoneyValue = (currencyCode, rawAmount, locale) => {\n  if (!currencyCode) return null;\n\n  const currency = currencies[currencyCode];\n  if (!currency) return null;\n\n  if (rawAmount.length === 0 || !isNumberish(rawAmount)) return null;\n\n  warning(\n    locale || currency.fractionDigits !== 0,\n    `A locale must be provided when currency has no fraction digits (${currencyCode})`\n  );\n  const amountAsNumber = parseRawAmountToNumber(rawAmount, locale);\n  if (isNaN(amountAsNumber)) return null;\n\n  // The cent amount is rounded to the currencie's default number\n  // of fraction digits for prices with high precision.\n  //\n  // Additionally, JavaScript is sometimes incorrect when multiplying floats,\n  //   e.g. 2.49 * 100 -> 249.00000000000003\n  // While inaccuracy from multiplying floating point numbers is a\n  // general problem in JS, we can avoid it by cutting off all\n  // decimals. This is possible since cents is the base unit, so we\n  // operate on integers anyways\n  // Also we should the round the value to ensure that we come close\n  // to the nearest decimal value\n  // ref: https://github.com/commercetools/merchant-center-frontend/pull/770\n  const centAmount = Math.trunc(\n    Math.round(amountAsNumber * 10 ** currency.fractionDigits)\n  );\n\n  const fractionDigitsOfAmount =\n    // The conversion to a string will always use a dot as the separator.\n    // That means we don't have to handle a comma.\n    String(amountAsNumber).indexOf('.') === -1\n      ? 0\n      : String(amountAsNumber).length - String(amountAsNumber).indexOf('.') - 1;\n\n  if (fractionDigitsOfAmount > currency.fractionDigits) {\n    return {\n      type: 'highPrecision',\n      currencyCode,\n      centAmount,\n      preciseAmount: parseInt(\n        // Here we need to convert  a number like 8.066652 to its centamount\n        // We could do that by multiplying it with 10 ** number-of-fraction-digits\n        // but then we'll run into problems with JavaScript's floating point\n        // number precision and end up with 8066651.9999999, and then parseInt\n        // cuts off the remainder.\n        // So instead of using maths to convert the number, we just replace\n        // the dot inside the number which does the same thing.\n        // We don't need to replace \",\" as well, as numbers always us a dot\n        // when converted using String().\n        //\n        // The mathematical way: amountAsNumber * 10 ** fractionDigitsOfAmount,\n        String(amountAsNumber).replace('.', ''),\n        10\n      ),\n      fractionDigits: fractionDigitsOfAmount,\n    };\n  }\n\n  return {\n    type: 'centPrecision',\n    currencyCode,\n    centAmount,\n    fractionDigits: currency.fractionDigits,\n  };\n};\n\nconst getAmountAsNumberFromMoneyValue = (moneyValue) =>\n  moneyValue.type === 'highPrecision'\n    ? moneyValue.preciseAmount / 10 ** moneyValue.fractionDigits\n    : moneyValue.centAmount /\n      10 ** currencies[moneyValue.currencyCode].fractionDigits;\n\n// gets called with a string and should return a formatted string\nconst formatAmount = (rawAmount, currencyCode, locale) => {\n  // fallback in case the user didn't enter an amount yet (or it's invalid)\n  const moneyValue = createMoneyValue(currencyCode, rawAmount, locale) || {\n    currencyCode,\n    centAmount: NaN,\n  };\n\n  const amount = getAmountAsNumberFromMoneyValue(moneyValue);\n\n  const fractionDigits = moneyValue.preciseAmount\n    ? moneyValue.fractionDigits\n    : currencies[moneyValue.currencyCode].fractionDigits;\n\n  return isNaN(amount)\n    ? ''\n    : amount.toLocaleString(locale, { minimumFractionDigits: fractionDigits });\n};\n\nconst getAmountInputName = (name) => (name ? `${name}.amount` : undefined);\nconst getCurrencyDropdownName = (name) =>\n  name ? `${name}.currencyCode` : undefined;\n\nconst MoneyInput = (props) => {\n  const intl = useIntl();\n  const [currencyHasFocus, toggleCurrencyHasFocus] = useToggleState(false);\n  const [amountHasFocus, toggleAmountHasFocus] = useToggleState(false);\n\n  const containerRef = useRef();\n  const amountInputRef = useRef();\n\n  const { onFocus } = props;\n  const handleAmountFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getAmountInputId(props.id),\n          name: getAmountInputName(props.name),\n        },\n      });\n    toggleAmountHasFocus(true);\n  }, [toggleAmountHasFocus, onFocus, props.id, props.name]);\n\n  const { onChange } = props;\n  const handleAmountBlur = useCallback(() => {\n    const amount = props.value.amount.trim();\n    toggleAmountHasFocus(false);\n    // Skip formatting for empty value or when the input is used with an\n    // unknown currency.\n    if (amount.length > 0 && currencies[props.value.currencyCode]) {\n      const formattedAmount = formatAmount(\n        amount,\n        props.value.currencyCode,\n        intl.locale\n      );\n\n      // When the user entered a value with centPrecision, we can format\n      // the resulting value to that currency, e.g. 20.1 to 20.10\n      if (String(formattedAmount) !== amount) {\n        // We need to emit an event with the now formatted value\n        const fakeEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: formattedAmount,\n          },\n        };\n        onChange(fakeEvent);\n      }\n    }\n  }, [\n    intl.locale,\n    onChange,\n    props.id,\n    props.name,\n    props.value.amount,\n    props.value.currencyCode,\n    toggleAmountHasFocus,\n  ]);\n\n  const handleAmountChange = useCallback(\n    (event) => {\n      if (isNumberish(event.target.value)) {\n        onChange({\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: event.target.value,\n          },\n        });\n      }\n    },\n    [onChange, props.id, props.name]\n  );\n\n  const handleCurrencyChange = useCallback(\n    (option) => {\n      const currencyCode = option.value;\n      if (props.value.currencyCode !== currencyCode) {\n        // When the user changes from a currency with 3 fraction digits to\n        // a currency with 2 fraction digits, and when the input value was\n        // \"9.000\" (9), then it should change to \"9.00\" to reflect the new\n        // currency's number of fraction digits.\n        // When the currency was a high-precision price, then no digits should\n        // be lost\n        const formattedAmount = formatAmount(\n          props.value.amount.trim(),\n          currencyCode,\n          intl.locale\n        );\n        // The user could be changing the currency before entering any amount,\n        // or while the amount is invalid. In these cases, we don't attempt to\n        // format the amount.\n        const nextAmount = isNaN(formattedAmount)\n          ? props.value.amount\n          : formattedAmount;\n\n        // change currency code\n        const fakeCurrencyEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n            value: currencyCode || '',\n          },\n        };\n        onChange(fakeCurrencyEvent);\n\n        // change amount if necessary\n        if (props.value.amount !== nextAmount) {\n          onChange({\n            // eslint-disable-next-line @typescript-eslint/no-empty-function\n            persist: () => {},\n            target: {\n              id: MoneyInput.getAmountInputId(props.id),\n              name: getAmountInputName(props.name),\n              value: nextAmount,\n            },\n          });\n        }\n\n        amountInputRef.current.focus();\n      }\n    },\n    [\n      intl.locale,\n      onChange,\n      props.id,\n      props.name,\n      props.value.amount,\n      props.value.currencyCode,\n    ]\n  );\n\n  const handleCurrencyFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getCurrencyDropdownId(props.id),\n          name: getCurrencyDropdownName(props.name),\n        },\n      });\n\n    toggleCurrencyHasFocus(true);\n  }, [onFocus, toggleCurrencyHasFocus, props.name, props.id]);\n\n  const handleCurrencyBlur = useCallback(() => {\n    toggleCurrencyHasFocus(false);\n  }, [toggleCurrencyHasFocus]);\n\n  const hasNoCurrencies = props.currencies.length === 0;\n  const hasFocus = currencyHasFocus || amountHasFocus;\n  const theme = useTheme();\n  const currencySelectStyles = createCurrencySelectStyles(\n    {\n      hasWarning: props.hasWarning,\n      hasError: props.hasError,\n      isDisabled: props.isDisabled,\n      isReadOnly: props.isReadOnly,\n      hasFocus,\n      menuPortalZIndex: props.menuPortalZIndex,\n    },\n    theme\n  );\n  const options = props.currencies.map((currencyCode) => ({\n    label: currencyCode,\n    value: currencyCode,\n  }));\n\n  const option = (() => {\n    const matchedOption = options.find(\n      (optionCandidate) => optionCandidate.value === props.value.currencyCode\n    );\n    if (matchedOption) return matchedOption;\n    // ensure an option is found, even when the currencies don't include\n    // the money value's currencyCode\n    if (props.value.currencyCode.trim() !== '')\n      return {\n        label: props.value.currencyCode,\n        value: props.value.currencyCode,\n      };\n    return null;\n  })();\n\n  const id = MoneyInput.getCurrencyDropdownId(props.id);\n\n  const isHighPrecision =\n    !MoneyInput.isEmpty(props.value) &&\n    MoneyInput.isHighPrecision(props.value, intl.locale);\n\n  const { onBlur } = props;\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n          },\n        });\n        onBlur({\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n          },\n        });\n      }\n    },\n    [onBlur, props.id, props.name]\n  );\n\n  const TooltipPortal = useCallback(\n    (remainingProps) => <Portal {...remainingProps} id={props.id} />,\n    [props.id]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <div\n        ref={containerRef}\n        css={css`\n          font-family: inherit;\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n        data-testid=\"money-input-container\"\n        onBlur={handleContainerBlur}\n      >\n        {hasNoCurrencies ? (\n          <CurrencyLabel\n            id={MoneyInput.getAmountInputId(props.id)}\n            isDisabled={props.isDisabled}\n          >\n            {option && option.label}\n          </CurrencyLabel>\n        ) : (\n          <Select\n            inputId={id}\n            name={getCurrencyDropdownName(props.name)}\n            value={option}\n            isDisabled={props.isDisabled}\n            isSearchable={false}\n            components={{\n              // eslint-disable-next-line react/display-name\n              SingleValue: (innerProps) => (\n                <SingleValue {...innerProps} id={id} />\n              ),\n              // eslint-disable-next-line react/display-name\n              Input: (ownProps) => (\n                // eslint-disable-next-line react/prop-types\n                <components.Input {...ownProps} readOnly={props.isReadOnly} />\n              ),\n              DropdownIndicator,\n            }}\n            options={options}\n            menuIsOpen={props.isReadOnly ? false : undefined}\n            placeholder=\"\"\n            styles={currencySelectStyles}\n            onFocus={handleCurrencyFocus}\n            menuPortalTarget={props.menuPortalTarget}\n            menuShouldBlockScroll={props.menuShouldBlockScroll}\n            onBlur={handleCurrencyBlur}\n            onChange={handleCurrencyChange}\n            data-testid=\"currency-dropdown\"\n          />\n        )}\n        <div\n          css={css`\n            position: relative;\n            width: 100%;\n          `}\n        >\n          <input\n            ref={amountInputRef}\n            id={MoneyInput.getAmountInputId(props.id)}\n            autoComplete={props.autoComplete}\n            name={getAmountInputName(props.name)}\n            type=\"text\"\n            onFocus={handleAmountFocus}\n            value={props.value.amount}\n            css={[\n              getAmountInputStyles({ ...props, hasFocus }),\n              // accounts for size of icon\n              props.hasHighPrecisionBadge &&\n                isHighPrecision &&\n                css`\n                  padding-right: ${vars.spacingL};\n                `,\n            ]}\n            placeholder={props.placeholder}\n            onChange={handleAmountChange}\n            onBlur={handleAmountBlur}\n            disabled={props.isDisabled}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            {...filterDataAttributes(props)}\n          />\n          {props.hasHighPrecisionBadge && isHighPrecision && (\n            <>\n              {!props.isDisabled && <div id={getPortalId(props.id)} />}\n              <div\n                css={() =>\n                  getHighPrecisionWrapperStyles({\n                    isDisabled: props.isDisabled,\n                  })\n                }\n              >\n                <Tooltip\n                  off={props.isDisabled}\n                  placement=\"top-end\"\n                  // we use negative margin to make up for the padding in the Tooltip Wrapper\n                  // so that the tooltip is flush with the component\n                  styles={{\n                    body: {\n                      margin: `${vars.spacingS} -${vars.spacingXs} ${vars.spacingS} 0`,\n                    },\n                  }}\n                  title={intl.formatMessage(messages.highPrecision)}\n                  components={{\n                    TooltipWrapperComponent: TooltipPortal,\n                    WrapperComponent: TooltipWrapper,\n                  }}\n                >\n                  <FractionDigitsIcon\n                    color={props.isDisabled ? 'neutral60' : 'info'}\n                  />\n                </Tooltip>\n              </div>\n            </>\n          )}\n        </div>\n      </div>\n    </Constraints.Horizontal>\n  );\n};\n\nMoneyInput.displayName = 'MoneyInput';\n\nMoneyInput.getAmountInputId = getAmountInputName;\n\nMoneyInput.getCurrencyDropdownId = getCurrencyDropdownName;\n\nMoneyInput.convertToMoneyValue = (value, locale) =>\n  createMoneyValue(\n    value.currencyCode,\n    typeof value.amount === 'string' ? value.amount.trim() : '',\n    locale\n  );\n\nMoneyInput.parseMoneyValue = (moneyValue, locale) => {\n  if (!moneyValue) return { currencyCode: '', amount: '' };\n\n  warning(\n    typeof locale === 'string',\n    'MoneyInput.parseMoneyValue: A locale must be passed as the second argument'\n  );\n\n  warning(\n    typeof moneyValue === 'object',\n    'MoneyInput.parseMoneyValue: Value must be passed as an object or be undefined'\n  );\n\n  warning(\n    typeof moneyValue.currencyCode === 'string',\n    'MoneyInput.parseMoneyValue: Value must contain \"currencyCode\"'\n  );\n\n  warning(\n    has(currencies, moneyValue.currencyCode),\n    'MoneyInput.parseMoneyValue: Value must use known currency code'\n  );\n\n  warning(\n    // highPrecision or centPrecision values must be set\n    typeof moneyValue.centAmount === 'number' ||\n      (typeof moneyValue.preciseAmount === 'number' &&\n        typeof moneyValue.fractionDigits === 'number'),\n    'MoneyInput.parseMoneyValue: Value must contain \"amount\"'\n  );\n\n  const amount = formatAmount(\n    getAmountAsNumberFromMoneyValue(moneyValue).toLocaleString(locale, {\n      minimumFractionDigits: moneyValue.fractionDigits,\n    }),\n    moneyValue.currencyCode,\n    locale\n  );\n\n  return { amount, currencyCode: moneyValue.currencyCode };\n};\n\nMoneyInput.isEmpty = (formValue) =>\n  !formValue ||\n  formValue.amount.trim() === '' ||\n  formValue.currencyCode.trim() === '';\n\nMoneyInput.isHighPrecision = (formValue, locale) => {\n  warning(\n    !MoneyInput.isEmpty(formValue),\n    'MoneyValue.isHighPrecision may not be called with an empty money value.'\n  );\n  const moneyValue = MoneyInput.convertToMoneyValue(formValue, locale);\n  return moneyValue && moneyValue.type === 'highPrecision';\n};\n\nMoneyInput.isTouched = (touched) =>\n  Boolean(touched && touched.currencyCode && touched.amount);\n\nMoneyInput.propTypes = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`) and the currency dropdown (`${name}.currencyCode`).\n   */\n  name: PropTypes.string,\n  /**\n   * Value of the input. Consists of the currency code and an amount. `amount` is a string representing the amount. A dot has to be used as the decimal separator.\n   */\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  /**\n   * List of possible currencies. When not provided or empty, the component renders a label with the value's currency instead of a dropdown.\n   */\n  currencies: PropTypes.arrayOf(PropTypes.string).isRequired,\n  /**\n   * Placeholder text for the input\n   */\n  placeholder: PropTypes.string,\n  /**\n   * Called when input is blurred\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when input is focused\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Called with the event of the input or dropdown when either the currency or the amount have changed.\n   * <br />\n   * Signature: `(event) => void`\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Dom element to portal the currency select menu to\n   */\n  menuPortalTarget: PropTypes.instanceOf(SafeHTMLElement),\n  /**\n   * z-index value for the currency select menu portal\n   */\n  menuPortalZIndex: PropTypes.number,\n  /**\n   * whether the menu should block scroll while open\n   */\n  menuShouldBlockScroll: PropTypes.bool,\n  /**\n   * Indicates that input has errors\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning: PropTypes.bool,\n  /**\n   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge: PropTypes.bool,\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n};\n\nMoneyInput.defaultProps = {\n  currencies: [],\n  horizontalConstraint: 'scale',\n  menuPortalZIndex: 1,\n};\n\nexport default MoneyInput;\n"]} */",
777
777
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
778
778
  });
779
779
 
@@ -787,35 +787,39 @@ var getPortalNode = function getPortalNode(id) {
787
787
 
788
788
  var Portal = function Portal(props) {
789
789
  var domNode = getPortalNode(props.id);
790
- return /*#__PURE__*/ReactDOM__default['default'].createPortal(props.children, domNode);
790
+ return /*#__PURE__*/ReactDOM__default["default"].createPortal(props.children, domNode);
791
791
  };
792
792
 
793
793
  var CurrencyLabel = function CurrencyLabel(props) {
794
- return react.jsx("label", {
794
+ return jsxRuntime.jsx("label", {
795
795
  htmlFor: props.id,
796
- css: getCurrencyLabelStyles()
797
- }, props.children);
796
+ css: getCurrencyLabelStyles(),
797
+ children: props.children
798
+ });
798
799
  };
799
800
 
800
801
  CurrencyLabel.displayName = 'CurrencyLabel';
801
802
  CurrencyLabel.propTypes = process.env.NODE_ENV !== "production" ? {
802
- id: PropTypes__default['default'].string,
803
- children: PropTypes__default['default'].node
803
+ id: PropTypes__default["default"].string,
804
+ children: PropTypes__default["default"].node
804
805
  } : {};
805
806
 
806
807
  var _SingleValue = function SingleValue(_ref3) {
807
808
  var id = _ref3.id,
808
809
  props = _objectWithoutProperties(_ref3, _excluded);
809
810
 
810
- return react.jsx(Select.components.SingleValue, props, react.jsx("label", {
811
- htmlFor: id
812
- }, props.children));
811
+ return jsxRuntime.jsx(Select.components.SingleValue, _objectSpread(_objectSpread({}, props), {}, {
812
+ children: jsxRuntime.jsx("label", {
813
+ htmlFor: id,
814
+ children: props.children
815
+ })
816
+ }));
813
817
  };
814
818
 
815
819
  _SingleValue.displayName = 'SingleValue';
816
820
  _SingleValue.propTypes = process.env.NODE_ENV !== "production" ? {
817
- id: PropTypes__default['default'].string,
818
- children: PropTypes__default['default'].node
821
+ id: PropTypes__default["default"].string,
822
+ children: PropTypes__default["default"].node
819
823
  } : {}; // overwrite styles of createSelectStyles
820
824
 
821
825
  var createCurrencySelectStyles = function createCurrencySelectStyles(_ref4, theme) {
@@ -944,14 +948,15 @@ var parseRawAmountToNumber = function parseRawAmountToNumber(rawAmount, locale)
944
948
  var fractionsSeparator;
945
949
 
946
950
  if (locale) {
947
- fractionsSeparator = 2.5.toLocaleString(locale) // "symbol" for the provided locale
951
+ fractionsSeparator = 2.5 // we need any number with fractions, so that we know what is the fraction
952
+ .toLocaleString(locale) // "symbol" for the provided locale
948
953
  .replace(/\d/g, ''); // then we remove the numbers and keep the "symbol"
949
954
  } else {
950
955
  var _context, _context2;
951
956
 
952
- var lastDot = _lastIndexOfInstanceProperty__default['default'](_context = String(rawAmount)).call(_context, '.');
957
+ var lastDot = _lastIndexOfInstanceProperty__default["default"](_context = String(rawAmount)).call(_context, '.');
953
958
 
954
- var lastComma = _lastIndexOfInstanceProperty__default['default'](_context2 = String(rawAmount)).call(_context2, ',');
959
+ var lastComma = _lastIndexOfInstanceProperty__default["default"](_context2 = String(rawAmount)).call(_context2, ',');
955
960
 
956
961
  fractionsSeparator = lastComma > lastDot ? ',' : '.';
957
962
  }
@@ -962,7 +967,7 @@ var parseRawAmountToNumber = function parseRawAmountToNumber(rawAmount, locale)
962
967
  var normalizedAmount = String(rawAmount).replace(new RegExp("[^0-9".concat(fractionsSeparator, "]"), 'g'), '') // we just keep the numbers and the fraction symbol
963
968
  .replace(fractionsSeparator, '.'); // then we change whatever `fractionsSeparator` was to `.` so we can parse it as float
964
969
 
965
- return _parseFloat__default['default'](normalizedAmount, 10);
970
+ return _parseFloat__default["default"](normalizedAmount, 10);
966
971
  }; // Turns the user input into a value the MoneyInput can pass up through onChange
967
972
  // In case the number of fraction digits contained in "amount" exceeds the
968
973
  // number of fraction digits the currency uses, it will emit a price of
@@ -997,18 +1002,18 @@ var createMoneyValue = function createMoneyValue(currencyCode, rawAmount, locale
997
1002
  // to the nearest decimal value
998
1003
  // ref: https://github.com/commercetools/merchant-center-frontend/pull/770
999
1004
 
1000
- var centAmount = _Math$trunc__default['default'](Math.round(amountAsNumber * Math.pow(10, currency.fractionDigits)));
1005
+ var centAmount = _Math$trunc__default["default"](Math.round(amountAsNumber * Math.pow(10, currency.fractionDigits)));
1001
1006
 
1002
1007
  var fractionDigitsOfAmount = // The conversion to a string will always use a dot as the separator.
1003
1008
  // That means we don't have to handle a comma.
1004
- _indexOfInstanceProperty__default['default'](_context3 = String(amountAsNumber)).call(_context3, '.') === -1 ? 0 : String(amountAsNumber).length - _indexOfInstanceProperty__default['default'](_context4 = String(amountAsNumber)).call(_context4, '.') - 1;
1009
+ _indexOfInstanceProperty__default["default"](_context3 = String(amountAsNumber)).call(_context3, '.') === -1 ? 0 : String(amountAsNumber).length - _indexOfInstanceProperty__default["default"](_context4 = String(amountAsNumber)).call(_context4, '.') - 1;
1005
1010
 
1006
1011
  if (fractionDigitsOfAmount > currency.fractionDigits) {
1007
1012
  return {
1008
1013
  type: 'highPrecision',
1009
1014
  currencyCode: currencyCode,
1010
1015
  centAmount: centAmount,
1011
- preciseAmount: _parseInt__default['default']( // Here we need to convert a number like 8.066652 to its centamount
1016
+ preciseAmount: _parseInt__default["default"]( // Here we need to convert a number like 8.066652 to its centamount
1012
1017
  // We could do that by multiplying it with 10 ** number-of-fraction-digits
1013
1018
  // but then we'll run into problems with JavaScript's floating point
1014
1019
  // number precision and end up with 8066651.9999999, and then parseInt
@@ -1064,6 +1069,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
1064
1069
  } : {
1065
1070
  name: "h5hvsa-MoneyInput",
1066
1071
  styles: "position:relative;width:100%;label:MoneyInput;",
1072
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["money-input.js"],"names":[],"mappings":"AAwlBkB","file":"money-input.js","sourcesContent":["import { useRef, useCallback } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport has from 'lodash/has';\nimport requiredIf from 'react-required-if';\nimport Select, { components } from 'react-select';\nimport { useIntl } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport {\n  warning,\n  isNumberish,\n  SafeHTMLElement,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  DropdownIndicator,\n  createSelectStyles,\n} from '@commercetools-uikit/select-utils';\nimport { FractionDigitsIcon } from '@commercetools-uikit/icons';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport currencies from './currencies.json';\nimport {\n  getHighPrecisionWrapperStyles,\n  getCurrencyLabelStyles,\n  getAmountInputStyles,\n} from './money-input.styles';\nimport messages from './messages';\n\nconst TooltipWrapper = styled.div`\n  display: flex;\n`;\n\nconst getPortalId = (id) => `portal-${id}`;\nconst getPortalNode = (id) => document.querySelector(`#${getPortalId(id)}`);\n\nconst Portal = (props) => {\n  const domNode = getPortalNode(props.id);\n  return ReactDOM.createPortal(props.children, domNode);\n};\n\nconst CurrencyLabel = (props) => (\n  <label htmlFor={props.id} css={getCurrencyLabelStyles()}>\n    {props.children}\n  </label>\n);\n\nCurrencyLabel.displayName = 'CurrencyLabel';\n\nCurrencyLabel.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\nconst SingleValue = ({ id, ...props }) => (\n  <components.SingleValue {...props}>\n    <label htmlFor={id}>{props.children}</label>\n  </components.SingleValue>\n);\n\nSingleValue.displayName = 'SingleValue';\n\nSingleValue.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\n// overwrite styles of createSelectStyles\nconst createCurrencySelectStyles = (\n  { hasWarning, hasError, isDisabled, isReadOnly, hasFocus, menuPortalZIndex },\n  theme\n) => {\n  const selectStyles = createSelectStyles(\n    {\n      hasWarning,\n      hasError,\n      menuPortalZIndex,\n    },\n    theme\n  );\n  return {\n    ...selectStyles,\n    control: (base, state) => ({\n      ...selectStyles.control(base, state),\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      minWidth: '72px',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${vars.borderColorForInputWhenDisabled} !important`;\n        if (hasError) return vars.borderColorForInputWhenError;\n        if (hasWarning) return vars.borderColorForInputWhenWarning;\n        if (hasFocus) return vars.borderColorForInputWhenFocused;\n        if (isReadOnly)\n          return `${vars.borderColorForInputWhenReadonly} !important`;\n        return vars.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: (() => {\n        if (isReadOnly) return vars.backgroundColorForInput;\n        return base.backgroundColor;\n      })(),\n    }),\n    singleValue: (base) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: (() => {\n        if (isDisabled) return vars.fontColorForInputWhenDisabled;\n        if (hasError) return vars.fontColorForInputWhenError;\n        if (hasWarning) return vars.fontColorForInputWhenWarning;\n        if (isReadOnly) return vars.fontColorForInputWhenReadonly;\n        return base.color;\n      })(),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly ? vars.fontColorForInputWhenReadonly : '',\n    }),\n  };\n};\n\n// The MoneyInput component always operates on a value consisting of:\n//   { amount: String, currencyCode: String }\n//\n// The amount may only use a dot as the decimal separator.\n// The currencyCode must be supported by the API.\n//\n// The MoneyInput does not do any validation on its own. It only serves as a way\n// to get the amount and currencyCode input from the user. Validation is always\n// up to the parent.\n//\n// The CTP API supports prices two types of prices: centPrecision and\n// highPrecision. The MoneyInput itself does not know about these. However,\n// it has two static methods defined (convertToMoneyValue and parseMoneyValue),\n// which can be used to convert between MoneyInput value and the MoneyValue\n// supported by the API.\n// Some places in the API do not support highPrecision prices, but the\n// convertToMoneyValue will always return either a centPrecision or a\n// highPrecision price. It's up the MoneyInput's parent to show a validation\n// error in case a highPrecision price is used.\n//\n// A value is considered as to have highPrecision when the number of supplied\n// fraction digits exceed the number of fraction digits the currency uses. For\n// example, 42.00 € is always a centPrecision price, while 42.001 € is always a\n// highPrecision price. It is not possible to hae 42.00 € as a highPrecision\n// price.\n//\n// The first time the component renders, we want to try to show the centAmount\n// as a formatted number. To achieve this, the parseMoneyValue function can\n// be used to turn the API value into a value the MoneyInput understands.\n// During this transformation, the money value will get formatted into \"amount\".\n//\n// When the user changes the value, we don't want to format again. We only format\n// in case the user blurs the field. This avoids many edge cases where the\n// formatting would mess with the user's input.\n//\n//\n// A full example of an MoneyValue with centPrecision would be\n// {\n//   \"type\": \"centPrecision\",\n//   \"currencyCode\": \"EUR\",\n//   \"centAmount\": 4200,\n//   \"fractionDigits\": 2\n// }\n// which equals 42.00 €\n//\n// A full example of an MoneyValue with highPrecision would be\n// {\n//  \"type\": \"highPrecision\",\n//  \"currencyCode\": \"EUR\",\n//  \"centAmount\": 1,\n//  \"preciseAmount\": 123456,\n//  \"fractionDigits\": 7\n// }\n// which equals 0.0123456 €\n\n// Parsing\n// Since most users are not careful about how they enter values, we will parse\n// both `.` and `,` as decimal separators.\n// When a value is `1.000,00` we parse it as `1000`.\n// When a value is `1,000.00` we also parse it as `1000`.\n//\n// This means the highest amount always wins. We do this by comparing the last\n// position of `.` and `,`. Whatever occurs later is used as the decimal\n// separator.\nexport const parseRawAmountToNumber = (rawAmount, locale) => {\n  let fractionsSeparator;\n\n  if (locale) {\n    fractionsSeparator = (2.5) // we need any number with fractions, so that we know what is the fraction\n      .toLocaleString(locale) // \"symbol\" for the provided locale\n      .replace(/\\d/g, ''); // then we remove the numbers and keep the \"symbol\"\n  } else {\n    const lastDot = String(rawAmount).lastIndexOf('.');\n    const lastComma = String(rawAmount).lastIndexOf(',');\n    fractionsSeparator = lastComma > lastDot ? ',' : '.';\n  }\n\n  fractionsSeparator = fractionsSeparator === '.' ? '\\\\.' : fractionsSeparator; // here we escape the '.' to use it as regex\n  // The raw amount with only one sparator\n  const normalizedAmount = String(rawAmount)\n    .replace(new RegExp(`[^0-9${fractionsSeparator}]`, 'g'), '') // we just keep the numbers and the fraction symbol\n    .replace(fractionsSeparator, '.'); // then we change whatever `fractionsSeparator` was to `.` so we can parse it as float\n\n  return parseFloat(normalizedAmount, 10);\n};\n\n// Turns the user input into a value the MoneyInput can pass up through onChange\n// In case the number of fraction digits contained in \"amount\" exceeds the\n// number of fraction digits the currency uses, it will emit a price of\n// type \"highPrecision\" instead of the regular \"centPrecision\".\n// It will return \"null\" in case an invalid value is entered.\n// The value is invalid when\n//  - no amount was entered\n//  - an invalid amount was entered\n//  - no currency was selected\n//\n// This function expects the \"amount\" to be a trimmed value.\nexport const createMoneyValue = (currencyCode, rawAmount, locale) => {\n  if (!currencyCode) return null;\n\n  const currency = currencies[currencyCode];\n  if (!currency) return null;\n\n  if (rawAmount.length === 0 || !isNumberish(rawAmount)) return null;\n\n  warning(\n    locale || currency.fractionDigits !== 0,\n    `A locale must be provided when currency has no fraction digits (${currencyCode})`\n  );\n  const amountAsNumber = parseRawAmountToNumber(rawAmount, locale);\n  if (isNaN(amountAsNumber)) return null;\n\n  // The cent amount is rounded to the currencie's default number\n  // of fraction digits for prices with high precision.\n  //\n  // Additionally, JavaScript is sometimes incorrect when multiplying floats,\n  //   e.g. 2.49 * 100 -> 249.00000000000003\n  // While inaccuracy from multiplying floating point numbers is a\n  // general problem in JS, we can avoid it by cutting off all\n  // decimals. This is possible since cents is the base unit, so we\n  // operate on integers anyways\n  // Also we should the round the value to ensure that we come close\n  // to the nearest decimal value\n  // ref: https://github.com/commercetools/merchant-center-frontend/pull/770\n  const centAmount = Math.trunc(\n    Math.round(amountAsNumber * 10 ** currency.fractionDigits)\n  );\n\n  const fractionDigitsOfAmount =\n    // The conversion to a string will always use a dot as the separator.\n    // That means we don't have to handle a comma.\n    String(amountAsNumber).indexOf('.') === -1\n      ? 0\n      : String(amountAsNumber).length - String(amountAsNumber).indexOf('.') - 1;\n\n  if (fractionDigitsOfAmount > currency.fractionDigits) {\n    return {\n      type: 'highPrecision',\n      currencyCode,\n      centAmount,\n      preciseAmount: parseInt(\n        // Here we need to convert  a number like 8.066652 to its centamount\n        // We could do that by multiplying it with 10 ** number-of-fraction-digits\n        // but then we'll run into problems with JavaScript's floating point\n        // number precision and end up with 8066651.9999999, and then parseInt\n        // cuts off the remainder.\n        // So instead of using maths to convert the number, we just replace\n        // the dot inside the number which does the same thing.\n        // We don't need to replace \",\" as well, as numbers always us a dot\n        // when converted using String().\n        //\n        // The mathematical way: amountAsNumber * 10 ** fractionDigitsOfAmount,\n        String(amountAsNumber).replace('.', ''),\n        10\n      ),\n      fractionDigits: fractionDigitsOfAmount,\n    };\n  }\n\n  return {\n    type: 'centPrecision',\n    currencyCode,\n    centAmount,\n    fractionDigits: currency.fractionDigits,\n  };\n};\n\nconst getAmountAsNumberFromMoneyValue = (moneyValue) =>\n  moneyValue.type === 'highPrecision'\n    ? moneyValue.preciseAmount / 10 ** moneyValue.fractionDigits\n    : moneyValue.centAmount /\n      10 ** currencies[moneyValue.currencyCode].fractionDigits;\n\n// gets called with a string and should return a formatted string\nconst formatAmount = (rawAmount, currencyCode, locale) => {\n  // fallback in case the user didn't enter an amount yet (or it's invalid)\n  const moneyValue = createMoneyValue(currencyCode, rawAmount, locale) || {\n    currencyCode,\n    centAmount: NaN,\n  };\n\n  const amount = getAmountAsNumberFromMoneyValue(moneyValue);\n\n  const fractionDigits = moneyValue.preciseAmount\n    ? moneyValue.fractionDigits\n    : currencies[moneyValue.currencyCode].fractionDigits;\n\n  return isNaN(amount)\n    ? ''\n    : amount.toLocaleString(locale, { minimumFractionDigits: fractionDigits });\n};\n\nconst getAmountInputName = (name) => (name ? `${name}.amount` : undefined);\nconst getCurrencyDropdownName = (name) =>\n  name ? `${name}.currencyCode` : undefined;\n\nconst MoneyInput = (props) => {\n  const intl = useIntl();\n  const [currencyHasFocus, toggleCurrencyHasFocus] = useToggleState(false);\n  const [amountHasFocus, toggleAmountHasFocus] = useToggleState(false);\n\n  const containerRef = useRef();\n  const amountInputRef = useRef();\n\n  const { onFocus } = props;\n  const handleAmountFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getAmountInputId(props.id),\n          name: getAmountInputName(props.name),\n        },\n      });\n    toggleAmountHasFocus(true);\n  }, [toggleAmountHasFocus, onFocus, props.id, props.name]);\n\n  const { onChange } = props;\n  const handleAmountBlur = useCallback(() => {\n    const amount = props.value.amount.trim();\n    toggleAmountHasFocus(false);\n    // Skip formatting for empty value or when the input is used with an\n    // unknown currency.\n    if (amount.length > 0 && currencies[props.value.currencyCode]) {\n      const formattedAmount = formatAmount(\n        amount,\n        props.value.currencyCode,\n        intl.locale\n      );\n\n      // When the user entered a value with centPrecision, we can format\n      // the resulting value to that currency, e.g. 20.1 to 20.10\n      if (String(formattedAmount) !== amount) {\n        // We need to emit an event with the now formatted value\n        const fakeEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: formattedAmount,\n          },\n        };\n        onChange(fakeEvent);\n      }\n    }\n  }, [\n    intl.locale,\n    onChange,\n    props.id,\n    props.name,\n    props.value.amount,\n    props.value.currencyCode,\n    toggleAmountHasFocus,\n  ]);\n\n  const handleAmountChange = useCallback(\n    (event) => {\n      if (isNumberish(event.target.value)) {\n        onChange({\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: event.target.value,\n          },\n        });\n      }\n    },\n    [onChange, props.id, props.name]\n  );\n\n  const handleCurrencyChange = useCallback(\n    (option) => {\n      const currencyCode = option.value;\n      if (props.value.currencyCode !== currencyCode) {\n        // When the user changes from a currency with 3 fraction digits to\n        // a currency with 2 fraction digits, and when the input value was\n        // \"9.000\" (9), then it should change to \"9.00\" to reflect the new\n        // currency's number of fraction digits.\n        // When the currency was a high-precision price, then no digits should\n        // be lost\n        const formattedAmount = formatAmount(\n          props.value.amount.trim(),\n          currencyCode,\n          intl.locale\n        );\n        // The user could be changing the currency before entering any amount,\n        // or while the amount is invalid. In these cases, we don't attempt to\n        // format the amount.\n        const nextAmount = isNaN(formattedAmount)\n          ? props.value.amount\n          : formattedAmount;\n\n        // change currency code\n        const fakeCurrencyEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n            value: currencyCode || '',\n          },\n        };\n        onChange(fakeCurrencyEvent);\n\n        // change amount if necessary\n        if (props.value.amount !== nextAmount) {\n          onChange({\n            // eslint-disable-next-line @typescript-eslint/no-empty-function\n            persist: () => {},\n            target: {\n              id: MoneyInput.getAmountInputId(props.id),\n              name: getAmountInputName(props.name),\n              value: nextAmount,\n            },\n          });\n        }\n\n        amountInputRef.current.focus();\n      }\n    },\n    [\n      intl.locale,\n      onChange,\n      props.id,\n      props.name,\n      props.value.amount,\n      props.value.currencyCode,\n    ]\n  );\n\n  const handleCurrencyFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getCurrencyDropdownId(props.id),\n          name: getCurrencyDropdownName(props.name),\n        },\n      });\n\n    toggleCurrencyHasFocus(true);\n  }, [onFocus, toggleCurrencyHasFocus, props.name, props.id]);\n\n  const handleCurrencyBlur = useCallback(() => {\n    toggleCurrencyHasFocus(false);\n  }, [toggleCurrencyHasFocus]);\n\n  const hasNoCurrencies = props.currencies.length === 0;\n  const hasFocus = currencyHasFocus || amountHasFocus;\n  const theme = useTheme();\n  const currencySelectStyles = createCurrencySelectStyles(\n    {\n      hasWarning: props.hasWarning,\n      hasError: props.hasError,\n      isDisabled: props.isDisabled,\n      isReadOnly: props.isReadOnly,\n      hasFocus,\n      menuPortalZIndex: props.menuPortalZIndex,\n    },\n    theme\n  );\n  const options = props.currencies.map((currencyCode) => ({\n    label: currencyCode,\n    value: currencyCode,\n  }));\n\n  const option = (() => {\n    const matchedOption = options.find(\n      (optionCandidate) => optionCandidate.value === props.value.currencyCode\n    );\n    if (matchedOption) return matchedOption;\n    // ensure an option is found, even when the currencies don't include\n    // the money value's currencyCode\n    if (props.value.currencyCode.trim() !== '')\n      return {\n        label: props.value.currencyCode,\n        value: props.value.currencyCode,\n      };\n    return null;\n  })();\n\n  const id = MoneyInput.getCurrencyDropdownId(props.id);\n\n  const isHighPrecision =\n    !MoneyInput.isEmpty(props.value) &&\n    MoneyInput.isHighPrecision(props.value, intl.locale);\n\n  const { onBlur } = props;\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n          },\n        });\n        onBlur({\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n          },\n        });\n      }\n    },\n    [onBlur, props.id, props.name]\n  );\n\n  const TooltipPortal = useCallback(\n    (remainingProps) => <Portal {...remainingProps} id={props.id} />,\n    [props.id]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <div\n        ref={containerRef}\n        css={css`\n          font-family: inherit;\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n        data-testid=\"money-input-container\"\n        onBlur={handleContainerBlur}\n      >\n        {hasNoCurrencies ? (\n          <CurrencyLabel\n            id={MoneyInput.getAmountInputId(props.id)}\n            isDisabled={props.isDisabled}\n          >\n            {option && option.label}\n          </CurrencyLabel>\n        ) : (\n          <Select\n            inputId={id}\n            name={getCurrencyDropdownName(props.name)}\n            value={option}\n            isDisabled={props.isDisabled}\n            isSearchable={false}\n            components={{\n              // eslint-disable-next-line react/display-name\n              SingleValue: (innerProps) => (\n                <SingleValue {...innerProps} id={id} />\n              ),\n              // eslint-disable-next-line react/display-name\n              Input: (ownProps) => (\n                // eslint-disable-next-line react/prop-types\n                <components.Input {...ownProps} readOnly={props.isReadOnly} />\n              ),\n              DropdownIndicator,\n            }}\n            options={options}\n            menuIsOpen={props.isReadOnly ? false : undefined}\n            placeholder=\"\"\n            styles={currencySelectStyles}\n            onFocus={handleCurrencyFocus}\n            menuPortalTarget={props.menuPortalTarget}\n            menuShouldBlockScroll={props.menuShouldBlockScroll}\n            onBlur={handleCurrencyBlur}\n            onChange={handleCurrencyChange}\n            data-testid=\"currency-dropdown\"\n          />\n        )}\n        <div\n          css={css`\n            position: relative;\n            width: 100%;\n          `}\n        >\n          <input\n            ref={amountInputRef}\n            id={MoneyInput.getAmountInputId(props.id)}\n            autoComplete={props.autoComplete}\n            name={getAmountInputName(props.name)}\n            type=\"text\"\n            onFocus={handleAmountFocus}\n            value={props.value.amount}\n            css={[\n              getAmountInputStyles({ ...props, hasFocus }),\n              // accounts for size of icon\n              props.hasHighPrecisionBadge &&\n                isHighPrecision &&\n                css`\n                  padding-right: ${vars.spacingL};\n                `,\n            ]}\n            placeholder={props.placeholder}\n            onChange={handleAmountChange}\n            onBlur={handleAmountBlur}\n            disabled={props.isDisabled}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            {...filterDataAttributes(props)}\n          />\n          {props.hasHighPrecisionBadge && isHighPrecision && (\n            <>\n              {!props.isDisabled && <div id={getPortalId(props.id)} />}\n              <div\n                css={() =>\n                  getHighPrecisionWrapperStyles({\n                    isDisabled: props.isDisabled,\n                  })\n                }\n              >\n                <Tooltip\n                  off={props.isDisabled}\n                  placement=\"top-end\"\n                  // we use negative margin to make up for the padding in the Tooltip Wrapper\n                  // so that the tooltip is flush with the component\n                  styles={{\n                    body: {\n                      margin: `${vars.spacingS} -${vars.spacingXs} ${vars.spacingS} 0`,\n                    },\n                  }}\n                  title={intl.formatMessage(messages.highPrecision)}\n                  components={{\n                    TooltipWrapperComponent: TooltipPortal,\n                    WrapperComponent: TooltipWrapper,\n                  }}\n                >\n                  <FractionDigitsIcon\n                    color={props.isDisabled ? 'neutral60' : 'info'}\n                  />\n                </Tooltip>\n              </div>\n            </>\n          )}\n        </div>\n      </div>\n    </Constraints.Horizontal>\n  );\n};\n\nMoneyInput.displayName = 'MoneyInput';\n\nMoneyInput.getAmountInputId = getAmountInputName;\n\nMoneyInput.getCurrencyDropdownId = getCurrencyDropdownName;\n\nMoneyInput.convertToMoneyValue = (value, locale) =>\n  createMoneyValue(\n    value.currencyCode,\n    typeof value.amount === 'string' ? value.amount.trim() : '',\n    locale\n  );\n\nMoneyInput.parseMoneyValue = (moneyValue, locale) => {\n  if (!moneyValue) return { currencyCode: '', amount: '' };\n\n  warning(\n    typeof locale === 'string',\n    'MoneyInput.parseMoneyValue: A locale must be passed as the second argument'\n  );\n\n  warning(\n    typeof moneyValue === 'object',\n    'MoneyInput.parseMoneyValue: Value must be passed as an object or be undefined'\n  );\n\n  warning(\n    typeof moneyValue.currencyCode === 'string',\n    'MoneyInput.parseMoneyValue: Value must contain \"currencyCode\"'\n  );\n\n  warning(\n    has(currencies, moneyValue.currencyCode),\n    'MoneyInput.parseMoneyValue: Value must use known currency code'\n  );\n\n  warning(\n    // highPrecision or centPrecision values must be set\n    typeof moneyValue.centAmount === 'number' ||\n      (typeof moneyValue.preciseAmount === 'number' &&\n        typeof moneyValue.fractionDigits === 'number'),\n    'MoneyInput.parseMoneyValue: Value must contain \"amount\"'\n  );\n\n  const amount = formatAmount(\n    getAmountAsNumberFromMoneyValue(moneyValue).toLocaleString(locale, {\n      minimumFractionDigits: moneyValue.fractionDigits,\n    }),\n    moneyValue.currencyCode,\n    locale\n  );\n\n  return { amount, currencyCode: moneyValue.currencyCode };\n};\n\nMoneyInput.isEmpty = (formValue) =>\n  !formValue ||\n  formValue.amount.trim() === '' ||\n  formValue.currencyCode.trim() === '';\n\nMoneyInput.isHighPrecision = (formValue, locale) => {\n  warning(\n    !MoneyInput.isEmpty(formValue),\n    'MoneyValue.isHighPrecision may not be called with an empty money value.'\n  );\n  const moneyValue = MoneyInput.convertToMoneyValue(formValue, locale);\n  return moneyValue && moneyValue.type === 'highPrecision';\n};\n\nMoneyInput.isTouched = (touched) =>\n  Boolean(touched && touched.currencyCode && touched.amount);\n\nMoneyInput.propTypes = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`) and the currency dropdown (`${name}.currencyCode`).\n   */\n  name: PropTypes.string,\n  /**\n   * Value of the input. Consists of the currency code and an amount. `amount` is a string representing the amount. A dot has to be used as the decimal separator.\n   */\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  /**\n   * List of possible currencies. When not provided or empty, the component renders a label with the value's currency instead of a dropdown.\n   */\n  currencies: PropTypes.arrayOf(PropTypes.string).isRequired,\n  /**\n   * Placeholder text for the input\n   */\n  placeholder: PropTypes.string,\n  /**\n   * Called when input is blurred\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when input is focused\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Called with the event of the input or dropdown when either the currency or the amount have changed.\n   * <br />\n   * Signature: `(event) => void`\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Dom element to portal the currency select menu to\n   */\n  menuPortalTarget: PropTypes.instanceOf(SafeHTMLElement),\n  /**\n   * z-index value for the currency select menu portal\n   */\n  menuPortalZIndex: PropTypes.number,\n  /**\n   * whether the menu should block scroll while open\n   */\n  menuShouldBlockScroll: PropTypes.bool,\n  /**\n   * Indicates that input has errors\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning: PropTypes.bool,\n  /**\n   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge: PropTypes.bool,\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n};\n\nMoneyInput.defaultProps = {\n  currencies: [],\n  horizontalConstraint: 'scale',\n  menuPortalZIndex: 1,\n};\n\nexport default MoneyInput;\n"]} */",
1067
1073
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1068
1074
  };
1069
1075
 
@@ -1073,6 +1079,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
1073
1079
  } : {
1074
1080
  name: "1w49f4-MoneyInput",
1075
1081
  styles: "font-family:inherit;width:100%;position:relative;display:flex;label:MoneyInput;",
1082
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["money-input.js"],"names":[],"mappings":"AAwiBgB","file":"money-input.js","sourcesContent":["import { useRef, useCallback } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport has from 'lodash/has';\nimport requiredIf from 'react-required-if';\nimport Select, { components } from 'react-select';\nimport { useIntl } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport {\n  warning,\n  isNumberish,\n  SafeHTMLElement,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  DropdownIndicator,\n  createSelectStyles,\n} from '@commercetools-uikit/select-utils';\nimport { FractionDigitsIcon } from '@commercetools-uikit/icons';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport currencies from './currencies.json';\nimport {\n  getHighPrecisionWrapperStyles,\n  getCurrencyLabelStyles,\n  getAmountInputStyles,\n} from './money-input.styles';\nimport messages from './messages';\n\nconst TooltipWrapper = styled.div`\n  display: flex;\n`;\n\nconst getPortalId = (id) => `portal-${id}`;\nconst getPortalNode = (id) => document.querySelector(`#${getPortalId(id)}`);\n\nconst Portal = (props) => {\n  const domNode = getPortalNode(props.id);\n  return ReactDOM.createPortal(props.children, domNode);\n};\n\nconst CurrencyLabel = (props) => (\n  <label htmlFor={props.id} css={getCurrencyLabelStyles()}>\n    {props.children}\n  </label>\n);\n\nCurrencyLabel.displayName = 'CurrencyLabel';\n\nCurrencyLabel.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\nconst SingleValue = ({ id, ...props }) => (\n  <components.SingleValue {...props}>\n    <label htmlFor={id}>{props.children}</label>\n  </components.SingleValue>\n);\n\nSingleValue.displayName = 'SingleValue';\n\nSingleValue.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\n// overwrite styles of createSelectStyles\nconst createCurrencySelectStyles = (\n  { hasWarning, hasError, isDisabled, isReadOnly, hasFocus, menuPortalZIndex },\n  theme\n) => {\n  const selectStyles = createSelectStyles(\n    {\n      hasWarning,\n      hasError,\n      menuPortalZIndex,\n    },\n    theme\n  );\n  return {\n    ...selectStyles,\n    control: (base, state) => ({\n      ...selectStyles.control(base, state),\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      minWidth: '72px',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${vars.borderColorForInputWhenDisabled} !important`;\n        if (hasError) return vars.borderColorForInputWhenError;\n        if (hasWarning) return vars.borderColorForInputWhenWarning;\n        if (hasFocus) return vars.borderColorForInputWhenFocused;\n        if (isReadOnly)\n          return `${vars.borderColorForInputWhenReadonly} !important`;\n        return vars.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: (() => {\n        if (isReadOnly) return vars.backgroundColorForInput;\n        return base.backgroundColor;\n      })(),\n    }),\n    singleValue: (base) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: (() => {\n        if (isDisabled) return vars.fontColorForInputWhenDisabled;\n        if (hasError) return vars.fontColorForInputWhenError;\n        if (hasWarning) return vars.fontColorForInputWhenWarning;\n        if (isReadOnly) return vars.fontColorForInputWhenReadonly;\n        return base.color;\n      })(),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly ? vars.fontColorForInputWhenReadonly : '',\n    }),\n  };\n};\n\n// The MoneyInput component always operates on a value consisting of:\n//   { amount: String, currencyCode: String }\n//\n// The amount may only use a dot as the decimal separator.\n// The currencyCode must be supported by the API.\n//\n// The MoneyInput does not do any validation on its own. It only serves as a way\n// to get the amount and currencyCode input from the user. Validation is always\n// up to the parent.\n//\n// The CTP API supports prices two types of prices: centPrecision and\n// highPrecision. The MoneyInput itself does not know about these. However,\n// it has two static methods defined (convertToMoneyValue and parseMoneyValue),\n// which can be used to convert between MoneyInput value and the MoneyValue\n// supported by the API.\n// Some places in the API do not support highPrecision prices, but the\n// convertToMoneyValue will always return either a centPrecision or a\n// highPrecision price. It's up the MoneyInput's parent to show a validation\n// error in case a highPrecision price is used.\n//\n// A value is considered as to have highPrecision when the number of supplied\n// fraction digits exceed the number of fraction digits the currency uses. For\n// example, 42.00 € is always a centPrecision price, while 42.001 € is always a\n// highPrecision price. It is not possible to hae 42.00 € as a highPrecision\n// price.\n//\n// The first time the component renders, we want to try to show the centAmount\n// as a formatted number. To achieve this, the parseMoneyValue function can\n// be used to turn the API value into a value the MoneyInput understands.\n// During this transformation, the money value will get formatted into \"amount\".\n//\n// When the user changes the value, we don't want to format again. We only format\n// in case the user blurs the field. This avoids many edge cases where the\n// formatting would mess with the user's input.\n//\n//\n// A full example of an MoneyValue with centPrecision would be\n// {\n//   \"type\": \"centPrecision\",\n//   \"currencyCode\": \"EUR\",\n//   \"centAmount\": 4200,\n//   \"fractionDigits\": 2\n// }\n// which equals 42.00 €\n//\n// A full example of an MoneyValue with highPrecision would be\n// {\n//  \"type\": \"highPrecision\",\n//  \"currencyCode\": \"EUR\",\n//  \"centAmount\": 1,\n//  \"preciseAmount\": 123456,\n//  \"fractionDigits\": 7\n// }\n// which equals 0.0123456 €\n\n// Parsing\n// Since most users are not careful about how they enter values, we will parse\n// both `.` and `,` as decimal separators.\n// When a value is `1.000,00` we parse it as `1000`.\n// When a value is `1,000.00` we also parse it as `1000`.\n//\n// This means the highest amount always wins. We do this by comparing the last\n// position of `.` and `,`. Whatever occurs later is used as the decimal\n// separator.\nexport const parseRawAmountToNumber = (rawAmount, locale) => {\n  let fractionsSeparator;\n\n  if (locale) {\n    fractionsSeparator = (2.5) // we need any number with fractions, so that we know what is the fraction\n      .toLocaleString(locale) // \"symbol\" for the provided locale\n      .replace(/\\d/g, ''); // then we remove the numbers and keep the \"symbol\"\n  } else {\n    const lastDot = String(rawAmount).lastIndexOf('.');\n    const lastComma = String(rawAmount).lastIndexOf(',');\n    fractionsSeparator = lastComma > lastDot ? ',' : '.';\n  }\n\n  fractionsSeparator = fractionsSeparator === '.' ? '\\\\.' : fractionsSeparator; // here we escape the '.' to use it as regex\n  // The raw amount with only one sparator\n  const normalizedAmount = String(rawAmount)\n    .replace(new RegExp(`[^0-9${fractionsSeparator}]`, 'g'), '') // we just keep the numbers and the fraction symbol\n    .replace(fractionsSeparator, '.'); // then we change whatever `fractionsSeparator` was to `.` so we can parse it as float\n\n  return parseFloat(normalizedAmount, 10);\n};\n\n// Turns the user input into a value the MoneyInput can pass up through onChange\n// In case the number of fraction digits contained in \"amount\" exceeds the\n// number of fraction digits the currency uses, it will emit a price of\n// type \"highPrecision\" instead of the regular \"centPrecision\".\n// It will return \"null\" in case an invalid value is entered.\n// The value is invalid when\n//  - no amount was entered\n//  - an invalid amount was entered\n//  - no currency was selected\n//\n// This function expects the \"amount\" to be a trimmed value.\nexport const createMoneyValue = (currencyCode, rawAmount, locale) => {\n  if (!currencyCode) return null;\n\n  const currency = currencies[currencyCode];\n  if (!currency) return null;\n\n  if (rawAmount.length === 0 || !isNumberish(rawAmount)) return null;\n\n  warning(\n    locale || currency.fractionDigits !== 0,\n    `A locale must be provided when currency has no fraction digits (${currencyCode})`\n  );\n  const amountAsNumber = parseRawAmountToNumber(rawAmount, locale);\n  if (isNaN(amountAsNumber)) return null;\n\n  // The cent amount is rounded to the currencie's default number\n  // of fraction digits for prices with high precision.\n  //\n  // Additionally, JavaScript is sometimes incorrect when multiplying floats,\n  //   e.g. 2.49 * 100 -> 249.00000000000003\n  // While inaccuracy from multiplying floating point numbers is a\n  // general problem in JS, we can avoid it by cutting off all\n  // decimals. This is possible since cents is the base unit, so we\n  // operate on integers anyways\n  // Also we should the round the value to ensure that we come close\n  // to the nearest decimal value\n  // ref: https://github.com/commercetools/merchant-center-frontend/pull/770\n  const centAmount = Math.trunc(\n    Math.round(amountAsNumber * 10 ** currency.fractionDigits)\n  );\n\n  const fractionDigitsOfAmount =\n    // The conversion to a string will always use a dot as the separator.\n    // That means we don't have to handle a comma.\n    String(amountAsNumber).indexOf('.') === -1\n      ? 0\n      : String(amountAsNumber).length - String(amountAsNumber).indexOf('.') - 1;\n\n  if (fractionDigitsOfAmount > currency.fractionDigits) {\n    return {\n      type: 'highPrecision',\n      currencyCode,\n      centAmount,\n      preciseAmount: parseInt(\n        // Here we need to convert  a number like 8.066652 to its centamount\n        // We could do that by multiplying it with 10 ** number-of-fraction-digits\n        // but then we'll run into problems with JavaScript's floating point\n        // number precision and end up with 8066651.9999999, and then parseInt\n        // cuts off the remainder.\n        // So instead of using maths to convert the number, we just replace\n        // the dot inside the number which does the same thing.\n        // We don't need to replace \",\" as well, as numbers always us a dot\n        // when converted using String().\n        //\n        // The mathematical way: amountAsNumber * 10 ** fractionDigitsOfAmount,\n        String(amountAsNumber).replace('.', ''),\n        10\n      ),\n      fractionDigits: fractionDigitsOfAmount,\n    };\n  }\n\n  return {\n    type: 'centPrecision',\n    currencyCode,\n    centAmount,\n    fractionDigits: currency.fractionDigits,\n  };\n};\n\nconst getAmountAsNumberFromMoneyValue = (moneyValue) =>\n  moneyValue.type === 'highPrecision'\n    ? moneyValue.preciseAmount / 10 ** moneyValue.fractionDigits\n    : moneyValue.centAmount /\n      10 ** currencies[moneyValue.currencyCode].fractionDigits;\n\n// gets called with a string and should return a formatted string\nconst formatAmount = (rawAmount, currencyCode, locale) => {\n  // fallback in case the user didn't enter an amount yet (or it's invalid)\n  const moneyValue = createMoneyValue(currencyCode, rawAmount, locale) || {\n    currencyCode,\n    centAmount: NaN,\n  };\n\n  const amount = getAmountAsNumberFromMoneyValue(moneyValue);\n\n  const fractionDigits = moneyValue.preciseAmount\n    ? moneyValue.fractionDigits\n    : currencies[moneyValue.currencyCode].fractionDigits;\n\n  return isNaN(amount)\n    ? ''\n    : amount.toLocaleString(locale, { minimumFractionDigits: fractionDigits });\n};\n\nconst getAmountInputName = (name) => (name ? `${name}.amount` : undefined);\nconst getCurrencyDropdownName = (name) =>\n  name ? `${name}.currencyCode` : undefined;\n\nconst MoneyInput = (props) => {\n  const intl = useIntl();\n  const [currencyHasFocus, toggleCurrencyHasFocus] = useToggleState(false);\n  const [amountHasFocus, toggleAmountHasFocus] = useToggleState(false);\n\n  const containerRef = useRef();\n  const amountInputRef = useRef();\n\n  const { onFocus } = props;\n  const handleAmountFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getAmountInputId(props.id),\n          name: getAmountInputName(props.name),\n        },\n      });\n    toggleAmountHasFocus(true);\n  }, [toggleAmountHasFocus, onFocus, props.id, props.name]);\n\n  const { onChange } = props;\n  const handleAmountBlur = useCallback(() => {\n    const amount = props.value.amount.trim();\n    toggleAmountHasFocus(false);\n    // Skip formatting for empty value or when the input is used with an\n    // unknown currency.\n    if (amount.length > 0 && currencies[props.value.currencyCode]) {\n      const formattedAmount = formatAmount(\n        amount,\n        props.value.currencyCode,\n        intl.locale\n      );\n\n      // When the user entered a value with centPrecision, we can format\n      // the resulting value to that currency, e.g. 20.1 to 20.10\n      if (String(formattedAmount) !== amount) {\n        // We need to emit an event with the now formatted value\n        const fakeEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: formattedAmount,\n          },\n        };\n        onChange(fakeEvent);\n      }\n    }\n  }, [\n    intl.locale,\n    onChange,\n    props.id,\n    props.name,\n    props.value.amount,\n    props.value.currencyCode,\n    toggleAmountHasFocus,\n  ]);\n\n  const handleAmountChange = useCallback(\n    (event) => {\n      if (isNumberish(event.target.value)) {\n        onChange({\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: event.target.value,\n          },\n        });\n      }\n    },\n    [onChange, props.id, props.name]\n  );\n\n  const handleCurrencyChange = useCallback(\n    (option) => {\n      const currencyCode = option.value;\n      if (props.value.currencyCode !== currencyCode) {\n        // When the user changes from a currency with 3 fraction digits to\n        // a currency with 2 fraction digits, and when the input value was\n        // \"9.000\" (9), then it should change to \"9.00\" to reflect the new\n        // currency's number of fraction digits.\n        // When the currency was a high-precision price, then no digits should\n        // be lost\n        const formattedAmount = formatAmount(\n          props.value.amount.trim(),\n          currencyCode,\n          intl.locale\n        );\n        // The user could be changing the currency before entering any amount,\n        // or while the amount is invalid. In these cases, we don't attempt to\n        // format the amount.\n        const nextAmount = isNaN(formattedAmount)\n          ? props.value.amount\n          : formattedAmount;\n\n        // change currency code\n        const fakeCurrencyEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n            value: currencyCode || '',\n          },\n        };\n        onChange(fakeCurrencyEvent);\n\n        // change amount if necessary\n        if (props.value.amount !== nextAmount) {\n          onChange({\n            // eslint-disable-next-line @typescript-eslint/no-empty-function\n            persist: () => {},\n            target: {\n              id: MoneyInput.getAmountInputId(props.id),\n              name: getAmountInputName(props.name),\n              value: nextAmount,\n            },\n          });\n        }\n\n        amountInputRef.current.focus();\n      }\n    },\n    [\n      intl.locale,\n      onChange,\n      props.id,\n      props.name,\n      props.value.amount,\n      props.value.currencyCode,\n    ]\n  );\n\n  const handleCurrencyFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getCurrencyDropdownId(props.id),\n          name: getCurrencyDropdownName(props.name),\n        },\n      });\n\n    toggleCurrencyHasFocus(true);\n  }, [onFocus, toggleCurrencyHasFocus, props.name, props.id]);\n\n  const handleCurrencyBlur = useCallback(() => {\n    toggleCurrencyHasFocus(false);\n  }, [toggleCurrencyHasFocus]);\n\n  const hasNoCurrencies = props.currencies.length === 0;\n  const hasFocus = currencyHasFocus || amountHasFocus;\n  const theme = useTheme();\n  const currencySelectStyles = createCurrencySelectStyles(\n    {\n      hasWarning: props.hasWarning,\n      hasError: props.hasError,\n      isDisabled: props.isDisabled,\n      isReadOnly: props.isReadOnly,\n      hasFocus,\n      menuPortalZIndex: props.menuPortalZIndex,\n    },\n    theme\n  );\n  const options = props.currencies.map((currencyCode) => ({\n    label: currencyCode,\n    value: currencyCode,\n  }));\n\n  const option = (() => {\n    const matchedOption = options.find(\n      (optionCandidate) => optionCandidate.value === props.value.currencyCode\n    );\n    if (matchedOption) return matchedOption;\n    // ensure an option is found, even when the currencies don't include\n    // the money value's currencyCode\n    if (props.value.currencyCode.trim() !== '')\n      return {\n        label: props.value.currencyCode,\n        value: props.value.currencyCode,\n      };\n    return null;\n  })();\n\n  const id = MoneyInput.getCurrencyDropdownId(props.id);\n\n  const isHighPrecision =\n    !MoneyInput.isEmpty(props.value) &&\n    MoneyInput.isHighPrecision(props.value, intl.locale);\n\n  const { onBlur } = props;\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n          },\n        });\n        onBlur({\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n          },\n        });\n      }\n    },\n    [onBlur, props.id, props.name]\n  );\n\n  const TooltipPortal = useCallback(\n    (remainingProps) => <Portal {...remainingProps} id={props.id} />,\n    [props.id]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <div\n        ref={containerRef}\n        css={css`\n          font-family: inherit;\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n        data-testid=\"money-input-container\"\n        onBlur={handleContainerBlur}\n      >\n        {hasNoCurrencies ? (\n          <CurrencyLabel\n            id={MoneyInput.getAmountInputId(props.id)}\n            isDisabled={props.isDisabled}\n          >\n            {option && option.label}\n          </CurrencyLabel>\n        ) : (\n          <Select\n            inputId={id}\n            name={getCurrencyDropdownName(props.name)}\n            value={option}\n            isDisabled={props.isDisabled}\n            isSearchable={false}\n            components={{\n              // eslint-disable-next-line react/display-name\n              SingleValue: (innerProps) => (\n                <SingleValue {...innerProps} id={id} />\n              ),\n              // eslint-disable-next-line react/display-name\n              Input: (ownProps) => (\n                // eslint-disable-next-line react/prop-types\n                <components.Input {...ownProps} readOnly={props.isReadOnly} />\n              ),\n              DropdownIndicator,\n            }}\n            options={options}\n            menuIsOpen={props.isReadOnly ? false : undefined}\n            placeholder=\"\"\n            styles={currencySelectStyles}\n            onFocus={handleCurrencyFocus}\n            menuPortalTarget={props.menuPortalTarget}\n            menuShouldBlockScroll={props.menuShouldBlockScroll}\n            onBlur={handleCurrencyBlur}\n            onChange={handleCurrencyChange}\n            data-testid=\"currency-dropdown\"\n          />\n        )}\n        <div\n          css={css`\n            position: relative;\n            width: 100%;\n          `}\n        >\n          <input\n            ref={amountInputRef}\n            id={MoneyInput.getAmountInputId(props.id)}\n            autoComplete={props.autoComplete}\n            name={getAmountInputName(props.name)}\n            type=\"text\"\n            onFocus={handleAmountFocus}\n            value={props.value.amount}\n            css={[\n              getAmountInputStyles({ ...props, hasFocus }),\n              // accounts for size of icon\n              props.hasHighPrecisionBadge &&\n                isHighPrecision &&\n                css`\n                  padding-right: ${vars.spacingL};\n                `,\n            ]}\n            placeholder={props.placeholder}\n            onChange={handleAmountChange}\n            onBlur={handleAmountBlur}\n            disabled={props.isDisabled}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            {...filterDataAttributes(props)}\n          />\n          {props.hasHighPrecisionBadge && isHighPrecision && (\n            <>\n              {!props.isDisabled && <div id={getPortalId(props.id)} />}\n              <div\n                css={() =>\n                  getHighPrecisionWrapperStyles({\n                    isDisabled: props.isDisabled,\n                  })\n                }\n              >\n                <Tooltip\n                  off={props.isDisabled}\n                  placement=\"top-end\"\n                  // we use negative margin to make up for the padding in the Tooltip Wrapper\n                  // so that the tooltip is flush with the component\n                  styles={{\n                    body: {\n                      margin: `${vars.spacingS} -${vars.spacingXs} ${vars.spacingS} 0`,\n                    },\n                  }}\n                  title={intl.formatMessage(messages.highPrecision)}\n                  components={{\n                    TooltipWrapperComponent: TooltipPortal,\n                    WrapperComponent: TooltipWrapper,\n                  }}\n                >\n                  <FractionDigitsIcon\n                    color={props.isDisabled ? 'neutral60' : 'info'}\n                  />\n                </Tooltip>\n              </div>\n            </>\n          )}\n        </div>\n      </div>\n    </Constraints.Horizontal>\n  );\n};\n\nMoneyInput.displayName = 'MoneyInput';\n\nMoneyInput.getAmountInputId = getAmountInputName;\n\nMoneyInput.getCurrencyDropdownId = getCurrencyDropdownName;\n\nMoneyInput.convertToMoneyValue = (value, locale) =>\n  createMoneyValue(\n    value.currencyCode,\n    typeof value.amount === 'string' ? value.amount.trim() : '',\n    locale\n  );\n\nMoneyInput.parseMoneyValue = (moneyValue, locale) => {\n  if (!moneyValue) return { currencyCode: '', amount: '' };\n\n  warning(\n    typeof locale === 'string',\n    'MoneyInput.parseMoneyValue: A locale must be passed as the second argument'\n  );\n\n  warning(\n    typeof moneyValue === 'object',\n    'MoneyInput.parseMoneyValue: Value must be passed as an object or be undefined'\n  );\n\n  warning(\n    typeof moneyValue.currencyCode === 'string',\n    'MoneyInput.parseMoneyValue: Value must contain \"currencyCode\"'\n  );\n\n  warning(\n    has(currencies, moneyValue.currencyCode),\n    'MoneyInput.parseMoneyValue: Value must use known currency code'\n  );\n\n  warning(\n    // highPrecision or centPrecision values must be set\n    typeof moneyValue.centAmount === 'number' ||\n      (typeof moneyValue.preciseAmount === 'number' &&\n        typeof moneyValue.fractionDigits === 'number'),\n    'MoneyInput.parseMoneyValue: Value must contain \"amount\"'\n  );\n\n  const amount = formatAmount(\n    getAmountAsNumberFromMoneyValue(moneyValue).toLocaleString(locale, {\n      minimumFractionDigits: moneyValue.fractionDigits,\n    }),\n    moneyValue.currencyCode,\n    locale\n  );\n\n  return { amount, currencyCode: moneyValue.currencyCode };\n};\n\nMoneyInput.isEmpty = (formValue) =>\n  !formValue ||\n  formValue.amount.trim() === '' ||\n  formValue.currencyCode.trim() === '';\n\nMoneyInput.isHighPrecision = (formValue, locale) => {\n  warning(\n    !MoneyInput.isEmpty(formValue),\n    'MoneyValue.isHighPrecision may not be called with an empty money value.'\n  );\n  const moneyValue = MoneyInput.convertToMoneyValue(formValue, locale);\n  return moneyValue && moneyValue.type === 'highPrecision';\n};\n\nMoneyInput.isTouched = (touched) =>\n  Boolean(touched && touched.currencyCode && touched.amount);\n\nMoneyInput.propTypes = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`) and the currency dropdown (`${name}.currencyCode`).\n   */\n  name: PropTypes.string,\n  /**\n   * Value of the input. Consists of the currency code and an amount. `amount` is a string representing the amount. A dot has to be used as the decimal separator.\n   */\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  /**\n   * List of possible currencies. When not provided or empty, the component renders a label with the value's currency instead of a dropdown.\n   */\n  currencies: PropTypes.arrayOf(PropTypes.string).isRequired,\n  /**\n   * Placeholder text for the input\n   */\n  placeholder: PropTypes.string,\n  /**\n   * Called when input is blurred\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when input is focused\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Called with the event of the input or dropdown when either the currency or the amount have changed.\n   * <br />\n   * Signature: `(event) => void`\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Dom element to portal the currency select menu to\n   */\n  menuPortalTarget: PropTypes.instanceOf(SafeHTMLElement),\n  /**\n   * z-index value for the currency select menu portal\n   */\n  menuPortalZIndex: PropTypes.number,\n  /**\n   * whether the menu should block scroll while open\n   */\n  menuShouldBlockScroll: PropTypes.bool,\n  /**\n   * Indicates that input has errors\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning: PropTypes.bool,\n  /**\n   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge: PropTypes.bool,\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n};\n\nMoneyInput.defaultProps = {\n  currencies: [],\n  horizontalConstraint: 'scale',\n  menuPortalZIndex: 1,\n};\n\nexport default MoneyInput;\n"]} */",
1076
1083
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1077
1084
  };
1078
1085
 
@@ -1091,10 +1098,10 @@ var MoneyInput = function MoneyInput(props) {
1091
1098
  amountHasFocus = _useToggleState4[0],
1092
1099
  toggleAmountHasFocus = _useToggleState4[1];
1093
1100
 
1094
- var containerRef = React__default['default'].useRef();
1095
- var amountInputRef = React__default['default'].useRef();
1101
+ var containerRef = react$1.useRef();
1102
+ var amountInputRef = react$1.useRef();
1096
1103
  var onFocus = props.onFocus;
1097
- var handleAmountFocus = React__default['default'].useCallback(function () {
1104
+ var handleAmountFocus = react$1.useCallback(function () {
1098
1105
  if (onFocus) onFocus({
1099
1106
  target: {
1100
1107
  id: MoneyInput.getAmountInputId(props.id),
@@ -1104,10 +1111,10 @@ var MoneyInput = function MoneyInput(props) {
1104
1111
  toggleAmountHasFocus(true);
1105
1112
  }, [toggleAmountHasFocus, onFocus, props.id, props.name]);
1106
1113
  var onChange = props.onChange;
1107
- var handleAmountBlur = React__default['default'].useCallback(function () {
1114
+ var handleAmountBlur = react$1.useCallback(function () {
1108
1115
  var _context5;
1109
1116
 
1110
- var amount = _trimInstanceProperty__default['default'](_context5 = props.value.amount).call(_context5);
1117
+ var amount = _trimInstanceProperty__default["default"](_context5 = props.value.amount).call(_context5);
1111
1118
 
1112
1119
  toggleAmountHasFocus(false); // Skip formatting for empty value or when the input is used with an
1113
1120
  // unknown currency.
@@ -1131,7 +1138,7 @@ var MoneyInput = function MoneyInput(props) {
1131
1138
  }
1132
1139
  }
1133
1140
  }, [intl.locale, onChange, props.id, props.name, props.value.amount, props.value.currencyCode, toggleAmountHasFocus]);
1134
- var handleAmountChange = React__default['default'].useCallback(function (event) {
1141
+ var handleAmountChange = react$1.useCallback(function (event) {
1135
1142
  if (utils.isNumberish(event.target.value)) {
1136
1143
  onChange({
1137
1144
  // eslint-disable-next-line @typescript-eslint/no-empty-function
@@ -1144,7 +1151,7 @@ var MoneyInput = function MoneyInput(props) {
1144
1151
  });
1145
1152
  }
1146
1153
  }, [onChange, props.id, props.name]);
1147
- var handleCurrencyChange = React__default['default'].useCallback(function (option) {
1154
+ var handleCurrencyChange = react$1.useCallback(function (option) {
1148
1155
  var currencyCode = option.value;
1149
1156
 
1150
1157
  if (props.value.currencyCode !== currencyCode) {
@@ -1156,7 +1163,7 @@ var MoneyInput = function MoneyInput(props) {
1156
1163
  // currency's number of fraction digits.
1157
1164
  // When the currency was a high-precision price, then no digits should
1158
1165
  // be lost
1159
- var formattedAmount = formatAmount(_trimInstanceProperty__default['default'](_context6 = props.value.amount).call(_context6), currencyCode, intl.locale); // The user could be changing the currency before entering any amount,
1166
+ var formattedAmount = formatAmount(_trimInstanceProperty__default["default"](_context6 = props.value.amount).call(_context6), currencyCode, intl.locale); // The user could be changing the currency before entering any amount,
1160
1167
  // or while the amount is invalid. In these cases, we don't attempt to
1161
1168
  // format the amount.
1162
1169
 
@@ -1188,7 +1195,7 @@ var MoneyInput = function MoneyInput(props) {
1188
1195
  amountInputRef.current.focus();
1189
1196
  }
1190
1197
  }, [intl.locale, onChange, props.id, props.name, props.value.amount, props.value.currencyCode]);
1191
- var handleCurrencyFocus = React__default['default'].useCallback(function () {
1198
+ var handleCurrencyFocus = react$1.useCallback(function () {
1192
1199
  if (onFocus) onFocus({
1193
1200
  target: {
1194
1201
  id: MoneyInput.getCurrencyDropdownId(props.id),
@@ -1197,7 +1204,7 @@ var MoneyInput = function MoneyInput(props) {
1197
1204
  });
1198
1205
  toggleCurrencyHasFocus(true);
1199
1206
  }, [onFocus, toggleCurrencyHasFocus, props.name, props.id]);
1200
- var handleCurrencyBlur = React__default['default'].useCallback(function () {
1207
+ var handleCurrencyBlur = react$1.useCallback(function () {
1201
1208
  toggleCurrencyHasFocus(false);
1202
1209
  }, [toggleCurrencyHasFocus]);
1203
1210
  var hasNoCurrencies = props.currencies.length === 0;
@@ -1212,7 +1219,7 @@ var MoneyInput = function MoneyInput(props) {
1212
1219
  menuPortalZIndex: props.menuPortalZIndex
1213
1220
  }, theme);
1214
1221
 
1215
- var options = _mapInstanceProperty__default['default'](_context7 = props.currencies).call(_context7, function (currencyCode) {
1222
+ var options = _mapInstanceProperty__default["default"](_context7 = props.currencies).call(_context7, function (currencyCode) {
1216
1223
  return {
1217
1224
  label: currencyCode,
1218
1225
  value: currencyCode
@@ -1222,14 +1229,14 @@ var MoneyInput = function MoneyInput(props) {
1222
1229
  var option = function () {
1223
1230
  var _context8;
1224
1231
 
1225
- var matchedOption = _findInstanceProperty__default['default'](options).call(options, function (optionCandidate) {
1232
+ var matchedOption = _findInstanceProperty__default["default"](options).call(options, function (optionCandidate) {
1226
1233
  return optionCandidate.value === props.value.currencyCode;
1227
1234
  });
1228
1235
 
1229
1236
  if (matchedOption) return matchedOption; // ensure an option is found, even when the currencies don't include
1230
1237
  // the money value's currencyCode
1231
1238
 
1232
- if (_trimInstanceProperty__default['default'](_context8 = props.value.currencyCode).call(_context8) !== '') return {
1239
+ if (_trimInstanceProperty__default["default"](_context8 = props.value.currencyCode).call(_context8) !== '') return {
1233
1240
  label: props.value.currencyCode,
1234
1241
  value: props.value.currencyCode
1235
1242
  };
@@ -1239,7 +1246,7 @@ var MoneyInput = function MoneyInput(props) {
1239
1246
  var id = MoneyInput.getCurrencyDropdownId(props.id);
1240
1247
  var isHighPrecision = !MoneyInput.isEmpty(props.value) && MoneyInput.isHighPrecision(props.value, intl.locale);
1241
1248
  var onBlur = props.onBlur;
1242
- var handleContainerBlur = React__default['default'].useCallback(function (event) {
1249
+ var handleContainerBlur = react$1.useCallback(function (event) {
1243
1250
  // ensures that both fields are marked as touched when one of them
1244
1251
  // is blurred
1245
1252
  if (typeof onBlur === 'function' && !containerRef.current.contains(event.relatedTarget)) {
@@ -1257,100 +1264,108 @@ var MoneyInput = function MoneyInput(props) {
1257
1264
  });
1258
1265
  }
1259
1266
  }, [onBlur, props.id, props.name]);
1260
- var TooltipPortal = React__default['default'].useCallback(function (remainingProps) {
1261
- return react.jsx(Portal, _extends({}, remainingProps, {
1267
+ var TooltipPortal = react$1.useCallback(function (remainingProps) {
1268
+ return jsxRuntime.jsx(Portal, _objectSpread(_objectSpread({}, remainingProps), {}, {
1262
1269
  id: props.id
1263
1270
  }));
1264
1271
  }, [props.id]);
1265
- return react.jsx(Constraints__default['default'].Horizontal, {
1266
- max: props.horizontalConstraint
1267
- }, react.jsx("div", {
1268
- ref: containerRef,
1269
- css: _ref2,
1270
- "data-testid": "money-input-container",
1271
- onBlur: handleContainerBlur
1272
- }, hasNoCurrencies ? react.jsx(CurrencyLabel, {
1273
- id: MoneyInput.getAmountInputId(props.id),
1274
- isDisabled: props.isDisabled
1275
- }, option && option.label) : react.jsx(Select__default['default'], {
1276
- inputId: id,
1277
- name: getCurrencyDropdownName(props.name),
1278
- value: option,
1279
- isDisabled: props.isDisabled,
1280
- isSearchable: false,
1281
- components: {
1282
- // eslint-disable-next-line react/display-name
1283
- SingleValue: function SingleValue(innerProps) {
1284
- return react.jsx(_SingleValue, _extends({}, innerProps, {
1285
- id: id
1286
- }));
1287
- },
1288
- // eslint-disable-next-line react/display-name
1289
- Input: function Input(ownProps) {
1290
- return (// eslint-disable-next-line react/prop-types
1291
- react.jsx(Select.components.Input, _extends({}, ownProps, {
1292
- readOnly: props.isReadOnly
1293
- }))
1294
- );
1295
- },
1296
- DropdownIndicator: selectUtils.DropdownIndicator
1297
- },
1298
- options: options,
1299
- menuIsOpen: props.isReadOnly ? false : undefined,
1300
- placeholder: "",
1301
- styles: currencySelectStyles,
1302
- onFocus: handleCurrencyFocus,
1303
- menuPortalTarget: props.menuPortalTarget,
1304
- menuShouldBlockScroll: props.menuShouldBlockScroll,
1305
- onBlur: handleCurrencyBlur,
1306
- onChange: handleCurrencyChange,
1307
- "data-testid": "currency-dropdown"
1308
- }), react.jsx("div", {
1309
- css: _ref
1310
- }, react.jsx("input", _extends({
1311
- ref: amountInputRef,
1312
- id: MoneyInput.getAmountInputId(props.id),
1313
- autoComplete: props.autoComplete,
1314
- name: getAmountInputName(props.name),
1315
- type: "text",
1316
- onFocus: handleAmountFocus,
1317
- value: props.value.amount,
1318
- css: [getAmountInputStyles(_objectSpread(_objectSpread({}, props), {}, {
1319
- hasFocus: hasFocus
1320
- })), // accounts for size of icon
1321
- props.hasHighPrecisionBadge && isHighPrecision && /*#__PURE__*/react.css("padding-right:", designSystem.customProperties.spacingL, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MoneyInput;")), process.env.NODE_ENV === "production" ? "" : ";label:MoneyInput;"],
1322
- placeholder: props.placeholder,
1323
- onChange: handleAmountChange,
1324
- onBlur: handleAmountBlur,
1325
- disabled: props.isDisabled,
1326
- readOnly: props.isReadOnly,
1327
- autoFocus: props.isAutofocussed
1328
- }, utils.filterDataAttributes(props))), props.hasHighPrecisionBadge && isHighPrecision && react.jsx(React__default['default'].Fragment, null, !props.isDisabled && react.jsx("div", {
1329
- id: getPortalId(props.id)
1330
- }), react.jsx("div", {
1331
- css: function css() {
1332
- return getHighPrecisionWrapperStyles({
1333
- isDisabled: props.isDisabled
1334
- });
1335
- }
1336
- }, react.jsx(Tooltip__default['default'], {
1337
- off: props.isDisabled,
1338
- placement: "top-end" // we use negative margin to make up for the padding in the Tooltip Wrapper
1339
- // so that the tooltip is flush with the component
1340
- ,
1341
- styles: {
1342
- body: {
1343
- margin: _concatInstanceProperty__default['default'](_context9 = _concatInstanceProperty__default['default'](_context10 = "".concat(designSystem.customProperties.spacingS, " -")).call(_context10, designSystem.customProperties.spacingXs, " ")).call(_context9, designSystem.customProperties.spacingS, " 0")
1344
- }
1345
- },
1346
- title: intl.formatMessage(messages.highPrecision),
1347
- components: {
1348
- TooltipWrapperComponent: TooltipPortal,
1349
- WrapperComponent: TooltipWrapper
1350
- }
1351
- }, react.jsx(icons.FractionDigitsIcon, {
1352
- color: props.isDisabled ? 'neutral60' : 'info'
1353
- })))))));
1272
+ return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
1273
+ max: props.horizontalConstraint,
1274
+ children: jsxRuntime.jsxs("div", {
1275
+ ref: containerRef,
1276
+ css: _ref2,
1277
+ "data-testid": "money-input-container",
1278
+ onBlur: handleContainerBlur,
1279
+ children: [hasNoCurrencies ? jsxRuntime.jsx(CurrencyLabel, {
1280
+ id: MoneyInput.getAmountInputId(props.id),
1281
+ isDisabled: props.isDisabled,
1282
+ children: option && option.label
1283
+ }) : jsxRuntime.jsx(Select__default["default"], {
1284
+ inputId: id,
1285
+ name: getCurrencyDropdownName(props.name),
1286
+ value: option,
1287
+ isDisabled: props.isDisabled,
1288
+ isSearchable: false,
1289
+ components: {
1290
+ // eslint-disable-next-line react/display-name
1291
+ SingleValue: function SingleValue(innerProps) {
1292
+ return jsxRuntime.jsx(_SingleValue, _objectSpread(_objectSpread({}, innerProps), {}, {
1293
+ id: id
1294
+ }));
1295
+ },
1296
+ // eslint-disable-next-line react/display-name
1297
+ Input: function Input(ownProps) {
1298
+ return (// eslint-disable-next-line react/prop-types
1299
+ jsxRuntime.jsx(Select.components.Input, _objectSpread(_objectSpread({}, ownProps), {}, {
1300
+ readOnly: props.isReadOnly
1301
+ }))
1302
+ );
1303
+ },
1304
+ DropdownIndicator: selectUtils.DropdownIndicator
1305
+ },
1306
+ options: options,
1307
+ menuIsOpen: props.isReadOnly ? false : undefined,
1308
+ placeholder: "",
1309
+ styles: currencySelectStyles,
1310
+ onFocus: handleCurrencyFocus,
1311
+ menuPortalTarget: props.menuPortalTarget,
1312
+ menuShouldBlockScroll: props.menuShouldBlockScroll,
1313
+ onBlur: handleCurrencyBlur,
1314
+ onChange: handleCurrencyChange,
1315
+ "data-testid": "currency-dropdown"
1316
+ }), jsxRuntime.jsxs("div", {
1317
+ css: _ref,
1318
+ children: [jsxRuntime.jsx("input", _objectSpread({
1319
+ ref: amountInputRef,
1320
+ id: MoneyInput.getAmountInputId(props.id),
1321
+ autoComplete: props.autoComplete,
1322
+ name: getAmountInputName(props.name),
1323
+ type: "text",
1324
+ onFocus: handleAmountFocus,
1325
+ value: props.value.amount,
1326
+ css: [getAmountInputStyles(_objectSpread(_objectSpread({}, props), {}, {
1327
+ hasFocus: hasFocus
1328
+ })), // accounts for size of icon
1329
+ props.hasHighPrecisionBadge && isHighPrecision && /*#__PURE__*/react.css("padding-right:", designSystem.customProperties.spacingL, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MoneyInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["money-input.js"],"names":[],"mappings":"AA0mBmB","file":"money-input.js","sourcesContent":["import { useRef, useCallback } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport has from 'lodash/has';\nimport requiredIf from 'react-required-if';\nimport Select, { components } from 'react-select';\nimport { useIntl } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport {\n  warning,\n  isNumberish,\n  SafeHTMLElement,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  DropdownIndicator,\n  createSelectStyles,\n} from '@commercetools-uikit/select-utils';\nimport { FractionDigitsIcon } from '@commercetools-uikit/icons';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport currencies from './currencies.json';\nimport {\n  getHighPrecisionWrapperStyles,\n  getCurrencyLabelStyles,\n  getAmountInputStyles,\n} from './money-input.styles';\nimport messages from './messages';\n\nconst TooltipWrapper = styled.div`\n  display: flex;\n`;\n\nconst getPortalId = (id) => `portal-${id}`;\nconst getPortalNode = (id) => document.querySelector(`#${getPortalId(id)}`);\n\nconst Portal = (props) => {\n  const domNode = getPortalNode(props.id);\n  return ReactDOM.createPortal(props.children, domNode);\n};\n\nconst CurrencyLabel = (props) => (\n  <label htmlFor={props.id} css={getCurrencyLabelStyles()}>\n    {props.children}\n  </label>\n);\n\nCurrencyLabel.displayName = 'CurrencyLabel';\n\nCurrencyLabel.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\nconst SingleValue = ({ id, ...props }) => (\n  <components.SingleValue {...props}>\n    <label htmlFor={id}>{props.children}</label>\n  </components.SingleValue>\n);\n\nSingleValue.displayName = 'SingleValue';\n\nSingleValue.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\n// overwrite styles of createSelectStyles\nconst createCurrencySelectStyles = (\n  { hasWarning, hasError, isDisabled, isReadOnly, hasFocus, menuPortalZIndex },\n  theme\n) => {\n  const selectStyles = createSelectStyles(\n    {\n      hasWarning,\n      hasError,\n      menuPortalZIndex,\n    },\n    theme\n  );\n  return {\n    ...selectStyles,\n    control: (base, state) => ({\n      ...selectStyles.control(base, state),\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      minWidth: '72px',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${vars.borderColorForInputWhenDisabled} !important`;\n        if (hasError) return vars.borderColorForInputWhenError;\n        if (hasWarning) return vars.borderColorForInputWhenWarning;\n        if (hasFocus) return vars.borderColorForInputWhenFocused;\n        if (isReadOnly)\n          return `${vars.borderColorForInputWhenReadonly} !important`;\n        return vars.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: (() => {\n        if (isReadOnly) return vars.backgroundColorForInput;\n        return base.backgroundColor;\n      })(),\n    }),\n    singleValue: (base) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: (() => {\n        if (isDisabled) return vars.fontColorForInputWhenDisabled;\n        if (hasError) return vars.fontColorForInputWhenError;\n        if (hasWarning) return vars.fontColorForInputWhenWarning;\n        if (isReadOnly) return vars.fontColorForInputWhenReadonly;\n        return base.color;\n      })(),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly ? vars.fontColorForInputWhenReadonly : '',\n    }),\n  };\n};\n\n// The MoneyInput component always operates on a value consisting of:\n//   { amount: String, currencyCode: String }\n//\n// The amount may only use a dot as the decimal separator.\n// The currencyCode must be supported by the API.\n//\n// The MoneyInput does not do any validation on its own. It only serves as a way\n// to get the amount and currencyCode input from the user. Validation is always\n// up to the parent.\n//\n// The CTP API supports prices two types of prices: centPrecision and\n// highPrecision. The MoneyInput itself does not know about these. However,\n// it has two static methods defined (convertToMoneyValue and parseMoneyValue),\n// which can be used to convert between MoneyInput value and the MoneyValue\n// supported by the API.\n// Some places in the API do not support highPrecision prices, but the\n// convertToMoneyValue will always return either a centPrecision or a\n// highPrecision price. It's up the MoneyInput's parent to show a validation\n// error in case a highPrecision price is used.\n//\n// A value is considered as to have highPrecision when the number of supplied\n// fraction digits exceed the number of fraction digits the currency uses. For\n// example, 42.00 € is always a centPrecision price, while 42.001 € is always a\n// highPrecision price. It is not possible to hae 42.00 € as a highPrecision\n// price.\n//\n// The first time the component renders, we want to try to show the centAmount\n// as a formatted number. To achieve this, the parseMoneyValue function can\n// be used to turn the API value into a value the MoneyInput understands.\n// During this transformation, the money value will get formatted into \"amount\".\n//\n// When the user changes the value, we don't want to format again. We only format\n// in case the user blurs the field. This avoids many edge cases where the\n// formatting would mess with the user's input.\n//\n//\n// A full example of an MoneyValue with centPrecision would be\n// {\n//   \"type\": \"centPrecision\",\n//   \"currencyCode\": \"EUR\",\n//   \"centAmount\": 4200,\n//   \"fractionDigits\": 2\n// }\n// which equals 42.00 €\n//\n// A full example of an MoneyValue with highPrecision would be\n// {\n//  \"type\": \"highPrecision\",\n//  \"currencyCode\": \"EUR\",\n//  \"centAmount\": 1,\n//  \"preciseAmount\": 123456,\n//  \"fractionDigits\": 7\n// }\n// which equals 0.0123456 €\n\n// Parsing\n// Since most users are not careful about how they enter values, we will parse\n// both `.` and `,` as decimal separators.\n// When a value is `1.000,00` we parse it as `1000`.\n// When a value is `1,000.00` we also parse it as `1000`.\n//\n// This means the highest amount always wins. We do this by comparing the last\n// position of `.` and `,`. Whatever occurs later is used as the decimal\n// separator.\nexport const parseRawAmountToNumber = (rawAmount, locale) => {\n  let fractionsSeparator;\n\n  if (locale) {\n    fractionsSeparator = (2.5) // we need any number with fractions, so that we know what is the fraction\n      .toLocaleString(locale) // \"symbol\" for the provided locale\n      .replace(/\\d/g, ''); // then we remove the numbers and keep the \"symbol\"\n  } else {\n    const lastDot = String(rawAmount).lastIndexOf('.');\n    const lastComma = String(rawAmount).lastIndexOf(',');\n    fractionsSeparator = lastComma > lastDot ? ',' : '.';\n  }\n\n  fractionsSeparator = fractionsSeparator === '.' ? '\\\\.' : fractionsSeparator; // here we escape the '.' to use it as regex\n  // The raw amount with only one sparator\n  const normalizedAmount = String(rawAmount)\n    .replace(new RegExp(`[^0-9${fractionsSeparator}]`, 'g'), '') // we just keep the numbers and the fraction symbol\n    .replace(fractionsSeparator, '.'); // then we change whatever `fractionsSeparator` was to `.` so we can parse it as float\n\n  return parseFloat(normalizedAmount, 10);\n};\n\n// Turns the user input into a value the MoneyInput can pass up through onChange\n// In case the number of fraction digits contained in \"amount\" exceeds the\n// number of fraction digits the currency uses, it will emit a price of\n// type \"highPrecision\" instead of the regular \"centPrecision\".\n// It will return \"null\" in case an invalid value is entered.\n// The value is invalid when\n//  - no amount was entered\n//  - an invalid amount was entered\n//  - no currency was selected\n//\n// This function expects the \"amount\" to be a trimmed value.\nexport const createMoneyValue = (currencyCode, rawAmount, locale) => {\n  if (!currencyCode) return null;\n\n  const currency = currencies[currencyCode];\n  if (!currency) return null;\n\n  if (rawAmount.length === 0 || !isNumberish(rawAmount)) return null;\n\n  warning(\n    locale || currency.fractionDigits !== 0,\n    `A locale must be provided when currency has no fraction digits (${currencyCode})`\n  );\n  const amountAsNumber = parseRawAmountToNumber(rawAmount, locale);\n  if (isNaN(amountAsNumber)) return null;\n\n  // The cent amount is rounded to the currencie's default number\n  // of fraction digits for prices with high precision.\n  //\n  // Additionally, JavaScript is sometimes incorrect when multiplying floats,\n  //   e.g. 2.49 * 100 -> 249.00000000000003\n  // While inaccuracy from multiplying floating point numbers is a\n  // general problem in JS, we can avoid it by cutting off all\n  // decimals. This is possible since cents is the base unit, so we\n  // operate on integers anyways\n  // Also we should the round the value to ensure that we come close\n  // to the nearest decimal value\n  // ref: https://github.com/commercetools/merchant-center-frontend/pull/770\n  const centAmount = Math.trunc(\n    Math.round(amountAsNumber * 10 ** currency.fractionDigits)\n  );\n\n  const fractionDigitsOfAmount =\n    // The conversion to a string will always use a dot as the separator.\n    // That means we don't have to handle a comma.\n    String(amountAsNumber).indexOf('.') === -1\n      ? 0\n      : String(amountAsNumber).length - String(amountAsNumber).indexOf('.') - 1;\n\n  if (fractionDigitsOfAmount > currency.fractionDigits) {\n    return {\n      type: 'highPrecision',\n      currencyCode,\n      centAmount,\n      preciseAmount: parseInt(\n        // Here we need to convert  a number like 8.066652 to its centamount\n        // We could do that by multiplying it with 10 ** number-of-fraction-digits\n        // but then we'll run into problems with JavaScript's floating point\n        // number precision and end up with 8066651.9999999, and then parseInt\n        // cuts off the remainder.\n        // So instead of using maths to convert the number, we just replace\n        // the dot inside the number which does the same thing.\n        // We don't need to replace \",\" as well, as numbers always us a dot\n        // when converted using String().\n        //\n        // The mathematical way: amountAsNumber * 10 ** fractionDigitsOfAmount,\n        String(amountAsNumber).replace('.', ''),\n        10\n      ),\n      fractionDigits: fractionDigitsOfAmount,\n    };\n  }\n\n  return {\n    type: 'centPrecision',\n    currencyCode,\n    centAmount,\n    fractionDigits: currency.fractionDigits,\n  };\n};\n\nconst getAmountAsNumberFromMoneyValue = (moneyValue) =>\n  moneyValue.type === 'highPrecision'\n    ? moneyValue.preciseAmount / 10 ** moneyValue.fractionDigits\n    : moneyValue.centAmount /\n      10 ** currencies[moneyValue.currencyCode].fractionDigits;\n\n// gets called with a string and should return a formatted string\nconst formatAmount = (rawAmount, currencyCode, locale) => {\n  // fallback in case the user didn't enter an amount yet (or it's invalid)\n  const moneyValue = createMoneyValue(currencyCode, rawAmount, locale) || {\n    currencyCode,\n    centAmount: NaN,\n  };\n\n  const amount = getAmountAsNumberFromMoneyValue(moneyValue);\n\n  const fractionDigits = moneyValue.preciseAmount\n    ? moneyValue.fractionDigits\n    : currencies[moneyValue.currencyCode].fractionDigits;\n\n  return isNaN(amount)\n    ? ''\n    : amount.toLocaleString(locale, { minimumFractionDigits: fractionDigits });\n};\n\nconst getAmountInputName = (name) => (name ? `${name}.amount` : undefined);\nconst getCurrencyDropdownName = (name) =>\n  name ? `${name}.currencyCode` : undefined;\n\nconst MoneyInput = (props) => {\n  const intl = useIntl();\n  const [currencyHasFocus, toggleCurrencyHasFocus] = useToggleState(false);\n  const [amountHasFocus, toggleAmountHasFocus] = useToggleState(false);\n\n  const containerRef = useRef();\n  const amountInputRef = useRef();\n\n  const { onFocus } = props;\n  const handleAmountFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getAmountInputId(props.id),\n          name: getAmountInputName(props.name),\n        },\n      });\n    toggleAmountHasFocus(true);\n  }, [toggleAmountHasFocus, onFocus, props.id, props.name]);\n\n  const { onChange } = props;\n  const handleAmountBlur = useCallback(() => {\n    const amount = props.value.amount.trim();\n    toggleAmountHasFocus(false);\n    // Skip formatting for empty value or when the input is used with an\n    // unknown currency.\n    if (amount.length > 0 && currencies[props.value.currencyCode]) {\n      const formattedAmount = formatAmount(\n        amount,\n        props.value.currencyCode,\n        intl.locale\n      );\n\n      // When the user entered a value with centPrecision, we can format\n      // the resulting value to that currency, e.g. 20.1 to 20.10\n      if (String(formattedAmount) !== amount) {\n        // We need to emit an event with the now formatted value\n        const fakeEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: formattedAmount,\n          },\n        };\n        onChange(fakeEvent);\n      }\n    }\n  }, [\n    intl.locale,\n    onChange,\n    props.id,\n    props.name,\n    props.value.amount,\n    props.value.currencyCode,\n    toggleAmountHasFocus,\n  ]);\n\n  const handleAmountChange = useCallback(\n    (event) => {\n      if (isNumberish(event.target.value)) {\n        onChange({\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: event.target.value,\n          },\n        });\n      }\n    },\n    [onChange, props.id, props.name]\n  );\n\n  const handleCurrencyChange = useCallback(\n    (option) => {\n      const currencyCode = option.value;\n      if (props.value.currencyCode !== currencyCode) {\n        // When the user changes from a currency with 3 fraction digits to\n        // a currency with 2 fraction digits, and when the input value was\n        // \"9.000\" (9), then it should change to \"9.00\" to reflect the new\n        // currency's number of fraction digits.\n        // When the currency was a high-precision price, then no digits should\n        // be lost\n        const formattedAmount = formatAmount(\n          props.value.amount.trim(),\n          currencyCode,\n          intl.locale\n        );\n        // The user could be changing the currency before entering any amount,\n        // or while the amount is invalid. In these cases, we don't attempt to\n        // format the amount.\n        const nextAmount = isNaN(formattedAmount)\n          ? props.value.amount\n          : formattedAmount;\n\n        // change currency code\n        const fakeCurrencyEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n            value: currencyCode || '',\n          },\n        };\n        onChange(fakeCurrencyEvent);\n\n        // change amount if necessary\n        if (props.value.amount !== nextAmount) {\n          onChange({\n            // eslint-disable-next-line @typescript-eslint/no-empty-function\n            persist: () => {},\n            target: {\n              id: MoneyInput.getAmountInputId(props.id),\n              name: getAmountInputName(props.name),\n              value: nextAmount,\n            },\n          });\n        }\n\n        amountInputRef.current.focus();\n      }\n    },\n    [\n      intl.locale,\n      onChange,\n      props.id,\n      props.name,\n      props.value.amount,\n      props.value.currencyCode,\n    ]\n  );\n\n  const handleCurrencyFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getCurrencyDropdownId(props.id),\n          name: getCurrencyDropdownName(props.name),\n        },\n      });\n\n    toggleCurrencyHasFocus(true);\n  }, [onFocus, toggleCurrencyHasFocus, props.name, props.id]);\n\n  const handleCurrencyBlur = useCallback(() => {\n    toggleCurrencyHasFocus(false);\n  }, [toggleCurrencyHasFocus]);\n\n  const hasNoCurrencies = props.currencies.length === 0;\n  const hasFocus = currencyHasFocus || amountHasFocus;\n  const theme = useTheme();\n  const currencySelectStyles = createCurrencySelectStyles(\n    {\n      hasWarning: props.hasWarning,\n      hasError: props.hasError,\n      isDisabled: props.isDisabled,\n      isReadOnly: props.isReadOnly,\n      hasFocus,\n      menuPortalZIndex: props.menuPortalZIndex,\n    },\n    theme\n  );\n  const options = props.currencies.map((currencyCode) => ({\n    label: currencyCode,\n    value: currencyCode,\n  }));\n\n  const option = (() => {\n    const matchedOption = options.find(\n      (optionCandidate) => optionCandidate.value === props.value.currencyCode\n    );\n    if (matchedOption) return matchedOption;\n    // ensure an option is found, even when the currencies don't include\n    // the money value's currencyCode\n    if (props.value.currencyCode.trim() !== '')\n      return {\n        label: props.value.currencyCode,\n        value: props.value.currencyCode,\n      };\n    return null;\n  })();\n\n  const id = MoneyInput.getCurrencyDropdownId(props.id);\n\n  const isHighPrecision =\n    !MoneyInput.isEmpty(props.value) &&\n    MoneyInput.isHighPrecision(props.value, intl.locale);\n\n  const { onBlur } = props;\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n          },\n        });\n        onBlur({\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n          },\n        });\n      }\n    },\n    [onBlur, props.id, props.name]\n  );\n\n  const TooltipPortal = useCallback(\n    (remainingProps) => <Portal {...remainingProps} id={props.id} />,\n    [props.id]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <div\n        ref={containerRef}\n        css={css`\n          font-family: inherit;\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n        data-testid=\"money-input-container\"\n        onBlur={handleContainerBlur}\n      >\n        {hasNoCurrencies ? (\n          <CurrencyLabel\n            id={MoneyInput.getAmountInputId(props.id)}\n            isDisabled={props.isDisabled}\n          >\n            {option && option.label}\n          </CurrencyLabel>\n        ) : (\n          <Select\n            inputId={id}\n            name={getCurrencyDropdownName(props.name)}\n            value={option}\n            isDisabled={props.isDisabled}\n            isSearchable={false}\n            components={{\n              // eslint-disable-next-line react/display-name\n              SingleValue: (innerProps) => (\n                <SingleValue {...innerProps} id={id} />\n              ),\n              // eslint-disable-next-line react/display-name\n              Input: (ownProps) => (\n                // eslint-disable-next-line react/prop-types\n                <components.Input {...ownProps} readOnly={props.isReadOnly} />\n              ),\n              DropdownIndicator,\n            }}\n            options={options}\n            menuIsOpen={props.isReadOnly ? false : undefined}\n            placeholder=\"\"\n            styles={currencySelectStyles}\n            onFocus={handleCurrencyFocus}\n            menuPortalTarget={props.menuPortalTarget}\n            menuShouldBlockScroll={props.menuShouldBlockScroll}\n            onBlur={handleCurrencyBlur}\n            onChange={handleCurrencyChange}\n            data-testid=\"currency-dropdown\"\n          />\n        )}\n        <div\n          css={css`\n            position: relative;\n            width: 100%;\n          `}\n        >\n          <input\n            ref={amountInputRef}\n            id={MoneyInput.getAmountInputId(props.id)}\n            autoComplete={props.autoComplete}\n            name={getAmountInputName(props.name)}\n            type=\"text\"\n            onFocus={handleAmountFocus}\n            value={props.value.amount}\n            css={[\n              getAmountInputStyles({ ...props, hasFocus }),\n              // accounts for size of icon\n              props.hasHighPrecisionBadge &&\n                isHighPrecision &&\n                css`\n                  padding-right: ${vars.spacingL};\n                `,\n            ]}\n            placeholder={props.placeholder}\n            onChange={handleAmountChange}\n            onBlur={handleAmountBlur}\n            disabled={props.isDisabled}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            {...filterDataAttributes(props)}\n          />\n          {props.hasHighPrecisionBadge && isHighPrecision && (\n            <>\n              {!props.isDisabled && <div id={getPortalId(props.id)} />}\n              <div\n                css={() =>\n                  getHighPrecisionWrapperStyles({\n                    isDisabled: props.isDisabled,\n                  })\n                }\n              >\n                <Tooltip\n                  off={props.isDisabled}\n                  placement=\"top-end\"\n                  // we use negative margin to make up for the padding in the Tooltip Wrapper\n                  // so that the tooltip is flush with the component\n                  styles={{\n                    body: {\n                      margin: `${vars.spacingS} -${vars.spacingXs} ${vars.spacingS} 0`,\n                    },\n                  }}\n                  title={intl.formatMessage(messages.highPrecision)}\n                  components={{\n                    TooltipWrapperComponent: TooltipPortal,\n                    WrapperComponent: TooltipWrapper,\n                  }}\n                >\n                  <FractionDigitsIcon\n                    color={props.isDisabled ? 'neutral60' : 'info'}\n                  />\n                </Tooltip>\n              </div>\n            </>\n          )}\n        </div>\n      </div>\n    </Constraints.Horizontal>\n  );\n};\n\nMoneyInput.displayName = 'MoneyInput';\n\nMoneyInput.getAmountInputId = getAmountInputName;\n\nMoneyInput.getCurrencyDropdownId = getCurrencyDropdownName;\n\nMoneyInput.convertToMoneyValue = (value, locale) =>\n  createMoneyValue(\n    value.currencyCode,\n    typeof value.amount === 'string' ? value.amount.trim() : '',\n    locale\n  );\n\nMoneyInput.parseMoneyValue = (moneyValue, locale) => {\n  if (!moneyValue) return { currencyCode: '', amount: '' };\n\n  warning(\n    typeof locale === 'string',\n    'MoneyInput.parseMoneyValue: A locale must be passed as the second argument'\n  );\n\n  warning(\n    typeof moneyValue === 'object',\n    'MoneyInput.parseMoneyValue: Value must be passed as an object or be undefined'\n  );\n\n  warning(\n    typeof moneyValue.currencyCode === 'string',\n    'MoneyInput.parseMoneyValue: Value must contain \"currencyCode\"'\n  );\n\n  warning(\n    has(currencies, moneyValue.currencyCode),\n    'MoneyInput.parseMoneyValue: Value must use known currency code'\n  );\n\n  warning(\n    // highPrecision or centPrecision values must be set\n    typeof moneyValue.centAmount === 'number' ||\n      (typeof moneyValue.preciseAmount === 'number' &&\n        typeof moneyValue.fractionDigits === 'number'),\n    'MoneyInput.parseMoneyValue: Value must contain \"amount\"'\n  );\n\n  const amount = formatAmount(\n    getAmountAsNumberFromMoneyValue(moneyValue).toLocaleString(locale, {\n      minimumFractionDigits: moneyValue.fractionDigits,\n    }),\n    moneyValue.currencyCode,\n    locale\n  );\n\n  return { amount, currencyCode: moneyValue.currencyCode };\n};\n\nMoneyInput.isEmpty = (formValue) =>\n  !formValue ||\n  formValue.amount.trim() === '' ||\n  formValue.currencyCode.trim() === '';\n\nMoneyInput.isHighPrecision = (formValue, locale) => {\n  warning(\n    !MoneyInput.isEmpty(formValue),\n    'MoneyValue.isHighPrecision may not be called with an empty money value.'\n  );\n  const moneyValue = MoneyInput.convertToMoneyValue(formValue, locale);\n  return moneyValue && moneyValue.type === 'highPrecision';\n};\n\nMoneyInput.isTouched = (touched) =>\n  Boolean(touched && touched.currencyCode && touched.amount);\n\nMoneyInput.propTypes = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`) and the currency dropdown (`${name}.currencyCode`).\n   */\n  name: PropTypes.string,\n  /**\n   * Value of the input. Consists of the currency code and an amount. `amount` is a string representing the amount. A dot has to be used as the decimal separator.\n   */\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  /**\n   * List of possible currencies. When not provided or empty, the component renders a label with the value's currency instead of a dropdown.\n   */\n  currencies: PropTypes.arrayOf(PropTypes.string).isRequired,\n  /**\n   * Placeholder text for the input\n   */\n  placeholder: PropTypes.string,\n  /**\n   * Called when input is blurred\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when input is focused\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Called with the event of the input or dropdown when either the currency or the amount have changed.\n   * <br />\n   * Signature: `(event) => void`\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Dom element to portal the currency select menu to\n   */\n  menuPortalTarget: PropTypes.instanceOf(SafeHTMLElement),\n  /**\n   * z-index value for the currency select menu portal\n   */\n  menuPortalZIndex: PropTypes.number,\n  /**\n   * whether the menu should block scroll while open\n   */\n  menuShouldBlockScroll: PropTypes.bool,\n  /**\n   * Indicates that input has errors\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning: PropTypes.bool,\n  /**\n   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge: PropTypes.bool,\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n};\n\nMoneyInput.defaultProps = {\n  currencies: [],\n  horizontalConstraint: 'scale',\n  menuPortalZIndex: 1,\n};\n\nexport default MoneyInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:MoneyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["money-input.js"],"names":[],"mappings":"AAqmBY","file":"money-input.js","sourcesContent":["import { useRef, useCallback } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport has from 'lodash/has';\nimport requiredIf from 'react-required-if';\nimport Select, { components } from 'react-select';\nimport { useIntl } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { customProperties as vars } from '@commercetools-uikit/design-system';\nimport {\n  warning,\n  isNumberish,\n  SafeHTMLElement,\n  filterDataAttributes,\n} from '@commercetools-uikit/utils';\nimport Tooltip from '@commercetools-uikit/tooltip';\nimport {\n  DropdownIndicator,\n  createSelectStyles,\n} from '@commercetools-uikit/select-utils';\nimport { FractionDigitsIcon } from '@commercetools-uikit/icons';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport currencies from './currencies.json';\nimport {\n  getHighPrecisionWrapperStyles,\n  getCurrencyLabelStyles,\n  getAmountInputStyles,\n} from './money-input.styles';\nimport messages from './messages';\n\nconst TooltipWrapper = styled.div`\n  display: flex;\n`;\n\nconst getPortalId = (id) => `portal-${id}`;\nconst getPortalNode = (id) => document.querySelector(`#${getPortalId(id)}`);\n\nconst Portal = (props) => {\n  const domNode = getPortalNode(props.id);\n  return ReactDOM.createPortal(props.children, domNode);\n};\n\nconst CurrencyLabel = (props) => (\n  <label htmlFor={props.id} css={getCurrencyLabelStyles()}>\n    {props.children}\n  </label>\n);\n\nCurrencyLabel.displayName = 'CurrencyLabel';\n\nCurrencyLabel.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\nconst SingleValue = ({ id, ...props }) => (\n  <components.SingleValue {...props}>\n    <label htmlFor={id}>{props.children}</label>\n  </components.SingleValue>\n);\n\nSingleValue.displayName = 'SingleValue';\n\nSingleValue.propTypes = {\n  id: PropTypes.string,\n  children: PropTypes.node,\n};\n\n// overwrite styles of createSelectStyles\nconst createCurrencySelectStyles = (\n  { hasWarning, hasError, isDisabled, isReadOnly, hasFocus, menuPortalZIndex },\n  theme\n) => {\n  const selectStyles = createSelectStyles(\n    {\n      hasWarning,\n      hasError,\n      menuPortalZIndex,\n    },\n    theme\n  );\n  return {\n    ...selectStyles,\n    control: (base, state) => ({\n      ...selectStyles.control(base, state),\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      minWidth: '72px',\n      borderColor: (() => {\n        if (isDisabled)\n          return `${vars.borderColorForInputWhenDisabled} !important`;\n        if (hasError) return vars.borderColorForInputWhenError;\n        if (hasWarning) return vars.borderColorForInputWhenWarning;\n        if (hasFocus) return vars.borderColorForInputWhenFocused;\n        if (isReadOnly)\n          return `${vars.borderColorForInputWhenReadonly} !important`;\n        return vars.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: (() => {\n        if (isReadOnly) return vars.backgroundColorForInput;\n        return base.backgroundColor;\n      })(),\n    }),\n    singleValue: (base) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: (() => {\n        if (isDisabled) return vars.fontColorForInputWhenDisabled;\n        if (hasError) return vars.fontColorForInputWhenError;\n        if (hasWarning) return vars.fontColorForInputWhenWarning;\n        if (isReadOnly) return vars.fontColorForInputWhenReadonly;\n        return base.color;\n      })(),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly ? vars.fontColorForInputWhenReadonly : '',\n    }),\n  };\n};\n\n// The MoneyInput component always operates on a value consisting of:\n//   { amount: String, currencyCode: String }\n//\n// The amount may only use a dot as the decimal separator.\n// The currencyCode must be supported by the API.\n//\n// The MoneyInput does not do any validation on its own. It only serves as a way\n// to get the amount and currencyCode input from the user. Validation is always\n// up to the parent.\n//\n// The CTP API supports prices two types of prices: centPrecision and\n// highPrecision. The MoneyInput itself does not know about these. However,\n// it has two static methods defined (convertToMoneyValue and parseMoneyValue),\n// which can be used to convert between MoneyInput value and the MoneyValue\n// supported by the API.\n// Some places in the API do not support highPrecision prices, but the\n// convertToMoneyValue will always return either a centPrecision or a\n// highPrecision price. It's up the MoneyInput's parent to show a validation\n// error in case a highPrecision price is used.\n//\n// A value is considered as to have highPrecision when the number of supplied\n// fraction digits exceed the number of fraction digits the currency uses. For\n// example, 42.00 € is always a centPrecision price, while 42.001 € is always a\n// highPrecision price. It is not possible to hae 42.00 € as a highPrecision\n// price.\n//\n// The first time the component renders, we want to try to show the centAmount\n// as a formatted number. To achieve this, the parseMoneyValue function can\n// be used to turn the API value into a value the MoneyInput understands.\n// During this transformation, the money value will get formatted into \"amount\".\n//\n// When the user changes the value, we don't want to format again. We only format\n// in case the user blurs the field. This avoids many edge cases where the\n// formatting would mess with the user's input.\n//\n//\n// A full example of an MoneyValue with centPrecision would be\n// {\n//   \"type\": \"centPrecision\",\n//   \"currencyCode\": \"EUR\",\n//   \"centAmount\": 4200,\n//   \"fractionDigits\": 2\n// }\n// which equals 42.00 €\n//\n// A full example of an MoneyValue with highPrecision would be\n// {\n//  \"type\": \"highPrecision\",\n//  \"currencyCode\": \"EUR\",\n//  \"centAmount\": 1,\n//  \"preciseAmount\": 123456,\n//  \"fractionDigits\": 7\n// }\n// which equals 0.0123456 €\n\n// Parsing\n// Since most users are not careful about how they enter values, we will parse\n// both `.` and `,` as decimal separators.\n// When a value is `1.000,00` we parse it as `1000`.\n// When a value is `1,000.00` we also parse it as `1000`.\n//\n// This means the highest amount always wins. We do this by comparing the last\n// position of `.` and `,`. Whatever occurs later is used as the decimal\n// separator.\nexport const parseRawAmountToNumber = (rawAmount, locale) => {\n  let fractionsSeparator;\n\n  if (locale) {\n    fractionsSeparator = (2.5) // we need any number with fractions, so that we know what is the fraction\n      .toLocaleString(locale) // \"symbol\" for the provided locale\n      .replace(/\\d/g, ''); // then we remove the numbers and keep the \"symbol\"\n  } else {\n    const lastDot = String(rawAmount).lastIndexOf('.');\n    const lastComma = String(rawAmount).lastIndexOf(',');\n    fractionsSeparator = lastComma > lastDot ? ',' : '.';\n  }\n\n  fractionsSeparator = fractionsSeparator === '.' ? '\\\\.' : fractionsSeparator; // here we escape the '.' to use it as regex\n  // The raw amount with only one sparator\n  const normalizedAmount = String(rawAmount)\n    .replace(new RegExp(`[^0-9${fractionsSeparator}]`, 'g'), '') // we just keep the numbers and the fraction symbol\n    .replace(fractionsSeparator, '.'); // then we change whatever `fractionsSeparator` was to `.` so we can parse it as float\n\n  return parseFloat(normalizedAmount, 10);\n};\n\n// Turns the user input into a value the MoneyInput can pass up through onChange\n// In case the number of fraction digits contained in \"amount\" exceeds the\n// number of fraction digits the currency uses, it will emit a price of\n// type \"highPrecision\" instead of the regular \"centPrecision\".\n// It will return \"null\" in case an invalid value is entered.\n// The value is invalid when\n//  - no amount was entered\n//  - an invalid amount was entered\n//  - no currency was selected\n//\n// This function expects the \"amount\" to be a trimmed value.\nexport const createMoneyValue = (currencyCode, rawAmount, locale) => {\n  if (!currencyCode) return null;\n\n  const currency = currencies[currencyCode];\n  if (!currency) return null;\n\n  if (rawAmount.length === 0 || !isNumberish(rawAmount)) return null;\n\n  warning(\n    locale || currency.fractionDigits !== 0,\n    `A locale must be provided when currency has no fraction digits (${currencyCode})`\n  );\n  const amountAsNumber = parseRawAmountToNumber(rawAmount, locale);\n  if (isNaN(amountAsNumber)) return null;\n\n  // The cent amount is rounded to the currencie's default number\n  // of fraction digits for prices with high precision.\n  //\n  // Additionally, JavaScript is sometimes incorrect when multiplying floats,\n  //   e.g. 2.49 * 100 -> 249.00000000000003\n  // While inaccuracy from multiplying floating point numbers is a\n  // general problem in JS, we can avoid it by cutting off all\n  // decimals. This is possible since cents is the base unit, so we\n  // operate on integers anyways\n  // Also we should the round the value to ensure that we come close\n  // to the nearest decimal value\n  // ref: https://github.com/commercetools/merchant-center-frontend/pull/770\n  const centAmount = Math.trunc(\n    Math.round(amountAsNumber * 10 ** currency.fractionDigits)\n  );\n\n  const fractionDigitsOfAmount =\n    // The conversion to a string will always use a dot as the separator.\n    // That means we don't have to handle a comma.\n    String(amountAsNumber).indexOf('.') === -1\n      ? 0\n      : String(amountAsNumber).length - String(amountAsNumber).indexOf('.') - 1;\n\n  if (fractionDigitsOfAmount > currency.fractionDigits) {\n    return {\n      type: 'highPrecision',\n      currencyCode,\n      centAmount,\n      preciseAmount: parseInt(\n        // Here we need to convert  a number like 8.066652 to its centamount\n        // We could do that by multiplying it with 10 ** number-of-fraction-digits\n        // but then we'll run into problems with JavaScript's floating point\n        // number precision and end up with 8066651.9999999, and then parseInt\n        // cuts off the remainder.\n        // So instead of using maths to convert the number, we just replace\n        // the dot inside the number which does the same thing.\n        // We don't need to replace \",\" as well, as numbers always us a dot\n        // when converted using String().\n        //\n        // The mathematical way: amountAsNumber * 10 ** fractionDigitsOfAmount,\n        String(amountAsNumber).replace('.', ''),\n        10\n      ),\n      fractionDigits: fractionDigitsOfAmount,\n    };\n  }\n\n  return {\n    type: 'centPrecision',\n    currencyCode,\n    centAmount,\n    fractionDigits: currency.fractionDigits,\n  };\n};\n\nconst getAmountAsNumberFromMoneyValue = (moneyValue) =>\n  moneyValue.type === 'highPrecision'\n    ? moneyValue.preciseAmount / 10 ** moneyValue.fractionDigits\n    : moneyValue.centAmount /\n      10 ** currencies[moneyValue.currencyCode].fractionDigits;\n\n// gets called with a string and should return a formatted string\nconst formatAmount = (rawAmount, currencyCode, locale) => {\n  // fallback in case the user didn't enter an amount yet (or it's invalid)\n  const moneyValue = createMoneyValue(currencyCode, rawAmount, locale) || {\n    currencyCode,\n    centAmount: NaN,\n  };\n\n  const amount = getAmountAsNumberFromMoneyValue(moneyValue);\n\n  const fractionDigits = moneyValue.preciseAmount\n    ? moneyValue.fractionDigits\n    : currencies[moneyValue.currencyCode].fractionDigits;\n\n  return isNaN(amount)\n    ? ''\n    : amount.toLocaleString(locale, { minimumFractionDigits: fractionDigits });\n};\n\nconst getAmountInputName = (name) => (name ? `${name}.amount` : undefined);\nconst getCurrencyDropdownName = (name) =>\n  name ? `${name}.currencyCode` : undefined;\n\nconst MoneyInput = (props) => {\n  const intl = useIntl();\n  const [currencyHasFocus, toggleCurrencyHasFocus] = useToggleState(false);\n  const [amountHasFocus, toggleAmountHasFocus] = useToggleState(false);\n\n  const containerRef = useRef();\n  const amountInputRef = useRef();\n\n  const { onFocus } = props;\n  const handleAmountFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getAmountInputId(props.id),\n          name: getAmountInputName(props.name),\n        },\n      });\n    toggleAmountHasFocus(true);\n  }, [toggleAmountHasFocus, onFocus, props.id, props.name]);\n\n  const { onChange } = props;\n  const handleAmountBlur = useCallback(() => {\n    const amount = props.value.amount.trim();\n    toggleAmountHasFocus(false);\n    // Skip formatting for empty value or when the input is used with an\n    // unknown currency.\n    if (amount.length > 0 && currencies[props.value.currencyCode]) {\n      const formattedAmount = formatAmount(\n        amount,\n        props.value.currencyCode,\n        intl.locale\n      );\n\n      // When the user entered a value with centPrecision, we can format\n      // the resulting value to that currency, e.g. 20.1 to 20.10\n      if (String(formattedAmount) !== amount) {\n        // We need to emit an event with the now formatted value\n        const fakeEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: formattedAmount,\n          },\n        };\n        onChange(fakeEvent);\n      }\n    }\n  }, [\n    intl.locale,\n    onChange,\n    props.id,\n    props.name,\n    props.value.amount,\n    props.value.currencyCode,\n    toggleAmountHasFocus,\n  ]);\n\n  const handleAmountChange = useCallback(\n    (event) => {\n      if (isNumberish(event.target.value)) {\n        onChange({\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n            value: event.target.value,\n          },\n        });\n      }\n    },\n    [onChange, props.id, props.name]\n  );\n\n  const handleCurrencyChange = useCallback(\n    (option) => {\n      const currencyCode = option.value;\n      if (props.value.currencyCode !== currencyCode) {\n        // When the user changes from a currency with 3 fraction digits to\n        // a currency with 2 fraction digits, and when the input value was\n        // \"9.000\" (9), then it should change to \"9.00\" to reflect the new\n        // currency's number of fraction digits.\n        // When the currency was a high-precision price, then no digits should\n        // be lost\n        const formattedAmount = formatAmount(\n          props.value.amount.trim(),\n          currencyCode,\n          intl.locale\n        );\n        // The user could be changing the currency before entering any amount,\n        // or while the amount is invalid. In these cases, we don't attempt to\n        // format the amount.\n        const nextAmount = isNaN(formattedAmount)\n          ? props.value.amount\n          : formattedAmount;\n\n        // change currency code\n        const fakeCurrencyEvent = {\n          // eslint-disable-next-line @typescript-eslint/no-empty-function\n          persist: () => {},\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n            value: currencyCode || '',\n          },\n        };\n        onChange(fakeCurrencyEvent);\n\n        // change amount if necessary\n        if (props.value.amount !== nextAmount) {\n          onChange({\n            // eslint-disable-next-line @typescript-eslint/no-empty-function\n            persist: () => {},\n            target: {\n              id: MoneyInput.getAmountInputId(props.id),\n              name: getAmountInputName(props.name),\n              value: nextAmount,\n            },\n          });\n        }\n\n        amountInputRef.current.focus();\n      }\n    },\n    [\n      intl.locale,\n      onChange,\n      props.id,\n      props.name,\n      props.value.amount,\n      props.value.currencyCode,\n    ]\n  );\n\n  const handleCurrencyFocus = useCallback(() => {\n    if (onFocus)\n      onFocus({\n        target: {\n          id: MoneyInput.getCurrencyDropdownId(props.id),\n          name: getCurrencyDropdownName(props.name),\n        },\n      });\n\n    toggleCurrencyHasFocus(true);\n  }, [onFocus, toggleCurrencyHasFocus, props.name, props.id]);\n\n  const handleCurrencyBlur = useCallback(() => {\n    toggleCurrencyHasFocus(false);\n  }, [toggleCurrencyHasFocus]);\n\n  const hasNoCurrencies = props.currencies.length === 0;\n  const hasFocus = currencyHasFocus || amountHasFocus;\n  const theme = useTheme();\n  const currencySelectStyles = createCurrencySelectStyles(\n    {\n      hasWarning: props.hasWarning,\n      hasError: props.hasError,\n      isDisabled: props.isDisabled,\n      isReadOnly: props.isReadOnly,\n      hasFocus,\n      menuPortalZIndex: props.menuPortalZIndex,\n    },\n    theme\n  );\n  const options = props.currencies.map((currencyCode) => ({\n    label: currencyCode,\n    value: currencyCode,\n  }));\n\n  const option = (() => {\n    const matchedOption = options.find(\n      (optionCandidate) => optionCandidate.value === props.value.currencyCode\n    );\n    if (matchedOption) return matchedOption;\n    // ensure an option is found, even when the currencies don't include\n    // the money value's currencyCode\n    if (props.value.currencyCode.trim() !== '')\n      return {\n        label: props.value.currencyCode,\n        value: props.value.currencyCode,\n      };\n    return null;\n  })();\n\n  const id = MoneyInput.getCurrencyDropdownId(props.id);\n\n  const isHighPrecision =\n    !MoneyInput.isEmpty(props.value) &&\n    MoneyInput.isHighPrecision(props.value, intl.locale);\n\n  const { onBlur } = props;\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: MoneyInput.getCurrencyDropdownId(props.id),\n            name: getCurrencyDropdownName(props.name),\n          },\n        });\n        onBlur({\n          target: {\n            id: MoneyInput.getAmountInputId(props.id),\n            name: getAmountInputName(props.name),\n          },\n        });\n      }\n    },\n    [onBlur, props.id, props.name]\n  );\n\n  const TooltipPortal = useCallback(\n    (remainingProps) => <Portal {...remainingProps} id={props.id} />,\n    [props.id]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <div\n        ref={containerRef}\n        css={css`\n          font-family: inherit;\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n        data-testid=\"money-input-container\"\n        onBlur={handleContainerBlur}\n      >\n        {hasNoCurrencies ? (\n          <CurrencyLabel\n            id={MoneyInput.getAmountInputId(props.id)}\n            isDisabled={props.isDisabled}\n          >\n            {option && option.label}\n          </CurrencyLabel>\n        ) : (\n          <Select\n            inputId={id}\n            name={getCurrencyDropdownName(props.name)}\n            value={option}\n            isDisabled={props.isDisabled}\n            isSearchable={false}\n            components={{\n              // eslint-disable-next-line react/display-name\n              SingleValue: (innerProps) => (\n                <SingleValue {...innerProps} id={id} />\n              ),\n              // eslint-disable-next-line react/display-name\n              Input: (ownProps) => (\n                // eslint-disable-next-line react/prop-types\n                <components.Input {...ownProps} readOnly={props.isReadOnly} />\n              ),\n              DropdownIndicator,\n            }}\n            options={options}\n            menuIsOpen={props.isReadOnly ? false : undefined}\n            placeholder=\"\"\n            styles={currencySelectStyles}\n            onFocus={handleCurrencyFocus}\n            menuPortalTarget={props.menuPortalTarget}\n            menuShouldBlockScroll={props.menuShouldBlockScroll}\n            onBlur={handleCurrencyBlur}\n            onChange={handleCurrencyChange}\n            data-testid=\"currency-dropdown\"\n          />\n        )}\n        <div\n          css={css`\n            position: relative;\n            width: 100%;\n          `}\n        >\n          <input\n            ref={amountInputRef}\n            id={MoneyInput.getAmountInputId(props.id)}\n            autoComplete={props.autoComplete}\n            name={getAmountInputName(props.name)}\n            type=\"text\"\n            onFocus={handleAmountFocus}\n            value={props.value.amount}\n            css={[\n              getAmountInputStyles({ ...props, hasFocus }),\n              // accounts for size of icon\n              props.hasHighPrecisionBadge &&\n                isHighPrecision &&\n                css`\n                  padding-right: ${vars.spacingL};\n                `,\n            ]}\n            placeholder={props.placeholder}\n            onChange={handleAmountChange}\n            onBlur={handleAmountBlur}\n            disabled={props.isDisabled}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            {...filterDataAttributes(props)}\n          />\n          {props.hasHighPrecisionBadge && isHighPrecision && (\n            <>\n              {!props.isDisabled && <div id={getPortalId(props.id)} />}\n              <div\n                css={() =>\n                  getHighPrecisionWrapperStyles({\n                    isDisabled: props.isDisabled,\n                  })\n                }\n              >\n                <Tooltip\n                  off={props.isDisabled}\n                  placement=\"top-end\"\n                  // we use negative margin to make up for the padding in the Tooltip Wrapper\n                  // so that the tooltip is flush with the component\n                  styles={{\n                    body: {\n                      margin: `${vars.spacingS} -${vars.spacingXs} ${vars.spacingS} 0`,\n                    },\n                  }}\n                  title={intl.formatMessage(messages.highPrecision)}\n                  components={{\n                    TooltipWrapperComponent: TooltipPortal,\n                    WrapperComponent: TooltipWrapper,\n                  }}\n                >\n                  <FractionDigitsIcon\n                    color={props.isDisabled ? 'neutral60' : 'info'}\n                  />\n                </Tooltip>\n              </div>\n            </>\n          )}\n        </div>\n      </div>\n    </Constraints.Horizontal>\n  );\n};\n\nMoneyInput.displayName = 'MoneyInput';\n\nMoneyInput.getAmountInputId = getAmountInputName;\n\nMoneyInput.getCurrencyDropdownId = getCurrencyDropdownName;\n\nMoneyInput.convertToMoneyValue = (value, locale) =>\n  createMoneyValue(\n    value.currencyCode,\n    typeof value.amount === 'string' ? value.amount.trim() : '',\n    locale\n  );\n\nMoneyInput.parseMoneyValue = (moneyValue, locale) => {\n  if (!moneyValue) return { currencyCode: '', amount: '' };\n\n  warning(\n    typeof locale === 'string',\n    'MoneyInput.parseMoneyValue: A locale must be passed as the second argument'\n  );\n\n  warning(\n    typeof moneyValue === 'object',\n    'MoneyInput.parseMoneyValue: Value must be passed as an object or be undefined'\n  );\n\n  warning(\n    typeof moneyValue.currencyCode === 'string',\n    'MoneyInput.parseMoneyValue: Value must contain \"currencyCode\"'\n  );\n\n  warning(\n    has(currencies, moneyValue.currencyCode),\n    'MoneyInput.parseMoneyValue: Value must use known currency code'\n  );\n\n  warning(\n    // highPrecision or centPrecision values must be set\n    typeof moneyValue.centAmount === 'number' ||\n      (typeof moneyValue.preciseAmount === 'number' &&\n        typeof moneyValue.fractionDigits === 'number'),\n    'MoneyInput.parseMoneyValue: Value must contain \"amount\"'\n  );\n\n  const amount = formatAmount(\n    getAmountAsNumberFromMoneyValue(moneyValue).toLocaleString(locale, {\n      minimumFractionDigits: moneyValue.fractionDigits,\n    }),\n    moneyValue.currencyCode,\n    locale\n  );\n\n  return { amount, currencyCode: moneyValue.currencyCode };\n};\n\nMoneyInput.isEmpty = (formValue) =>\n  !formValue ||\n  formValue.amount.trim() === '' ||\n  formValue.currencyCode.trim() === '';\n\nMoneyInput.isHighPrecision = (formValue, locale) => {\n  warning(\n    !MoneyInput.isEmpty(formValue),\n    'MoneyValue.isHighPrecision may not be called with an empty money value.'\n  );\n  const moneyValue = MoneyInput.convertToMoneyValue(formValue, locale);\n  return moneyValue && moneyValue.type === 'highPrecision';\n};\n\nMoneyInput.isTouched = (touched) =>\n  Boolean(touched && touched.currencyCode && touched.amount);\n\nMoneyInput.propTypes = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  /**\n   * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`) and the currency dropdown (`${name}.currencyCode`).\n   */\n  name: PropTypes.string,\n  /**\n   * Value of the input. Consists of the currency code and an amount. `amount` is a string representing the amount. A dot has to be used as the decimal separator.\n   */\n  value: PropTypes.shape({\n    amount: PropTypes.string.isRequired,\n    currencyCode: PropTypes.string.isRequired,\n  }).isRequired,\n  /**\n   * List of possible currencies. When not provided or empty, the component renders a label with the value's currency instead of a dropdown.\n   */\n  currencies: PropTypes.arrayOf(PropTypes.string).isRequired,\n  /**\n   * Placeholder text for the input\n   */\n  placeholder: PropTypes.string,\n  /**\n   * Called when input is blurred\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when input is focused\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Called with the event of the input or dropdown when either the currency or the amount have changed.\n   * <br />\n   * Signature: `(event) => void`\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Dom element to portal the currency select menu to\n   */\n  menuPortalTarget: PropTypes.instanceOf(SafeHTMLElement),\n  /**\n   * z-index value for the currency select menu portal\n   */\n  menuPortalZIndex: PropTypes.number,\n  /**\n   * whether the menu should block scroll while open\n   */\n  menuShouldBlockScroll: PropTypes.bool,\n  /**\n   * Indicates that input has errors\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning: PropTypes.bool,\n  /**\n   * Shows high precision badge in case current value uses high precision.\n   */\n  hasHighPrecisionBadge: PropTypes.bool,\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n};\n\nMoneyInput.defaultProps = {\n  currencies: [],\n  horizontalConstraint: 'scale',\n  menuPortalZIndex: 1,\n};\n\nexport default MoneyInput;\n"]} */"],
1330
+ placeholder: props.placeholder,
1331
+ onChange: handleAmountChange,
1332
+ onBlur: handleAmountBlur,
1333
+ disabled: props.isDisabled,
1334
+ readOnly: props.isReadOnly,
1335
+ autoFocus: props.isAutofocussed
1336
+ }, utils.filterDataAttributes(props))), props.hasHighPrecisionBadge && isHighPrecision && jsxRuntime.jsxs(jsxRuntime.Fragment, {
1337
+ children: [!props.isDisabled && jsxRuntime.jsx("div", {
1338
+ id: getPortalId(props.id)
1339
+ }), jsxRuntime.jsx("div", {
1340
+ css: function css() {
1341
+ return getHighPrecisionWrapperStyles({
1342
+ isDisabled: props.isDisabled
1343
+ });
1344
+ },
1345
+ children: jsxRuntime.jsx(Tooltip__default["default"], {
1346
+ off: props.isDisabled,
1347
+ placement: "top-end" // we use negative margin to make up for the padding in the Tooltip Wrapper
1348
+ // so that the tooltip is flush with the component
1349
+ ,
1350
+ styles: {
1351
+ body: {
1352
+ margin: _concatInstanceProperty__default["default"](_context9 = _concatInstanceProperty__default["default"](_context10 = "".concat(designSystem.customProperties.spacingS, " -")).call(_context10, designSystem.customProperties.spacingXs, " ")).call(_context9, designSystem.customProperties.spacingS, " 0")
1353
+ }
1354
+ },
1355
+ title: intl.formatMessage(messages.highPrecision),
1356
+ components: {
1357
+ TooltipWrapperComponent: TooltipPortal,
1358
+ WrapperComponent: TooltipWrapper
1359
+ },
1360
+ children: jsxRuntime.jsx(icons.FractionDigitsIcon, {
1361
+ color: props.isDisabled ? 'neutral60' : 'info'
1362
+ })
1363
+ })
1364
+ })]
1365
+ })]
1366
+ })]
1367
+ })
1368
+ });
1354
1369
  };
1355
1370
 
1356
1371
  MoneyInput.displayName = 'MoneyInput';
@@ -1360,7 +1375,7 @@ MoneyInput.getCurrencyDropdownId = getCurrencyDropdownName;
1360
1375
  MoneyInput.convertToMoneyValue = function (value, locale) {
1361
1376
  var _context11;
1362
1377
 
1363
- return createMoneyValue(value.currencyCode, typeof value.amount === 'string' ? _trimInstanceProperty__default['default'](_context11 = value.amount).call(_context11) : '', locale);
1378
+ return createMoneyValue(value.currencyCode, typeof value.amount === 'string' ? _trimInstanceProperty__default["default"](_context11 = value.amount).call(_context11) : '', locale);
1364
1379
  };
1365
1380
 
1366
1381
  MoneyInput.parseMoneyValue = function (moneyValue, locale) {
@@ -1371,7 +1386,7 @@ MoneyInput.parseMoneyValue = function (moneyValue, locale) {
1371
1386
  process.env.NODE_ENV !== "production" ? utils.warning(typeof locale === 'string', 'MoneyInput.parseMoneyValue: A locale must be passed as the second argument') : void 0;
1372
1387
  process.env.NODE_ENV !== "production" ? utils.warning(_typeof(moneyValue) === 'object', 'MoneyInput.parseMoneyValue: Value must be passed as an object or be undefined') : void 0;
1373
1388
  process.env.NODE_ENV !== "production" ? utils.warning(typeof moneyValue.currencyCode === 'string', 'MoneyInput.parseMoneyValue: Value must contain "currencyCode"') : void 0;
1374
- process.env.NODE_ENV !== "production" ? utils.warning(has__default['default'](currencies, moneyValue.currencyCode), 'MoneyInput.parseMoneyValue: Value must use known currency code') : void 0;
1389
+ process.env.NODE_ENV !== "production" ? utils.warning(has__default["default"](currencies, moneyValue.currencyCode), 'MoneyInput.parseMoneyValue: Value must use known currency code') : void 0;
1375
1390
  process.env.NODE_ENV !== "production" ? utils.warning( // highPrecision or centPrecision values must be set
1376
1391
  typeof moneyValue.centAmount === 'number' || typeof moneyValue.preciseAmount === 'number' && typeof moneyValue.fractionDigits === 'number', 'MoneyInput.parseMoneyValue: Value must contain "amount"') : void 0;
1377
1392
  var amount = formatAmount(getAmountAsNumberFromMoneyValue(moneyValue).toLocaleString(locale, {
@@ -1386,7 +1401,7 @@ MoneyInput.parseMoneyValue = function (moneyValue, locale) {
1386
1401
  MoneyInput.isEmpty = function (formValue) {
1387
1402
  var _context12, _context13;
1388
1403
 
1389
- return !formValue || _trimInstanceProperty__default['default'](_context12 = formValue.amount).call(_context12) === '' || _trimInstanceProperty__default['default'](_context13 = formValue.currencyCode).call(_context13) === '';
1404
+ return !formValue || _trimInstanceProperty__default["default"](_context12 = formValue.amount).call(_context12) === '' || _trimInstanceProperty__default["default"](_context13 = formValue.currencyCode).call(_context13) === '';
1390
1405
  };
1391
1406
 
1392
1407
  MoneyInput.isHighPrecision = function (formValue, locale) {
@@ -1403,104 +1418,104 @@ MoneyInput.propTypes = process.env.NODE_ENV !== "production" ? {
1403
1418
  /**
1404
1419
  * Used as HTML id property. An id is auto-generated when it is not specified.
1405
1420
  */
1406
- id: PropTypes__default['default'].string,
1421
+ id: PropTypes__default["default"].string,
1407
1422
 
1408
1423
  /**
1409
1424
  * Used as HTML `autocomplete` property
1410
1425
  */
1411
- autoComplete: PropTypes__default['default'].string,
1426
+ autoComplete: PropTypes__default["default"].string,
1412
1427
 
1413
1428
  /**
1414
1429
  * The prefix used to create a HTML `name` property for the amount input field (`${name}.amount`) and the currency dropdown (`${name}.currencyCode`).
1415
1430
  */
1416
- name: PropTypes__default['default'].string,
1431
+ name: PropTypes__default["default"].string,
1417
1432
 
1418
1433
  /**
1419
1434
  * Value of the input. Consists of the currency code and an amount. `amount` is a string representing the amount. A dot has to be used as the decimal separator.
1420
1435
  */
1421
- value: PropTypes__default['default'].shape({
1422
- amount: PropTypes__default['default'].string.isRequired,
1423
- currencyCode: PropTypes__default['default'].string.isRequired
1436
+ value: PropTypes__default["default"].shape({
1437
+ amount: PropTypes__default["default"].string.isRequired,
1438
+ currencyCode: PropTypes__default["default"].string.isRequired
1424
1439
  }).isRequired,
1425
1440
 
1426
1441
  /**
1427
1442
  * List of possible currencies. When not provided or empty, the component renders a label with the value's currency instead of a dropdown.
1428
1443
  */
1429
- currencies: PropTypes__default['default'].arrayOf(PropTypes__default['default'].string).isRequired,
1444
+ currencies: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string).isRequired,
1430
1445
 
1431
1446
  /**
1432
1447
  * Placeholder text for the input
1433
1448
  */
1434
- placeholder: PropTypes__default['default'].string,
1449
+ placeholder: PropTypes__default["default"].string,
1435
1450
 
1436
1451
  /**
1437
1452
  * Called when input is blurred
1438
1453
  */
1439
- onBlur: PropTypes__default['default'].func,
1454
+ onBlur: PropTypes__default["default"].func,
1440
1455
 
1441
1456
  /**
1442
1457
  * Called when input is focused
1443
1458
  */
1444
- onFocus: PropTypes__default['default'].func,
1459
+ onFocus: PropTypes__default["default"].func,
1445
1460
 
1446
1461
  /**
1447
1462
  * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).
1448
1463
  */
1449
- isDisabled: PropTypes__default['default'].bool,
1464
+ isDisabled: PropTypes__default["default"].bool,
1450
1465
 
1451
1466
  /**
1452
1467
  * Indicates that the field is displaying read-only content
1453
1468
  */
1454
- isReadOnly: PropTypes__default['default'].bool,
1469
+ isReadOnly: PropTypes__default["default"].bool,
1455
1470
 
1456
1471
  /**
1457
1472
  * Focus the input on initial render
1458
1473
  */
1459
- isAutofocussed: PropTypes__default['default'].bool,
1474
+ isAutofocussed: PropTypes__default["default"].bool,
1460
1475
 
1461
1476
  /**
1462
1477
  * Called with the event of the input or dropdown when either the currency or the amount have changed.
1463
1478
  * <br />
1464
1479
  * Signature: `(event) => void`
1465
1480
  */
1466
- onChange: requiredIf__default['default'](PropTypes__default['default'].func, function (props) {
1481
+ onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
1467
1482
  return !props.isReadOnly;
1468
1483
  }),
1469
1484
 
1470
1485
  /**
1471
1486
  * Dom element to portal the currency select menu to
1472
1487
  */
1473
- menuPortalTarget: PropTypes__default['default'].instanceOf(utils.SafeHTMLElement),
1488
+ menuPortalTarget: PropTypes__default["default"].instanceOf(utils.SafeHTMLElement),
1474
1489
 
1475
1490
  /**
1476
1491
  * z-index value for the currency select menu portal
1477
1492
  */
1478
- menuPortalZIndex: PropTypes__default['default'].number,
1493
+ menuPortalZIndex: PropTypes__default["default"].number,
1479
1494
 
1480
1495
  /**
1481
1496
  * whether the menu should block scroll while open
1482
1497
  */
1483
- menuShouldBlockScroll: PropTypes__default['default'].bool,
1498
+ menuShouldBlockScroll: PropTypes__default["default"].bool,
1484
1499
 
1485
1500
  /**
1486
1501
  * Indicates that input has errors
1487
1502
  */
1488
- hasError: PropTypes__default['default'].bool,
1503
+ hasError: PropTypes__default["default"].bool,
1489
1504
 
1490
1505
  /**
1491
1506
  * Control to indicate on the input if there are selected values that are potentially invalid
1492
1507
  */
1493
- hasWarning: PropTypes__default['default'].bool,
1508
+ hasWarning: PropTypes__default["default"].bool,
1494
1509
 
1495
1510
  /**
1496
1511
  * Shows high precision badge in case current value uses high precision.
1497
1512
  */
1498
- hasHighPrecisionBadge: PropTypes__default['default'].bool,
1513
+ hasHighPrecisionBadge: PropTypes__default["default"].bool,
1499
1514
 
1500
1515
  /**
1501
1516
  * Horizontal size limit of the input fields.
1502
1517
  */
1503
- horizontalConstraint: PropTypes__default['default'].oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
1518
+ horizontalConstraint: PropTypes__default["default"].oneOf([3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
1504
1519
  } : {};
1505
1520
  MoneyInput.defaultProps = {
1506
1521
  currencies: [],
@@ -1509,8 +1524,8 @@ MoneyInput.defaultProps = {
1509
1524
  };
1510
1525
  var MoneyInput$1 = MoneyInput;
1511
1526
 
1512
- // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
1513
- var version = '12.2.2';
1527
+ // NOTE: This string will be replaced on build time with the package version.
1528
+ var version = "12.2.6";
1514
1529
 
1515
- exports['default'] = MoneyInput$1;
1530
+ exports["default"] = MoneyInput$1;
1516
1531
  exports.version = version;