@commercetools-uikit/localized-multiline-text-input 13.0.2 → 13.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -9,17 +9,13 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
9
9
  var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
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
- var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
13
12
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
14
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
+ var _pt = require('prop-types');
15
15
  var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
16
16
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
17
17
  var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
18
- var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
19
18
  var react$1 = require('react');
20
- var PropTypes = require('prop-types');
21
- var requiredIf = require('react-required-if');
22
- var commonTags = require('common-tags');
23
19
  var reactIntl = require('react-intl');
24
20
  var react = require('@emotion/react');
25
21
  var hooks = require('@commercetools-uikit/hooks');
@@ -45,12 +41,10 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
45
41
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
46
42
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
47
43
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
44
+ var _pt__default = /*#__PURE__*/_interopDefault(_pt);
48
45
  var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
49
46
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
50
47
  var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
51
- var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
52
- var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
53
- var requiredIf__default = /*#__PURE__*/_interopDefault(requiredIf);
54
48
  var Stack__default = /*#__PURE__*/_interopDefault(Stack);
55
49
  var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
56
50
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
@@ -72,7 +66,7 @@ var _ref$2 = process.env.NODE_ENV === "production" ? {
72
66
  } : {
73
67
  name: "1h6gnzr-baseStyles",
74
68
  styles: "overflow:hidden;label:baseStyles;",
75
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0VGV4dGFyZWFTdHlsZXMgPSAocHJvcHMpID0+IHtcbiAgY29uc3QgYmFzZVN0eWxlcyA9IFtcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgYCxcbiAgICBwcm9wcy5pc0NvbGxhcHNlZCAmJlxuICAgICAgY3NzYFxuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgYCxcbiAgXTtcbiAgcmV0dXJuIGJhc2VTdHlsZXM7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzLCB0aGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKCR7dmFycy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7dmFycy5ib3JkZXJSYWRpdXMxfSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
69
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChcbiAgX3Byb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzLFxuICB0aGVtZTogVGhlbWVcbikgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKCR7dmFycy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7dmFycy5ib3JkZXJSYWRpdXMxfSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
76
70
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
77
71
  };
78
72
 
@@ -82,7 +76,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
82
76
  } : {
83
77
  name: "pb9fe4-baseStyles",
84
78
  styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;",
85
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhTyIsImZpbGUiOiJ0cmFuc2xhdGlvbi1pbnB1dC5zdHlsZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxTdHlsZXMgPSAocHJvcHMsIHRoZW1lKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi52YXJzLFxuICAgIC4uLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoJHt2YXJzLnNpemVIZWlnaHRJbnB1dH0gLSAyICogJHt2YXJzLmJvcmRlclJhZGl1czF9KTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
79
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQk8iLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChcbiAgX3Byb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzLFxuICB0aGVtZTogVGhlbWVcbikgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKCR7dmFycy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7dmFycy5ib3JkZXJSYWRpdXMxfSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
86
80
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
87
81
  };
88
82
 
@@ -91,16 +85,16 @@ var getTextareaStyles = function getTextareaStyles(props) {
91
85
  return baseStyles;
92
86
  };
93
87
 
94
- var getLanguageLabelStyles = function getLanguageLabelStyles(props, theme) {
88
+ var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
95
89
  var overwrittenVars = _objectSpread$3(_objectSpread$3({}, designSystem.customProperties), theme);
96
90
 
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 */");
91
+ 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q1kiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChcbiAgX3Byb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzLFxuICB0aGVtZTogVGhlbWVcbikgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKCR7dmFycy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7dmFycy5ib3JkZXJSYWRpdXMxfSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */");
98
92
  };
99
93
 
100
94
  var ToggleButtonWrapper = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
