@commercetools-uikit/localized-text-input 12.2.7 → 13.0.2

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.
package/README.md CHANGED
@@ -48,25 +48,25 @@ export default Example;
48
48
 
49
49
  ## Properties
50
50
 
51
- | Props | Type | Required | Default | Description |
52
- | ------------------------------- | -------------------------------------------------------------------------------------------------------- | :------: | --------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------- |
53
- | `id` | `string` | | | |
54
- | `name` | `string` | | | |
55
- | `autoComplete` | `string` | | | |
56
- | `value` | `objectOf(string)` | ✅ | | |
57
- | `onChange` | `custom` | | | Gets called when any input is changed. Is called with the change event of the changed input. |
58
- | `selectedLanguage` | `string` | ✅ | | Specifies which language will be shown in case the `LocalizedTextInput` is collapsed. |
59
- | `onBlur` | `func` | | | Called when any field is blurred. Is called with the `event` of that field. |
60
- | `onFocus` | `func` | | | Called when any field is focussed. Is called with the `event` of that field. |
61
- | `hideLanguageExpansionControls` | `bool` | | | Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`. |
62
- | `defaultExpandLanguages` | `custom` | | | Controls whether one or all languages are visible by default |
63
- | `isAutofocussed` | `bool` | | | Focus the input field on initial render |
64
- | `isDisabled` | `bool` | | | Disables all input fields. |
65
- | `isReadOnly` | `bool` | | | Disables all input fields and shows them in read-only mode. |
66
- | `placeholder` | `objectOf(string)` | | | Placeholders for each language. Object of the same shape as `value`. |
67
- | `horizontalConstraint` | `enum`<br/>Possible values:<br/>`1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | Horizontal size limit of the input fields. |
68
- | `hasError` | `bool` | | | Will apply the error state to each input without showing any error message. |
69
- | `errors` | `objectOf(node)` | | | Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key. |
51
+ | Props | Type | Required | Default | Description |
52
+ | ------------------------------- | ----------------------------------------------------------------------------------------------------------- | :------: | --------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
53
+ | `id` | `string` | | | |
54
+ | `name` | `string` | | | |
55
+ | `autoComplete` | `string` | | | |
56
+ | `value` | `Record` | ✅ | | then input doesn't accept a "languages" prop, instead all possible&#xA;languages have to exist (with empty or filled strings) on the value:&#xA;{ en: 'foo', de: '', es: '' } |
57
+ | `onChange` | `ChangeEventHandler` | | | Gets called when any input is changed. Is called with the change event of the changed input. |
58
+ | `selectedLanguage` | `string` | ✅ | | Specifies which language will be shown in case the `LocalizedTextInput` is collapsed. |
59
+ | `onBlur` | `FocusEventHandler` | | | Called when any field is blurred. Is called with the `event` of that field. |
60
+ | `onFocus` | `FocusEventHandler` | | | Called when any field is focussed. Is called with the `event` of that field. |
61
+ | `hideLanguageExpansionControls` | `boolean` | | | Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`. |
62
+ | `defaultExpandLanguages` | `boolean` | | | Controls whether one or all languages are visible by default |
63
+ | `isAutofocussed` | `boolean` | | | Focus the input field on initial render |
64
+ | `isDisabled` | `boolean` | | | Disables all input fields. |
65
+ | `isReadOnly` | `boolean` | | | Disables all input fields and shows them in read-only mode. |
66
+ | `placeholder` | `Record` | | | Placeholders for each language. Object of the same shape as `value`. |
67
+ | `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | Horizontal size limit of the input fields. |
68
+ | `hasError` | `boolean` | | | Will apply the error state to each input without showing any error message. |
69
+ | `errors` | `Record` | | | Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key. |
70
70
 
71
71
  ## `data-*` props
72
72
 
@@ -0,0 +1,2 @@
1
+ export * from "./declarations/src/index";
2
+ export { default } from "./declarations/src/index";
@@ -9,16 +9,12 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
9
9
  var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
10
10
  var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
11
11
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
12
- var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
13
12
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
14
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
+ var _pt = require('prop-types');
15
15
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
16
16
  var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
17
- var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
18
17
  var react$1 = require('react');
19
- var PropTypes = require('prop-types');
20
- var requiredIf = require('react-required-if');
21
- var commonTags = require('common-tags');
22
18
  var reactIntl = require('react-intl');
23
19
  var react = require('@emotion/react');
24
20
  var hooks = require('@commercetools-uikit/hooks');
@@ -42,19 +38,17 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
42
38
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
43
39
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
44
40
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
41
+ var _pt__default = /*#__PURE__*/_interopDefault(_pt);
45
42
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
46
43
  var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
47
- var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
48
- var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
49
- var requiredIf__default = /*#__PURE__*/_interopDefault(requiredIf);
50
44
  var Stack__default = /*#__PURE__*/_interopDefault(Stack);
51
45
  var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
52
46
  var Text__default = /*#__PURE__*/_interopDefault(Text);
53
47
  var TextInput__default = /*#__PURE__*/_interopDefault(TextInput);
54
48
 
55
- function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (enumerableOnly) { symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
49
+ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
56
50
 
57
- function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
51
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
58
52
 
59
53
  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)."; }
60
54
  // * a disabled-field currently does not display warning/error-states so it takes precedence
@@ -67,7 +61,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
67
61
  } : {
68
62
  name: "bqcila-getLocalizedInputStyles",
69
63
  styles: "border-top-left-radius:0;border-bottom-left-radius:0;border-style:solid;flex:auto;label:getLocalizedInputStyles;",
70
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXSyIsImZpbGUiOiJsb2NhbGl6ZWQtdGV4dC1pbnB1dC5zdHlsZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcyA9ICgpID0+IFtcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItc3R5bGU6IHNvbGlkO1xuICAgIGZsZXg6IGF1dG87XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzLCB0aGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBsaW5lLWhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuZXhwb3J0IHsgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMgfTtcbiJdfQ== */",
64
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXSyIsImZpbGUiOiJsb2NhbGl6ZWQtdGV4dC1pbnB1dC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHR5cGUgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcyA9ICgpID0+IFtcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItc3R5bGU6IHNvbGlkO1xuICAgIGZsZXg6IGF1dG87XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKF9wcm9wczogdW5rbm93biwgdGhlbWU6IFRoZW1lKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi52YXJzLFxuICAgIC4uLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBoZWlnaHQ6ICR7dmFycy5zaXplSGVpZ2h0SW5wdXR9O1xuICAgIGxpbmUtaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5leHBvcnQgeyBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyB9O1xuIl19 */",
71
65
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
72
66
  };
