@commercetools-uikit/localized-multiline-text-input 12.2.1 → 12.2.5

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.
@@ -10,14 +10,13 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
10
10
  var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
11
11
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
12
12
  var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
13
- var _extends = require('@babel/runtime-corejs3/helpers/extends');
14
13
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
14
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
16
15
  var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
17
16
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
18
17
  var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
19
18
  var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
20
- var React = require('react');
19
+ var react$1 = require('react');
21
20
  var PropTypes = require('prop-types');
22
21
  var requiredIf = require('react-required-if');
23
22
  var commonTags = require('common-tags');
@@ -34,6 +33,7 @@ var icons = require('@commercetools-uikit/icons');
34
33
  var utils = require('@commercetools-uikit/utils');
35
34
  var designSystem = require('@commercetools-uikit/design-system');
36
35
  var Text = require('@commercetools-uikit/text');
36
+ var jsxRuntime = require('@emotion/react/jsx-runtime');
37
37
  var messages = require('@commercetools-uikit/messages');
38
38
 
39
39
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
@@ -49,7 +49,6 @@ var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInsta
49
49
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
50
50
  var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
51
51
  var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
52
- var React__default = /*#__PURE__*/_interopDefault(React);
53
52
  var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
54
53
  var requiredIf__default = /*#__PURE__*/_interopDefault(requiredIf);
55
54
  var Stack__default = /*#__PURE__*/_interopDefault(Stack);
@@ -58,22 +57,23 @@ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
58
57
  var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
59
58
  var Text__default = /*#__PURE__*/_interopDefault(Text);
60
59
 
61
- 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; }
60
+ function ownKeys$3(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; }
62
61
 
63
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default['default'](_context = ownKeys(Object(source), true)).call(_context, 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 _context2; _forEachInstanceProperty__default['default'](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default['default'](target, key, _Object$getOwnPropertyDescriptor__default['default'](source, key)); }); } } return target; }
62
+ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default["default"](_context = ownKeys$3(Object(source), true)).call(_context, 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 _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
64
63
 
65
- 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)."; }
64
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { 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)."; }
66
65
  // * a disabled-field currently does not display warning/error-states so it takes precedence
67
66
  // * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first
68
67
  // how you can interact with the field is controlled separately by the props, this only influences visuals
69
68
 
70
- var _ref = process.env.NODE_ENV === "production" ? {
69
+ var _ref$2 = process.env.NODE_ENV === "production" ? {
71
70
  name: "d3v9zr",
72
71
  styles: "overflow:hidden"
73
72
  } : {
74
73
  name: "1h6gnzr-baseStyles",
75
74
  styles: "overflow:hidden;label:baseStyles;",
76
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
75
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0VGV4dGFyZWFTdHlsZXMgPSAocHJvcHMpID0+IHtcbiAgY29uc3QgYmFzZVN0eWxlcyA9IFtcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgYCxcbiAgICBwcm9wcy5pc0NvbGxhcHNlZCAmJlxuICAgICAgY3NzYFxuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgYCxcbiAgXTtcbiAgcmV0dXJuIGJhc2VTdHlsZXM7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzLCB0aGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKCR7dmFycy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7dmFycy5ib3JkZXJSYWRpdXMxfSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
76
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
77
77
  };
78
78
 
79
79
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -82,21 +82,22 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
82
82
  } : {
83
83
  name: "pb9fe4-baseStyles",
84
84
  styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;",
85
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhTyIsImZpbGUiOiJ0cmFuc2xhdGlvbi1pbnB1dC5zdHlsZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxTdHlsZXMgPSAocHJvcHMsIHRoZW1lKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi52YXJzLFxuICAgIC4uLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoJHt2YXJzLnNpemVIZWlnaHRJbnB1dH0gLSAyICogJHt2YXJzLmJvcmRlclJhZGl1czF9KTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
86
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
86
87
  };
87
88
 
88
89
  var getTextareaStyles = function getTextareaStyles(props) {
89
- var baseStyles = [_ref2, props.isCollapsed && _ref];
90
+ var baseStyles = [_ref2, props.isCollapsed && _ref$2];
90
91
  return baseStyles;
91
92
  };
92
93
 