101
- target: "ed3jgad0"
95
+ target: "e1yehb270"
102
96
  } : {
103
- target: "ed3jgad0",
97
+ target: "e1yehb270",
104
98
  label: "ToggleButtonWrapper"
105
99
  })(process.env.NODE_ENV === "production" ? {
106
100
  name: "ejz79s",
@@ -108,7 +102,7 @@ var ToggleButtonWrapper = _styled__default["default"]("div", process.env.NODE_EN
108
102
  } : {
109
103
  name: "ejz79s",
110
104
  styles: "flex:0;display:flex",
111
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RHNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7XG4gIGN1c3RvbVByb3BlcnRpZXMgYXMgdmFycyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuLy8gTk9URTogb3JkZXIgaXMgaW1wb3J0YW50IGhlcmVcbi8vICogYSBkaXNhYmxlZC1maWVsZCBjdXJyZW50bHkgZG9lcyBub3QgZGlzcGxheSB3YXJuaW5nL2Vycm9yLXN0YXRlcyBzbyBpdCB0YWtlcyBwcmVjZWRlbmNlXG4vLyAqIGEgcmVhZG9ubHktZmllbGQgY2Fubm90IGJlIGNoYW5nZWQsIGJ1dCBpdCBtaWdodCBiZSByZWxldmFudCBmb3IgdmFsaWRhdGlvbiwgc28gZXJyb3IgYW5kIHdhcm5pbmcgYXJlIGNoZWNrZWQgZmlyc3Rcbi8vIGhvdyB5b3UgY2FuIGludGVyYWN0IHdpdGggdGhlIGZpZWxkIGlzIGNvbnRyb2xsZWQgc2VwYXJhdGVseSBieSB0aGUgcHJvcHMsIHRoaXMgb25seSBpbmZsdWVuY2VzIHZpc3VhbHNcbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wcywgdGhlbWUpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLnZhcnMsXG4gICAgLi4udGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIGZsZXg6IDEgMCBhdXRvO1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYygke3ZhcnMuc2l6ZUhlaWdodElucHV0fSAtIDIgKiAke3ZhcnMuYm9yZGVyUmFkaXVzMX0pO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHt2YXJzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgZ2V0VGV4dGFyZWFTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
105
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRXNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgdHlwZSBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7XG4gIGN1c3RvbVByb3BlcnRpZXMgYXMgdmFycyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuLy8gTk9URTogb3JkZXIgaXMgaW1wb3J0YW50IGhlcmVcbi8vICogYSBkaXNhYmxlZC1maWVsZCBjdXJyZW50bHkgZG9lcyBub3QgZGlzcGxheSB3YXJuaW5nL2Vycm9yLXN0YXRlcyBzbyBpdCB0YWtlcyBwcmVjZWRlbmNlXG4vLyAqIGEgcmVhZG9ubHktZmllbGQgY2Fubm90IGJlIGNoYW5nZWQsIGJ1dCBpdCBtaWdodCBiZSByZWxldmFudCBmb3IgdmFsaWRhdGlvbiwgc28gZXJyb3IgYW5kIHdhcm5pbmcgYXJlIGNoZWNrZWQgZmlyc3Rcbi8vIGhvdyB5b3UgY2FuIGludGVyYWN0IHdpdGggdGhlIGZpZWxkIGlzIGNvbnRyb2xsZWQgc2VwYXJhdGVseSBieSB0aGUgcHJvcHMsIHRoaXMgb25seSBpbmZsdWVuY2VzIHZpc3VhbHNcblxudHlwZSBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzID0ge1xuICBpc0NvbGxhcHNlZD86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxTdHlsZXMgPSAoXG4gIF9wcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyxcbiAgdGhlbWU6IFRoZW1lXG4pID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLnZhcnMsXG4gICAgLi4udGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIGZsZXg6IDEgMCBhdXRvO1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYygke3ZhcnMuc2l6ZUhlaWdodElucHV0fSAtIDIgKiAke3ZhcnMuYm9yZGVyUmFkaXVzMX0pO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHt2YXJzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgZ2V0VGV4dGFyZWFTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
112
106
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
113
107
  });
114
108
 
@@ -119,9 +113,9 @@ function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) {
119
113
  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)."; }
120
114
 
121
115
  var LeftColumn = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