73
67
 
@@ -75,17 +69,15 @@ var getLocalizedInputStyles = function getLocalizedInputStyles() {
75
69
  return [_ref$1];
76
70
  };
77
71
 
78
- var getLanguageLabelStyles = function getLanguageLabelStyles(props, theme) {
72
+ var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
79
73
  var overwrittenVars = _objectSpread$1(_objectSpread$1({}, designSystem.customProperties), theme);
80
74
 
81
- return /*#__PURE__*/react.css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";height:", designSystem.customProperties.sizeHeightInput, ";line-height:", designSystem.customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoibG9jYWxpemVkLXRleHQtaW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMgPSAoKSA9PiBbXG4gIGNzc2BcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgICBmbGV4OiBhdXRvO1xuICBgLFxuXTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wcywgdGhlbWUpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLnZhcnMsXG4gICAgLi4udGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIGZsZXg6IDEgMCBhdXRvO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgbGluZS1oZWlnaHQ6ICR7dmFycy5zaXplSGVpZ2h0SW5wdXR9O1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHt2YXJzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmV4cG9ydCB7IGdldExvY2FsaXplZElucHV0U3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzIH07XG4iXX0= */");
75
+ return /*#__PURE__*/react.css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";height:", designSystem.customProperties.sizeHeightInput, ";line-height:", designSystem.customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoibG9jYWxpemVkLXRleHQtaW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMgPSAoKSA9PiBbXG4gIGNzc2BcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgICBmbGV4OiBhdXRvO1xuICBgLFxuXTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChfcHJvcHM6IHVua25vd24sIHRoZW1lOiBUaGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBsaW5lLWhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuZXhwb3J0IHsgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMgfTtcbiJdfQ== */");
82
76
  };
83
77
 
84
- var _templateObject;
78
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
85
79
 
86
- function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (enumerableOnly) { symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
87
-
88
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context3; _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
80
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
89
81
 
90
82
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
91
83
  var sequentialId = utils.createSequentialId('localized-text-input-');
@@ -96,7 +88,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
96
88
  } : {
97
89
  name: "1ysn02y-LocalizedInput",
98
90
  styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
99
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.js"],"names":[],"mappings":"AA6Dc","file":"localized-text-input.js","sourcesContent":["import { useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { oneLine } from 'common-tags';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  return (\n    <div\n      key={props.language}\n      css={css`\n        width: 100%;\n        position: relative;\n        display: flex;\n      `}\n    >\n      <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\nLocalizedInput.propTypes = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  placeholder: PropTypes.string,\n};\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={toggleLanguages}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.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 strings) on the value:\n  //   { en: 'foo', de: '', es: '' }\n  value: PropTypes.objectOf(PropTypes.string).isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: PropTypes.string.isRequired,\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls: PropTypes.bool,\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideLanguageExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideLanguageExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Disables all input fields.\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    1,\n    2,\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
91
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.tsx"],"names":[],"mappings":"AAkLc","file":"localized-text-input.tsx","sourcesContent":["import {\n  type FocusEventHandler,\n  type ChangeEventHandler,\n  useCallback,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\ntype TLocalizedTextInputProps = {\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  /**\n   *   then input doesn't accept a \"languages\" prop, instead all possible\n  languages have to exist (with empty or filled strings) on the value:\n    { en: 'foo', de: '', es: '' }\n   */\n  value: Record<string, string>;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur?: FocusEventHandler;\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls?: boolean;\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages?: boolean;\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Disables all input fields.\n   */\n  isDisabled?: boolean;\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError?: boolean;\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors?: Record<string, string>;\n};\n\ntype TLocalizedInputProps = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id?: string;\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  value: string;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  language: string;\n  onBlur?: FocusEventHandler;\n  onFocus?: FocusEventHandler;\n  isAutofocussed?: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasError?: boolean;\n  placeholder?: string;\n};\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props: TLocalizedInputProps) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <div\n      key={props.language}\n      css={css`\n        width: 100%;\n        position: relative;\n        display: flex;\n      `}\n    >\n      <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props: TLocalizedTextInputProps) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const onLocalizedInputToggle = useCallback(\n    () => toggleLanguages(),\n    [toggleLanguages]\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.defaultExpandLanguages !== 'boolean',\n      'LocalizedTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={onLocalizedInputToggle}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
100
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
93
  };
102
94
 
@@ -114,11 +106,15 @@ var LocalizedInput = function LocalizedInput(props) {
114
106
  // might clear it using the knob, and then we can't parse the language from
115
107
  // the input name anymore.
116
108
  //
117
- // eslint-disable-next-line no-param-reassign
118
109
  event.target.language = props.language;
119
- onChange(event);
110
+ onChange === null || onChange === void 0 ? void 0 : onChange(event);
120
111
  }, [props.language, onChange]);
121
112
  var theme = react.useTheme();
