@commercetools-uikit/localized-rich-text-input 13.0.3 → 13.0.4

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 react = require('@emotion/react');
24
20
  var Stack = require('@commercetools-uikit/spacings-stack');
25
21
  var Constraints = require('@commercetools-uikit/constraints');
@@ -27,16 +23,17 @@ var hooks = require('@commercetools-uikit/hooks');
27
23
  var localizedUtils = require('@commercetools-uikit/localized-utils');
28
24
  var inputUtils = require('@commercetools-uikit/input-utils');
29
25
  var richTextUtils = require('@commercetools-uikit/rich-text-utils');
26
+ var utils = require('@commercetools-uikit/utils');
30
27
  var _Reflect$construct = require('@babel/runtime-corejs3/core-js-stable/reflect/construct');
31
28
  var _classCallCheck = require('@babel/runtime-corejs3/helpers/classCallCheck');
32
29
  var _createClass = require('@babel/runtime-corejs3/helpers/createClass');
33
30
  var _inherits = require('@babel/runtime-corejs3/helpers/inherits');
34
31
  var _possibleConstructorReturn = require('@babel/runtime-corejs3/helpers/possibleConstructorReturn');
35
32
  var _getPrototypeOf = require('@babel/runtime-corejs3/helpers/getPrototypeOf');
33
+ var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
36
34
  var _setTimeout = require('@babel/runtime-corejs3/core-js-stable/set-timeout');
37
35
  var pick = require('lodash/pick');
38
36
  var slateReact = require('slate-react');
39
- var utils = require('@commercetools-uikit/utils');
40
37
  var _styled = require('@emotion/styled/base');
41
38
  var reactIntl = require('react-intl');
42
39
  var designSystem = require('@commercetools-uikit/design-system');
@@ -56,15 +53,14 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
56
53
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
57
54
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
58
55
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
56
+ var _pt__default = /*#__PURE__*/_interopDefault(_pt);
59
57
  var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
60
58
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
61
59
  var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
62
- var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
63
- var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
64
- var requiredIf__default = /*#__PURE__*/_interopDefault(requiredIf);
65
60
  var Stack__default = /*#__PURE__*/_interopDefault(Stack);
66
61
  var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
67
62
  var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
63
+ var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
68
64
  var _setTimeout__default = /*#__PURE__*/_interopDefault(_setTimeout);
69
65
  var pick__default = /*#__PURE__*/_interopDefault(pick);