122
- target: "ecub1e22"
116
+ target: "eepo5hu2"
123
117
  } : {
124
- target: "ecub1e22",
118
+ target: "eepo5hu2",
125
119
  label: "LeftColumn"
126
120
  })(process.env.NODE_ENV === "production" ? {
127
121
  name: "82a6rk",
@@ -129,14 +123,14 @@ var LeftColumn = _styled__default["default"]("div", process.env.NODE_ENV === "pr
129
123
  } : {
130
124
  name: "82a6rk",
131
125
  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
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA6D6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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"]} */",
133
127
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
134
128
  });
135
129
 
136
130
  var RightColumn = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
137
- target: "ecub1e21"
131
+ target: "eepo5hu1"
138
132
  } : {
139
- target: "ecub1e21",
133
+ target: "eepo5hu1",
140
134
  label: "RightColumn"
141
135
  })(process.env.NODE_ENV === "production" ? {
142
136
  name: "1m04uhl",
@@ -144,14 +138,14 @@ var RightColumn = _styled__default["default"]("div", process.env.NODE_ENV === "p
144
138
  } : {
145
139
  name: "1m04uhl",
146
140
  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"]} */",
141
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAiE8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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"]} */",
148
142
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
149
143
  });
150
144
 
151
145
  var Row = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
152
- target: "ecub1e20"
146
+ target: "eepo5hu0"
153
147
  } : {
154
- target: "ecub1e20",
148
+ target: "eepo5hu0",
155
149
  label: "Row"
156
150
  })(process.env.NODE_ENV === "production" ? {
157
151
  name: "skgbeu",
@@ -159,7 +153,7 @@ var Row = _styled__default["default"]("div", process.env.NODE_ENV === "productio
159
153
  } : {
160
154
  name: "skgbeu",
161
155
  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"]} */",
156
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAwEsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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
157
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
164
158
  });
165
159
 
@@ -169,7 +163,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
169
163
  } : {
170
164
  name: "1r0st9p-TranslationInput",
171
165
  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"]} */",
166
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAuJgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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"]} */",
173
167
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
174
168
  };
175
169
 
@@ -197,13 +191,13 @@ var TranslationInput = function TranslationInput(props) {
197
191
  //
198
192
  // eslint-disable-next-line no-param-reassign
199
193
  event.target.language = props.language;
200
- onChange(event);
194
+ onChange === null || onChange === void 0 ? void 0 : onChange(event);
201
195
  }, [onChange, props.language]);
202
196
  var onFocus = props.onFocus,
203
197
  onToggle = props.onToggle;
204
198
  var handleFocus = react$1.useCallback(function () {
205
199
  // Expand the input on focus
206
- if (props.isCollapsed) onToggle();
200
+ if (props.isCollapsed) onToggle === null || onToggle === void 0 ? void 0 : onToggle();
207
201
  if (onFocus) onFocus();
208
202
  }, [props.isCollapsed, onFocus, onToggle]); // This checks if the content in the textarea overflows the minimum
209
203
  // amount of lines it should have when collapsed