113
+
114
+ if (!props.isReadOnly) {
115
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocaliszedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
116
+ }
117
+
122
118
  return jsxRuntime.jsxs("div", {
123
119
  css: _ref,
124
120
  children: [jsxRuntime.jsx("label", {
@@ -135,39 +131,22 @@ var LocalizedInput = function LocalizedInput(props) {
135
131
  }, props.language);
136
132
  };
137
133
 
138
- LocalizedInput.displayName = 'LocalizedInput';
139
134
  LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
140
- /**
141
- * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.
142
- */
143
- id: PropTypes__default["default"].string,
144
-
145
- /**
146
- * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`
147
- */
148
- name: PropTypes__default["default"].string,
149
-
150
- /**
151
- * Used as HTML `autocomplete` property
152
- */
153
- autoComplete: PropTypes__default["default"].string,
154
- value: PropTypes__default["default"].string.isRequired,
155
-
156
- /**
157
- * Gets called when any input is changed. Is called with the change event of the changed input.
158
- */
159
- onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
160
- return !props.isReadOnly;
161
- }),
162
- language: PropTypes__default["default"].string.isRequired,
163
- onBlur: PropTypes__default["default"].func,
164
- onFocus: PropTypes__default["default"].func,
165
- isAutofocussed: PropTypes__default["default"].bool,
166
- isDisabled: PropTypes__default["default"].bool,
167
- isReadOnly: PropTypes__default["default"].bool,
168
- hasError: PropTypes__default["default"].bool,
169
- placeholder: PropTypes__default["default"].string
135
+ id: _pt__default["default"].string,
136
+ name: _pt__default["default"].string,
137
+ autoComplete: _pt__default["default"].string,
138
+ value: _pt__default["default"].string.isRequired,
139
+ onChange: _pt__default["default"].func,
140
+ language: _pt__default["default"].string.isRequired,
141
+ onBlur: _pt__default["default"].func,
142
+ onFocus: _pt__default["default"].func,
143
+ isAutofocussed: _pt__default["default"].bool,
144
+ isDisabled: _pt__default["default"].bool,
145
+ isReadOnly: _pt__default["default"].bool,
146
+ hasError: _pt__default["default"].bool,
147
+ placeholder: _pt__default["default"].string
170
148
  } : {};
149
+ LocalizedInput.displayName = 'LocalizedInput';
171
150
 
172
151
  var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
173
152
  return jsxRuntime.jsx(messages.ErrorMessage, {
@@ -186,6 +165,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
186
165
  areLanguagesExpanded = _useToggleState2[0],
187
166
  toggleLanguages = _useToggleState2[1];
188
167
 
168
+ var onLocalizedInputToggle = react$1.useCallback(function () {
169
+ return toggleLanguages();
170
+ }, [toggleLanguages]);
189
171
  var languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default["default"](props.value));
190
172
  var id = hooks.useFieldId(props.id, sequentialId);
191
173
  var hasErrorInRemainingLanguages = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
@@ -199,6 +181,15 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
199
181
  }
200
182
 
201
183
  var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
184
+
185
+ if (!props.isReadOnly) {
186
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocalizedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
187
+ }
188
+
189
+ if (props.hideLanguageExpansionControls) {
190
+ process.env.NODE_ENV !== "production" ? utils.warning(typeof props.defaultExpandLanguages !== 'boolean', 'LocalizedTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
191
+ }
192
+
202
193
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
203
194
  max: props.horizontalConstraint,
204
195
  children: jsxRuntime.jsxs(Stack__default["default"], {
@@ -230,7 +221,7 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
230
221
  })
231
222
  }), shouldRenderLanguagesButton && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
232
223
  isOpen: areLanguagesExpanded,
233
- onClick: toggleLanguages,
224
+ onClick: onLocalizedInputToggle,
234
225
  isDisabled: areLanguagesExpanded && hasErrorInRemainingLanguages,
235
226
  remainingLocalizations: languages.length - 1
236
227
  })]
@@ -238,96 +229,27 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
238
229
  });
239
230
  };
240
231
 
241
- LocalizedTextInput.displayName = 'LocalizedTextInput';
242
- LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
243
232
  LocalizedTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
244
- id: PropTypes__default["default"].string,
245
- name: PropTypes__default["default"].string,
246
- autoComplete: PropTypes__default["default"].string,
247
- // then input doesn't accept a "languages" prop, instead all possible
248
- // languages have to exist (with empty or filled strings) on the value:
249
- // { en: 'foo', de: '', es: '' }
250
- value: PropTypes__default["default"].objectOf(PropTypes__default["default"].string).isRequired,
251
-
252
- /**
253
- * Gets called when any input is changed. Is called with the change event of the changed input.
254
- */
255
- onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
256
- return !props.isReadOnly;
257
- }),
258
-
259
- /**
260
- * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.
261
- */
262
- selectedLanguage: PropTypes__default["default"].string.isRequired,
263
-
264
- /**
265
- * Called when any field is blurred. Is called with the `event` of that field.
266
- */
267
- onBlur: PropTypes__default["default"].func,
268
-
269
- /**
270
- * Called when any field is focussed. Is called with the `event` of that field.
271
- */
272
- onFocus: PropTypes__default["default"].func,
273
-
274
- /**
275
- * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.
276
- */
277
- hideLanguageExpansionControls: PropTypes__default["default"].bool,
278
-
279
- /**
280
- * Controls whether one or all languages are visible by default
281
- */
282
- defaultExpandLanguages: function defaultExpandLanguages(props, propName, componentName) {
283
- var _context;
284
-
285
- if (props.hideLanguageExpansionControls && typeof props[propName] === 'boolean') {
286
- throw new Error(commonTags.oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideLanguageExpansionControls\" is set.\n "])), componentName, propName));
287
- }
288
-
289
- for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
290
- rest[_key - 3] = arguments[_key];
291
- }
292
-
293
- return PropTypes__default["default"].bool.apply(PropTypes__default["default"], _concatInstanceProperty__default["default"](_context = [props, propName, componentName]).call(_context, rest));
294
- },
295
-
296
- /**
297
- * Focus the input field on initial render
298
- */
299
- isAutofocussed: PropTypes__default["default"].bool,
300
-
301
- /**
302
- * Disables all input fields.
303
- */
304
- isDisabled: PropTypes__default["default"].bool,
305
-
306
- /**
307
- * Disables all input fields and shows them in read-only mode.
308
- */
309
- isReadOnly: PropTypes__default["default"].bool,
310
-
311
- /**
312
- * Placeholders for each language. Object of the same shape as `value`.
313
- */
314
- placeholder: PropTypes__default["default"].objectOf(PropTypes__default["default"].string),
315
-
316
- /**
317
- * Horizontal size limit of the input fields.
318
- */
319
- horizontalConstraint: PropTypes__default["default"].oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
320
-
321
- /**
322
- * Will apply the error state to each input without showing any error message.
323
- */
324
- hasError: PropTypes__default["default"].bool,
325
-
326
- /**
327
- * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.
328
- */
329
- errors: PropTypes__default["default"].objectOf(PropTypes__default["default"].node)
233
+ id: _pt__default["default"].string,
234
+ name: _pt__default["default"].string,
235
+ autoComplete: _pt__default["default"].string,
236
+ value: _pt__default["default"].objectOf(_pt__default["default"].string).isRequired,
237
+ onChange: _pt__default["default"].func,
238
+ selectedLanguage: _pt__default["default"].string.isRequired,
239
+ onBlur: _pt__default["default"].func,
240
+ onFocus: _pt__default["default"].func,
241
+ hideLanguageExpansionControls: _pt__default["default"].bool,
242
+ defaultExpandLanguages: _pt__default["default"].bool,
243
+ isAutofocussed: _pt__default["default"].bool,
244
+ isDisabled: _pt__default["default"].bool,
245
+ isReadOnly: _pt__default["default"].bool,
246
+ placeholder: _pt__default["default"].objectOf(_pt__default["default"].string),
247
+ horizontalConstraint: _pt__default["default"].oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
248
+ hasError: _pt__default["default"].bool,
249
+ errors: _pt__default["default"].objectOf(_pt__default["default"].string)
330
250
  } : {};