93
94
  var getLanguageLabelStyles = function getLanguageLabelStyles(props, theme) {
94
- var overwrittenVars = _objectSpread(_objectSpread({}, designSystem.customProperties), theme);
95
+ var overwrittenVars = _objectSpread$3(_objectSpread$3({}, designSystem.customProperties), theme);
95
96
 
96
- return /*#__PURE__*/react.css("flex:1 0 auto;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";line-height:calc(", designSystem.customProperties.sizeHeightInput, " - 2 * ", designSystem.customProperties.borderRadius1, ");background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"));
97
+ return /*#__PURE__*/react.css("flex:1 0 auto;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";line-height:calc(", designSystem.customProperties.sizeHeightInput, " - 2 * ", designSystem.customProperties.borderRadius1, ");background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQlkiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0VGV4dGFyZWFTdHlsZXMgPSAocHJvcHMpID0+IHtcbiAgY29uc3QgYmFzZVN0eWxlcyA9IFtcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgYCxcbiAgICBwcm9wcy5pc0NvbGxhcHNlZCAmJlxuICAgICAgY3NzYFxuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgYCxcbiAgXTtcbiAgcmV0dXJuIGJhc2VTdHlsZXM7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzLCB0aGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKCR7dmFycy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7dmFycy5ib3JkZXJSYWRpdXMxfSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */");
97
98
  };
98
99
 
99
- var ToggleButtonWrapper = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
100
+ var ToggleButtonWrapper = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
100
101
  target: "ed3jgad0"
101
102
  } : {
102
103
  target: "ed3jgad0",
@@ -107,12 +108,17 @@ var ToggleButtonWrapper = _styled__default['default']("div", process.env.NODE_EN
107
108
  } : {
108
109
  name: "ejz79s",
109
110
  styles: "flex:0;display:flex",
110
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
111
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RHNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7XG4gIGN1c3RvbVByb3BlcnRpZXMgYXMgdmFycyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuLy8gTk9URTogb3JkZXIgaXMgaW1wb3J0YW50IGhlcmVcbi8vICogYSBkaXNhYmxlZC1maWVsZCBjdXJyZW50bHkgZG9lcyBub3QgZGlzcGxheSB3YXJuaW5nL2Vycm9yLXN0YXRlcyBzbyBpdCB0YWtlcyBwcmVjZWRlbmNlXG4vLyAqIGEgcmVhZG9ubHktZmllbGQgY2Fubm90IGJlIGNoYW5nZWQsIGJ1dCBpdCBtaWdodCBiZSByZWxldmFudCBmb3IgdmFsaWRhdGlvbiwgc28gZXJyb3IgYW5kIHdhcm5pbmcgYXJlIGNoZWNrZWQgZmlyc3Rcbi8vIGhvdyB5b3UgY2FuIGludGVyYWN0IHdpdGggdGhlIGZpZWxkIGlzIGNvbnRyb2xsZWQgc2VwYXJhdGVseSBieSB0aGUgcHJvcHMsIHRoaXMgb25seSBpbmZsdWVuY2VzIHZpc3VhbHNcbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wcywgdGhlbWUpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLnZhcnMsXG4gICAgLi4udGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIGZsZXg6IDEgMCBhdXRvO1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYygke3ZhcnMuc2l6ZUhlaWdodElucHV0fSAtIDIgKiAke3ZhcnMuYm9yZGVyUmFkaXVzMX0pO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHt2YXJzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgZ2V0VGV4dGFyZWFTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
112
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
111
113
  });
112
114
 
115
+ function ownKeys$2(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; }
116
+
117
+ function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default["default"](_context = ownKeys$2(Object(source), true)).call(_context, 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 _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
118
+
113
119
  function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { 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)."; }
114
120
 
115
- var LeftColumn = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
121
+ var LeftColumn = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
116
122
  target: "ecub1e22"
117
123
  } : {
118
124
  target: "ecub1e22",
@@ -123,10 +129,11 @@ var LeftColumn = _styled__default['default']("div", process.env.NODE_ENV === "pr
123
129
  } : {
124
130
  name: "82a6rk",
125
131
  styles: "flex:1",
132
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AAqB6B","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
126
133
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
127
134
  });
128
135
 
129
- var RightColumn = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
136
+ var RightColumn = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
130
137
  target: "ecub1e21"
131
138
  } : {
132
139
  target: "ecub1e21",
@@ -137,10 +144,11 @@ var RightColumn = _styled__default['default']("div", process.env.NODE_ENV === "p
137
144
  } : {
138
145
  name: "1m04uhl",
139
146
  styles: "position:relative;flex:0;display:flex;align-items:flex-start",
147
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AAyB8B","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
140
148
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
141
149
  });
142
150
 
143
- var Row = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
151
+ var Row = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
144
152
  target: "ecub1e20"
145
153
  } : {
146
154
  target: "ecub1e20",
@@ -151,6 +159,7 @@ var Row = _styled__default['default']("div", process.env.NODE_ENV === "productio
151
159
  } : {
152
160
  name: "skgbeu",
153
161
  styles: "display:flex;justify-content:flex-end",
162
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AAgCsB","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
154
163
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
155
164
  });
156
165
 
@@ -160,20 +169,21 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
160
169
  } : {
161
170
  name: "1r0st9p-TranslationInput",
162
171
  styles: "width:100%;position:relative;display:flex;label:TranslationInput;",
172
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AAuGgB","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
163
173
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
164
174
  };
165
175
 