70
66
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
@@ -79,29 +75,29 @@ function _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) {
79
75
  function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
80
76
 
81
77
  var EditorLanguageLabel = _styled__default["default"]("label", process.env.NODE_ENV === "production" ? {
82
- target: "e1ujjdh2"
78
+ target: "ew063c2"
83
79
  } : {
84
- target: "e1ujjdh2",
80
+ target: "ew063c2",
85
81
  label: "EditorLanguageLabel"
86
82
  })(function (props) {
87
83
  var overwrittenVars = _objectSpread$4(_objectSpread$4({}, designSystem.customProperties), props.theme);
88
84
 
89
- return /*#__PURE__*/react.css("white-space:nowrap;flex:0;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";line-height:calc(\n ", designSystem.customProperties.sizeHeightInput, " - 2 *\n ", designSystem.customProperties.borderRadius1, "\n );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;cursor:inherit;" + (process.env.NODE_ENV === "production" ? "" : ";label:EditorLanguageLabel;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY1kiLCJmaWxlIjoiZWRpdG9yLnN0eWxlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnQgKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7XG4gIGN1c3RvbVByb3BlcnRpZXMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbmNvbnN0IEVkaXRvckxhbmd1YWdlTGFiZWwgPSBzdHlsZWQubGFiZWwoKHByb3BzKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi5jdXN0b21Qcm9wZXJ0aWVzLFxuICAgIC4uLnByb3BzLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgIGZsZXg6IDA7XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNpemVIZWlnaHRJbnB1dH0gLSAyICpcbiAgICAgICAgJHtjdXN0b21Qcm9wZXJ0aWVzLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7Y3VzdG9tUHJvcGVydGllcy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG5cbiAgICAvKiBjdXJzb3Igc2hvdWxkIGJlIGluaGVyaXRlZCBmcm9tIHBhcmVudCxcbiAgICAqIEdJVkVOIHBhcmVudCBoYXMgJ25vdC1hbGxvd2VkJyBjdXJzb3JcbiAgICAqIFRIRU4gdGhlIGxhbmd1YWdlIGxhYmVsIHNob3VsZCBhbHNvIGhhdmUgdGhhdCAoaW5zdGVhZCBvZiBsYWJlbCdzIGRlZmF1bHQgY3Vyc29yKVxuICAgICovXG4gICAgY3Vyc29yOiBpbmhlcml0O1xuICBgO1xufSk7XG5cbmNvbnN0IEVkaXRvcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICB3aWR0aDogMTAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBjdXJzb3I6ICR7KHByb3BzKSA9PlxuICAgIHByb3BzLmlzRGlzYWJsZWQgfHwgcHJvcHMuaXNSZWFkT25seSA/ICdub3QtYWxsb3dlZCcgOiAnaW5oZXJpdCd9O1xuYDtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBFZGl0b3JMYW5ndWFnZUxhYmVsLCBFZGl0b3JXcmFwcGVyLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */");
90
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRCIiwiZmlsZSI6ImVkaXRvci5zdHlsZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBpbXBvcnQvcHJlZmVyLWRlZmF1bHQtZXhwb3J0ICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBFZGl0b3JMYW5ndWFnZUxhYmVsID0gc3R5bGVkLmxhYmVsKChwcm9wcykgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4uY3VzdG9tUHJvcGVydGllcyxcbiAgICAuLi5wcm9wcy50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICBmbGV4OiAwO1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAgICR7Y3VzdG9tUHJvcGVydGllcy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqXG4gICAgICAgICR7Y3VzdG9tUHJvcGVydGllcy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuXG4gICAgLyogY3Vyc29yIHNob3VsZCBiZSBpbmhlcml0ZWQgZnJvbSBwYXJlbnQsXG4gICAgKiBHSVZFTiBwYXJlbnQgaGFzICdub3QtYWxsb3dlZCcgY3Vyc29yXG4gICAgKiBUSEVOIHRoZSBsYW5ndWFnZSBsYWJlbCBzaG91bGQgYWxzbyBoYXZlIHRoYXQgKGluc3RlYWQgb2YgbGFiZWwncyBkZWZhdWx0IGN1cnNvcilcbiAgICAqL1xuICAgIGN1cnNvcjogaW5oZXJpdDtcbiAgYDtcbn0pO1xuXG5jb25zdCBFZGl0b3JXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6IDEwMCU7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgY3Vyc29yOiAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5pc0Rpc2FibGVkIHx8IHByb3BzLmlzUmVhZE9ubHkgPyAnbm90LWFsbG93ZWQnIDogJ2luaGVyaXQnfTtcbmA7XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgRWRpdG9yTGFuZ3VhZ2VMYWJlbCwgRWRpdG9yV3JhcHBlciwgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */");
85
+ return /*#__PURE__*/react.css("white-space:nowrap;flex:0;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";line-height:calc(\n ", designSystem.customProperties.sizeHeightInput, " - 2 *\n ", designSystem.customProperties.borderRadius1, "\n );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;cursor:inherit;" + (process.env.NODE_ENV === "production" ? "" : ";label:EditorLanguageLabel;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY1kiLCJmaWxlIjoiZWRpdG9yLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7XG4gIGN1c3RvbVByb3BlcnRpZXMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRFZGl0b3JQcm9wcyB9IGZyb20gJy4vZWRpdG9yJztcblxuY29uc3QgRWRpdG9yTGFuZ3VhZ2VMYWJlbCA9IHN0eWxlZC5sYWJlbCgocHJvcHMpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLmN1c3RvbVByb3BlcnRpZXMsXG4gICAgLi4ucHJvcHMudGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgZmxleDogMDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke2N1c3RvbVByb3BlcnRpZXMuc2l6ZUhlaWdodElucHV0fSAtIDIgKlxuICAgICAgICAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzMX1cbiAgICApO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcblxuICAgIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgICBjdXJzb3I6IGluaGVyaXQ7XG4gIGA7XG59KTtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXY8XG4gIFBpY2s8VEVkaXRvclByb3BzLCAnaXNEaXNhYmxlZCcgfCAnaXNSZWFkT25seSc+XG4+YFxuICB3aWR0aDogMTAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBjdXJzb3I6ICR7KHByb3BzKSA9PlxuICAgIHByb3BzLmlzRGlzYWJsZWQgfHwgcHJvcHMuaXNSZWFkT25seSA/ICdub3QtYWxsb3dlZCcgOiAnaW5oZXJpdCd9O1xuYDtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBFZGl0b3JMYW5ndWFnZUxhYmVsLCBFZGl0b3JXcmFwcGVyLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */");
86
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRCIiwiZmlsZSI6ImVkaXRvci5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHR5cGUgeyBURWRpdG9yUHJvcHMgfSBmcm9tICcuL2VkaXRvcic7XG5cbmNvbnN0IEVkaXRvckxhbmd1YWdlTGFiZWwgPSBzdHlsZWQubGFiZWwoKHByb3BzKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi5jdXN0b21Qcm9wZXJ0aWVzLFxuICAgIC4uLnByb3BzLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgIGZsZXg6IDA7XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNpemVIZWlnaHRJbnB1dH0gLSAyICpcbiAgICAgICAgJHtjdXN0b21Qcm9wZXJ0aWVzLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7Y3VzdG9tUHJvcGVydGllcy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG5cbiAgICAvKiBjdXJzb3Igc2hvdWxkIGJlIGluaGVyaXRlZCBmcm9tIHBhcmVudCxcbiAgICAqIEdJVkVOIHBhcmVudCBoYXMgJ25vdC1hbGxvd2VkJyBjdXJzb3JcbiAgICAqIFRIRU4gdGhlIGxhbmd1YWdlIGxhYmVsIHNob3VsZCBhbHNvIGhhdmUgdGhhdCAoaW5zdGVhZCBvZiBsYWJlbCdzIGRlZmF1bHQgY3Vyc29yKVxuICAgICovXG4gICAgY3Vyc29yOiBpbmhlcml0O1xuICBgO1xufSk7XG5cbmNvbnN0IEVkaXRvcldyYXBwZXIgPSBzdHlsZWQuZGl2PFxuICBQaWNrPFRFZGl0b3JQcm9wcywgJ2lzRGlzYWJsZWQnIHwgJ2lzUmVhZE9ubHknPlxuPmBcbiAgd2lkdGg6IDEwMCU7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgY3Vyc29yOiAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5pc0Rpc2FibGVkIHx8IHByb3BzLmlzUmVhZE9ubHkgPyAnbm90LWFsbG93ZWQnIDogJ2luaGVyaXQnfTtcbmA7XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgRWRpdG9yTGFuZ3VhZ2VMYWJlbCwgRWRpdG9yV3JhcHBlciwgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */");
91
87
 
92
88
  var EditorWrapper = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
93
- target: "e1ujjdh1"
89
+ target: "ew063c1"
94
90
  } : {
95
- target: "e1ujjdh1",
91
+ target: "ew063c1",
96
92
  label: "EditorWrapper"
97
93
  })("width:100%;position:relative;display:flex;cursor:", function (props) {
98
94
  return props.isDisabled || props.isReadOnly ? 'not-allowed' : 'inherit';
99
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0RnQyIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgaW1wb3J0L3ByZWZlci1kZWZhdWx0LWV4cG9ydCAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgRWRpdG9yTGFuZ3VhZ2VMYWJlbCA9IHN0eWxlZC5sYWJlbCgocHJvcHMpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLmN1c3RvbVByb3BlcnRpZXMsXG4gICAgLi4ucHJvcHMudGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgZmxleDogMDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke2N1c3RvbVByb3BlcnRpZXMuc2l6ZUhlaWdodElucHV0fSAtIDIgKlxuICAgICAgICAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzMX1cbiAgICApO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcblxuICAgIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgICBjdXJzb3I6IGluaGVyaXQ7XG4gIGA7XG59KTtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHdpZHRoOiAxMDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGN1cnNvcjogJHsocHJvcHMpID0+XG4gICAgcHJvcHMuaXNEaXNhYmxlZCB8fCBwcm9wcy5pc1JlYWRPbmx5ID8gJ25vdC1hbGxvd2VkJyA6ICdpbmhlcml0J307XG5gO1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IEVkaXRvckxhbmd1YWdlTGFiZWwsIEVkaXRvcldyYXBwZXIsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */"));
95
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0RDIiwiZmlsZSI6ImVkaXRvci5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHR5cGUgeyBURWRpdG9yUHJvcHMgfSBmcm9tICcuL2VkaXRvcic7XG5cbmNvbnN0IEVkaXRvckxhbmd1YWdlTGFiZWwgPSBzdHlsZWQubGFiZWwoKHByb3BzKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi5jdXN0b21Qcm9wZXJ0aWVzLFxuICAgIC4uLnByb3BzLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgIGZsZXg6IDA7XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNpemVIZWlnaHRJbnB1dH0gLSAyICpcbiAgICAgICAgJHtjdXN0b21Qcm9wZXJ0aWVzLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7Y3VzdG9tUHJvcGVydGllcy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG5cbiAgICAvKiBjdXJzb3Igc2hvdWxkIGJlIGluaGVyaXRlZCBmcm9tIHBhcmVudCxcbiAgICAqIEdJVkVOIHBhcmVudCBoYXMgJ25vdC1hbGxvd2VkJyBjdXJzb3JcbiAgICAqIFRIRU4gdGhlIGxhbmd1YWdlIGxhYmVsIHNob3VsZCBhbHNvIGhhdmUgdGhhdCAoaW5zdGVhZCBvZiBsYWJlbCdzIGRlZmF1bHQgY3Vyc29yKVxuICAgICovXG4gICAgY3Vyc29yOiBpbmhlcml0O1xuICBgO1xufSk7XG5cbmNvbnN0IEVkaXRvcldyYXBwZXIgPSBzdHlsZWQuZGl2PFxuICBQaWNrPFRFZGl0b3JQcm9wcywgJ2lzRGlzYWJsZWQnIHwgJ2lzUmVhZE9ubHknPlxuPmBcbiAgd2lkdGg6IDEwMCU7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgY3Vyc29yOiAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5pc0Rpc2FibGVkIHx8IHByb3BzLmlzUmVhZE9ubHkgPyAnbm90LWFsbG93ZWQnIDogJ2luaGVyaXQnfTtcbmA7XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgRWRpdG9yTGFuZ3VhZ2VMYWJlbCwgRWRpdG9yV3JhcHBlciwgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */"));
100
96
 
101
97
  var ToggleButtonWrapper = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
102
- target: "e1ujjdh0"
98
+ target: "ew063c0"
103
99
  } : {
104
- target: "e1ujjdh0",
100
+ target: "ew063c0",
105
101
  label: "ToggleButtonWrapper"
106
102
  })(process.env.NODE_ENV === "production" ? {
107
103
  name: "ejz79s",
@@ -109,7 +105,7 @@ var ToggleButtonWrapper = _styled__default["default"]("div", process.env.NODE_EN
109
105
  } : {
110
106
  name: "ejz79s",
111
107
  styles: "flex:0;display:flex",
112
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMERzQyIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgaW1wb3J0L3ByZWZlci1kZWZhdWx0LWV4cG9ydCAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgRWRpdG9yTGFuZ3VhZ2VMYWJlbCA9IHN0eWxlZC5sYWJlbCgocHJvcHMpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLmN1c3RvbVByb3BlcnRpZXMsXG4gICAgLi4ucHJvcHMudGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgZmxleDogMDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke2N1c3RvbVByb3BlcnRpZXMuc2l6ZUhlaWdodElucHV0fSAtIDIgKlxuICAgICAgICAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzMX1cbiAgICApO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcblxuICAgIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgICBjdXJzb3I6IGluaGVyaXQ7XG4gIGA7XG59KTtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHdpZHRoOiAxMDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGN1cnNvcjogJHsocHJvcHMpID0+XG4gICAgcHJvcHMuaXNEaXNhYmxlZCB8fCBwcm9wcy5pc1JlYWRPbmx5ID8gJ25vdC1hbGxvd2VkJyA6ICdpbmhlcml0J307XG5gO1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IEVkaXRvckxhbmd1YWdlTGFiZWwsIEVkaXRvcldyYXBwZXIsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
108
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNERzQyIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB0eXBlIHsgVEVkaXRvclByb3BzIH0gZnJvbSAnLi9lZGl0b3InO1xuXG5jb25zdCBFZGl0b3JMYW5ndWFnZUxhYmVsID0gc3R5bGVkLmxhYmVsKChwcm9wcykgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4uY3VzdG9tUHJvcGVydGllcyxcbiAgICAuLi5wcm9wcy50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICBmbGV4OiAwO1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAgICR7Y3VzdG9tUHJvcGVydGllcy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqXG4gICAgICAgICR7Y3VzdG9tUHJvcGVydGllcy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuXG4gICAgLyogY3Vyc29yIHNob3VsZCBiZSBpbmhlcml0ZWQgZnJvbSBwYXJlbnQsXG4gICAgKiBHSVZFTiBwYXJlbnQgaGFzICdub3QtYWxsb3dlZCcgY3Vyc29yXG4gICAgKiBUSEVOIHRoZSBsYW5ndWFnZSBsYWJlbCBzaG91bGQgYWxzbyBoYXZlIHRoYXQgKGluc3RlYWQgb2YgbGFiZWwncyBkZWZhdWx0IGN1cnNvcilcbiAgICAqL1xuICAgIGN1cnNvcjogaW5oZXJpdDtcbiAgYDtcbn0pO1xuXG5jb25zdCBFZGl0b3JXcmFwcGVyID0gc3R5bGVkLmRpdjxcbiAgUGljazxURWRpdG9yUHJvcHMsICdpc0Rpc2FibGVkJyB8ICdpc1JlYWRPbmx5Jz5cbj5gXG4gIHdpZHRoOiAxMDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGN1cnNvcjogJHsocHJvcHMpID0+XG4gICAgcHJvcHMuaXNEaXNhYmxlZCB8fCBwcm9wcy5pc1JlYWRPbmx5ID8gJ25vdC1hbGxvd2VkJyA6ICdpbmhlcml0J307XG5gO1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IEVkaXRvckxhbmd1YWdlTGFiZWwsIEVkaXRvcldyYXBwZXIsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
113
109
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
114
110
  });
115
111
 
@@ -121,9 +117,9 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to string
121
117
  var COLLAPSED_HEIGHT = 32;
122
118
 
123
119
  var LeftColumn = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
124
- target: "egz4dsd2"
120
+ target: "el9zors2"
125
121
  } : {
126
- target: "egz4dsd2",
122
+ target: "el9zors2",
127
123
  label: "LeftColumn"
128
124
  })(process.env.NODE_ENV === "production" ? {
129
125
  name: "147rp59",
@@ -131,14 +127,14 @@ var LeftColumn = _styled__default["default"]("div", process.env.NODE_ENV === "pr
131
127
  } : {
132
128
  name: "147rp59",
133
129
  styles: "flex:1;display:flex;align-items:flex-start",
134
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AA4B6B","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */",
130
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAsC6B","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */",
135
131
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
136
132
  });
137
133
 
138
134
  var RightColumn = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
139
- target: "egz4dsd1"
135
+ target: "el9zors1"
140
136
  } : {
141
- target: "egz4dsd1",
137
+ target: "el9zors1",
142
138
  label: "RightColumn"
143
139
  })(process.env.NODE_ENV === "production" ? {
144
140
  name: "1m04uhl",
@@ -146,14 +142,14 @@ var RightColumn = _styled__default["default"]("div", process.env.NODE_ENV === "p
146
142
  } : {
147
143
  name: "1m04uhl",
148
144
  styles: "position:relative;flex:0;display:flex;align-items:flex-start",
149
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AAkC8B","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */",
145
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AA4C8B","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */",
150
146
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
151
147
  });
152
148
 
153
149
  var Row = _styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
154
- target: "egz4dsd0"
150
+ target: "el9zors0"
155
151
  } : {
156
- target: "egz4dsd0",
152
+ target: "el9zors0",
157
153
  label: "Row"
158
154
  })(process.env.NODE_ENV === "production" ? {
159
155
  name: "skgbeu",
@@ -161,7 +157,7 @@ var Row = _styled__default["default"]("div", process.env.NODE_ENV === "productio
161
157
  } : {
162
158
  name: "skgbeu",
163
159
  styles: "display:flex;justify-content:flex-end",
164
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AAyCsB","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */",
160
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAmDsB","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */",
165
161
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
166
162
  });
167
163
 
@@ -171,14 +167,20 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
171
167
  } : {
172
168
  name: "16ohn6x-container",
173
169
  styles: "flex:auto;width:0;border-top-left-radius:0;border-bottom-left-radius:0;label:container;",
174
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AA6HgC","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */",
170
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AA6KgC","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */",
175
171
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
176
172
  };