251
+ LocalizedTextInput.displayName = 'LocalizedTextInput';
252
+ LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
331
253
  LocalizedTextInput.defaultProps = {
332
254
  horizontalConstraint: 'scale'
333
255
  };
@@ -340,7 +262,7 @@ LocalizedTextInput.isTouched = localizedUtils.isTouched;
340
262
  var LocalizedTextInput$1 = LocalizedTextInput;
341
263
 
342
264
  // NOTE: This string will be replaced on build time with the package version.
343
- var version = "12.2.7";
265
+ var version = "13.0.2";
344
266
 
345
267
  exports["default"] = LocalizedTextInput$1;
346
268
  exports.version = version;
@@ -9,16 +9,12 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
9
9
  var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
10
10
  var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
11
11
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
12
- require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
13
12
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
14
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
+ require('prop-types');
15
15
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
16
16
  var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
17
- require('@babel/runtime-corejs3/core-js-stable/instance/concat');
18
17
  var react$1 = require('react');
19
- require('prop-types');
20
- require('react-required-if');
21
- require('common-tags');
22
18
  var reactIntl = require('react-intl');
23
19
  var react = require('@emotion/react');
24
20
  var hooks = require('@commercetools-uikit/hooks');
@@ -49,9 +45,9 @@ var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
49
45
  var Text__default = /*#__PURE__*/_interopDefault(Text);
50
46
  var TextInput__default = /*#__PURE__*/_interopDefault(TextInput);
51
47
 
52
- function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (enumerableOnly) { symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
48
+ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
53
49
 
54
- function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
50
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
55
51
  // * a disabled-field currently does not display warning/error-states so it takes precedence
56
52
  // * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first
57
53
  // how you can interact with the field is controlled separately by the props, this only influences visuals
@@ -65,15 +61,15 @@ var getLocalizedInputStyles = function getLocalizedInputStyles() {
65
61
  return [_ref$1];
66
62
  };
67
63
 
68
- var getLanguageLabelStyles = function getLanguageLabelStyles(props, theme) {
64
+ var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
69
65
  var overwrittenVars = _objectSpread$1(_objectSpread$1({}, designSystem.customProperties), theme);
70
66
 
71
67
  return /*#__PURE__*/react.css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";height:", designSystem.customProperties.sizeHeightInput, ";line-height:", designSystem.customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + ("" ), "" );
72
68
  };
73
69
 
74
- function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); if (enumerableOnly) { symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
70
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
75
71
 
76
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source), true)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default["default"]) { _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)); } else { var _context3; _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } } return target; }
72
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
77
73
  var sequentialId = utils.createSequentialId('localized-text-input-');
78
74
 
79
75
  var _ref = {
@@ -95,11 +91,13 @@ var LocalizedInput = function LocalizedInput(props) {
95
91
  // might clear it using the knob, and then we can't parse the language from
96
92
  // the input name anymore.
97
93
  //
98
- // eslint-disable-next-line no-param-reassign
99
94
  event.target.language = props.language;
100
- onChange(event);
95
+ onChange === null || onChange === void 0 ? void 0 : onChange(event);
101
96
  }, [props.language, onChange]);
102
97
  var theme = react.useTheme();
98
+
99
+ if (!props.isReadOnly) ;
100
+
103
101
  return jsxRuntime.jsxs("div", {
104
102
  css: _ref,
105
103
  children: [jsxRuntime.jsx("label", {
@@ -116,8 +114,8 @@ var LocalizedInput = function LocalizedInput(props) {
116
114
  }, props.language);
117
115
  };
118
116
 
119
- LocalizedInput.displayName = 'LocalizedInput';
120
117
  LocalizedInput.propTypes = {};
118
+ LocalizedInput.displayName = 'LocalizedInput';
121
119
 
122
120
  var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
123
121
  return jsxRuntime.jsx(messages.ErrorMessage, {
@@ -136,6 +134,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
136
134
  areLanguagesExpanded = _useToggleState2[0],
137
135
  toggleLanguages = _useToggleState2[1];
138
136
 
137
+ var onLocalizedInputToggle = react$1.useCallback(function () {
138
+ return toggleLanguages();
139
+ }, [toggleLanguages]);
139
140
  var languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default["default"](props.value));
140
141
  var id = hooks.useFieldId(props.id, sequentialId);
141
142
  var hasErrorInRemainingLanguages = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
@@ -149,6 +150,11 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
149
150
  }
150
151
 
151
152
  var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
153
+
154
+ if (!props.isReadOnly) ;
155
+
156
+ if (props.hideLanguageExpansionControls) ;
157
+
152
158
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
153
159
  max: props.horizontalConstraint,
154
160
  children: jsxRuntime.jsxs(Stack__default["default"], {
@@ -180,7 +186,7 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
180
186
  })
181
187
  }), shouldRenderLanguagesButton && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
182
188
  isOpen: areLanguagesExpanded,
183
- onClick: toggleLanguages,
189
+ onClick: onLocalizedInputToggle,
184
190
  isDisabled: areLanguagesExpanded && hasErrorInRemainingLanguages,
185
191
  remainingLocalizations: languages.length - 1
186
192
  })]