@@ -220,6 +214,11 @@ var TranslationInput = function TranslationInput(props) {
220
214
  */
221
215
  !props.isCollapsed && contentExceedsShownRows && !props.hasLanguagesControl || props.error || props.warning;
222
216
  var theme = react.useTheme();
217
+
218
+ if (!props.isReadOnly) {
219
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocaliszedMultilineTextInput: "onChange" is required when isReadOnly is not true') : void 0;
220
+ }
221
+
223
222
  return jsxRuntime.jsxs(Stack__default["default"], {
224
223
  scale: "xs",
225
224
  children: [jsxRuntime.jsxs("div", {
@@ -232,7 +231,6 @@ var TranslationInput = function TranslationInput(props) {
232
231
  children: props.language.toUpperCase()
233
232
  })
234
233
  }), jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread$2({
235
- theme: theme,
236
234
  id: props.id,
237
235
  name: props.name,
238
236
  autoComplete: props.autoComplete,
@@ -258,7 +256,7 @@ var TranslationInput = function TranslationInput(props) {
258
256
  // does the trick.
259
257
  // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
260
258
  , {
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"]} */"),
259
+ 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.tsx"],"names":[],"mappings":"AA+LgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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
260
  children: [function () {
263
261
  if (props.error) return jsxRuntime.jsx(LeftColumn, {
264
262
  children: jsxRuntime.jsx("div", {
@@ -274,7 +272,7 @@ var TranslationInput = function TranslationInput(props) {
274
272
  }(), !props.isCollapsed && contentExceedsShownRows && jsxRuntime.jsxs(jsxRuntime.Fragment, {
275
273
  children: [jsxRuntime.jsx(LeftColumn, {}), jsxRuntime.jsx(RightColumn, {
276
274
  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"]} */"],
275
+ 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.tsx"],"names":[],"mappings":"AA2NuB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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.tsx"],"names":[],"mappings":"AAyNgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type ReactNode,\n} from 'react';\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, warning } 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\ntype TEvent = {\n  target: {\n    language: string;\n  };\n};\n\ntype TranslationInputProps = {\n  onChange?: (event: TEvent) => void;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: ChangeEventHandler<Element>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\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: TranslationInputProps) => {\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\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\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          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\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
276
  children: jsxRuntime.jsx(FlatButton__default["default"], {
279
277
  onClick: props.onToggle,
280
278
  isDisabled: props.isDisabled,
@@ -290,33 +288,31 @@ var TranslationInput = function TranslationInput(props) {
290
288
  });
291
289
  };
292
290
 
293
- TranslationInput.displayName = 'TranslationInput';
294
291
  TranslationInput.propTypes = process.env.NODE_ENV !== "production" ? {
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) {
300
- return !props.isReadOnly;
301
- }),
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
315
- }).isRequired,
316
- error: PropTypes__default["default"].node,
317
- warning: PropTypes__default["default"].node,
318
- hasLanguagesControl: PropTypes__default["default"].bool
319
- } : {}; // The minimum ammount of rows the MultilineTextInput will show.
292
+ onChange: _pt__default["default"].func,
293
+ language: _pt__default["default"].string.isRequired,
294
+ onFocus: _pt__default["default"].func,
295
+ onToggle: _pt__default["default"].func,
296
+ isCollapsed: _pt__default["default"].bool,
297
+ hasLanguagesControl: _pt__default["default"].bool,
298
+ warning: _pt__default["default"].node,
299
+ error: _pt__default["default"].node,
300
+ id: _pt__default["default"].string,
301
+ name: _pt__default["default"].string,
302
+ autoComplete: _pt__default["default"].string,
303
+ value: _pt__default["default"].string.isRequired,
304
+ onBlur: _pt__default["default"].func,
305
+ isDisabled: _pt__default["default"].bool,
306
+ placeholder: _pt__default["default"].string,
307
+ hasWarning: _pt__default["default"].bool,
308
+ hasError: _pt__default["default"].bool,
309
+ isReadOnly: _pt__default["default"].bool,
310
+ isAutofocussed: _pt__default["default"].bool,
311
+ intl: _pt__default["default"].shape({
312
+ formatMessage: _pt__default["default"].func.isRequired
313
+ }).isRequired
314
+ } : {};
315
+ TranslationInput.displayName = 'TranslationInput'; // The minimum ammount of rows the MultilineTextInput will show.
320
316
  // When the input is closed, this is used as the maximum row count as well
321
317
  // so that the input "collapses".
322
318
 
@@ -336,11 +332,9 @@ var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
336
332
  RequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';
337
333
  var RequiredValueErrorMessage$1 = RequiredValueErrorMessage;
338
334
 
339
- var _templateObject;
340
-
341
335
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
342
336
 
343
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context4, _context5; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source), !0)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _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; }
337
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
344
338
 
345
339
  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)."; }
346
340
 
@@ -377,7 +371,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
377
371
  } : {
378
372
  name: "1nns3eb-LocalizedMultilineTextInput",
379
373
  styles: "align-self:flex-start;label:LocalizedMultilineTextInput;",
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"]} */",
374
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-multiline-text-input.tsx"],"names":[],"mappings":"AAoToB","file":"localized-multiline-text-input.tsx","sourcesContent":["import { useReducer, useCallback } from 'react';\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';\nimport { warning } from '@commercetools-uikit/utils';\n\ntype TState = {\n  [key: string]: string;\n};\n\ntype TExpandedTranslationsReducerState = {\n  state?: TState;\n};\n\ntype TExpandedTranslationsReducerAction = {\n  type: string;\n  payload: string;\n};\n\ntype TLocalizedMultilineTextInputProps = {\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?: 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?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: 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: {\n    [key: string]: string;\n  };\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?: () => void;\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: () => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: () => void;\n  /**\n   * Expands input components holding multiline values instead of collpasing them by default.\n   */\n  defaultExpandMultilineText?: boolean;\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls?: boolean;\n  /**\n   * Controls whether one or all languages are visible by default. Pass `true` to show all languages by default.\n   */\n  defaultExpandLanguages?: boolean;\n\n  /**\n   * Sets the focus on the first input when `true` is passed.\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Disables all input fields.\n   */\n  isDisabled?: boolean;\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder?: {\n    [key: string]: string;\n  };\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\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   * Will apply the error state to each input without showing any error message.\n   */\n  hasError?: boolean;\n  /**\n   * Will apply the warning state to each input without showing any error message.\n   */\n  hasWarning?: boolean;\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?: {\n    [key: string]: string;\n  };\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?: {\n    [key: string]: string;\n  };\n};\n\nconst expandedTranslationsReducer = (\n  state: TExpandedTranslationsReducerState,\n  action: TExpandedTranslationsReducerAction\n) => {\n  switch (action.type) {\n    case 'toggle':\n      return {\n        ...state,\n        [action.payload]: !state[action.payload as keyof typeof state],\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 = (\n  props: TLocalizedMultilineTextInputProps\n) => {\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    (\n      prevState: TExpandedTranslationsReducerState,\n      action: TExpandedTranslationsReducerAction\n    ) => TState\n  >(expandedTranslationsReducer, initialExpandedTranslationsState);\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: Array<string> = 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 onLocalizedInputToggle = useCallback(\n    () => toggleLanguages(),\n    [toggleLanguages]\n  );\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.hideLanguageExpansionControls === 'boolean',\n      'LocaliszedMultilineTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\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={onLocalizedInputToggle}\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.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
375
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
382
376
  };
383
377
 
@@ -421,7 +415,19 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
421
415
  }
422
416
  }
423
417
 
418
+ var onLocalizedInputToggle = react$1.useCallback(function () {
419
+ return toggleLanguages();
420
+ }, [toggleLanguages]);
424
421
  var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
422
+
423
+ if (!props.isReadOnly) {
424
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocaliszedMultilineTextInput: "onChange" is required when isReadOnly is not true') : void 0;
425
+ }
426
+
427
+ if (props.hideLanguageExpansionControls) {
428
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.hideLanguageExpansionControls === 'boolean', 'LocaliszedMultilineTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
429
+ }
430
+
425
431
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
426
432
  max: props.horizontalConstraint,
427
433
  children: jsxRuntime.jsxs(Stack__default["default"], {
@@ -462,7 +468,7 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
462
468
  css: _ref,
463
469
  children: jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
464
470
  isOpen: areLanguagesOpened,
465
- onClick: toggleLanguages,
471
+ onClick: onLocalizedInputToggle,
466
472
  isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
467
473
  remainingLocalizations: languages.length - 1
468
474
  })
@@ -471,129 +477,30 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
471
477
  });
472
478
  };