166
176
  var TranslationInput = function TranslationInput(props) {
167
- var _React$useState = React__default['default'].useState(TranslationInput.MIN_ROW_COUNT),
168
- _React$useState2 = _slicedToArray(_React$useState, 2),
169
- contentRowCount = _React$useState2[0],
170
- setContentRowCount = _React$useState2[1];
177
+ var _useState = react$1.useState(TranslationInput.MIN_ROW_COUNT),
178
+ _useState2 = _slicedToArray(_useState, 2),
179
+ contentRowCount = _useState2[0],
180
+ setContentRowCount = _useState2[1];
171
181
 
172
- var handleHeightChange = React__default['default'].useCallback(function (_, rowCount) {
182
+ var handleHeightChange = react$1.useCallback(function (_, rowCount) {
173
183
  setContentRowCount(rowCount);
174
184
  }, [setContentRowCount]);
175
185
  var onChange = props.onChange;
176
- var handleChange = React__default['default'].useCallback(function (event) {
186
+ var handleChange = react$1.useCallback(function (event) {
177
187
  // We manipulate the event to add the language to the target.
178
188
  // That way the users of LocalizedTextInput's onChange can read
179
189
  // event.target.language and event.target.value to determine the next value.
@@ -191,7 +201,7 @@ var TranslationInput = function TranslationInput(props) {
191
201
  }, [onChange, props.language]);
192
202
  var onFocus = props.onFocus,
193
203
  onToggle = props.onToggle;
194
- var handleFocus = React__default['default'].useCallback(function () {
204
+ var handleFocus = react$1.useCallback(function () {
195
205
  // Expand the input on focus
196
206
  if (props.isCollapsed) onToggle();
197
207
  if (onFocus) onFocus();
@@ -210,116 +220,141 @@ var TranslationInput = function TranslationInput(props) {
210
220
  */
211
221
  !props.isCollapsed && contentExceedsShownRows && !props.hasLanguagesControl || props.error || props.warning;
212
222
  var theme = react.useTheme();
213
- return react.jsx(Stack__default['default'], {
214
- scale: "xs"
215
- }, react.jsx("div", {
216
- key: props.language,
217
- css: _ref$1
218
- }, react.jsx("label", {
219
- htmlFor: props.id,
220
- css: getLanguageLabelStyles(props, theme)
221
- }, react.jsx(Text__default['default'].Detail, {
222
- tone: "secondary"
223
- }, props.language.toUpperCase())), react.jsx(inputUtils.MultilineInput, _extends({
224
- theme: theme,
225
- id: props.id,
226
- name: props.name,
227
- autoComplete: props.autoComplete,
228
- value: props.value,
229
- onChange: handleChange,
230
- onHeightChange: handleHeightChange,
231
- onBlur: props.onBlur,
232
- onFocus: handleFocus,
233
- isDisabled: props.isDisabled,
234
- placeholder: props.placeholder,
235
- css: getTextareaStyles(props),
236
- hasError: props.hasError,
237
- hasWarning: props.hasWarning,
238
- isReadOnly: props.isReadOnly,
239
- isAutofocussed: props.isAutofocussed,
240
- isOpen: !props.isCollapsed
241
- }, utils.filterDataAttributes(props)))), react.jsx(Row // NOTE: applying this style withing the `styled` component results in the production
242
- // bundle to apply the style in the wrong order.
243
- // For instance, we need to override the marging of the spacing component, which also
244
- // uses `!important`.
245
- // Anyway, apparently by passing the style as a `css` prop to the `styled` component
246
- // does the trick.
247
- // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
248
- , {
249
- css: /*#__PURE__*/react.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"))
250
- }, function () {
251
- if (props.error) return react.jsx(LeftColumn, null, react.jsx("div", null, props.error));
252
- if (props.warning) return react.jsx(LeftColumn, null, react.jsx("div", null, props.warning));
253
- return null;
254
- }(), !props.isCollapsed && contentExceedsShownRows && react.jsx(React__default['default'].Fragment, null, react.jsx(LeftColumn, null), react.jsx(RightColumn, null, react.jsx(ToggleButtonWrapper, {
255
- css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-top:", designSystem.customProperties.spacingXs, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;")), process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"]
256
- }, react.jsx(FlatButton__default['default'], {
257
- onClick: props.onToggle,
258
- isDisabled: props.isDisabled,
259
- label: props.intl.formatMessage(inputUtils.messagesMultilineInput.collapse),
260
- icon: react.jsx(icons.AngleUpIcon, {
261
- size: "small"
262
- })
263
- }))))));
223
+ return jsxRuntime.jsxs(Stack__default["default"], {
224
+ scale: "xs",
225
+ children: [jsxRuntime.jsxs("div", {
226
+ css: _ref$1,
227
+ children: [jsxRuntime.jsx("label", {
228
+ htmlFor: props.id,
229
+ css: getLanguageLabelStyles(props, theme),
230
+ children: jsxRuntime.jsx(Text__default["default"].Detail, {
231
+ tone: "secondary",
232
+ children: props.language.toUpperCase()
233
+ })
234
+ }), jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread$2({
235
+ theme: theme,
236
+ id: props.id,
237
+ name: props.name,
238
+ autoComplete: props.autoComplete,
239
+ value: props.value,
240
+ onChange: handleChange,
241
+ onHeightChange: handleHeightChange,
242
+ onBlur: props.onBlur,
243
+ onFocus: handleFocus,
244
+ isDisabled: props.isDisabled,
245
+ placeholder: props.placeholder,
246
+ css: getTextareaStyles(props),
247
+ hasError: props.hasError,
248
+ hasWarning: props.hasWarning,
249
+ isReadOnly: props.isReadOnly,
250
+ isAutofocussed: props.isAutofocussed,
251
+ isOpen: !props.isCollapsed
252
+ }, utils.filterDataAttributes(props)))]
253
+ }, props.language), jsxRuntime.jsxs(Row // NOTE: applying this style withing the `styled` component results in the production
254
+ // bundle to apply the style in the wrong order.
255
+ // For instance, we need to override the marging of the spacing component, which also
256
+ // uses `!important`.
257
+ // Anyway, apparently by passing the style as a `css` prop to the `styled` component
258
+ // does the trick.
259
+ // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
260
+ , {
261
+ css: /*#__PURE__*/react.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AAgJgB","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"),
262
+ children: [function () {
263
+ if (props.error) return jsxRuntime.jsx(LeftColumn, {
264
+ children: jsxRuntime.jsx("div", {
265
+ children: props.error
266
+ })
267
+ });
268
+ if (props.warning) return jsxRuntime.jsx(LeftColumn, {
269
+ children: jsxRuntime.jsx("div", {
270
+ children: props.warning
271
+ })
272
+ });
273
+ return null;
274
+ }(), !props.isCollapsed && contentExceedsShownRows && jsxRuntime.jsxs(jsxRuntime.Fragment, {
275
+ children: [jsxRuntime.jsx(LeftColumn, {}), jsxRuntime.jsx(RightColumn, {
276
+ children: jsxRuntime.jsx(ToggleButtonWrapper, {
277
+ css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-top:", designSystem.customProperties.spacingXs, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AA4KuB","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.js"],"names":[],"mappings":"AA0KgB","file":"translation-input.js","sourcesContent":["import { useState, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          theme={theme}\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${customProperties.spacingXs};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nTranslationInput.propTypes = {\n  id: PropTypes.string,\n  autoComplete: PropTypes.string,\n  name: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isCollapsed: PropTypes.bool,\n  onToggle: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  placeholder: PropTypes.string,\n  intl: PropTypes.shape({\n    formatMessage: PropTypes.func.isRequired,\n  }).isRequired,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  hasLanguagesControl: PropTypes.bool,\n};\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"],
278
+ children: jsxRuntime.jsx(FlatButton__default["default"], {
279
+ onClick: props.onToggle,
280
+ isDisabled: props.isDisabled,
281
+ label: props.intl.formatMessage(inputUtils.messagesMultilineInput.collapse),
282
+ icon: jsxRuntime.jsx(icons.AngleUpIcon, {
283
+ size: "small"
284
+ })
285
+ })
286
+ })
287
+ })]
288
+ })]
289
+ })]
290
+ });
264
291
  };
265
292
 
266
293
  TranslationInput.displayName = 'TranslationInput';
267
294
  TranslationInput.propTypes = process.env.NODE_ENV !== "production" ? {
268
- id: PropTypes__default['default'].string,
269
- autoComplete: PropTypes__default['default'].string,
270
- name: PropTypes__default['default'].string,
271
- value: PropTypes__default['default'].string.isRequired,
272
- onChange: requiredIf__default['default'](PropTypes__default['default'].func, function (props) {
295
+ id: PropTypes__default["default"].string,
296
+ autoComplete: PropTypes__default["default"].string,
297
+ name: PropTypes__default["default"].string,
298
+ value: PropTypes__default["default"].string.isRequired,
299
+ onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
273
300
  return !props.isReadOnly;
274
301
  }),
275
- language: PropTypes__default['default'].string.isRequired,
276
- onBlur: PropTypes__default['default'].func,
277
- onFocus: PropTypes__default['default'].func,
278
- isCollapsed: PropTypes__default['default'].bool,
279
- onToggle: PropTypes__default['default'].func,
280
- isAutofocussed: PropTypes__default['default'].bool,
281
- isDisabled: PropTypes__default['default'].bool,
282
- isReadOnly: PropTypes__default['default'].bool,
283
- hasError: PropTypes__default['default'].bool,
284
- hasWarning: PropTypes__default['default'].bool,
285
- placeholder: PropTypes__default['default'].string,
286
- intl: PropTypes__default['default'].shape({
287
- formatMessage: PropTypes__default['default'].func.isRequired
302
+ language: PropTypes__default["default"].string.isRequired,
303
+ onBlur: PropTypes__default["default"].func,
304
+ onFocus: PropTypes__default["default"].func,
305
+ isCollapsed: PropTypes__default["default"].bool,
306
+ onToggle: PropTypes__default["default"].func,
307
+ isAutofocussed: PropTypes__default["default"].bool,
308
+ isDisabled: PropTypes__default["default"].bool,
309
+ isReadOnly: PropTypes__default["default"].bool,
310
+ hasError: PropTypes__default["default"].bool,
311
+ hasWarning: PropTypes__default["default"].bool,
312
+ placeholder: PropTypes__default["default"].string,
313
+ intl: PropTypes__default["default"].shape({
314
+ formatMessage: PropTypes__default["default"].func.isRequired
288
315
  }).isRequired,
289
- error: PropTypes__default['default'].node,
290
- warning: PropTypes__default['default'].node,
291
- hasLanguagesControl: PropTypes__default['default'].bool
316
+ error: PropTypes__default["default"].node,
317
+ warning: PropTypes__default["default"].node,
318
+ hasLanguagesControl: PropTypes__default["default"].bool
292
319
  } : {}; // The minimum ammount of rows the MultilineTextInput will show.
293
320
  // When the input is closed, this is used as the maximum row count as well
294
321
  // so that the input "collapses".
295
322
 
296
323
  TranslationInput.MIN_ROW_COUNT = 1;
324
+ var TranslationInput$1 = TranslationInput;
325
+
326
+ function ownKeys$1(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; }
327
+
328
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), true)).call(_context, 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 _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
297
329
 
298
330
  var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
299
- return react.jsx(messages.ErrorMessage, null, react.jsx(reactIntl.FormattedMessage, inputUtils.messagesLocalizedInput.missingRequiredField));
331
+ return jsxRuntime.jsx(messages.ErrorMessage, {
332
+ children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$1({}, inputUtils.messagesLocalizedInput.missingRequiredField))
333
+ });
300
334
  };
301
335
 
302
336
  RequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';
337
+ var RequiredValueErrorMessage$1 = RequiredValueErrorMessage;
303
338
 
304
339
  var _templateObject;
305
340
 
306
- function ownKeys$1(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; }
341
+ 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; }
307
342
 
308
- function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context4; _forEachInstanceProperty__default['default'](_context4 = ownKeys$1(Object(source), true)).call(_context4, 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 _context5; _forEachInstanceProperty__default['default'](_context5 = ownKeys$1(Object(source))).call(_context5, function (key) { _Object$defineProperty__default['default'](target, key, _Object$getOwnPropertyDescriptor__default['default'](source, key)); }); } } return target; }
343
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context4; _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source), true)).call(_context4, 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 _context5; _forEachInstanceProperty__default["default"](_context5 = ownKeys(Object(source))).call(_context5, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
309
344
 
310
- function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { 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)."; }
345
+ 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)."; }
311
346
 
312
347
  var expandedTranslationsReducer = function expandedTranslationsReducer(state, action) {
313
348
  switch (action.type) {
314
349
  case 'toggle':
315
- return _objectSpread$1(_objectSpread$1({}, state), {}, _defineProperty({}, action.payload, !state[action.payload]));
350
+ return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, action.payload, !state[action.payload]));
316
351
 
317
352
  case 'toggleAll':
318
353
  {
319
354
  var _context;
320
355
 
321
- var newState = _reduceInstanceProperty__default['default'](_context = _Object$keys__default['default'](state)).call(_context, function (translations, locale) {
322
- return _objectSpread$1(_defineProperty({}, locale, true), translations);
356
+ var newState = _reduceInstanceProperty__default["default"](_context = _Object$keys__default["default"](state)).call(_context, function (translations, locale) {
357
+ return _objectSpread(_defineProperty({}, locale, true), translations);
323
358
  }, {});
324
359
 
325
360
  return newState;
@@ -336,13 +371,14 @@ var expandedTranslationsReducer = function expandedTranslationsReducer(state, ac
336
371
  // languages.
337
372
 
338
373
 
339
- var _ref$2 = process.env.NODE_ENV === "production" ? {
374
+ var _ref = process.env.NODE_ENV === "production" ? {
340
375
  name: "xyzkeb",
341
376
  styles: "align-self:flex-start"
342
377
  } : {
343
378
  name: "1nns3eb-LocalizedMultilineTextInput",
344
379
  styles: "align-self:flex-start;label:LocalizedMultilineTextInput;",
345
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
380
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-multiline-text-input.js"],"names":[],"mappings":"AAgKoB","file":"localized-multiline-text-input.js","sourcesContent":["import { useReducer, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { oneLine } from 'common-tags';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport TranslationInput from './translation-input';\nimport RequiredValueErrorMessage from './required-value-error-message';\n\nconst expandedTranslationsReducer = (state, action) => {\n  switch (action.type) {\n    case 'toggle':\n      return {\n        ...state,\n        [action.payload]: !state[action.payload],\n      };\n\n    case 'toggleAll': {\n      const newState = Object.keys(state).reduce((translations, locale) => {\n        return {\n          [locale]: true,\n          ...translations,\n        };\n      }, {});\n      return newState;\n    }\n    default:\n      return state;\n  }\n};\n\n// This component supports expanding/collapsing multiline inputs, but it also\n// supports showing/hiding the remaining languages.\n// These two features are both about opening/closing something, and so the code\n// can get quite confusing. We try to stick to expand/collapse for the\n// multiline inputs, while we use show/hide/open/close for the remaining\n// languages.\nconst LocalizedMultilineTextInput = (props) => {\n  const intl = useIntl();\n\n  const initialExpandedTranslationsState = Object.keys(props.value).reduce(\n    (translations, locale) => {\n      return {\n        [locale]: Boolean(props.defaultExpandMultilineText),\n        ...translations,\n      };\n    },\n    {}\n  );\n\n  const [expandedTranslationsState, expandedTranslationsDispatch] = useReducer(\n    expandedTranslationsReducer,\n    initialExpandedTranslationsState\n  );\n\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages ||\n    // useToggleState's default is `true`, but we want `false`\n    false;\n\n  const [areLanguagesOpened, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const toggleLanguage = useCallback(\n    (language) => {\n      expandedTranslationsDispatch({ type: 'toggle', payload: language });\n    },\n    [expandedTranslationsDispatch]\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n  const hasWarningInRemainingLanguages =\n    props.hasWarning ||\n    getHasWarningOnRemainingLanguages(props.warnings, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages || hasWarningInRemainingLanguages) {\n    if (!areLanguagesOpened) {\n      // this update within render replaces the old `getDerivedStateFromProps` functionality\n      // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack scale=\"s\">\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesOpened) return null;\n            const isLastLanguage = index === languages.length - 1;\n\n            const hasLanguagesControl =\n              (isFirstLanguage && !areLanguagesOpened) || isLastLanguage;\n\n            return (\n              <TranslationInput\n                key={language}\n                autoComplete={props.autoComplete}\n                id={LocalizedMultilineTextInput.getId(props.id, language)}\n                name={LocalizedMultilineTextInput.getName(props.name, language)}\n                value={props.value[language]}\n                onChange={props.onChange}\n                language={language}\n                isCollapsed={!expandedTranslationsState[language]}\n                onToggle={() => toggleLanguage(language)}\n                placeholder={\n                  props.placeholder ? props.placeholder[language] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isAutofocussed={index === 0 && props.isAutofocussed}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[language])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[language])\n                )}\n                intl={intl}\n                warning={props.warnings && props.warnings[language]}\n                error={props.errors && props.errors[language]}\n                hasLanguagesControl={hasLanguagesControl}\n                {...createLocalizedDataAttributes(props, language)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <div\n            css={css`\n              align-self: flex-start;\n            `}\n          >\n            <LocalizedInputToggle\n              isOpen={areLanguagesOpened}\n              onClick={toggleLanguages}\n              isDisabled={\n                areLanguagesOpened &&\n                Boolean(\n                  hasErrorInRemainingLanguages || hasWarningInRemainingLanguages\n                )\n              }\n              remainingLocalizations={languages.length - 1}\n            />\n          </div>\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedMultilineTextInput.displayName = 'LocalizedMultilineTextInput';\n\nLocalizedMultilineTextInput.RequiredValueErrorMessage =\n  RequiredValueErrorMessage;\n\nLocalizedMultilineTextInput.propTypes = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  /**\n   * Values to use. Keyed by language, the values are the actual values, e.g. `{ en: 'Horse', de: 'Pferd' }`\n   * <br />\n   * The input doesn't accept a \"languages\" prop, instead all possible\n   * languages have to exist (with empty or filled strings) on the value:\n   * <br />   { en: 'foo', de: '', es: '' }\n   */\n  value: PropTypes.objectOf(PropTypes.string).isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   * <br />\n   * Signature: `(event) => void`\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: PropTypes.string.isRequired,\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   * Expands input components holding multiline values instead of collpasing them by default.\n   */\n  defaultExpandMultilineText: PropTypes.bool,\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls: PropTypes.bool,\n  /**\n   * Controls whether one or all languages are visible by default. Pass `true` to show all languages by default.\n   */\n  defaultExpandLanguages: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideLanguageExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideLanguageExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  /**\n   * Sets the focus on the first input when `true` is passed.\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Disables all input fields.\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\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   * Will apply the error state to each input without showing any error message.\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Will apply the warning state to each input without showing any error message.\n   */\n  hasWarning: PropTypes.bool,\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors: PropTypes.objectOf(PropTypes.node),\n  /**\n   * Used to show warnings underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the warning to show for that key.\n   */\n  warnings: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedMultilineTextInput.getId = getId;\n\nLocalizedMultilineTextInput.getName = getName;\n\nLocalizedMultilineTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedMultilineTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedMultilineTextInput.isEmpty = isEmpty;\n\nLocalizedMultilineTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedMultilineTextInput.isTouched = isTouched;\n\nexport default LocalizedMultilineTextInput;\n"]} */",
381
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
346
382
  };
347
383
 
348
384
  var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
@@ -350,14 +386,14 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
350
386
 
351
387
  var intl = reactIntl.useIntl();
352
388
 
353
- var initialExpandedTranslationsState = _reduceInstanceProperty__default['default'](_context2 = _Object$keys__default['default'](props.value)).call(_context2, function (translations, locale) {
354
- return _objectSpread$1(_defineProperty({}, locale, Boolean(props.defaultExpandMultilineText)), translations);
389
+ var initialExpandedTranslationsState = _reduceInstanceProperty__default["default"](_context2 = _Object$keys__default["default"](props.value)).call(_context2, function (translations, locale) {
390
+ return _objectSpread(_defineProperty({}, locale, Boolean(props.defaultExpandMultilineText)), translations);
355
391
  }, {});
356
392
 
357
- var _React$useReducer = React__default['default'].useReducer(expandedTranslationsReducer, initialExpandedTranslationsState),
358
- _React$useReducer2 = _slicedToArray(_React$useReducer, 2),
359
- expandedTranslationsState = _React$useReducer2[0],
360
- expandedTranslationsDispatch = _React$useReducer2[1];
393
+ var _useReducer = react$1.useReducer(expandedTranslationsReducer, initialExpandedTranslationsState),
394
+ _useReducer2 = _slicedToArray(_useReducer, 2),
395
+ expandedTranslationsState = _useReducer2[0],
396
+ expandedTranslationsDispatch = _useReducer2[1];
361
397
 
362
398
  var defaultExpansionState = props.hideLanguageExpansionControls || props.defaultExpandLanguages || // useToggleState's default is `true`, but we want `false`
363
399
  false;
@@ -367,13 +403,13 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
367
403
  areLanguagesOpened = _useToggleState2[0],
368
404
  toggleLanguages = _useToggleState2[1];
369
405
 
370
- var toggleLanguage = React__default['default'].useCallback(function (language) {
406
+ var toggleLanguage = react$1.useCallback(function (language) {
371
407
  expandedTranslationsDispatch({
372
408
  type: 'toggle',
373
409
  payload: language
374
410
  });
375
411
  }, [expandedTranslationsDispatch]);
376
- var languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default['default'](props.value));
412
+ var languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default["default"](props.value));
377
413
  var hasErrorInRemainingLanguages = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
378
414
  var hasWarningInRemainingLanguages = props.hasWarning || localizedUtils.getHasWarningOnRemainingLanguages(props.warnings, props.selectedLanguage);
379
415
 
@@ -386,69 +422,72 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
386
422
  }
387
423
 
388
424
  var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
389
- return react.jsx(Constraints__default['default'].Horizontal, {
390
- max: props.horizontalConstraint
391
- }, react.jsx(Stack__default['default'], {
392
- scale: "xs"
393
- }, react.jsx(Stack__default['default'], {
394
- scale: "s"
395
- }, _mapInstanceProperty__default['default'](languages).call(languages, function (language, index) {
396
- var isFirstLanguage = index === 0;
397
- if (!isFirstLanguage && !areLanguagesOpened) return null;
398
- var isLastLanguage = index === languages.length - 1;
399
- var hasLanguagesControl = isFirstLanguage && !areLanguagesOpened || isLastLanguage;
400
- return react.jsx(TranslationInput, _extends({
401
- key: language,
402
- autoComplete: props.autoComplete,
403
- id: LocalizedMultilineTextInput.getId(props.id, language),
404
- name: LocalizedMultilineTextInput.getName(props.name, language),
405
- value: props.value[language],
406
- onChange: props.onChange,
407
- language: language,
408
- isCollapsed: !expandedTranslationsState[language],
409
- onToggle: function onToggle() {
410
- return toggleLanguage(language);
411
- },
412
- placeholder: props.placeholder ? props.placeholder[language] : undefined,
413
- onBlur: props.onBlur,
414
- onFocus: props.onFocus,
415
- isAutofocussed: index === 0 && props.isAutofocussed,
416
- isDisabled: props.isDisabled,
417
- isReadOnly: props.isReadOnly,
418
- hasError: Boolean(props.hasError || props.errors && props.errors[language]),
419
- hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[language]),
420
- intl: intl,
421
- warning: props.warnings && props.warnings[language],
422
- error: props.errors && props.errors[language],
423
- hasLanguagesControl: hasLanguagesControl
424
- }, localizedUtils.createLocalizedDataAttributes(props, language)));
425
- })), shouldRenderLanguagesButton && react.jsx("div", {
426
- css: _ref$2
427
- }, react.jsx(inputUtils.LocalizedInputToggle, {
428
- isOpen: areLanguagesOpened,
429
- onClick: toggleLanguages,
430
- isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
431
- remainingLocalizations: languages.length - 1
432
- }))));
425
+ return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
426
+ max: props.horizontalConstraint,
427
+ children: jsxRuntime.jsxs(Stack__default["default"], {
428
+ scale: "xs",
429
+ children: [jsxRuntime.jsx(Stack__default["default"], {
430
+ scale: "s",
431
+ children: _mapInstanceProperty__default["default"](languages).call(languages, function (language, index) {
432
+ var isFirstLanguage = index === 0;
433
+ if (!isFirstLanguage && !areLanguagesOpened) return null;
434
+ var isLastLanguage = index === languages.length - 1;
435
+ var hasLanguagesControl = isFirstLanguage && !areLanguagesOpened || isLastLanguage;
436
+ return jsxRuntime.jsx(TranslationInput$1, _objectSpread({
437
+ autoComplete: props.autoComplete,
438
+ id: LocalizedMultilineTextInput.getId(props.id, language),
439
+ name: LocalizedMultilineTextInput.getName(props.name, language),
440
+ value: props.value[language],
441
+ onChange: props.onChange,
442
+ language: language,
443
+ isCollapsed: !expandedTranslationsState[language],
444
+ onToggle: function onToggle() {
445
+ return toggleLanguage(language);
446
+ },
447
+ placeholder: props.placeholder ? props.placeholder[language] : undefined,
448
+ onBlur: props.onBlur,
449
+ onFocus: props.onFocus,
450
+ isAutofocussed: index === 0 && props.isAutofocussed,
451
+ isDisabled: props.isDisabled,
452
+ isReadOnly: props.isReadOnly,
453
+ hasError: Boolean(props.hasError || props.errors && props.errors[language]),
454
+ hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[language]),
455
+ intl: intl,
456
+ warning: props.warnings && props.warnings[language],
457
+ error: props.errors && props.errors[language],
458
+ hasLanguagesControl: hasLanguagesControl
459
+ }, localizedUtils.createLocalizedDataAttributes(props, language)), language);
460
+ })
461
+ }), shouldRenderLanguagesButton && jsxRuntime.jsx("div", {
462
+ css: _ref,
463
+ children: jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
464
+ isOpen: areLanguagesOpened,
465
+ onClick: toggleLanguages,
466
+ isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
467
+ remainingLocalizations: languages.length - 1
468
+ })
469
+ })]
470
+ })
471
+ });
433
472
  };
434
473
 
435
474
  LocalizedMultilineTextInput.displayName = 'LocalizedMultilineTextInput';
436
- LocalizedMultilineTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
475
+ LocalizedMultilineTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage$1;
437
476
  LocalizedMultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
438
477
  /**
439
478
  * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`
440
479
  */
441
- id: PropTypes__default['default'].string,
480
+ id: PropTypes__default["default"].string,
442
481
 
443
482
  /**
444
483
  * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`
445
484
  */
446
- name: PropTypes__default['default'].string,
485
+ name: PropTypes__default["default"].string,
447
486
 
448
487
  /**
449
488
  * Used as HTML `autocomplete` property
450
489
  */
451
- autoComplete: PropTypes__default['default'].string,
490
+ autoComplete: PropTypes__default["default"].string,
452
491
 
453
492
  /**
454
493
  * Values to use. Keyed by language, the values are the actual values, e.g. `{ en: 'Horse', de: 'Pferd' }`
@@ -457,41 +496,41 @@ LocalizedMultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ?
457
496
  * languages have to exist (with empty or filled strings) on the value:
458
497
  * <br /> { en: 'foo', de: '', es: '' }
459
498
  */
460
- value: PropTypes__default['default'].objectOf(PropTypes__default['default'].string).isRequired,
499
+ value: PropTypes__default["default"].objectOf(PropTypes__default["default"].string).isRequired,
461
500
 
462
501
  /**
463
502
  * Gets called when any input is changed. Is called with the change event of the changed input.
464
503
  * <br />
465
504
  * Signature: `(event) => void`
466
505
  */
467
- onChange: requiredIf__default['default'](PropTypes__default['default'].func, function (props) {
506
+ onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
468
507
  return !props.isReadOnly;
469
508
  }),
470
509
 
471
510
  /**
472
511
  * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.
473
512
  */
474
- selectedLanguage: PropTypes__default['default'].string.isRequired,
513
+ selectedLanguage: PropTypes__default["default"].string.isRequired,
475
514
 
476
515
  /**
477
516
  * Called when input is blurred
478
517
  */
479
- onBlur: PropTypes__default['default'].func,
518
+ onBlur: PropTypes__default["default"].func,
480
519
 
481
520
  /**
482
521
  * Called when input is focused
483
522
  */
484
- onFocus: PropTypes__default['default'].func,
523
+ onFocus: PropTypes__default["default"].func,
485
524
 
486
525
  /**
487
526
  * Expands input components holding multiline values instead of collpasing them by default.
488
527
  */
489
- defaultExpandMultilineText: PropTypes__default['default'].bool,
528
+ defaultExpandMultilineText: PropTypes__default["default"].bool,
490
529
 
491
530
  /**
492
531
  * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.
493
532
  */
494
- hideLanguageExpansionControls: PropTypes__default['default'].bool,
533
+ hideLanguageExpansionControls: PropTypes__default["default"].bool,
495
534
 
496
535
  /**
497
536
  * Controls whether one or all languages are visible by default. Pass `true` to show all languages by default.
@@ -507,53 +546,53 @@ LocalizedMultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ?
507
546
  rest[_key - 3] = arguments[_key];
508
547
  }
509
548
 
510
- return PropTypes__default['default'].bool.apply(PropTypes__default['default'], _concatInstanceProperty__default['default'](_context3 = [props, propName, componentName]).call(_context3, rest));
549
+ return PropTypes__default["default"].bool.apply(PropTypes__default["default"], _concatInstanceProperty__default["default"](_context3 = [props, propName, componentName]).call(_context3, rest));
511
550
  },
512
551
 
513
552
  /**
514
553
  * Sets the focus on the first input when `true` is passed.
515
554
  */
516
- isAutofocussed: PropTypes__default['default'].bool,
555
+ isAutofocussed: PropTypes__default["default"].bool,
517
556
 
518
557
  /**
519
558
  * Disables all input fields.
520
559
  */
521
- isDisabled: PropTypes__default['default'].bool,
560
+ isDisabled: PropTypes__default["default"].bool,
522
561
 
523
562
  /**
524
563
  * Disables all input fields and shows them in read-only mode.
525
564
  */
526
- isReadOnly: PropTypes__default['default'].bool,
565
+ isReadOnly: PropTypes__default["default"].bool,
527
566
 
528
567
  /**
529
568
  * Placeholders for each language. Object of the same shape as `value`.
530
569
  */
531
- placeholder: PropTypes__default['default'].objectOf(PropTypes__default['default'].string),
570
+ placeholder: PropTypes__default["default"].objectOf(PropTypes__default["default"].string),
532
571
 
533
572
  /**
534
573
  * Horizontal size limit of the input fields.
535
574
  */
536
- horizontalConstraint: PropTypes__default['default'].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
575
+ horizontalConstraint: PropTypes__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
537
576
 
538
577
  /**
539
578
  * Will apply the error state to each input without showing any error message.
540
579
  */
541
- hasError: PropTypes__default['default'].bool,
580
+ hasError: PropTypes__default["default"].bool,
542
581
 
543
582
  /**
544
583
  * Will apply the warning state to each input without showing any error message.
545
584
  */
546
- hasWarning: PropTypes__default['default'].bool,
585
+ hasWarning: PropTypes__default["default"].bool,
547
586
 
548
587
  /**
549
588
  * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.
550
589
  */
551
- errors: PropTypes__default['default'].objectOf(PropTypes__default['default'].node),
590
+ errors: PropTypes__default["default"].objectOf(PropTypes__default["default"].node),
552
591
 
553
592
  /**
554
593
  * Used to show warnings underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the warning to show for that key.
555
594
  */
556
- warnings: PropTypes__default['default'].objectOf(PropTypes__default['default'].node)
595
+ warnings: PropTypes__default["default"].objectOf(PropTypes__default["default"].node)
557
596
  } : {};
558
597
  LocalizedMultilineTextInput.getId = localizedUtils.getId;
559
598
  LocalizedMultilineTextInput.getName = localizedUtils.getName;
@@ -564,9 +603,10 @@ LocalizedMultilineTextInput.createLocalizedString = localizedUtils.createLocaliz
564
603
  LocalizedMultilineTextInput.isEmpty = localizedUtils.isEmpty;
565
604
  LocalizedMultilineTextInput.omitEmptyTranslations = localizedUtils.omitEmptyTranslations;
566
605
  LocalizedMultilineTextInput.isTouched = localizedUtils.isTouched;
606
+ var LocalizedMultilineTextInput$1 = LocalizedMultilineTextInput;
567
607
 
568
- // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
569
- var version = '12.2.1';
608
+ // NOTE: This string will be replaced on build time with the package version.
609
+ var version = "12.2.5";
570
610
 
571
- exports.default = LocalizedMultilineTextInput;
611
+ exports["default"] = LocalizedMultilineTextInput$1;
572
612
  exports.version = version;