@@ -188,9 +194,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
188
194
  });
189
195
  };
190
196
 
197
+ LocalizedTextInput.propTypes = {};
191
198
  LocalizedTextInput.displayName = 'LocalizedTextInput';
192
199
  LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
193
- LocalizedTextInput.propTypes = {};
194
200
  LocalizedTextInput.defaultProps = {
195
201
  horizontalConstraint: 'scale'
196
202
  };
@@ -203,7 +209,7 @@ LocalizedTextInput.isTouched = localizedUtils.isTouched;
203
209
  var LocalizedTextInput$1 = LocalizedTextInput;
204
210
 
205
211
  // NOTE: This string will be replaced on build time with the package version.
206
- var version = "12.2.7";
212
+ var version = "13.0.2";
207
213
 
208
214
  exports["default"] = LocalizedTextInput$1;
209
215
  exports.version = version;
@@ -5,16 +5,12 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
5
5
  import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
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
- import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
9
8
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
10
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
+ import _pt from 'prop-types';
11
11
  import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
12
12
  import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
13
- import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
14
13
  import { useCallback } from 'react';
15
- import PropTypes from 'prop-types';
16
- import requiredIf from 'react-required-if';
17
- import { oneLine } from 'common-tags';
18
14
  import { FormattedMessage } from 'react-intl';
19
15
  import { css, useTheme } from '@emotion/react';
20
16
  import { useToggleState, useFieldId } from '@commercetools-uikit/hooks';
@@ -23,15 +19,15 @@ import Stack from '@commercetools-uikit/spacings-stack';
23
19
  import Constraints from '@commercetools-uikit/constraints';
24
20
  import Text from '@commercetools-uikit/text';
25
21
  import { sortLanguages, getHasErrorOnRemainingLanguages, createLocalizedDataAttributes, getId, getName, createLocalizedString, isEmpty, omitEmptyTranslations, isTouched } from '@commercetools-uikit/localized-utils';
26
- import { createSequentialId } from '@commercetools-uikit/utils';
22
+ import { createSequentialId, warning } from '@commercetools-uikit/utils';
27
23
  import TextInput from '@commercetools-uikit/text-input';
28
24
  import { LocalizedInputToggle, messagesLocalizedInput } from '@commercetools-uikit/input-utils';
29
25
  import { customProperties, designTokens } from '@commercetools-uikit/design-system';
30
26
  import { jsx, jsxs } from '@emotion/react/jsx-runtime';
31
27
 
32
- 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; }
28
+ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
33
29
 
34
- 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; }
30
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
35
31
 
36
32
  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)."; }
37
33
  // * a disabled-field currently does not display warning/error-states so it takes precedence
@@ -44,7 +40,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
44
40
  } : {
45
41
  name: "bqcila-getLocalizedInputStyles",
46
42
  styles: "border-top-left-radius:0;border-bottom-left-radius:0;border-style:solid;flex:auto;label:getLocalizedInputStyles;",
47
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXSyIsImZpbGUiOiJsb2NhbGl6ZWQtdGV4dC1pbnB1dC5zdHlsZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcyA9ICgpID0+IFtcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItc3R5bGU6IHNvbGlkO1xuICAgIGZsZXg6IGF1dG87XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzLCB0aGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBsaW5lLWhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuZXhwb3J0IHsgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMgfTtcbiJdfQ== */",
43
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXSyIsImZpbGUiOiJsb2NhbGl6ZWQtdGV4dC1pbnB1dC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHR5cGUgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcyA9ICgpID0+IFtcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItc3R5bGU6IHNvbGlkO1xuICAgIGZsZXg6IGF1dG87XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKF9wcm9wczogdW5rbm93biwgdGhlbWU6IFRoZW1lKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi52YXJzLFxuICAgIC4uLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBoZWlnaHQ6ICR7dmFycy5zaXplSGVpZ2h0SW5wdXR9O1xuICAgIGxpbmUtaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5leHBvcnQgeyBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyB9O1xuIl19 */",
48
44
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
49
45
  };
50
46
 
@@ -52,17 +48,15 @@ var getLocalizedInputStyles = function getLocalizedInputStyles() {
52
48
  return [_ref$1];
53
49
  };
54
50
 
55
- var getLanguageLabelStyles = function getLanguageLabelStyles(props, theme) {
51
+ var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
56
52
  var overwrittenVars = _objectSpread$1(_objectSpread$1({}, customProperties), theme);
57
53
 
58
- return /*#__PURE__*/css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designTokens.fontColorForInputWhenDisabled], ";height:", customProperties.sizeHeightInput, ";line-height:", customProperties.sizeHeightInput, ";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;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoibG9jYWxpemVkLXRleHQtaW5wdXQuc3R5bGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMgPSAoKSA9PiBbXG4gIGNzc2BcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgICBmbGV4OiBhdXRvO1xuICBgLFxuXTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wcywgdGhlbWUpID0+IHtcbiAgY29uc3Qgb3ZlcndyaXR0ZW5WYXJzID0ge1xuICAgIC4uLnZhcnMsXG4gICAgLi4udGhlbWUsXG4gIH07XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIGZsZXg6IDEgMCBhdXRvO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gICAgY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19O1xuICAgIGhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgbGluZS1oZWlnaHQ6ICR7dmFycy5zaXplSGVpZ2h0SW5wdXR9O1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gICAgXX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlcjogMXB4ICR7b3ZlcndyaXR0ZW5WYXJzW2Rlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX1cbiAgICAgIHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHt2YXJzLnNwYWNpbmdTfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmV4cG9ydCB7IGdldExvY2FsaXplZElucHV0U3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzIH07XG4iXX0= */");
54
+ return /*#__PURE__*/css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designTokens.fontColorForInputWhenDisabled], ";height:", customProperties.sizeHeightInput, ";line-height:", customProperties.sizeHeightInput, ";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;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoibG9jYWxpemVkLXRleHQtaW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMgPSAoKSA9PiBbXG4gIGNzc2BcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgICBmbGV4OiBhdXRvO1xuICBgLFxuXTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChfcHJvcHM6IHVua25vd24sIHRoZW1lOiBUaGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBsaW5lLWhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuZXhwb3J0IHsgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMgfTtcbiJdfQ== */");
59
55
  };
