@commercetools-uikit/localized-rich-text-input 12.2.2 → 12.2.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,18 +6,17 @@ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-st
6
6
  import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
7
7
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
8
8
  import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
9
- import _extends from '@babel/runtime-corejs3/helpers/esm/extends';
10
9
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
11
10
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
12
11
  import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
13
12
  import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
14
13
  import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
15
14
  import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
16
- import React from 'react';
15
+ import { cloneElement, useRef, useState, useCallback, useEffect, PureComponent, useReducer } from 'react';
17
16
  import PropTypes from 'prop-types';
18
17
  import requiredIf from 'react-required-if';
19
18
  import { oneLine } from 'common-tags';
20
- import { css, jsx, useTheme } from '@emotion/react';
19
+ import { css, useTheme } from '@emotion/react';
21
20
  import Stack from '@commercetools-uikit/spacings-stack';
22
21
  import Constraints from '@commercetools-uikit/constraints';
23
22
  import { usePrevious, useToggleState } from '@commercetools-uikit/hooks';
@@ -41,11 +40,12 @@ import CollapsibleMotion from '@commercetools-uikit/collapsible-motion';
41
40
  import { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';
42
41
  import Text from '@commercetools-uikit/text';
43
42
  import FlatButton from '@commercetools-uikit/flat-button';
43
+ import { jsxs, jsx } from '@emotion/react/jsx-runtime';
44
44
  import { ErrorMessage } from '@commercetools-uikit/messages';
45
45
 
46
- function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
46
+ function ownKeys$4(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
47
47
 
48
- function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty(_context = ownKeys$3(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context2; _forEachInstanceProperty(_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
48
+ function _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty(_context = ownKeys$4(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context2; _forEachInstanceProperty(_context2 = ownKeys$4(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
49
49
 
50
50
  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)."; }
51
51
 
@@ -55,10 +55,10 @@ var EditorLanguageLabel = _styled("label", process.env.NODE_ENV === "production"
55
55
  target: "e1ujjdh2",
56
56
  label: "EditorLanguageLabel"
57
57
  })(function (props) {
58
- var overwrittenVars = _objectSpread$3(_objectSpread$3({}, customProperties), props.theme);
58
+ var overwrittenVars = _objectSpread$4(_objectSpread$4({}, customProperties), props.theme);
59
59
 
60
- return /*#__PURE__*/css("white-space:nowrap;flex:0;color:", overwrittenVars[designTokens.fontColorForInputWhenDisabled], ";line-height:calc(\n ", customProperties.sizeHeightInput, " - 2 *\n ", customProperties.borderRadius1, "\n );background-color:", overwrittenVars[designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", customProperties.spacingS, ";transition:border-color ", customProperties.transitionStandard, ",background-color ", customProperties.transitionStandard, ",color ", customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;cursor:inherit;" + (process.env.NODE_ENV === "production" ? "" : ";label:EditorLanguageLabel;"));
61
- });
60
+ return /*#__PURE__*/css("white-space:nowrap;flex:0;color:", overwrittenVars[designTokens.fontColorForInputWhenDisabled], ";line-height:calc(\n ", customProperties.sizeHeightInput, " - 2 *\n ", customProperties.borderRadius1, "\n );background-color:", overwrittenVars[designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", customProperties.spacingS, ";transition:border-color ", customProperties.transitionStandard, ",background-color ", customProperties.transitionStandard, ",color ", 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= */");
61
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRCIiwiZmlsZSI6ImVkaXRvci5zdHlsZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBpbXBvcnQvcHJlZmVyLWRlZmF1bHQtZXhwb3J0ICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5jb25zdCBFZGl0b3JMYW5ndWFnZUxhYmVsID0gc3R5bGVkLmxhYmVsKChwcm9wcykgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4uY3VzdG9tUHJvcGVydGllcyxcbiAgICAuLi5wcm9wcy50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICBmbGV4OiAwO1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAgICR7Y3VzdG9tUHJvcGVydGllcy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqXG4gICAgICAgICR7Y3VzdG9tUHJvcGVydGllcy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2N1c3RvbVByb3BlcnRpZXMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuXG4gICAgLyogY3Vyc29yIHNob3VsZCBiZSBpbmhlcml0ZWQgZnJvbSBwYXJlbnQsXG4gICAgKiBHSVZFTiBwYXJlbnQgaGFzICdub3QtYWxsb3dlZCcgY3Vyc29yXG4gICAgKiBUSEVOIHRoZSBsYW5ndWFnZSBsYWJlbCBzaG91bGQgYWxzbyBoYXZlIHRoYXQgKGluc3RlYWQgb2YgbGFiZWwncyBkZWZhdWx0IGN1cnNvcilcbiAgICAqL1xuICAgIGN1cnNvcjogaW5oZXJpdDtcbiAgYDtcbn0pO1xuXG5jb25zdCBFZGl0b3JXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6IDEwMCU7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgY3Vyc29yOiAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5pc0Rpc2FibGVkIHx8IHByb3BzLmlzUmVhZE9ubHkgPyAnbm90LWFsbG93ZWQnIDogJ2luaGVyaXQnfTtcbmA7XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgRWRpdG9yTGFuZ3VhZ2VMYWJlbCwgRWRpdG9yV3JhcHBlciwgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */");
62
62
 
63
63
  var EditorWrapper = _styled("div", process.env.NODE_ENV === "production" ? {
64
64
  target: "e1ujjdh1"
@@ -67,7 +67,7 @@ var EditorWrapper = _styled("div", process.env.NODE_ENV === "production" ? {
67
67
  label: "EditorWrapper"
68
68
  })("width:100%;position:relative;display:flex;cursor:", function (props) {
69
69
  return props.isDisabled || props.isReadOnly ? 'not-allowed' : 'inherit';
70
- }, ";");
70
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0RnQyIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgaW1wb3J0L3ByZWZlci1kZWZhdWx0LWV4cG9ydCAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgRWRpdG9yTGFuZ3VhZ2VMYWJlbCA9IHN0eWxlZC5sYWJlbCgocHJvcHMpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLmN1c3RvbVByb3BlcnRpZXMsXG4gICAgLi4ucHJvcHMudGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgZmxleDogMDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke2N1c3RvbVByb3BlcnRpZXMuc2l6ZUhlaWdodElucHV0fSAtIDIgKlxuICAgICAgICAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzMX1cbiAgICApO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcblxuICAgIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgICBjdXJzb3I6IGluaGVyaXQ7XG4gIGA7XG59KTtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHdpZHRoOiAxMDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGN1cnNvcjogJHsocHJvcHMpID0+XG4gICAgcHJvcHMuaXNEaXNhYmxlZCB8fCBwcm9wcy5pc1JlYWRPbmx5ID8gJ25vdC1hbGxvd2VkJyA6ICdpbmhlcml0J307XG5gO1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IEVkaXRvckxhbmd1YWdlTGFiZWwsIEVkaXRvcldyYXBwZXIsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */"));
71
71
 
72
72
  var ToggleButtonWrapper = _styled("div", process.env.NODE_ENV === "production" ? {
73
73
  target: "e1ujjdh0"
@@ -80,12 +80,13 @@ var ToggleButtonWrapper = _styled("div", process.env.NODE_ENV === "production" ?
80
80
  } : {
81
81
  name: "ejz79s",
82
82
  styles: "flex:0;display:flex",
83
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMERzQyIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgaW1wb3J0L3ByZWZlci1kZWZhdWx0LWV4cG9ydCAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcblxuY29uc3QgRWRpdG9yTGFuZ3VhZ2VMYWJlbCA9IHN0eWxlZC5sYWJlbCgocHJvcHMpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLmN1c3RvbVByb3BlcnRpZXMsXG4gICAgLi4ucHJvcHMudGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgZmxleDogMDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke2N1c3RvbVByb3BlcnRpZXMuc2l6ZUhlaWdodElucHV0fSAtIDIgKlxuICAgICAgICAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzMX1cbiAgICApO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtjdXN0b21Qcm9wZXJ0aWVzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7Y3VzdG9tUHJvcGVydGllcy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtjdXN0b21Qcm9wZXJ0aWVzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcblxuICAgIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgICBjdXJzb3I6IGluaGVyaXQ7XG4gIGA7XG59KTtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHdpZHRoOiAxMDAlO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGN1cnNvcjogJHsocHJvcHMpID0+XG4gICAgcHJvcHMuaXNEaXNhYmxlZCB8fCBwcm9wcy5pc1JlYWRPbmx5ID8gJ25vdC1hbGxvd2VkJyA6ICdpbmhlcml0J307XG5gO1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IEVkaXRvckxhbmd1YWdlTGFiZWwsIEVkaXRvcldyYXBwZXIsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
83
84
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
84
85
  });
85
86
 
86
- function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
87
+ function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
87
88
 
88
- function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty(_context = ownKeys$2(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context2; _forEachInstanceProperty(_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
89
+ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty(_context = ownKeys$3(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context2; _forEachInstanceProperty(_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
89
90
 
90
91
  function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
91
92
  var COLLAPSED_HEIGHT = 32;
@@ -101,6 +102,7 @@ var LeftColumn = _styled("div", process.env.NODE_ENV === "production" ? {
101
102
  } : {
102
103
  name: "147rp59",
103
104
  styles: "flex:1;display:flex;align-items:flex-start",
105
+ 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"]} */",
104
106
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
105
107
  });
106
108
 
@@ -115,6 +117,7 @@ var RightColumn = _styled("div", process.env.NODE_ENV === "production" ? {
115
117
  } : {
116
118
  name: "1m04uhl",
117
119
  styles: "position:relative;flex:0;display:flex;align-items:flex-start",
120
+ 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"]} */",
118
121
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
119
122
  });
120
123
 
@@ -129,6 +132,7 @@ var Row = _styled("div", process.env.NODE_ENV === "production" ? {
129
132
  } : {
130
133
  name: "skgbeu",
131
134
  styles: "display:flex;justify-content:flex-end",
135
+ 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"]} */",
132
136
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
133
137
  });
134
138
 
@@ -138,24 +142,25 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
138
142
  } : {
139
143
  name: "16ohn6x-container",
140
144
  styles: "flex:auto;width:0;border-top-left-radius:0;border-bottom-left-radius:0;label:container;",
145
+ 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"]} */",
141
146
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
142
147
  };
143
148
 
144
149
  var Editor = function Editor(props) {
145
150
  var intl = useIntl();
146
- var ref = React.useRef();
151
+ var ref = useRef();
147
152
  var prevIsFocused = usePrevious(props.editor.value.selection.isFocused);
148
153
 
149
- var _React$useState = React.useState(false),
150
- _React$useState2 = _slicedToArray(_React$useState, 2),
151
- renderToggleButton = _React$useState2[0],
152
- setRenderToggleButton = _React$useState2[1];
154
+ var _useState = useState(false),
155
+ _useState2 = _slicedToArray(_useState, 2),
156
+ renderToggleButton = _useState2[0],
157
+ setRenderToggleButton = _useState2[1];
153
158
 
154
159
  var toggleLanguage = props.toggleLanguage;
155
- var onToggle = React.useCallback(function () {
160
+ var onToggle = useCallback(function () {
156
161
  toggleLanguage(props.language);
157
162
  }, [toggleLanguage, props.language]);
158
- var updateRenderToggleButton = React.useCallback(function () {
163
+ var updateRenderToggleButton = useCallback(function () {
159
164
  var doesExceedCollapsedHeightLimit = ref.current.clientHeight > COLLAPSED_HEIGHT;
160
165
 
161
166
  if (doesExceedCollapsedHeightLimit && !renderToggleButton) {
@@ -166,7 +171,7 @@ var Editor = function Editor(props) {
166
171
  setRenderToggleButton(false);
167
172
  }
168
173
  }, [setRenderToggleButton, renderToggleButton]);
169
- React.useEffect(function () {
174
+ useEffect(function () {
170
175
  updateRenderToggleButton();
171
176
  }, [props.editor.value.document, updateRenderToggleButton]); // opens the input if it regains focus and it's closed
172
177
 
@@ -189,89 +194,108 @@ var Editor = function Editor(props) {
189
194
  minHeight: COLLAPSED_HEIGHT,
190
195
  isClosed: !props.isOpen,
191
196
  onToggle: onToggle,
192
- isDefaultClosed: !props.defaultExpandMultilineText
193
- }, function (_ref2) {
194
- var isOpen = _ref2.isOpen,
195
- toggle = _ref2.toggle,
196
- containerStyles = _ref2.containerStyles,
197
- registerContentNode = _ref2.registerContentNode;
198
- return jsx(Stack, {
199
- scale: "xs"
200
- }, jsx(EditorWrapper, {
201
- key: props.language,
202
- isDisabled: props.isDisabled,
203
- isReadOnly: props.isReadOnly
204
- }, jsx(EditorLanguageLabel, {
205
- htmlFor: props.id,
206
- theme: theme
207
- }, jsx(Text.Detail, {
208
- tone: "secondary"
209
- }, props.language.toUpperCase())), jsx(RichTextBody, {
210
- ref: {
211
- containerRef: ref,
212
- registerContentNode: registerContentNode
213
- },
214
- styles: {
215
- container: _ref$1
216
- },
217
- isOpen: props.isOpen,
218
- hasError: props.hasError,
219
- isDisabled: props.isDisabled,
220
- hasWarning: props.hasWarning,
221
- isReadOnly: props.isReadOnly,
222
- editor: props.editor,
223
- containerStyles: containerStyles,
224
- showExpandIcon: props.showExpandIcon,
225
- onClickExpand: props.onClickExpand
226
- }, props.children)), jsx(Row // NOTE: applying this style withing the `styled` component results in the production
227
- // bundle to apply the style in the wrong order.
228
- // For instance, we need to override the marging of the spacing component, which also
229
- // uses `!important`.
230
- // Anyway, apparently by passing the style as a `css` prop to the `styled` component
231
- // does the trick.
232
- // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
233
- , {
234
- css: /*#__PURE__*/css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"))
235
- }, function () {
236
- if (props.error) return jsx(LeftColumn, null, jsx("div", null, props.error));
237
- if (props.warning) return jsx(LeftColumn, null, jsx("div", null, props.warning));
238
- return null;
239
- }(), renderToggleButton && jsx(RightColumn, null, jsx(ToggleButtonWrapper, {
240
- css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/css("position:absolute;top:0;right:0;margin-top:", customProperties.spacingXs, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;")), process.env.NODE_ENV === "production" ? "" : ";label:Editor;"]
241
- }, jsx(FlatButton, {
242
- onClick: toggle,
243
- label: intl.formatMessage(isOpen ? messagesMultilineInput.collapse : messagesMultilineInput.expand),
244
- icon: isOpen ? jsx(AngleUpIcon, {
245
- size: "small"
246
- }) : jsx(AngleDownIcon, {
247
- size: "small"
248
- })
249
- })))));
197
+ isDefaultClosed: !props.defaultExpandMultilineText,
198
+ children: function children(_ref2) {
199
+ var isOpen = _ref2.isOpen,
200
+ toggle = _ref2.toggle,
201
+ containerStyles = _ref2.containerStyles,
202
+ registerContentNode = _ref2.registerContentNode;
203
+ return jsxs(Stack, {
204
+ scale: "xs",
205
+ children: [jsxs(EditorWrapper, {
206
+ isDisabled: props.isDisabled,
207
+ isReadOnly: props.isReadOnly,
208
+ children: [jsx(EditorLanguageLabel, {
209
+ htmlFor: props.id,
210
+ theme: theme,
211
+ children: jsx(Text.Detail, {
212
+ tone: "secondary",
213
+ children: props.language.toUpperCase()
214
+ })
215
+ }), jsx(RichTextBody, {
216
+ ref: {
217
+ containerRef: ref,
218
+ registerContentNode: registerContentNode
219
+ },
220
+ styles: {
221
+ container: _ref$1
222
+ },
223
+ isOpen: props.isOpen,
224
+ hasError: props.hasError,
225
+ isDisabled: props.isDisabled,
226
+ hasWarning: props.hasWarning,
227
+ isReadOnly: props.isReadOnly,
228
+ editor: props.editor,
229
+ containerStyles: containerStyles,
230
+ showExpandIcon: props.showExpandIcon,
231
+ onClickExpand: props.onClickExpand,
232
+ children: props.children
233
+ })]
234
+ }, props.language), jsxs(Row // NOTE: applying this style withing the `styled` component results in the production
235
+ // bundle to apply the style in the wrong order.
236
+ // For instance, we need to override the marging of the spacing component, which also
237
+ // uses `!important`.
238
+ // Anyway, apparently by passing the style as a `css` prop to the `styled` component
239
+ // does the trick.
240
+ // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
241
+ , {
242
+ css: /*#__PURE__*/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"]} */"),
243
+ children: [function () {
244
+ if (props.error) return jsx(LeftColumn, {
245
+ children: jsx("div", {
246
+ children: props.error
247
+ })
248
+ });
249
+ if (props.warning) return jsx(LeftColumn, {
250
+ children: jsx("div", {
251
+ children: props.warning
252
+ })
253
+ });
254
+ return null;
255
+ }(), renderToggleButton && jsx(RightColumn, {
256
+ children: jsx(ToggleButtonWrapper, {
257
+ css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/css("position:absolute;top:0;right:0;margin-top:", 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"]} */"],
258
+ children: jsx(FlatButton, {
259
+ onClick: toggle,
260
+ label: intl.formatMessage(isOpen ? messagesMultilineInput.collapse : messagesMultilineInput.expand),
261
+ icon: isOpen ? jsx(AngleUpIcon, {
262
+ size: "small"
263
+ }) : jsx(AngleDownIcon, {
264
+ size: "small"
265
+ })
266
+ })
267
+ })
268
+ })]
269
+ })]
270
+ });
271
+ }
250
272
  });
251
273
  }; // eslint-disable-next-line react/display-name
252
274
 
253
275
 
254
276
  var renderEditor = function renderEditor(props, editor, next) {
255
277
  var internalId = "".concat(props.id, "__internal__id");
256
- var children = /*#__PURE__*/React.cloneElement(next(), {
278
+ var children = /*#__PURE__*/cloneElement(next(), {
257
279
  id: internalId
258
280
  });
259
281
 
260
- var passedProps = _objectSpread$2(_objectSpread$2({
282
+ var passedProps = _objectSpread$3(_objectSpread$3({
261
283
  id: props.id,
262
284
  isDisabled: props.disabled,
263
285
  isReadOnly: props.readOnly
264
286
  }, pick(props.options, ['defaultExpandMultilineText', 'language', 'warning', 'error', 'hasWarning', 'hasError', 'toggleLanguage', 'isOpen', 'showExpandIcon', 'onClickExpand', 'hasLanguagesControl'])), filterDataAttributes(props));
265
287
 
266
288
  var isFocused = props.editor.value.selection.isFocused;
267
- return jsx(Editor, _extends({
289
+ return jsxs(Editor, _objectSpread$3(_objectSpread$3({
268
290
  editor: editor
269
- }, passedProps), children, jsx(HiddenInput, {
270
- isFocused: isFocused,
271
- handleFocus: editor.focus,
272
- disabled: props.disabled,
273
- readOnly: props.readOnly,
274
- id: props.id
291
+ }, passedProps), {}, {
292
+ children: [children, jsx(HiddenInput, {
293
+ isFocused: isFocused,
294
+ handleFocus: editor.focus,
295
+ disabled: props.disabled,
296
+ readOnly: props.readOnly,
297
+ id: props.id
298
+ })]
275
299
  }));
276
300
  };
277
301
 
@@ -320,16 +344,16 @@ renderEditor.propTypes = process.env.NODE_ENV !== "production" ? {
320
344
  } : {};
321
345
  var renderEditor$1 = renderEditor;
322
346
 
323
- function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
347
+ function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
324
348
 
325
- function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys$1(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context3; _forEachInstanceProperty(_context3 = ownKeys$1(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
349
+ function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys$2(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context3; _forEachInstanceProperty(_context3 = ownKeys$2(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
326
350
 
327
351
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
328
352
 
329
353
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct) return false; if (_Reflect$construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
330
354
 
331
- var RichTextInput = /*#__PURE__*/function (_React$PureComponent) {
332
- _inherits(RichTextInput, _React$PureComponent);
355
+ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
356
+ _inherits(RichTextInput, _PureComponent);
333
357
 
334
358
  var _super = _createSuper(RichTextInput);
335
359
 
@@ -429,7 +453,7 @@ var RichTextInput = /*#__PURE__*/function (_React$PureComponent) {
429
453
  }, {
430
454
  key: "render",
431
455
  value: function render() {
432
- return jsx(Editor$1, _extends({}, filterDataAttributes(this.props), {
456
+ return jsx(Editor$1, _objectSpread$2(_objectSpread$2({}, filterDataAttributes(this.props)), {}, {
433
457
  id: this.props.id,
434
458
  name: this.props.name,
435
459
  disabled: this.props.isDisabled,
@@ -440,7 +464,7 @@ var RichTextInput = /*#__PURE__*/function (_React$PureComponent) {
440
464
  // warning in the console,
441
465
  // so instead we pass our extra this.props through this `options` prop.
442
466
  ,
443
- options: _objectSpread$1({
467
+ options: _objectSpread$2({
444
468
  hasLanguagesControl: this.props.hasLanguagesControl
445
469
  }, pick(this.props, ['language', 'onToggle', 'toggleLanguage', 'isOpen', 'warning', 'error', 'defaultExpandMultilineText', 'hasWarning', 'hasError', 'placeholder', 'onClickExpand', 'showExpandIcon'])),
446
470
  onChange: this.onValueChange,
@@ -451,7 +475,7 @@ var RichTextInput = /*#__PURE__*/function (_React$PureComponent) {
451
475
  }]);
452
476
 
453
477
  return RichTextInput;
454
- }(React.PureComponent);
478
+ }(PureComponent);
455
479
 
456
480
  RichTextInput.defaultProps = {
457
481
  defaultExpandMultilineText: false,
@@ -481,8 +505,14 @@ RichTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
481
505
  } : {};
482
506
  var RichTextInput$1 = RichTextInput;
483
507
 
508
+ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
509
+
510
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty(_context = ownKeys$1(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { var _context2; _forEachInstanceProperty(_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
511
+
484
512
  var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
485
- return jsx(ErrorMessage, null, jsx(FormattedMessage, messagesLocalizedInput.missingRequiredField));
513
+ return jsx(ErrorMessage, {
514
+ children: jsx(FormattedMessage, _objectSpread$1({}, messagesLocalizedInput.missingRequiredField))
515
+ });
486
516
  };
487
517
 
488
518
  RequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';
@@ -529,6 +559,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
529
559
  } : {
530
560
  name: "9a4cy7-LocalizedRichTextInput",
531
561
  styles: "align-self:flex-start;label:LocalizedRichTextInput;",
562
+ 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"]} */",
532
563
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
533
564
  };
534
565
 
@@ -539,10 +570,10 @@ var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
539
570
  return _objectSpread(_defineProperty({}, locale, Boolean(props.defaultExpandMultilineText)), translations);
540
571
  }, {});
541
572
 
542
- var _React$useReducer = React.useReducer(expandedTranslationsReducer, initialExpandedTranslationsState),
543
- _React$useReducer2 = _slicedToArray(_React$useReducer, 2),
544
- expandedTranslationsState = _React$useReducer2[0],
545
- expandedTranslationsDispatch = _React$useReducer2[1];
573
+ var _useReducer = useReducer(expandedTranslationsReducer, initialExpandedTranslationsState),
574
+ _useReducer2 = _slicedToArray(_useReducer, 2),
575
+ expandedTranslationsState = _useReducer2[0],
576
+ expandedTranslationsDispatch = _useReducer2[1];
546
577
 
547
578
  var defaultExpansionState = props.hideLanguageExpansionControls || props.defaultExpandLanguages || // useToggleState's default is `true`, but we want `false`
548
579
  false;
@@ -552,7 +583,7 @@ var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
552
583
  areLanguagesOpened = _useToggleState2[0],
553
584
  toggleLanguages = _useToggleState2[1];
554
585
 
555
- var toggleLanguage = React.useCallback(function (language) {
586
+ var toggleLanguage = useCallback(function (language) {
556
587
  expandedTranslationsDispatch({
557
588
  type: 'toggle',
558
589
  payload: language
@@ -572,47 +603,51 @@ var LocalizedRichTextInput = function LocalizedRichTextInput(props) {
572
603
 
573
604
  var shouldRenderLanguagesControl = languages.length > 1 && !props.hideLanguageExpansionControls;
574
605
  return jsx(Constraints.Horizontal, {
575
- max: props.horizontalConstraint
576
- }, jsx(Stack, {
577
- scale: "xs"
578
- }, jsx(Stack, null, _mapInstanceProperty(languages).call(languages, function (language, index) {
579
- var isFirstLanguage = index === 0;
580
- if (!isFirstLanguage && !areLanguagesOpened) return null;
581
- var isLastLanguage = index === languages.length - 1;
582
- var hasLanguagesControl = isFirstLanguage && !areLanguagesOpened || isLastLanguage;
583
- return jsx(RichTextInput$1, _extends({
584
- key: language,
585
- autoComplete: props.autoComplete,
586
- id: LocalizedRichTextInput.getId(props.id, language),
587
- name: LocalizedRichTextInput.getName(props.name, language),
588
- value: props.value[language],
589
- onChange: props.onChange,
590
- language: language,
591
- isOpen: expandedTranslationsState[language],
592
- toggleLanguage: toggleLanguage,
593
- placeholder: props.placeholder ? props.placeholder[language] : undefined,
594
- onBlur: props.onBlur,
595
- onFocus: props.onFocus,
596
- isAutofocussed: index === 0 && props.isAutofocussed,
597
- isDisabled: props.isDisabled,
598
- isReadOnly: props.isReadOnly,
599
- toggleLanguages: toggleLanguages,
600
- hasError: Boolean(props.hasError || props.errors && props.errors[language]),
601
- hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[language]),
602
- warning: props.warnings && props.warnings[language],
603
- error: props.errors && props.errors[language],
604
- showExpandIcon: props.showExpandIcon,
605
- onClickExpand: props.onClickExpand,
606
- hasLanguagesControl: hasLanguagesControl
607
- }, createLocalizedDataAttributes(props, language)));
608
- })), shouldRenderLanguagesControl && jsx("div", {
609
- css: _ref
610
- }, jsx(LocalizedInputToggle, {
611
- isOpen: areLanguagesOpened,
612
- onClick: toggleLanguages,
613
- isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
614
- remainingLocalizations: languages.length - 1
615
- }))));
606
+ max: props.horizontalConstraint,
607
+ children: jsxs(Stack, {
608
+ scale: "xs",
609
+ children: [jsx(Stack, {
610
+ children: _mapInstanceProperty(languages).call(languages, function (language, index) {
611
+ var isFirstLanguage = index === 0;
612
+ if (!isFirstLanguage && !areLanguagesOpened) return null;
613
+ var isLastLanguage = index === languages.length - 1;
614
+ var hasLanguagesControl = isFirstLanguage && !areLanguagesOpened || isLastLanguage;
615
+ return jsx(RichTextInput$1, _objectSpread({
616
+ autoComplete: props.autoComplete,
617
+ id: LocalizedRichTextInput.getId(props.id, language),
618
+ name: LocalizedRichTextInput.getName(props.name, language),
619
+ value: props.value[language],
620
+ onChange: props.onChange,
621
+ language: language,
622
+ isOpen: expandedTranslationsState[language],
623
+ toggleLanguage: toggleLanguage,
624
+ placeholder: props.placeholder ? props.placeholder[language] : undefined,
625
+ onBlur: props.onBlur,
626
+ onFocus: props.onFocus,
627
+ isAutofocussed: index === 0 && props.isAutofocussed,
628
+ isDisabled: props.isDisabled,
629
+ isReadOnly: props.isReadOnly,
630
+ toggleLanguages: toggleLanguages,
631
+ hasError: Boolean(props.hasError || props.errors && props.errors[language]),
632
+ hasWarning: Boolean(props.hasWarning || props.warnings && props.warnings[language]),
633
+ warning: props.warnings && props.warnings[language],
634
+ error: props.errors && props.errors[language],
635
+ showExpandIcon: props.showExpandIcon,
636
+ onClickExpand: props.onClickExpand,
637
+ hasLanguagesControl: hasLanguagesControl
638
+ }, createLocalizedDataAttributes(props, language)), language);
639
+ })
640
+ }), shouldRenderLanguagesControl && jsx("div", {
641
+ css: _ref,
642
+ children: jsx(LocalizedInputToggle, {
643
+ isOpen: areLanguagesOpened,
644
+ onClick: toggleLanguages,
645
+ isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
646
+ remainingLocalizations: languages.length - 1
647
+ })
648
+ })]
649
+ })
650
+ });
616
651
  };
617
652
 
618
653
  LocalizedRichTextInput.displayName = 'LocalizedRichTextInput';
@@ -672,7 +707,7 @@ LocalizedRichTextInput.omitEmptyTranslations = localized.omitEmptyTranslations;
672
707
  LocalizedRichTextInput.isTouched = isTouched;
673
708
  var LocalizedRichTextInput$1 = LocalizedRichTextInput;
674
709
 
675
- // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
676
- var version = '12.2.2';
710
+ // NOTE: This string will be replaced on build time with the package version.
711
+ var version = "12.2.6";
677
712
 
678
713
  export { LocalizedRichTextInput$1 as default, version };