473
479
 
474
- LocalizedMultilineTextInput.displayName = 'LocalizedMultilineTextInput';
475
- LocalizedMultilineTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage$1;
476
480
  LocalizedMultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
477
- /**
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`
479
- */
480
- id: PropTypes__default["default"].string,
481
-
482
- /**
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`
484
- */
485
- name: PropTypes__default["default"].string,
486
-
487
- /**
488
- * Used as HTML `autocomplete` property
489
- */
490
- autoComplete: PropTypes__default["default"].string,
491
-
492
- /**
493
- * Values to use. Keyed by language, the values are the actual values, e.g. `{ en: 'Horse', de: 'Pferd' }`
494
- * <br />
495
- * The input doesn't accept a "languages" prop, instead all possible
496
- * languages have to exist (with empty or filled strings) on the value:
497
- * <br /> { en: 'foo', de: '', es: '' }
498
- */
499
- value: PropTypes__default["default"].objectOf(PropTypes__default["default"].string).isRequired,
500
-
501
- /**
502
- * Gets called when any input is changed. Is called with the change event of the changed input.
503
- * <br />
504
- * Signature: `(event) => void`
505
- */
506
- onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
507
- return !props.isReadOnly;
508
- }),
509
-
510
- /**
511
- * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.
512
- */
513
- selectedLanguage: PropTypes__default["default"].string.isRequired,
514
-
515
- /**
516
- * Called when input is blurred
517
- */
518
- onBlur: PropTypes__default["default"].func,
519
-
520
- /**
521
- * Called when input is focused
522
- */
523
- onFocus: PropTypes__default["default"].func,
524
-
525
- /**
526
- * Expands input components holding multiline values instead of collpasing them by default.
527
- */
528
- defaultExpandMultilineText: PropTypes__default["default"].bool,
529
-
530
- /**
531
- * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.
532
- */
533
- hideLanguageExpansionControls: PropTypes__default["default"].bool,
534
-
535
- /**
536
- * Controls whether one or all languages are visible by default. Pass `true` to show all languages by default.
537
- */
538
- defaultExpandLanguages: function defaultExpandLanguages(props, propName, componentName) {
539
- var _context3;
540
-
541
- if (props.hideLanguageExpansionControls && typeof props[propName] === 'boolean') {
542
- throw new Error(commonTags.oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideLanguageExpansionControls\" is set.\n "])), componentName, propName));
543
- }
544
-
545
- for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
546
- rest[_key - 3] = arguments[_key];
547
- }
548
-
549
- return PropTypes__default["default"].bool.apply(PropTypes__default["default"], _concatInstanceProperty__default["default"](_context3 = [props, propName, componentName]).call(_context3, rest));
550
- },
551
-
552
- /**
553
- * Sets the focus on the first input when `true` is passed.
554
- */
555
- isAutofocussed: PropTypes__default["default"].bool,
556
-
557
- /**
558
- * Disables all input fields.
559
- */
560
- isDisabled: PropTypes__default["default"].bool,
561
-
562
- /**
563
- * Disables all input fields and shows them in read-only mode.
564
- */
565
- isReadOnly: PropTypes__default["default"].bool,
566
-
567
- /**
568
- * Placeholders for each language. Object of the same shape as `value`.
569
- */
570
- placeholder: PropTypes__default["default"].objectOf(PropTypes__default["default"].string),
571
-
572
- /**
573
- * Horizontal size limit of the input fields.
574
- */
575
- horizontalConstraint: PropTypes__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
576
-
577
- /**
578
- * Will apply the error state to each input without showing any error message.
579
- */
580
- hasError: PropTypes__default["default"].bool,
581
-
582
- /**
583
- * Will apply the warning state to each input without showing any error message.
584
- */
585
- hasWarning: PropTypes__default["default"].bool,
586
-
587
- /**
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.
589
- */
590
- errors: PropTypes__default["default"].objectOf(PropTypes__default["default"].node),
591
-
592
- /**
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.
594
- */
595
- warnings: PropTypes__default["default"].objectOf(PropTypes__default["default"].node)
481
+ id: _pt__default["default"].string,
482
+ name: _pt__default["default"].string,
483
+ autoComplete: _pt__default["default"].string,
484
+ value: _pt__default["default"].objectOf(_pt__default["default"].string).isRequired,
485
+ onChange: _pt__default["default"].func,
486
+ selectedLanguage: _pt__default["default"].string.isRequired,
487
+ onBlur: _pt__default["default"].func,
488
+ onFocus: _pt__default["default"].func,
489
+ defaultExpandMultilineText: _pt__default["default"].bool,
490
+ hideLanguageExpansionControls: _pt__default["default"].bool,
491
+ defaultExpandLanguages: _pt__default["default"].bool,
492
+ isAutofocussed: _pt__default["default"].bool,
493
+ isDisabled: _pt__default["default"].bool,
494
+ isReadOnly: _pt__default["default"].bool,
495
+ placeholder: _pt__default["default"].objectOf(_pt__default["default"].string),
496
+ horizontalConstraint: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
497
+ hasError: _pt__default["default"].bool,
498
+ hasWarning: _pt__default["default"].bool,
499
+ errors: _pt__default["default"].objectOf(_pt__default["default"].string),
500
+ warnings: _pt__default["default"].objectOf(_pt__default["default"].string)
596
501
  } : {};
502
+ LocalizedMultilineTextInput.displayName = 'LocalizedMultilineTextInput';
503
+ LocalizedMultilineTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage$1;
597
504
  LocalizedMultilineTextInput.getId = localizedUtils.getId;
598
505
  LocalizedMultilineTextInput.getName = localizedUtils.getName;
599
506
  LocalizedMultilineTextInput.defaultProps = {
@@ -606,7 +513,7 @@ LocalizedMultilineTextInput.isTouched = localizedUtils.isTouched;
606
513
  var LocalizedMultilineTextInput$1 = LocalizedMultilineTextInput;
607
514
 
608
515
  // NOTE: This string will be replaced on build time with the package version.
609
- var version = "13.0.2";
516
+ var version = "13.0.3";
610
517
 
611
518
  exports["default"] = LocalizedMultilineTextInput$1;
612
519
  exports.version = version;