60
56
 
61
- var _templateObject;
57
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
62
58
 
63
- function ownKeys(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; }
64
-
65
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context2; _forEachInstanceProperty(_context2 = ownKeys(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(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
59
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
66
60
 
67
61
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
68
62
  var sequentialId = createSequentialId('localized-text-input-');
@@ -73,7 +67,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
73
67
  } : {
74
68
  name: "1ysn02y-LocalizedInput",
75
69
  styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
76
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.js"],"names":[],"mappings":"AA6Dc","file":"localized-text-input.js","sourcesContent":["import { useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { oneLine } from 'common-tags';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  return (\n    <div\n      key={props.language}\n      css={css`\n        width: 100%;\n        position: relative;\n        display: flex;\n      `}\n    >\n      <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\nLocalizedInput.propTypes = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  placeholder: PropTypes.string,\n};\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={toggleLanguages}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.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 strings) on the value:\n  //   { en: 'foo', de: '', es: '' }\n  value: PropTypes.objectOf(PropTypes.string).isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: PropTypes.string.isRequired,\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls: PropTypes.bool,\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideLanguageExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideLanguageExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Disables all input fields.\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    1,\n    2,\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
70
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.tsx"],"names":[],"mappings":"AAkLc","file":"localized-text-input.tsx","sourcesContent":["import {\n  type FocusEventHandler,\n  type ChangeEventHandler,\n  useCallback,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\ntype TLocalizedTextInputProps = {\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  /**\n   *   then input doesn't accept a \"languages\" prop, instead all possible\n  languages have to exist (with empty or filled strings) on the value:\n    { en: 'foo', de: '', es: '' }\n   */\n  value: Record<string, string>;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur?: FocusEventHandler;\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls?: boolean;\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages?: boolean;\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Disables all input fields.\n   */\n  isDisabled?: boolean;\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError?: boolean;\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors?: Record<string, string>;\n};\n\ntype TLocalizedInputProps = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id?: string;\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  value: string;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  language: string;\n  onBlur?: FocusEventHandler;\n  onFocus?: FocusEventHandler;\n  isAutofocussed?: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasError?: boolean;\n  placeholder?: string;\n};\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props: TLocalizedInputProps) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      //\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <div\n      key={props.language}\n      css={css`\n        width: 100%;\n        position: relative;\n        display: flex;\n      `}\n    >\n      <label htmlFor={props.id} css={getLanguageLabelStyles(props, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props: TLocalizedTextInputProps) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const onLocalizedInputToggle = useCallback(\n    () => toggleLanguages(),\n    [toggleLanguages]\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.defaultExpandLanguages !== 'boolean',\n      'LocalizedTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={onLocalizedInputToggle}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
77
71
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
78
72
  };
79
73
 
@@ -91,11 +85,15 @@ var LocalizedInput = function LocalizedInput(props) {
91
85
  // might clear it using the knob, and then we can't parse the language from
92
86
  // the input name anymore.
93
87
  //
94
- // eslint-disable-next-line no-param-reassign
95
88
  event.target.language = props.language;
96
- onChange(event);
89
+ onChange === null || onChange === void 0 ? void 0 : onChange(event);
97
90
  }, [props.language, onChange]);
98
91
  var theme = useTheme();