177
173
 
178
- var Editor = function Editor(props) {
174
+ var Editor$1 = function Editor(props) {
175
+ var _props$editor, _props$editor2, _props$editor3, _props$editor4;
176
+
179
177
  var intl = reactIntl.useIntl();
180
178
  var ref = react$1.useRef();
181
- var prevIsFocused = hooks.usePrevious(props.editor.value.selection.isFocused);
179
+ var prevIsFocused = hooks.usePrevious((_props$editor = props.editor) === null || _props$editor === void 0 ? void 0 : _props$editor.value.selection.isFocused);
180
+
181
+ if (props.showExpandIcon) {
182
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onClickExpand === 'function', 'Editor: "onClickExpand" is required when showExpandIcon is true') : void 0;
183
+ }
182
184
 
183
185
  var _useState = react$1.useState(false),
184
186
  _useState2 = _slicedToArray(_useState, 2),
@@ -190,7 +192,9 @@ var Editor = function Editor(props) {
190
192
  toggleLanguage(props.language);
191
193
  }, [toggleLanguage, props.language]);
192
194
  var updateRenderToggleButton = react$1.useCallback(function () {
193
- var doesExceedCollapsedHeightLimit = ref.current.clientHeight > COLLAPSED_HEIGHT;
195
+ var _ref$current;
196
+
197
+ var doesExceedCollapsedHeightLimit = Number((_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.clientHeight) > COLLAPSED_HEIGHT;
194
198
 
195
199
  if (doesExceedCollapsedHeightLimit && !renderToggleButton) {
196
200
  setRenderToggleButton(true);
@@ -202,9 +206,9 @@ var Editor = function Editor(props) {
202
206
  }, [setRenderToggleButton, renderToggleButton]);
203
207
  react$1.useEffect(function () {
204
208
  updateRenderToggleButton();
205
- }, [props.editor.value.document, updateRenderToggleButton]); // opens the input if it regains focus and it's closed
209
+ }, [(_props$editor2 = props.editor) === null || _props$editor2 === void 0 ? void 0 : _props$editor2.value.document, updateRenderToggleButton]); // opens the input if it regains focus and it's closed
206
210
 
207
- if (prevIsFocused !== props.editor.value.selection.isFocused && props.editor.value.selection.isFocused && !props.isOpen) {
211
+ if (prevIsFocused !== ((_props$editor3 = props.editor) === null || _props$editor3 === void 0 ? void 0 : _props$editor3.value.selection.isFocused) && (_props$editor4 = props.editor) !== null && _props$editor4 !== void 0 && _props$editor4.value.selection.isFocused && !props.isOpen) {
208
212
  onToggle();
209
213
  }
210
214
 
@@ -229,6 +233,10 @@ var Editor = function Editor(props) {
229
233
  toggle = _ref2.toggle,
230
234
  containerStyles = _ref2.containerStyles,
231
235
  registerContentNode = _ref2.registerContentNode;
236
+ var refObj = {
237
+ containerRef: ref,
238
+ registerContentNode: registerContentNode
239
+ };
232
240
  return jsxRuntime.jsxs(Stack__default["default"], {
233
241
  scale: "xs",
234
242
  children: [jsxRuntime.jsxs(EditorWrapper, {
@@ -242,18 +250,14 @@ var Editor = function Editor(props) {
242
250
  children: props.language.toUpperCase()
243
251
  })
244
252
  }), jsxRuntime.jsx(richTextUtils.RichTextBody, {
245
- ref: {
246
- containerRef: ref,
247
- registerContentNode: registerContentNode
248
- },
253
+ ref: refObj,
249
254
  styles: {
250
255
  container: _ref$1
251
256
  },
252
- isOpen: props.isOpen,
253
257
  hasError: props.hasError,
254
258
  isDisabled: props.isDisabled,
255
259
  hasWarning: props.hasWarning,
256
- isReadOnly: props.isReadOnly,
260
+ isReadOnly: Boolean(props.isReadOnly),
257
261
  editor: props.editor,
258
262
  containerStyles: containerStyles,
259
263
  showExpandIcon: props.showExpandIcon,
@@ -268,7 +272,7 @@ var Editor = function Editor(props) {
268
272
  // does the trick.
269
273
  // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
270
274
  , {
271
- css: /*#__PURE__*/react.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AAyJsB","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */"),
275
+ css: /*#__PURE__*/react.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAwMsB","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */"),
272
276
  children: [function () {
273
277
  if (props.error) return jsxRuntime.jsx(LeftColumn, {
274
278
  children: jsxRuntime.jsx("div", {
@@ -283,7 +287,7 @@ var Editor = function Editor(props) {
283
287
  return null;
284
288
  }(), renderToggleButton && jsxRuntime.jsx(RightColumn, {
285
289
  children: jsxRuntime.jsx(ToggleButtonWrapper, {
286
- css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-top:", designSystem.customProperties.spacingXs, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AAmL2B","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:Editor;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.js"],"names":[],"mappings":"AAiLoB","file":"editor.js","sourcesContent":["import { useRef, useState, useCallback, useEffect, cloneElement } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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 Editor = (props) => {\n  const intl = useIntl();\n  const ref = useRef();\n  const prevIsFocused = usePrevious(props.editor.value.selection.isFocused);\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      ref.current.clientHeight > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor.value.selection.isFocused &&\n    props.editor.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={{\n                  containerRef: ref,\n                  registerContentNode,\n                }}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                isOpen={props.isOpen}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={props.isReadOnly}\n                editor={props.editor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\n// eslint-disable-next-line react/display-name\nconst renderEditor = (props, editor, next) => {\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={isFocused}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\nEditor.propTypes = {\n  children: PropTypes.node.isRequired,\n  id: PropTypes.string,\n  isOpen: PropTypes.bool.isRequired,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  hasError: PropTypes.bool,\n  editor: PropTypes.any,\n  error: PropTypes.node,\n  warning: PropTypes.node,\n  defaultExpandMultilineText: PropTypes.bool.isRequired,\n  toggleLanguage: PropTypes.func.isRequired,\n  language: PropTypes.string.isRequired,\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n  hasLanguagesControl: PropTypes.bool,\n};\n\nrenderEditor.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  disabled: PropTypes.bool,\n  readOnly: PropTypes.bool,\n  editor: PropTypes.any,\n  options: PropTypes.shape({\n    language: PropTypes.string.isRequired,\n    error: PropTypes.node,\n    warning: PropTypes.node,\n    hasWarning: PropTypes.bool,\n    hasError: PropTypes.bool,\n    defaultExpandMultilineText: PropTypes.bool.isRequired,\n    toggleLanguage: PropTypes.func.isRequired,\n    isOpen: PropTypes.bool.isRequired,\n    showExpandIcon: PropTypes.bool.isRequired,\n    onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n    hasLanguagesControl: PropTypes.bool,\n  }),\n};\n\nexport default renderEditor;\n"]} */"],
290
+ css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-top:", designSystem.customProperties.spacingXs, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAkO2B","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:Editor;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAgOoB","file":"editor.tsx","sourcesContent":["import {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  cloneElement,\n  type ReactNode,\n  type ReactElement,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n} from 'react';\nimport pick from 'lodash/pick';\nimport { css, useTheme } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { customProperties } from '@commercetools-uikit/design-system';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { usePrevious } from '@commercetools-uikit/hooks';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\nimport type { TEditor } from './editor.types';\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\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\nexport type TEditorProps = {\n  children: ReactNode;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  editor?: TEditor;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst Editor = (props: TEditorProps) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const prevIsFocused = usePrevious(props.editor?.value.selection.isFocused);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [props.editor?.value.document, updateRenderToggleButton]);\n\n  // opens the input if it regains focus and it's closed\n  if (\n    prevIsFocused !== props.editor?.value.selection.isFocused &&\n    props.editor?.value.selection.isFocused &&\n    !props.isOpen\n  ) {\n    onToggle();\n  }\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    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  const theme = useTheme();\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <EditorLanguageLabel htmlFor={props.id} theme={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              </EditorLanguageLabel>\n\n              <RichTextBody\n                ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                styles={{\n                  container: css`\n                    flex: auto;\n                    width: 0;\n                    border-top-left-radius: 0;\n                    border-bottom-left-radius: 0;\n                  `,\n                }}\n                hasError={props.hasError}\n                isDisabled={props.isDisabled}\n                hasWarning={props.hasWarning}\n                isReadOnly={Boolean(props.isReadOnly)}\n                editor={props.editor as TEditor}\n                containerStyles={containerStyles}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n              >\n                {props.children}\n              </RichTextBody>\n            </EditorWrapper>\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              {renderToggleButton && (\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={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n};\n\ntype TOptions = {\n  language: string;\n  error?: ReactNode;\n  warning?: ReactNode;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  isOpen: boolean;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n};\n\nexport type TRenderEditorProps = {\n  id?: string;\n  name?: string;\n  disabled?: boolean;\n  readOnly?: boolean;\n  editor?: TEditor;\n  options: TOptions;\n};\nexport type TRenderEditor = (\n  props: TRenderEditorProps,\n  editor: TEditor,\n  next: () => ReactElement\n) => ReturnType<typeof Editor>;\n\nconst renderEditor: TRenderEditor = (props, editor, next) => {\n  if (props.options.showExpandIcon) {\n    warning(\n      typeof props.options.onClickExpand === 'function',\n      'renderEditor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const internalId = `${props.id}__internal__id`;\n\n  const children = cloneElement(next(), {\n    id: internalId,\n  });\n\n  const passedProps = {\n    id: props.id,\n    isDisabled: props.disabled,\n    isReadOnly: props.readOnly,\n    ...pick(props.options, [\n      'defaultExpandMultilineText',\n      'language',\n      'warning',\n      'error',\n      'hasWarning',\n      'hasError',\n      'toggleLanguage',\n      'isOpen',\n      'showExpandIcon',\n      'onClickExpand',\n      'hasLanguagesControl',\n    ]),\n    ...filterDataAttributes(props),\n  };\n\n  const isFocused = props.editor?.value.selection.isFocused;\n\n  return (\n    <Editor editor={editor} {...passedProps}>\n      {children}\n      <HiddenInput\n        isFocused={Boolean(isFocused)}\n        handleFocus={editor.focus}\n        disabled={props.disabled}\n        readOnly={props.readOnly}\n        id={props.id}\n      />\n    </Editor>\n  );\n};\n\nEditor.displayName = 'Editor';\n\nexport default renderEditor;\n"]} */"],
287
291
  children: jsxRuntime.jsx(FlatButton__default["default"], {
288
292
  onClick: toggle,
289
293
  label: intl.formatMessage(isOpen ? inputUtils.messagesMultilineInput.collapse : inputUtils.messagesMultilineInput.expand),
@@ -299,10 +303,34 @@ var Editor = function Editor(props) {
299
303
  });
300
304
  }
301
305
  });
302
- }; // eslint-disable-next-line react/display-name
306
+ };
303
307
 
308
+ Editor$1.propTypes = process.env.NODE_ENV !== "production" ? {
309
+ children: _pt__default["default"].node.isRequired,
310
+ id: _pt__default["default"].string,
311
+ isOpen: _pt__default["default"].bool.isRequired,
312
+ isDisabled: _pt__default["default"].bool,
313
+ isReadOnly: _pt__default["default"].bool,
314
+ hasWarning: _pt__default["default"].bool,
315
+ hasError: _pt__default["default"].bool,
316
+ editor: _pt__default["default"].any,
317
+ error: _pt__default["default"].node,
318
+ warning: _pt__default["default"].node,
319
+ defaultExpandMultilineText: _pt__default["default"].bool.isRequired,
320
+ toggleLanguage: _pt__default["default"].func.isRequired,
321
+ language: _pt__default["default"].string.isRequired,
322
+ showExpandIcon: _pt__default["default"].bool.isRequired,
323
+ onClickExpand: _pt__default["default"].func,
324
+ hasLanguagesControl: _pt__default["default"].bool
325
+ } : {};
304
326
 
305
327
  var renderEditor = function renderEditor(props, editor, next) {
328
+ var _props$editor5;
329
+
330
+ if (props.options.showExpandIcon) {
331
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.options.onClickExpand === 'function', 'renderEditor: "onClickExpand" is required when showExpandIcon is true') : void 0;
332
+ }
333
+
306
334
  var internalId = "".concat(props.id, "__internal__id");
307
335
  var children = /*#__PURE__*/react$1.cloneElement(next(), {
308
336
  id: internalId
@@ -314,12 +342,12 @@ var renderEditor = function renderEditor(props, editor, next) {
314
342
  isReadOnly: props.readOnly
315
343
  }, pick__default["default"](props.options, ['defaultExpandMultilineText', 'language', 'warning', 'error', 'hasWarning', 'hasError', 'toggleLanguage', 'isOpen', 'showExpandIcon', 'onClickExpand', 'hasLanguagesControl'])), utils.filterDataAttributes(props));
316
344
 
317
- var isFocused = props.editor.value.selection.isFocused;
318
- return jsxRuntime.jsxs(Editor, _objectSpread$3(_objectSpread$3({
345
+ var isFocused = (_props$editor5 = props.editor) === null || _props$editor5 === void 0 ? void 0 : _props$editor5.value.selection.isFocused;
346
+ return jsxRuntime.jsxs(Editor$1, _objectSpread$3(_objectSpread$3({
319
347
  editor: editor
320
348
  }, passedProps), {}, {
321
349
  children: [children, jsxRuntime.jsx(richTextUtils.HiddenInput, {
322
- isFocused: isFocused,
350
+ isFocused: Boolean(isFocused),
323
351
  handleFocus: editor.focus,
324
352
  disabled: props.disabled,
325
353
  readOnly: props.readOnly,
@@ -328,58 +356,35 @@ var renderEditor = function renderEditor(props, editor, next) {
328
356
  }));
329
357
  };
330
358
 
331
- Editor.displayName = 'Editor';
332
- Editor.propTypes = process.env.NODE_ENV !== "production" ? {
333
- children: PropTypes__default["default"].node.isRequired,
334
- id: PropTypes__default["default"].string,
335
- isOpen: PropTypes__default["default"].bool.isRequired,
336
- isDisabled: PropTypes__default["default"].bool,
337
- isReadOnly: PropTypes__default["default"].bool,
338
- hasWarning: PropTypes__default["default"].bool,
339
- hasError: PropTypes__default["default"].bool,
340
- editor: PropTypes__default["default"].any,
341
- error: PropTypes__default["default"].node,
342
- warning: PropTypes__default["default"].node,
343
- defaultExpandMultilineText: PropTypes__default["default"].bool.isRequired,
344
- toggleLanguage: PropTypes__default["default"].func.isRequired,
345
- language: PropTypes__default["default"].string.isRequired,
346
- showExpandIcon: PropTypes__default["default"].bool.isRequired,
347
- onClickExpand: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
348
- return props.showExpandIcon;
349
- }),
350
- hasLanguagesControl: PropTypes__default["default"].bool
351
- } : {};
352
- renderEditor.propTypes = process.env.NODE_ENV !== "production" ? {
353
- id: PropTypes__default["default"].string,
354
- name: PropTypes__default["default"].string,
355
- disabled: PropTypes__default["default"].bool,
356
- readOnly: PropTypes__default["default"].bool,
357
- editor: PropTypes__default["default"].any,
358
- options: PropTypes__default["default"].shape({
359
- language: PropTypes__default["default"].string.isRequired,
360
- error: PropTypes__default["default"].node,
361
- warning: PropTypes__default["default"].node,
362
- hasWarning: PropTypes__default["default"].bool,
363
- hasError: PropTypes__default["default"].bool,
364
- defaultExpandMultilineText: PropTypes__default["default"].bool.isRequired,
365
- toggleLanguage: PropTypes__default["default"].func.isRequired,
366
- isOpen: PropTypes__default["default"].bool.isRequired,
367
- showExpandIcon: PropTypes__default["default"].bool.isRequired,
368
- onClickExpand: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
369
- return props.showExpandIcon;
370
- }),
371
- hasLanguagesControl: PropTypes__default["default"].bool
372
- })
373
- } : {};
359
+ Editor$1.displayName = 'Editor';
374
360
  var renderEditor$1 = renderEditor;
375
361
 
362
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
363
+
364
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct__default["default"]) return false; if (_Reflect$construct__default["default"].sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); return true; } catch (e) { return false; } }
365
+
376
366
  function ownKeys$2(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; }
377
367
 
378
368
  function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$2(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$2(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
379
369
 
380
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
370
+ // This is a temporary wrapper component helping to mitigate typing issues of `slate-react@0.22.10` package.
371
+ // TODO: remove after upgrade of `slate-react` to the latest version
372
+ var Editor = function Editor(props) {
373
+ return jsxRuntime.jsx(slateReact.Editor, _objectSpread$2({}, props));
374
+ };
381
375
 
382
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct__default["default"]) return false; if (_Reflect$construct__default["default"].sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); return true; } catch (e) { return false; } }
376
+ Editor.propTypes = process.env.NODE_ENV !== "production" ? {
377
+ id: _pt__default["default"].string,
378
+ name: _pt__default["default"].string,
379
+ onFocus: _pt__default["default"].func,
380
+ onBlur: _pt__default["default"].func,
381
+ disabled: _pt__default["default"].bool,
382
+ readOnly: _pt__default["default"].bool,
383
+ value: _pt__default["default"].any.isRequired,
384
+ onChange: _pt__default["default"].func,
385
+ plugins: _pt__default["default"].any.isRequired,
386
+ renderEditor: _pt__default["default"].any.isRequired
387
+ } : {};
383
388
 
384
389
  var RichTextInput = /*#__PURE__*/function (_PureComponent) {
385
390
  _inherits(RichTextInput, _PureComponent);
@@ -415,6 +420,8 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
415
420
  // onChange unless this value changes.
416
421
 
417
422
  if (hasSerializedValueChanged) {
423
+ var _this$props$onChange, _this$props;
424
+
418
425
  var fakeEvent = {
419
426
  target: {
420
427
  id: _this.props.id,
@@ -423,8 +430,7 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
423
430
  value: serializedValue
424
431
  }
425
432
  };
426
-
427
- _this.props.onChange(fakeEvent);
433
+ (_this$props$onChange = (_this$props = _this.props).onChange) === null || _this$props$onChange === void 0 ? void 0 : _this$props$onChange.call(_this$props, fakeEvent);
428
434
  }
429
435
 
430
436
  if (hasInternalSlateValueChanged && !hasSerializedValueChanged) {
@@ -433,7 +439,7 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
433
439
  }
434
440
  };
435
441
 
436
- _this.onBlur = function (event, editor, next) {
442
+ _this.onBlur = function (_event, _editor, next) {
437
443
  next();
438
444
 
439
445
  if (_this.props.onBlur) {
@@ -445,12 +451,14 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
445
451
  };
446
452
 
447
453
  _setTimeout__default["default"](function () {
448
- return _this.props.onBlur(fakeEvent);
454
+ var _this$props$onBlur, _this$props2;
455
+
456
+ return (_this$props$onBlur = (_this$props2 = _this.props).onBlur) === null || _this$props$onBlur === void 0 ? void 0 : _this$props$onBlur.call(_this$props2, fakeEvent);
449
457
  }, 0);
450
458
  }
451
459
  };
452
460
 
453
- _this.onFocus = function (event, editor, next) {
461
+ _this.onFocus = function (_event, _editor, next) {
454
462
  next();
455
463
 
456
464
  if (_this.props.onFocus) {
@@ -462,7 +470,9 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
462
470
  };
463
471
 
464
472
  _setTimeout__default["default"](function () {
465
- return _this.props.onFocus(fakeEvent);
473
+ var _this$props$onFocus, _this$props3;
474
+
475
+ return (_this$props$onFocus = (_this$props3 = _this.props).onFocus) === null || _this$props$onFocus === void 0 ? void 0 : _this$props$onFocus.call(_this$props3, fakeEvent);
466
476
  }, 0);
467
477
  }
468
478
  };
@@ -482,7 +492,15 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
482
492
  }, {
483
493
  key: "render",
484
494
  value: function render() {
485
- return jsxRuntime.jsx(slateReact.Editor, _objectSpread$2(_objectSpread$2({}, utils.filterDataAttributes(this.props)), {}, {
495
+ if (!this.props.isReadOnly) {
496
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof this.props.onChange === 'function', 'RichTextInput: `onChange` is required when field is not read only.') : void 0;
497
+ }
498
+
499
+ if (this.props.showExpandIcon) {
500
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof this.props.onClickExpand === 'function', 'RichTextInput: "onClickExpand" is required when showExpandIcon is true') : void 0;
501
+ }
502
+
503
+ return jsxRuntime.jsx(Editor, _objectSpread$2(_objectSpread$2({}, utils.filterDataAttributes(this.props)), {}, {
486
504
  id: this.props.id,
487
505
  name: this.props.name,
488
506
  disabled: this.props.isDisabled,
@@ -493,9 +511,7 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
493
511
  // warning in the console,
494
512
  // so instead we pass our extra this.props through this `options` prop.
495
513
  ,
496
- options: _objectSpread$2({
497
- hasLanguagesControl: this.props.hasLanguagesControl
498
- }, pick__default["default"](this.props, ['language', 'onToggle', 'toggleLanguage', 'isOpen', 'warning', 'error', 'defaultExpandMultilineText', 'hasWarning', 'hasError', 'placeholder', 'onClickExpand', 'showExpandIcon'])),
514
+ options: pick__default["default"](this.props, ['language', 'onToggle', 'toggleLanguage', 'isOpen', 'warning', 'error', 'defaultExpandMultilineText', 'hasWarning', 'hasError', 'placeholder', 'onClickExpand', 'showExpandIcon', 'hasLanguagesControl']),
499
515
  onChange: this.onValueChange,
500
516
  plugins: richTextUtils.richTextPlugins,
501
517
  renderEditor: renderEditor$1
@@ -512,25 +528,26 @@ RichTextInput.defaultProps = {
512
528
  };
513
529
  RichTextInput.displayName = 'RichTextInput';
514
530
  RichTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
515
- defaultExpandMultilineText: PropTypes__default["default"].bool,
516
- hasError: PropTypes__default["default"].bool,
517
- hasWarning: PropTypes__default["default"].bool,
518
- id: PropTypes__default["default"].string,
519
- name: PropTypes__default["default"].string,
520
- placeholder: PropTypes__default["default"].string.isRequired,
521
- isDisabled: PropTypes__default["default"].bool,
522
- isReadOnly: PropTypes__default["default"].bool,
523
- onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
524
- return !props.isReadOnly;
525
- }),
526
- onFocus: PropTypes__default["default"].func,
527
- onBlur: PropTypes__default["default"].func,
528
- value: PropTypes__default["default"].string.isRequired,
529
- showExpandIcon: PropTypes__default["default"].bool.isRequired,
530
- onClickExpand: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
531
- return props.showExpandIcon;
532
- }),
533
- hasLanguagesControl: PropTypes__default["default"].bool
531
+ defaultExpandMultilineText: _pt__default["default"].bool,
532
+ hasError: _pt__default["default"].bool,
533
+ hasWarning: _pt__default["default"].bool,
534
+ id: _pt__default["default"].string,
535
+ name: _pt__default["default"].string,
536
+ placeholder: _pt__default["default"].string,
537
+ isDisabled: _pt__default["default"].bool,
538
+ isReadOnly: _pt__default["default"].bool,
539
+ onChange: _pt__default["default"].func,
540
+ onBlur: _pt__default["default"].func,
541
+ onFocus: _pt__default["default"].func,
542
+ value: _pt__default["default"].string.isRequired,
543
+ showExpandIcon: _pt__default["default"].bool.isRequired,
544
+ onClickExpand: _pt__default["default"].func,
545
+ hasLanguagesControl: _pt__default["default"].bool,
546
+ language: _pt__default["default"].string.isRequired,
547
+ isOpen: _pt__default["default"].bool.isRequired,
548
+ toggleLanguage: _pt__default["default"].func.isRequired,
549
+ warning: _pt__default["default"].node,
550
+ error: _pt__default["default"].string
534
551
  } : {};
535
552
  var RichTextInput$1 = RichTextInput;
536
553
 
@@ -547,13 +564,15 @@ var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
547
564
  RequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';
548
565
  var RequiredValueErrorMessage$1 = RequiredValueErrorMessage;
549
566
 
550
- var _templateObject;
551
-
552
567
  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; }
553
568
 
554
- 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; }
569
+ 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; }
555
570
 
556
571
  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)."; }
572
+ var defaultProps = {
573
+ horizontalConstraint: 'scale',
574
+ showExpandIcon: false
575
+ };
557
576
 
558
577
  var expandedTranslationsReducer = function expandedTranslationsReducer(state, action) {
559
578
  switch (action.type) {
@@ -588,13 +607,25 @@ var _ref = process.env.NODE_ENV === "production" ? {
588
607
  } : {
589
608
  name: "9a4cy7-LocalizedRichTextInput",
590
609
  styles: "align-self:flex-start;label:LocalizedRichTextInput;",
591
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-rich-text-input.js"],"names":[],"mappings":"AA8JoB","file":"localized-rich-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 { css } from '@emotion/react';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  isTouched,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport { localized } from '@commercetools-uikit/rich-text-utils';\nimport RichTextInput from './rich-text-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 rich text 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 LocalizedRichTextInput = (props) => {\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\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 shouldRenderLanguagesControl =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\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              <RichTextInput\n                key={language}\n                autoComplete={props.autoComplete}\n                id={LocalizedRichTextInput.getId(props.id, language)}\n                name={LocalizedRichTextInput.getName(props.name, language)}\n                value={props.value[language]}\n                onChange={props.onChange}\n                language={language}\n                isOpen={expandedTranslationsState[language]}\n                toggleLanguage={toggleLanguage}\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                toggleLanguages={toggleLanguages}\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                warning={props.warnings && props.warnings[language]}\n                error={props.errors && props.errors[language]}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n                hasLanguagesControl={hasLanguagesControl}\n                {...createLocalizedDataAttributes(props, language)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesControl && (\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\nLocalizedRichTextInput.displayName = 'LocalizedRichTextInput';\n\nLocalizedRichTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedRichTextInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  autoComplete: PropTypes.string,\n  // then input doesn't accept a \"languages\" prop, instead all possible\n  // languages have to exist (with empty or filled slate values) on the value:\n  //   { en: slateValue, de: slateValue, es: slateValue }\n  value: PropTypes.objectOf(PropTypes.any).isRequired,\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  selectedLanguage: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  defaultExpandMultilineText: PropTypes.bool,\n  hideLanguageExpansionControls: PropTypes.bool,\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  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  horizontalConstraint: PropTypes.oneOf([\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  hasError: PropTypes.bool,\n  hasWarning: PropTypes.bool,\n  errors: PropTypes.objectOf(PropTypes.node),\n  warnings: PropTypes.objectOf(PropTypes.node),\n  showExpandIcon: PropTypes.bool.isRequired,\n  onClickExpand: requiredIf(PropTypes.func, (props) => props.showExpandIcon),\n};\n\nLocalizedRichTextInput.getId = getId;\n\nLocalizedRichTextInput.getName = getName;\n\nLocalizedRichTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n  showExpandIcon: false,\n};\n\nLocalizedRichTextInput.createLocalizedString = localized.createLocalizedString;\n\nLocalizedRichTextInput.isEmpty = localized.isEmpty;\n\nLocalizedRichTextInput.omitEmptyTranslations = localized.omitEmptyTranslations;\n\nLocalizedRichTextInput.isTouched = isTouched;\n\nexport default LocalizedRichTextInput;\n"]} */",
610
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-rich-text-input.tsx"],"names":[],"mappings":"AAqToB","file":"localized-rich-text-input.tsx","sourcesContent":["import {\n  useReducer,\n  useCallback,\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n} from 'react';\nimport { css } from '@emotion/react';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  isTouched,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport { localized } from '@commercetools-uikit/rich-text-utils';\nimport { warning } from '@commercetools-uikit/utils';\nimport RichTextInput from './rich-text-input';\nimport RequiredValueErrorMessage from './required-value-error-message';\n\ntype TErrors = Record<string, string>;\ntype TWarnings = Record<string, ReactNode>;\n\ntype TEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    language?: string;\n    value?: string;\n  };\n};\n\ntype TLocalizedRichTextInputProps = {\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  // then input doesn't accept a \"languages\" prop, instead all possible\n  // languages have to exist (with empty or filled slate values) on the value:\n  //   { en: slateValue, de: slateValue, es: slateValue }\n  /**\n   * Values to use. Keyed by language, the values are the actual values, e.g. `{ en: '<p>Horse</p>', de: '<p>Pferd</p>' }\n   */\n  value: Record<string, string>;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: (event: TEvent) => void;\n  /**\n   * Specifies which language will be shown in case the `LocalizedRichTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   *Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur?: (event: TEvent) => void;\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus?: (event: TEvent) => void;\n  /**\n   * Expands input components holding multiline values instead of collapsing 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   * Disables all input\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\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\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 warning message.\n   */\n  hasWarning?: boolean;\n  /**\n   * Used to show errors underneath the inputs of specific languages. Pass an object whose key is a language and whose value is the error to show for that key.\n   */\n  errors?: TErrors;\n  /**\n   * Used to show warnings underneath the inputs of specific languages. Pass an object whose key is a language and whose value is the warning to show for that key.\n   */\n  warnings?: TWarnings;\n  /**\n   * Shows an `expand` icon in the toolbar\n   */\n  showExpandIcon: boolean;\n  /**\n   * Called when the `expand` button is clicked\n   */\n  onClickExpand?: () => boolean;\n};\n\ntype TReducerState = {\n  [id: string]: boolean;\n};\n\ntype TReducerAction =\n  | { type: 'toggle'; payload: string }\n  | { type: 'toggleAll'; payload: string };\n\nconst defaultProps: Pick<\n  TLocalizedRichTextInputProps,\n  'horizontalConstraint' | 'showExpandIcon'\n> = {\n  horizontalConstraint: 'scale',\n  showExpandIcon: false,\n};\n\nconst expandedTranslationsReducer = (\n  state: TReducerState,\n  action: TReducerAction\n) => {\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 rich text 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 LocalizedRichTextInput = (props: TLocalizedRichTextInputProps) => {\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedRichTextInput: `onChange` is required when input is not read only.'\n    );\n  }\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'LocalizedRichTextInput: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.defaultExpandLanguages !== 'boolean',\n      'LocalizedRichTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\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\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 shouldRenderLanguagesControl =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\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              <RichTextInput\n                key={language}\n                id={LocalizedRichTextInput.getId(props.id, language)}\n                name={LocalizedRichTextInput.getName(props.name, language)}\n                value={props.value[language]}\n                onChange={props.onChange}\n                language={language}\n                isOpen={expandedTranslationsState[language]}\n                toggleLanguage={toggleLanguage}\n                placeholder={\n                  props.placeholder ? props.placeholder[language] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[language])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[language])\n                )}\n                warning={props.warnings && props.warnings[language]}\n                error={props.errors && props.errors[language]}\n                showExpandIcon={props.showExpandIcon}\n                onClickExpand={props.onClickExpand}\n                hasLanguagesControl={hasLanguagesControl}\n                {...createLocalizedDataAttributes(props, language)}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesControl && (\n          <div\n            css={css`\n              align-self: flex-start;\n            `}\n          >\n            <LocalizedInputToggle\n              isOpen={areLanguagesOpened}\n              onClick={\n                toggleLanguages as (\n                  event:\n                    | MouseEvent<HTMLButtonElement>\n                    | KeyboardEvent<HTMLButtonElement>\n                    | boolean\n                ) => void\n              }\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\nLocalizedRichTextInput.displayName = 'LocalizedRichTextInput';\n\nLocalizedRichTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedRichTextInput.getId = getId;\n\nLocalizedRichTextInput.getName = getName;\n\nLocalizedRichTextInput.defaultProps = defaultProps;\n\nLocalizedRichTextInput.createLocalizedString = localized.createLocalizedString;\n\nLocalizedRichTextInput.isEmpty = localized.isEmpty;\n\nLocalizedRichTextInput.omitEmptyTranslations = localized.omitEmptyTranslations;\n\nLocalizedRichTextInput.isTouched = isTouched;\n\nexport default LocalizedRichTextInput;\n"]} */",
592
611
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
593
612
  };
594
613
 
595
614
  var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
596
615
  var _context2;
597
616
 
617
+ if (!props.isReadOnly) {
618
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocalizedRichTextInput: `onChange` is required when input is not read only.') : void 0;
619
+ }
620
+
621
+ if (props.showExpandIcon) {
622
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onClickExpand === 'function', 'LocalizedRichTextInput: "onClickExpand" is required when showExpandIcon is true') : void 0;
623
+ }
624
+
625
+ if (props.hideLanguageExpansionControls) {
626
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.defaultExpandLanguages !== 'boolean', 'LocalizedRichTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
627
+ }
628
+
598
629
  var initialExpandedTranslationsState = _reduceInstanceProperty__default["default"](_context2 = _Object$keys__default["default"](props.value)).call(_context2, function (translations, locale) {
599
630
  return _objectSpread(_defineProperty({}, locale, Boolean(props.defaultExpandMultilineText)), translations);
600
631
  }, {});
@@ -642,7 +673,6 @@ var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
642
673
  var isLastLanguage = index === languages.length - 1;
643
674
  var hasLanguagesControl = isFirstLanguage && !areLanguagesOpened || isLastLanguage;
644
675
  return jsxRuntime.jsx(RichTextInput$1, _objectSpread({
645
- autoComplete: props.autoComplete,
646
676
  id: LocalizedRichTextInput.getId(props.id, language),
647
677
  name: LocalizedRichTextInput.getName(props.name, language),
648
678
  value: props.value[language],
@@ -653,10 +683,8 @@ var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
653
683
  placeholder: props.placeholder ? props.placeholder[language] : undefined,
654
684
  onBlur: props.onBlur,
655
685
  onFocus: props.onFocus,
656
- isAutofocussed: index === 0 && props.isAutofocussed,
657
686
  isDisabled: props.isDisabled,
658
687
  isReadOnly: props.isReadOnly,
659
- toggleLanguages: toggleLanguages,
660
688
  hasError: Boolean(props.hasError || props.errors && props.errors[language]),
661
689
  hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[language]),
662
690
  warning: props.warnings && props.warnings[language],
@@ -679,57 +707,33 @@ var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
679
707
  });
680
708
  };
681
709
 
682
- LocalizedRichTextInput.displayName = 'LocalizedRichTextInput';
683
- LocalizedRichTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage$1;
684
710
  LocalizedRichTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
685
- id: PropTypes__default["default"].string,
686
- name: PropTypes__default["default"].string,
687
- autoComplete: PropTypes__default["default"].string,
688
- // then input doesn't accept a "languages" prop, instead all possible
689
- // languages have to exist (with empty or filled slate values) on the value:
690
- // { en: slateValue, de: slateValue, es: slateValue }
691
- value: PropTypes__default["default"].objectOf(PropTypes__default["default"].any).isRequired,
692
- onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
693
- return !props.isReadOnly;
694
- }),
695
- selectedLanguage: PropTypes__default["default"].string.isRequired,
696
- onBlur: PropTypes__default["default"].func,
697
- onFocus: PropTypes__default["default"].func,
698
- defaultExpandMultilineText: PropTypes__default["default"].bool,
699
- hideLanguageExpansionControls: PropTypes__default["default"].bool,
700
- defaultExpandLanguages: function defaultExpandLanguages(props, propName, componentName) {
701
- var _context3;
702
-
703
- if (props.hideLanguageExpansionControls && typeof props[propName] === 'boolean') {
704
- throw new Error(commonTags.oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideLanguageExpansionControls\" is set.\n "])), componentName, propName));
705
- }
706
-
707
- for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
708
- rest[_key - 3] = arguments[_key];
709
- }
710
-
711
- return PropTypes__default["default"].bool.apply(PropTypes__default["default"], _concatInstanceProperty__default["default"](_context3 = [props, propName, componentName]).call(_context3, rest));
712
- },
713
- isAutofocussed: PropTypes__default["default"].bool,
714
- isDisabled: PropTypes__default["default"].bool,
715
- isReadOnly: PropTypes__default["default"].bool,
716
- placeholder: PropTypes__default["default"].objectOf(PropTypes__default["default"].string),
717
- horizontalConstraint: PropTypes__default["default"].oneOf([7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
718
- hasError: PropTypes__default["default"].bool,
719
- hasWarning: PropTypes__default["default"].bool,
720
- errors: PropTypes__default["default"].objectOf(PropTypes__default["default"].node),
721
- warnings: PropTypes__default["default"].objectOf(PropTypes__default["default"].node),
722
- showExpandIcon: PropTypes__default["default"].bool.isRequired,
723
- onClickExpand: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
724
- return props.showExpandIcon;
725
- })
711
+ id: _pt__default["default"].string,
712
+ name: _pt__default["default"].string,
713
+ value: _pt__default["default"].objectOf(_pt__default["default"].string).isRequired,
714
+ onChange: _pt__default["default"].func,
715
+ selectedLanguage: _pt__default["default"].string.isRequired,
716
+ onBlur: _pt__default["default"].func,
717
+ onFocus: _pt__default["default"].func,
718
+ defaultExpandMultilineText: _pt__default["default"].bool,
719
+ hideLanguageExpansionControls: _pt__default["default"].bool,
720
+ defaultExpandLanguages: _pt__default["default"].bool,
721
+ isDisabled: _pt__default["default"].bool,
722
+ isReadOnly: _pt__default["default"].bool,
723
+ placeholder: _pt__default["default"].objectOf(_pt__default["default"].string),
724
+ horizontalConstraint: _pt__default["default"].oneOf([7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
725
+ hasError: _pt__default["default"].bool,
726
+ hasWarning: _pt__default["default"].bool,
727
+ errors: _pt__default["default"].objectOf(_pt__default["default"].string),
728
+ warnings: _pt__default["default"].objectOf(_pt__default["default"].node),
729
+ showExpandIcon: _pt__default["default"].bool.isRequired,
730
+ onClickExpand: _pt__default["default"].func
726
731
  } : {};
732
+ LocalizedRichTextInput.displayName = 'LocalizedRichTextInput';
733
+ LocalizedRichTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage$1;
727
734
  LocalizedRichTextInput.getId = localizedUtils.getId;
728
735
  LocalizedRichTextInput.getName = localizedUtils.getName;
729
- LocalizedRichTextInput.defaultProps = {
730
- horizontalConstraint: 'scale',
731
- showExpandIcon: false
732
- };
736
+ LocalizedRichTextInput.defaultProps = defaultProps;
733
737
  LocalizedRichTextInput.createLocalizedString = richTextUtils.localized.createLocalizedString;
734
738
  LocalizedRichTextInput.isEmpty = richTextUtils.localized.isEmpty;
735
739
  LocalizedRichTextInput.omitEmptyTranslations = richTextUtils.localized.omitEmptyTranslations;
@@ -737,7 +741,7 @@ LocalizedRichTextInput.isTouched = localizedUtils.isTouched;
737
741
  var LocalizedRichTextInput$1 = LocalizedRichTextInput;
738
742
 
739
743
  // NOTE: This string will be replaced on build time with the package version.
740
- var version = "13.0.3";
744
+ var version = "13.0.4";
741
745
 
742
746
  exports["default"] = LocalizedRichTextInput$1;
743
747
  exports.version = version;