92
+
93
+ if (!props.isReadOnly) {
94
+ process.env.NODE_ENV !== "production" ? warning(typeof props.onChange === 'function', 'LocaliszedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
95
+ }
96
+
99
97
  return jsxs("div", {
100
98
  css: _ref,
101
99
  children: [jsx("label", {
@@ -112,39 +110,22 @@ var LocalizedInput = function LocalizedInput(props) {
112
110
  }, props.language);
113
111
  };
114
112
 
115
- LocalizedInput.displayName = 'LocalizedInput';
116
113
  LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
117
- /**
118
- * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.
119
- */
120
- id: PropTypes.string,
121
-
122
- /**
123
- * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`
124
- */
125
- name: PropTypes.string,
126
-
127
- /**
128
- * Used as HTML `autocomplete` property
129
- */
130
- autoComplete: PropTypes.string,
131
- value: PropTypes.string.isRequired,
132
-
133
- /**
134
- * Gets called when any input is changed. Is called with the change event of the changed input.
135
- */
136
- onChange: requiredIf(PropTypes.func, function (props) {
137
- return !props.isReadOnly;
138
- }),
139
- language: PropTypes.string.isRequired,
140
- onBlur: PropTypes.func,
141
- onFocus: PropTypes.func,
142
- isAutofocussed: PropTypes.bool,
143
- isDisabled: PropTypes.bool,
144
- isReadOnly: PropTypes.bool,
145
- hasError: PropTypes.bool,
146
- placeholder: PropTypes.string
114
+ id: _pt.string,
115
+ name: _pt.string,
116
+ autoComplete: _pt.string,
117
+ value: _pt.string.isRequired,
118
+ onChange: _pt.func,
119
+ language: _pt.string.isRequired,
120
+ onBlur: _pt.func,
121
+ onFocus: _pt.func,
122
+ isAutofocussed: _pt.bool,
123
+ isDisabled: _pt.bool,
124
+ isReadOnly: _pt.bool,
125
+ hasError: _pt.bool,
126
+ placeholder: _pt.string
147
127
  } : {};
128
+ LocalizedInput.displayName = 'LocalizedInput';
148
129
 
149
130
  var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
150
131
  return jsx(ErrorMessage, {
@@ -163,6 +144,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
163
144
  areLanguagesExpanded = _useToggleState2[0],
164
145
  toggleLanguages = _useToggleState2[1];
165
146
 
147
+ var onLocalizedInputToggle = useCallback(function () {
148
+ return toggleLanguages();
149
+ }, [toggleLanguages]);
166
150
  var languages = sortLanguages(props.selectedLanguage, _Object$keys(props.value));
167
151
  var id = useFieldId(props.id, sequentialId);
168
152
  var hasErrorInRemainingLanguages = props.hasError || getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
@@ -176,6 +160,15 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
176
160
  }
177
161
 
178
162
  var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
163
+
164
+ if (!props.isReadOnly) {
165
+ process.env.NODE_ENV !== "production" ? warning(typeof props.onChange === 'function', 'LocalizedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
166
+ }
167
+
168
+ if (props.hideLanguageExpansionControls) {
169
+ process.env.NODE_ENV !== "production" ? warning(typeof props.defaultExpandLanguages !== 'boolean', 'LocalizedTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
170
+ }
171
+
179
172
  return jsx(Constraints.Horizontal, {
180
173
  max: props.horizontalConstraint,
181
174
  children: jsxs(Stack, {
@@ -207,7 +200,7 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
207
200
  })
208
201
  }), shouldRenderLanguagesButton && jsx(LocalizedInputToggle, {
209
202
  isOpen: areLanguagesExpanded,
210
- onClick: toggleLanguages,
203
+ onClick: onLocalizedInputToggle,
211
204
  isDisabled: areLanguagesExpanded && hasErrorInRemainingLanguages,
212
205
  remainingLocalizations: languages.length - 1
213
206
  })]
@@ -215,96 +208,27 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
215
208
  });
216
209
  };
217
210
 
218
- LocalizedTextInput.displayName = 'LocalizedTextInput';
219
- LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
220
211
  LocalizedTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
221
- id: PropTypes.string,
222
- name: PropTypes.string,
223
- autoComplete: PropTypes.string,
224
- // then input doesn't accept a "languages" prop, instead all possible
225
- // languages have to exist (with empty or filled strings) on the value:
226
- // { en: 'foo', de: '', es: '' }
227
- value: PropTypes.objectOf(PropTypes.string).isRequired,
228
-
229
- /**
230
- * Gets called when any input is changed. Is called with the change event of the changed input.
231
- */
232
- onChange: requiredIf(PropTypes.func, function (props) {
233
- return !props.isReadOnly;
234
- }),
235
-
236
- /**
237
- * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.
238
- */
239
- selectedLanguage: PropTypes.string.isRequired,
240
-
241
- /**
242
- * Called when any field is blurred. Is called with the `event` of that field.
243
- */
244
- onBlur: PropTypes.func,
245
-
246
- /**
247
- * Called when any field is focussed. Is called with the `event` of that field.
248
- */
249
- onFocus: PropTypes.func,
250
-
251
- /**
252
- * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.
253
- */
254
- hideLanguageExpansionControls: PropTypes.bool,
255
-
256
- /**
257
- * Controls whether one or all languages are visible by default
258
- */
259
- defaultExpandLanguages: function defaultExpandLanguages(props, propName, componentName) {
260
- var _context;
261
-
262
- if (props.hideLanguageExpansionControls && typeof props[propName] === 'boolean') {
263
- throw new Error(oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideLanguageExpansionControls\" is set.\n "])), componentName, propName));
264
- }
265
-
266
- for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
267
- rest[_key - 3] = arguments[_key];
268
- }
269
-
270
- return PropTypes.bool.apply(PropTypes, _concatInstanceProperty(_context = [props, propName, componentName]).call(_context, rest));
271
- },
272
-
273
- /**
274
- * Focus the input field on initial render
275
- */
276
- isAutofocussed: PropTypes.bool,
277
-
278
- /**
279
- * Disables all input fields.
280
- */
281
- isDisabled: PropTypes.bool,
282
-
283
- /**
284
- * Disables all input fields and shows them in read-only mode.
285
- */
286
- isReadOnly: PropTypes.bool,
287
-
288
- /**
289
- * Placeholders for each language. Object of the same shape as `value`.
290
- */
291
- placeholder: PropTypes.objectOf(PropTypes.string),
292
-
293
- /**
294
- * Horizontal size limit of the input fields.
295
- */
296
- horizontalConstraint: PropTypes.oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
297
-
298
- /**
299
- * Will apply the error state to each input without showing any error message.
300
- */
301
- hasError: PropTypes.bool,
302
-
303
- /**
304
- * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.
305
- */
306
- errors: PropTypes.objectOf(PropTypes.node)
212
+ id: _pt.string,
213
+ name: _pt.string,
214
+ autoComplete: _pt.string,
215
+ value: _pt.objectOf(_pt.string).isRequired,
216
+ onChange: _pt.func,
217
+ selectedLanguage: _pt.string.isRequired,
218
+ onBlur: _pt.func,
219
+ onFocus: _pt.func,
220
+ hideLanguageExpansionControls: _pt.bool,
221
+ defaultExpandLanguages: _pt.bool,
222
+ isAutofocussed: _pt.bool,
223
+ isDisabled: _pt.bool,
224
+ isReadOnly: _pt.bool,
225
+ placeholder: _pt.objectOf(_pt.string),
226
+ horizontalConstraint: _pt.oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
227
+ hasError: _pt.bool,
228
+ errors: _pt.objectOf(_pt.string)
307
229
  } : {};
230
+ LocalizedTextInput.displayName = 'LocalizedTextInput';
231
+ LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
308
232
  LocalizedTextInput.defaultProps = {
309
233
  horizontalConstraint: 'scale'
310
234
  };
@@ -317,6 +241,6 @@ LocalizedTextInput.isTouched = isTouched;
317
241
  var LocalizedTextInput$1 = LocalizedTextInput;
318
242
 
319
243
  // NOTE: This string will be replaced on build time with the package version.
320
- var version = "12.2.7";
244
+ var version = "13.0.2";
321
245
 
322
246
  export { LocalizedTextInput$1 as default, version };
@@ -0,0 +1,2 @@
1
+ export { default } from './localized-text-input';
2
+ export { default as version } from './version';
@@ -0,0 +1,50 @@
1
+ import { type FocusEventHandler, type ChangeEventHandler } from 'react';
2
+ declare type TLocalizedTextInputProps = {
3
+ id?: string;
4
+ name?: string;
5
+ autoComplete?: string;
6
+ value: Record<string, string>;
7
+ onChange?: ChangeEventHandler;
8
+ selectedLanguage: string;
9
+ onBlur?: FocusEventHandler;
10
+ onFocus?: FocusEventHandler;
11
+ hideLanguageExpansionControls?: boolean;
12
+ defaultExpandLanguages?: boolean;
13
+ isAutofocussed?: boolean;
14
+ isDisabled?: boolean;
15
+ isReadOnly?: boolean;
16
+ placeholder?: Record<string, string>;
17
+ horizontalConstraint?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
18
+ hasError?: boolean;
19
+ errors?: Record<string, string>;
20
+ };
21
+ declare const LocalizedTextInput: {
22
+ (props: TLocalizedTextInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
23
+ displayName: string;
24
+ RequiredValueErrorMessage: {
25
+ (): import("@emotion/react/jsx-runtime").JSX.Element;
26
+ displayName: string;
27
+ };
28
+ defaultProps: {
29
+ horizontalConstraint: string;
30
+ };
31
+ getId: (idPrefix?: string | undefined, language?: string | undefined) => string | undefined;
32
+ getName: (namePrefix?: string | undefined, language?: string | undefined) => string | undefined;
33
+ createLocalizedString: (languages: string[], existingTranslations?: {
34
+ [locale: string]: string;
35
+ }) => {
36
+ [locale: string]: string;
37
+ };
38
+ isEmpty: (localizedString?: {
39
+ [locale: string]: string;
40
+ } | undefined) => boolean;
41
+ omitEmptyTranslations: <TTranslations extends {
42
+ [locale: string]: string;
43
+ }>(localizedString: TTranslations) => {
44
+ [locale: string]: string;
45
+ };
46
+ isTouched: (touched?: {
47
+ [locale: string]: boolean;
48
+ } | undefined) => boolean;
49
+ };
50
+ export default LocalizedTextInput;
@@ -0,0 +1,4 @@
1
+ import { type Theme } from '@emotion/react';
2
+ declare const getLocalizedInputStyles: () => import("@emotion/utils").SerializedStyles[];
3
+ declare const getLanguageLabelStyles: (_props: unknown, theme: Theme) => import("@emotion/utils").SerializedStyles;
4
+ export { getLocalizedInputStyles, getLanguageLabelStyles };
@@ -0,0 +1,2 @@
1
+ declare const _default: "__@UI_KIT_PACKAGE/VERSION_OF_RELEASE__";
2
+ export default _default;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/localized-text-input",
3
3
  "description": "A controlled text input component for localized single-line strings with validation states.",
4
- "version": "12.2.7",
4
+ "version": "13.0.2",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -19,29 +19,29 @@
19
19
  "module": "dist/commercetools-uikit-localized-text-input.esm.js",
20
20
  "files": ["dist"],
21
21
  "dependencies": {
22
- "@babel/runtime": "7.16.3",
23
- "@babel/runtime-corejs3": "7.16.3",
24
- "@commercetools-uikit/constraints": "12.2.5",
25
- "@commercetools-uikit/design-system": "12.2.5",
26
- "@commercetools-uikit/flat-button": "12.2.5",
27
- "@commercetools-uikit/hooks": "12.2.5",
28
- "@commercetools-uikit/icons": "12.2.7",
29
- "@commercetools-uikit/input-utils": "12.2.7",
30
- "@commercetools-uikit/localized-utils": "12.2.5",
31
- "@commercetools-uikit/messages": "12.2.5",
32
- "@commercetools-uikit/spacings-stack": "12.2.5",
33
- "@commercetools-uikit/text": "12.2.5",
34
- "@commercetools-uikit/text-input": "12.2.7",
35
- "@commercetools-uikit/utils": "12.2.5",
22
+ "@babel/runtime": "7.17.2",
23
+ "@babel/runtime-corejs3": "7.17.2",
24
+ "@commercetools-uikit/constraints": "13.0.2",
25
+ "@commercetools-uikit/design-system": "13.0.0",
26
+ "@commercetools-uikit/flat-button": "13.0.2",
27
+ "@commercetools-uikit/hooks": "13.0.2",
28
+ "@commercetools-uikit/icons": "13.0.2",
29
+ "@commercetools-uikit/input-utils": "13.0.2",
30
+ "@commercetools-uikit/localized-utils": "13.0.2",
31
+ "@commercetools-uikit/messages": "13.0.2",
32
+ "@commercetools-uikit/spacings-stack": "13.0.2",
33
+ "@commercetools-uikit/text": "13.0.2",
34
+ "@commercetools-uikit/text-input": "13.0.2",
35
+ "@commercetools-uikit/utils": "13.0.2",
36
36
  "@emotion/react": "^11.4.0",
37
37
  "@emotion/styled": "^11.3.0",
38
38
  "common-tags": "1.8.2",
39
- "prop-types": "15.7.2",
39
+ "prop-types": "15.8.1",
40
40
  "react-required-if": "1.0.3"
41
41
  },
42
42
  "devDependencies": {
43
43
  "react": "17.0.2",
44
- "react-intl": "5.21.2"
44
+ "react-intl": "5.24.6"
45
45
  },
46
46
  "peerDependencies": {
47
47
  "react": "17.x",