@commercetools-uikit/multiline-text-input 19.4.0 → 19.6.0

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,29 @@ export default Example;
48
48
 
49
49
  ## Properties
50
50
 
51
- | Props | Type | Required | Default | Description |
52
- | ---------------------------- | -------------------------------------------------------------------------------------------- | :------: | ------- | ------------------------------------------------------------------------------------------------------------------------- |
53
- | `name` | `string` | | | Used as HTML name of the input component. property |
54
- | `aria-invalid` | `boolean` | | | Indicate if the value entered in the input is invalid. |
55
- | `aria-errormessage` | `string` | | | HTML ID of an element containing an error message related to the input. |
56
- | `autoComplete` | `string` | | | Used as HTML `autocomplete` property |
57
- | `id` | `string` | | | Used as HTML id property. An id is auto-generated when it is not specified. |
58
- | `value` | `string` | ✅ | | Value of the input component. |
59
- | `onChange` | `ChangeEventHandler` | | | Called with an event containing the new value. Required when input is not read only. Parent should pass it back as value. |
60
- | `onBlur` | `FocusEventHandler` | | | Called when input is blurred |
61
- | `onFocus` | `FocusEventHandler` | | | Called when input is focused |
62
- | `isAutofocussed` | `boolean` | | | Focus the input on initial render |
63
- | `defaultExpandMultilineText` | `boolean` | | `false` | Expands multiline text input initially |
64
- | `isDisabled` | `boolean` | | | Indicates that the input cannot be modified (e.g not authorized, or changes currently saving). |
65
- | `isReadOnly` | `boolean` | | | Indicates that the field is displaying read-only content |
66
- | `placeholder` | `string` | | | Placeholder text for the input |
67
- | `hasError` | `boolean` | | | Indicates that input has errors |
68
- | `hasWarning` | `boolean` | | | Control to indicate on the input if there are selected values that are potentially invalid |
69
- | `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | | Horizontal size limit of the input fields. |
51
+ | Props | Type | Required | Default | Description |
52
+ | ---------------------------- | -------------------------------------------------------------------------------------------- | :------: | ------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------- |
53
+ | `name` | `string` | | | Used as HTML name of the input component. property |
54
+ | `aria-invalid` | `boolean` | | | Indicate if the value entered in the input is invalid. |
55
+ | `aria-errormessage` | `string` | | | HTML ID of an element containing an error message related to the input. |
56
+ | `autoComplete` | `string` | | | Used as HTML `autocomplete` property |
57
+ | `id` | `string` | | | Used as HTML id property. An id is auto-generated when it is not specified. |
58
+ | `value` | `string` | ✅ | | Value of the input component. |
59
+ | `onChange` | `ChangeEventHandler` | | | Called with an event containing the new value. Required when input is not read only. Parent should pass it back as value. |
60
+ | `onBlur` | `FocusEventHandler` | | | Called when input is blurred |
61
+ | `onFocus` | `FocusEventHandler` | | | Called when input is focused |
62
+ | `isAutofocussed` | `boolean` | | | Focus the input on initial render |
63
+ | `defaultExpandMultilineText` | `boolean` | | `false` | Expands multiline text input initially |
64
+ | `isDisabled` | `boolean` | | | Indicates that the input cannot be modified (e.g not authorized, or changes currently saving). |
65
+ | `isReadOnly` | `boolean` | | | Indicates that the field is displaying read-only content |
66
+ | `placeholder` | `string` | | | Placeholder text for the input |
67
+ | `hasError` | `boolean` | | | Indicates that input has errors |
68
+ | `hasWarning` | `boolean` | | | Control to indicate on the input if there are selected values that are potentially invalid |
69
+ | `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | | Horizontal size limit of the input fields. |
70
+ | `rightActionIcon` | `ReactElement` | | | Custom action icon to be displayed on the right side of the input. |
71
+ | `rightActionProps` | `TSecondaryButtonIconProps` | | | Props for the right-action icon-button. Required when rightActionIcon is provided.&#xA;At least a `label` and an `onClick` prop/function need to be provided. |
72
+ | `isCondensed` | `boolean` | | | Set this to `true` to reduce the paddings of the input allowing the input to display&#xA;more data in less space. |
73
+ | `maxRows` | `number` | | | Set this to value to determine the maximum text rows of the text area.&#xA;Any text overflow past this row number would implement a scroll |
70
74
 
71
75
  ## Static methods
72
76
 
@@ -14,16 +14,19 @@ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
15
  var _pt = require('prop-types');
16
16
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
17
- var react = require('react');
17
+ var react$1 = require('react');
18
+ var SecondaryIconButton = require('@commercetools-uikit/secondary-icon-button');
18
19
  var reactIntl = require('react-intl');
19
- require('@emotion/react');
20
+ var react = require('@emotion/react');
20
21
  var icons = require('@commercetools-uikit/icons');
21
22
  var FlatButton = require('@commercetools-uikit/flat-button');
22
23
  var hooks = require('@commercetools-uikit/hooks');
23
24
  var utils = require('@commercetools-uikit/utils');
24
25
  var Stack = require('@commercetools-uikit/spacings-stack');
25
26
  var Constraints = require('@commercetools-uikit/constraints');
27
+ var designSystem = require('@commercetools-uikit/design-system');
26
28
  var inputUtils = require('@commercetools-uikit/input-utils');
29
+ var _styled = require('@emotion/styled/base');
27
30
  var jsxRuntime = require('@emotion/react/jsx-runtime');
28
31
 
29
32
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
@@ -38,9 +41,28 @@ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$def
38
41
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
39
42
  var _pt__default = /*#__PURE__*/_interopDefault(_pt);
40
43
  var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
44
+ var SecondaryIconButton__default = /*#__PURE__*/_interopDefault(SecondaryIconButton);
41
45
  var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
42
46
  var Stack__default = /*#__PURE__*/_interopDefault(Stack);
43
47
  var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
48
+ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
49
+
50
+ 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)."; }
51
+ const getMultilineTextInputActionIconStyles = props => /*#__PURE__*/react.css("position:absolute;right:", designSystem.designTokens.spacing30, ";top:0;height:", props.isCondensed ? "".concat(designSystem.designTokens.heightForInputAsSmall) : "".concat(designSystem.designTokens.heightForInput), ";padding:0;display:flex;justify-content:center;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:getMultilineTextInputActionIconStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm11bHRpbGluZS10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPUSIsImZpbGUiOiJtdWx0aWxpbmUtdGV4dC1pbnB1dC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IHR5cGUgVE11bHRpbGluZVRleHRJbnB1dFByb3BzIH0gZnJvbSAnLi9tdWx0aWxpbmUtdGV4dC1pbnB1dCc7XG5cbmNvbnN0IGdldE11bHRpbGluZVRleHRJbnB1dEFjdGlvbkljb25TdHlsZXMgPSAoXG4gIHByb3BzOiBUTXVsdGlsaW5lVGV4dElucHV0UHJvcHNcbikgPT4gY3NzYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICB0b3A6IDA7XG4gIGhlaWdodDogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgID8gYCR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbH1gXG4gICAgOiBgJHtkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9YH07XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgTXVsdGlsaW5lSW5wdXRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IHsgZ2V0TXVsdGlsaW5lVGV4dElucHV0QWN0aW9uSWNvblN0eWxlcywgTXVsdGlsaW5lSW5wdXRXcmFwcGVyIH07XG4iXX0= */");
52
+ const MultilineInputWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
53
+ target: "eg1owae0"
54
+ } : {
55
+ target: "eg1owae0",
56
+ label: "MultilineInputWrapper"
57
+ })(process.env.NODE_ENV === "production" ? {
58
+ name: "8sarsy",
59
+ styles: "position:relative;display:inline-block;width:100%"
60
+ } : {
61
+ name: "8sarsy",
62
+ styles: "position:relative;display:inline-block;width:100%",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm11bHRpbGluZS10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQndDIiwiZmlsZSI6Im11bHRpbGluZS10ZXh0LWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHsgdHlwZSBUTXVsdGlsaW5lVGV4dElucHV0UHJvcHMgfSBmcm9tICcuL211bHRpbGluZS10ZXh0LWlucHV0JztcblxuY29uc3QgZ2V0TXVsdGlsaW5lVGV4dElucHV0QWN0aW9uSWNvblN0eWxlcyA9IChcbiAgcHJvcHM6IFRNdWx0aWxpbmVUZXh0SW5wdXRQcm9wc1xuKSA9PiBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmczMH07XG4gIHRvcDogMDtcbiAgaGVpZ2h0OiAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgPyBgJHtkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsfWBcbiAgICA6IGAke2Rlc2lnblRva2Vucy5oZWlnaHRGb3JJbnB1dH1gfTtcbiAgcGFkZGluZzogMDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBNdWx0aWxpbmVJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgd2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgeyBnZXRNdWx0aWxpbmVUZXh0SW5wdXRBY3Rpb25JY29uU3R5bGVzLCBNdWx0aWxpbmVJbnB1dFdyYXBwZXIgfTtcbiJdfQ== */",
64
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
65
+ });
44
66
 
45
67
  function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
46
68
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
@@ -54,12 +76,12 @@ var _ref = process.env.NODE_ENV === "production" ? {
54
76
  } : {
55
77
  name: "7hlegj-MultilineTextInput",
56
78
  styles: "display:flex;justify-content:flex-end;label:MultilineTextInput;",
57
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm11bHRpbGluZS10ZXh0LWlucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtS29CIiwiZmlsZSI6Im11bHRpbGluZS10ZXh0LWlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHVzZVN0YXRlLFxuICB1c2VDYWxsYmFjayxcbiAgdHlwZSBDaGFuZ2VFdmVudEhhbmRsZXIsXG4gIHR5cGUgRm9jdXNFdmVudEhhbmRsZXIsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFuZ2xlVXBJY29uLCBBbmdsZURvd25JY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IEZsYXRCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZmxhdC1idXR0b24nO1xuaW1wb3J0IHsgdXNlVG9nZ2xlU3RhdGUgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9ob29rcyc7XG5pbXBvcnQgeyBmaWx0ZXJEYXRhQXR0cmlidXRlcyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3V0aWxzJztcbmltcG9ydCBTdGFjayBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zcGFjaW5ncy1zdGFjayc7XG5pbXBvcnQgQ29uc3RyYWludHMgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29uc3RyYWludHMnO1xuaW1wb3J0IHtcbiAgTXVsdGlsaW5lSW5wdXQsXG4gIG1lc3NhZ2VzTXVsdGlsaW5lSW5wdXQsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2lucHV0LXV0aWxzJztcblxuZXhwb3J0IHR5cGUgVE11bHRpbGluZVRleHRJbnB1dFByb3BzID0ge1xuICAvKipcbiAgICogVXNlZCBhcyBIVE1MIG5hbWUgb2YgdGhlIGlucHV0IGNvbXBvbmVudC4gcHJvcGVydHlcbiAgICovXG4gIG5hbWU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJbmRpY2F0ZSBpZiB0aGUgdmFsdWUgZW50ZXJlZCBpbiB0aGUgaW5wdXQgaXMgaW52YWxpZC5cbiAgICovXG4gICdhcmlhLWludmFsaWQnPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEhUTUwgSUQgb2YgYW4gZWxlbWVudCBjb250YWluaW5nIGFuIGVycm9yIG1lc3NhZ2UgcmVsYXRlZCB0byB0aGUgaW5wdXQuXG4gICAqL1xuICAnYXJpYS1lcnJvcm1lc3NhZ2UnPzogc3RyaW5nO1xuICAvKipcbiAgICogVXNlZCBhcyBIVE1MIGBhdXRvY29tcGxldGVgIHByb3BlcnR5XG4gICAqL1xuICBhdXRvQ29tcGxldGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBVc2VkIGFzIEhUTUwgaWQgcHJvcGVydHkuIEFuIGlkIGlzIGF1dG8tZ2VuZXJhdGVkIHdoZW4gaXQgaXMgbm90IHNwZWNpZmllZC5cbiAgICovXG4gIGlkPzogc3RyaW5nO1xuICAvKipcbiAgICogVmFsdWUgb2YgdGhlIGlucHV0IGNvbXBvbmVudC5cbiAgICovXG4gIHZhbHVlOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBDYWxsZWQgd2l0aCBhbiBldmVudCBjb250YWluaW5nIHRoZSBuZXcgdmFsdWUuIFJlcXVpcmVkIHdoZW4gaW5wdXQgaXMgbm90IHJlYWQgb25seS4gUGFyZW50IHNob3VsZCBwYXNzIGl0IGJhY2sgYXMgdmFsdWUuXG4gICAqL1xuICBvbkNoYW5nZT86IENoYW5nZUV2ZW50SGFuZGxlcjxIVE1MVGV4dEFyZWFFbGVtZW50PjtcbiAgLyoqXG4gICAqIENhbGxlZCB3aGVuIGlucHV0IGlzIGJsdXJyZWRcbiAgICovXG4gIG9uQmx1cj86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxUZXh0QXJlYUVsZW1lbnQ+O1xuICAvKipcbiAgICogQ2FsbGVkIHdoZW4gaW5wdXQgaXMgZm9jdXNlZFxuICAgKi9cbiAgb25Gb2N1cz86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxUZXh0QXJlYUVsZW1lbnQ+O1xuICAvKipcbiAgICogRm9jdXMgdGhlIGlucHV0IG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBpc0F1dG9mb2N1c3NlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBFeHBhbmRzIG11bHRpbGluZSB0ZXh0IGlucHV0IGluaXRpYWxseVxuICAgKi9cbiAgZGVmYXVsdEV4cGFuZE11bHRpbGluZVRleHQ/OiBib29sZWFuO1xuICAvKipcbiAgICogSW5kaWNhdGVzIHRoYXQgdGhlIGlucHV0IGNhbm5vdCBiZSBtb2RpZmllZCAoZS5nIG5vdCBhdXRob3JpemVkLCBvciBjaGFuZ2VzIGN1cnJlbnRseSBzYXZpbmcpLlxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZmllbGQgaXMgZGlzcGxheWluZyByZWFkLW9ubHkgY29udGVudFxuICAgKi9cbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBQbGFjZWhvbGRlciB0ZXh0IGZvciB0aGUgaW5wdXRcbiAgICovXG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICAvKipcbiAgICogSW5kaWNhdGVzIHRoYXQgaW5wdXQgaGFzIGVycm9yc1xuICAgKi9cbiAgaGFzRXJyb3I/OiBib29sZWFuO1xuICAvKipcbiAgICogQ29udHJvbCB0byBpbmRpY2F0ZSBvbiB0aGUgaW5wdXQgaWYgdGhlcmUgYXJlIHNlbGVjdGVkIHZhbHVlcyB0aGF0IGFyZSBwb3RlbnRpYWxseSBpbnZhbGlkXG4gICAqL1xuICBoYXNXYXJuaW5nPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEhvcml6b250YWwgc2l6ZSBsaW1pdCBvZiB0aGUgaW5wdXQgZmllbGRzLlxuICAgKi9cbiAgaG9yaXpvbnRhbENvbnN0cmFpbnQ/OlxuICAgIHwgNlxuICAgIHwgN1xuICAgIHwgOFxuICAgIHwgOVxuICAgIHwgMTBcbiAgICB8IDExXG4gICAgfCAxMlxuICAgIHwgMTNcbiAgICB8IDE0XG4gICAgfCAxNVxuICAgIHwgMTZcbiAgICB8ICdzY2FsZSdcbiAgICB8ICdhdXRvJztcbn07XG5cbmNvbnN0IGRlZmF1bHRQcm9wczogUGljazxcbiAgVE11bHRpbGluZVRleHRJbnB1dFByb3BzLFxuICAnZGVmYXVsdEV4cGFuZE11bHRpbGluZVRleHQnXG4+ID0ge1xuICBkZWZhdWx0RXhwYW5kTXVsdGlsaW5lVGV4dDogZmFsc2UsXG59O1xuXG5jb25zdCBNdWx0aWxpbmVUZXh0SW5wdXQgPSAocHJvcHM6IFRNdWx0aWxpbmVUZXh0SW5wdXRQcm9wcykgPT4ge1xuICBjb25zdCBpbnRsID0gdXNlSW50bCgpO1xuICBjb25zdCBbc2hvdWxkUmVuZGVyVG9nZ2xlQnV0dG9uLCBzZXRTaG91bGRSZW5kZXJUb2dnbGVCdXR0b25dID1cbiAgICB1c2VTdGF0ZShmYWxzZSk7XG5cbiAgY29uc3QgW2lzT3BlbiwgdG9nZ2xlXSA9IHVzZVRvZ2dsZVN0YXRlKHByb3BzLmRlZmF1bHRFeHBhbmRNdWx0aWxpbmVUZXh0KTtcblxuICBjb25zdCB7IG9uRm9jdXMgfSA9IHByb3BzO1xuICBjb25zdCBoYW5kbGVGb2N1cyA9IHVzZUNhbGxiYWNrPEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxUZXh0QXJlYUVsZW1lbnQ+PihcbiAgICAoZXZlbnQpID0+IHtcbiAgICAgIGlmICghaXNPcGVuKSB0b2dnbGUodHJ1ZSk7XG4gICAgICBpZiAob25Gb2N1cykgb25Gb2N1cyhldmVudCk7XG4gICAgfSxcbiAgICBbaXNPcGVuLCBvbkZvY3VzLCB0b2dnbGVdXG4gICk7XG5cbiAgY29uc3QgaGFuZGxlSGVpZ2h0Q2hhbmdlID0gdXNlQ2FsbGJhY2s8XG4gICAgKGhlaWdodDogbnVtYmVyLCByb3dDb3VudDogbnVtYmVyKSA9PiB2b2lkXG4gID4oXG4gICAgKF8sIHJvd0NvdW50KSA9PiB7XG4gICAgICAvLyBUaGlzIGNoZWNrcyBpZiB0aGUgY29udGVudCBpbiB0aGUgdGV4dGFyZWEgaXMgZ3JlYXRlciB0aGFuIG9uZSByb3cuIElmIGl0IGlzLCB0aGVuIHRoZSB0b2dnbGUgYnV0dG9uIHdpbGwgYmUgc2hvd24uXG4gICAgICAvLyBUaGlzIGlzIHRvIHByZXZlbnQgdGhlIHRvZ2dsZSBidXR0b24gZnJvbSBzaG93aW5nIHdoZW4gdGhlcmUgaXMgbm90IGVub3VnaCBjb250ZW50IHRvIGV4cGFuZC9jb2xsYXBzZS5cbiAgICAgIHNldFNob3VsZFJlbmRlclRvZ2dsZUJ1dHRvbihyb3dDb3VudCA+IDEpO1xuICAgIH0sXG4gICAgW3NldFNob3VsZFJlbmRlclRvZ2dsZUJ1dHRvbl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxDb25zdHJhaW50cy5Ib3Jpem9udGFsIG1heD17cHJvcHMuaG9yaXpvbnRhbENvbnN0cmFpbnR9PlxuICAgICAgPFN0YWNrIHNjYWxlPVwieHNcIj5cbiAgICAgICAgPE11bHRpbGluZUlucHV0XG4gICAgICAgICAgbmFtZT17cHJvcHMubmFtZX1cbiAgICAgICAgICBhdXRvQ29tcGxldGU9e3Byb3BzLmF1dG9Db21wbGV0ZX1cbiAgICAgICAgICB2YWx1ZT17cHJvcHMudmFsdWV9XG4gICAgICAgICAgb25DaGFuZ2U9e3Byb3BzLm9uQ2hhbmdlfVxuICAgICAgICAgIG9uSGVpZ2h0Q2hhbmdlPXtoYW5kbGVIZWlnaHRDaGFuZ2V9XG4gICAgICAgICAgaWQ9e3Byb3BzLmlkfVxuICAgICAgICAgIG9uQmx1cj17cHJvcHMub25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e2hhbmRsZUZvY3VzfVxuICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgaGFzRXJyb3I9e3Byb3BzLmhhc0Vycm9yfVxuICAgICAgICAgIGhhc1dhcm5pbmc9e3Byb3BzLmhhc1dhcm5pbmd9XG4gICAgICAgICAgcGxhY2Vob2xkZXI9e3Byb3BzLnBsYWNlaG9sZGVyfVxuICAgICAgICAgIGlzUmVhZE9ubHk9e3Byb3BzLmlzUmVhZE9ubHl9XG4gICAgICAgICAgaXNBdXRvZm9jdXNzZWQ9e3Byb3BzLmlzQXV0b2ZvY3Vzc2VkfVxuICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgIHsuLi5maWx0ZXJEYXRhQXR0cmlidXRlcyhwcm9wcyl9XG4gICAgICAgICAgLyogQVJJQSAqL1xuICAgICAgICAgIGFyaWEtaW52YWxpZD17cHJvcHNbJ2FyaWEtaW52YWxpZCddfVxuICAgICAgICAgIGFyaWEtZXJyb3JtZXNzYWdlPXtwcm9wc1snYXJpYS1lcnJvcm1lc3NhZ2UnXX1cbiAgICAgICAgLz5cbiAgICAgICAge3Nob3VsZFJlbmRlclRvZ2dsZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPGRpdlxuICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxGbGF0QnV0dG9uXG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHRvZ2dsZSgpfVxuICAgICAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgICAgICBsYWJlbD17aW50bC5mb3JtYXRNZXNzYWdlKFxuICAgICAgICAgICAgICAgIGlzT3BlblxuICAgICAgICAgICAgICAgICAgPyBtZXNzYWdlc011bHRpbGluZUlucHV0LmNvbGxhcHNlXG4gICAgICAgICAgICAgICAgICA6IG1lc3NhZ2VzTXVsdGlsaW5lSW5wdXQuZXhwYW5kXG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgIGljb249e1xuICAgICAgICAgICAgICAgIGlzT3BlbiA/IChcbiAgICAgICAgICAgICAgICAgIDxBbmdsZVVwSWNvbiBzaXplPVwic21hbGxcIiAvPlxuICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICA8QW5nbGVEb3duSWNvbiBzaXplPVwic21hbGxcIiAvPlxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgKX1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9Db25zdHJhaW50cy5Ib3Jpem9udGFsPlxuICApO1xufTtcblxuTXVsdGlsaW5lVGV4dElucHV0LmRpc3BsYXlOYW1lID0gJ011bHRpbGluZVRleHRJbnB1dCc7XG5cbk11bHRpbGluZVRleHRJbnB1dC5pc0VtcHR5ID0gKHZhbHVlOiBUTXVsdGlsaW5lVGV4dElucHV0UHJvcHNbJ3ZhbHVlJ10pID0+XG4gICF2YWx1ZSB8fCB2YWx1ZS50cmltKCkubGVuZ3RoID09PSAwO1xuTXVsdGlsaW5lVGV4dElucHV0LmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgTXVsdGlsaW5lVGV4dElucHV0O1xuIl19 */",
79
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AA6NoB","file":"multiline-text-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  ReactElement,\n} from 'react';\nimport SecondaryIconButton, {\n  type TSecondaryButtonIconProps,\n} from '@commercetools-uikit/secondary-icon-button';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  MultilineInputWrapper,\n  getMultilineTextInputActionIconStyles,\n} from './multiline-text-input.styles';\n\nexport type TMultilineTextInputProps = {\n  /**\n   * Used as HTML name of the input component. property\n   */\n  name?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Value of the input component.\n   */\n  value: string;\n  /**\n   * Called with an event containing the new value. Required when input is not read only. Parent should pass it back as value.\n   */\n  onChange?: ChangeEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Expands multiline text input initially\n   */\n  defaultExpandMultilineText?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n\n  /**\n   * Custom action icon to be displayed on the right side of the input.\n   */\n  rightActionIcon?: ReactElement;\n  /**\n   * Props for the right-action icon-button. Required when rightActionIcon is provided.\n   * At least a `label` and an `onClick` prop/function need to be provided.\n   */\n  rightActionProps?: TSecondaryButtonIconProps;\n  /**\n   * Set this to `true` to reduce the paddings of the input allowing the input to display\n   * more data in less space.\n   *\n   */\n  isCondensed?: boolean;\n  /**\n   * Set this to value to determine the maximum text rows of the text area.\n   * Any text overflow past this row number would implement a scroll\n   */\n  maxRows?: number;\n};\n\nconst defaultProps: Pick<\n  TMultilineTextInputProps,\n  'defaultExpandMultilineText'\n> = {\n  defaultExpandMultilineText: false,\n};\n\nconst MultilineTextInput = (props: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(props.defaultExpandMultilineText);\n\n  const { onFocus } = props;\n  const handleFocus = useCallback<FocusEventHandler<HTMLTextAreaElement>>(\n    (event) => {\n      if (!isOpen) toggle(true);\n      if (onFocus) onFocus(event);\n    },\n    [isOpen, onFocus, toggle]\n  );\n\n  const handleHeightChange = useCallback<\n    (height: number, rowCount: number) => void\n  >(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setShouldRenderToggleButton(rowCount > 1);\n    },\n    [setShouldRenderToggleButton]\n  );\n\n  if (props.rightActionIcon && !props.rightActionProps) {\n    warning(\n      false,\n      'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <MultilineInputWrapper>\n          <MultilineInput\n            name={props.name}\n            autoComplete={props.autoComplete}\n            value={props.value}\n            onChange={props.onChange}\n            onHeightChange={handleHeightChange}\n            id={props.id}\n            onBlur={props.onBlur}\n            onFocus={handleFocus}\n            isDisabled={props.isDisabled}\n            hasError={props.hasError}\n            hasWarning={props.hasWarning}\n            placeholder={props.placeholder}\n            isReadOnly={props.isReadOnly}\n            isAutofocussed={props.isAutofocussed}\n            isOpen={isOpen}\n            cacheMeasurements={false}\n            css={css`\n              padding-right: ${props.rightActionIcon &&\n              props.rightActionProps &&\n              designTokens.spacing50};\n            `}\n            isCondensed={props.isCondensed}\n            maxRows={props.maxRows}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div css={getMultilineTextInputActionIconStyles(props)}>\n              <SecondaryIconButton\n                color=\"info\"\n                isDisabled={props.isDisabled || props.isReadOnly}\n                size={props.isCondensed ? '30' : '40'}\n                icon={props.rightActionIcon}\n                {...props.rightActionProps}\n              />\n            </div>\n          )}\n        </MultilineInputWrapper>\n        {shouldRenderToggleButton && (\n          <div\n            css={css`\n              display: flex;\n              justify-content: flex-end;\n            `}\n          >\n            <FlatButton\n              onClick={() => toggle()}\n              isDisabled={props.isDisabled}\n              label={intl.formatMessage(\n                isOpen\n                  ? messagesMultilineInput.collapse\n                  : messagesMultilineInput.expand\n              )}\n              icon={\n                isOpen ? (\n                  <AngleUpIcon size=\"small\" />\n                ) : (\n                  <AngleDownIcon size=\"small\" />\n                )\n              }\n            />\n          </div>\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nMultilineTextInput.displayName = 'MultilineTextInput';\n\nMultilineTextInput.isEmpty = (value: TMultilineTextInputProps['value']) =>\n  !value || value.trim().length === 0;\nMultilineTextInput.defaultProps = defaultProps;\n\nexport default MultilineTextInput;\n"]} */",
58
80
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
81
  };
60
82
  const MultilineTextInput = props => {
61
83
  const intl = reactIntl.useIntl();
62
- const _useState = react.useState(false),
84
+ const _useState = react$1.useState(false),
63
85
  _useState2 = _slicedToArray(_useState, 2),
64
86
  shouldRenderToggleButton = _useState2[0],
65
87
  setShouldRenderToggleButton = _useState2[1];
@@ -68,40 +90,57 @@ const MultilineTextInput = props => {
68
90
  isOpen = _useToggleState2[0],
69
91
  toggle = _useToggleState2[1];
70
92
  const onFocus = props.onFocus;
71
- const handleFocus = react.useCallback(event => {
93
+ const handleFocus = react$1.useCallback(event => {
72
94
  if (!isOpen) toggle(true);
73
95
  if (onFocus) onFocus(event);
74
96
  }, [isOpen, onFocus, toggle]);
75
- const handleHeightChange = react.useCallback((_, rowCount) => {
97
+ const handleHeightChange = react$1.useCallback((_, rowCount) => {
76
98
  // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.
77
99
  // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.
78
100
  setShouldRenderToggleButton(rowCount > 1);
79
101
  }, [setShouldRenderToggleButton]);
102
+ if (props.rightActionIcon && !props.rightActionProps) {
103
+ process.env.NODE_ENV !== "production" ? utils.warning(false, 'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.') : void 0;
104
+ }
80
105
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
81
106
  max: props.horizontalConstraint,
82
107
  children: jsxRuntime.jsxs(Stack__default["default"], {
83
108
  scale: "xs",
84
- children: [jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread(_objectSpread({
85
- name: props.name,
86
- autoComplete: props.autoComplete,
87
- value: props.value,
88
- onChange: props.onChange,
89
- onHeightChange: handleHeightChange,
90
- id: props.id,
91
- onBlur: props.onBlur,
92
- onFocus: handleFocus,
93
- isDisabled: props.isDisabled,
94
- hasError: props.hasError,
95
- hasWarning: props.hasWarning,
96
- placeholder: props.placeholder,
97
- isReadOnly: props.isReadOnly,
98
- isAutofocussed: props.isAutofocussed,
99
- isOpen: isOpen
100
- }, utils.filterDataAttributes(props)), {}, {
101
- /* ARIA */
102
- "aria-invalid": props['aria-invalid'],
103
- "aria-errormessage": props['aria-errormessage']
104
- })), shouldRenderToggleButton && jsxRuntime.jsx("div", {
109
+ children: [jsxRuntime.jsxs(MultilineInputWrapper, {
110
+ children: [jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread(_objectSpread({
111
+ name: props.name,
112
+ autoComplete: props.autoComplete,
113
+ value: props.value,
114
+ onChange: props.onChange,
115
+ onHeightChange: handleHeightChange,
116
+ id: props.id,
117
+ onBlur: props.onBlur,
118
+ onFocus: handleFocus,
119
+ isDisabled: props.isDisabled,
120
+ hasError: props.hasError,
121
+ hasWarning: props.hasWarning,
122
+ placeholder: props.placeholder,
123
+ isReadOnly: props.isReadOnly,
124
+ isAutofocussed: props.isAutofocussed,
125
+ isOpen: isOpen,
126
+ cacheMeasurements: false,
127
+ css: /*#__PURE__*/react.css("padding-right:", props.rightActionIcon && props.rightActionProps && designSystem.designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MultilineTextInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AAmMoB","file":"multiline-text-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  ReactElement,\n} from 'react';\nimport SecondaryIconButton, {\n  type TSecondaryButtonIconProps,\n} from '@commercetools-uikit/secondary-icon-button';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  MultilineInputWrapper,\n  getMultilineTextInputActionIconStyles,\n} from './multiline-text-input.styles';\n\nexport type TMultilineTextInputProps = {\n  /**\n   * Used as HTML name of the input component. property\n   */\n  name?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Value of the input component.\n   */\n  value: string;\n  /**\n   * Called with an event containing the new value. Required when input is not read only. Parent should pass it back as value.\n   */\n  onChange?: ChangeEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Expands multiline text input initially\n   */\n  defaultExpandMultilineText?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n\n  /**\n   * Custom action icon to be displayed on the right side of the input.\n   */\n  rightActionIcon?: ReactElement;\n  /**\n   * Props for the right-action icon-button. Required when rightActionIcon is provided.\n   * At least a `label` and an `onClick` prop/function need to be provided.\n   */\n  rightActionProps?: TSecondaryButtonIconProps;\n  /**\n   * Set this to `true` to reduce the paddings of the input allowing the input to display\n   * more data in less space.\n   *\n   */\n  isCondensed?: boolean;\n  /**\n   * Set this to value to determine the maximum text rows of the text area.\n   * Any text overflow past this row number would implement a scroll\n   */\n  maxRows?: number;\n};\n\nconst defaultProps: Pick<\n  TMultilineTextInputProps,\n  'defaultExpandMultilineText'\n> = {\n  defaultExpandMultilineText: false,\n};\n\nconst MultilineTextInput = (props: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(props.defaultExpandMultilineText);\n\n  const { onFocus } = props;\n  const handleFocus = useCallback<FocusEventHandler<HTMLTextAreaElement>>(\n    (event) => {\n      if (!isOpen) toggle(true);\n      if (onFocus) onFocus(event);\n    },\n    [isOpen, onFocus, toggle]\n  );\n\n  const handleHeightChange = useCallback<\n    (height: number, rowCount: number) => void\n  >(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setShouldRenderToggleButton(rowCount > 1);\n    },\n    [setShouldRenderToggleButton]\n  );\n\n  if (props.rightActionIcon && !props.rightActionProps) {\n    warning(\n      false,\n      'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <MultilineInputWrapper>\n          <MultilineInput\n            name={props.name}\n            autoComplete={props.autoComplete}\n            value={props.value}\n            onChange={props.onChange}\n            onHeightChange={handleHeightChange}\n            id={props.id}\n            onBlur={props.onBlur}\n            onFocus={handleFocus}\n            isDisabled={props.isDisabled}\n            hasError={props.hasError}\n            hasWarning={props.hasWarning}\n            placeholder={props.placeholder}\n            isReadOnly={props.isReadOnly}\n            isAutofocussed={props.isAutofocussed}\n            isOpen={isOpen}\n            cacheMeasurements={false}\n            css={css`\n              padding-right: ${props.rightActionIcon &&\n              props.rightActionProps &&\n              designTokens.spacing50};\n            `}\n            isCondensed={props.isCondensed}\n            maxRows={props.maxRows}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div css={getMultilineTextInputActionIconStyles(props)}>\n              <SecondaryIconButton\n                color=\"info\"\n                isDisabled={props.isDisabled || props.isReadOnly}\n                size={props.isCondensed ? '30' : '40'}\n                icon={props.rightActionIcon}\n                {...props.rightActionProps}\n              />\n            </div>\n          )}\n        </MultilineInputWrapper>\n        {shouldRenderToggleButton && (\n          <div\n            css={css`\n              display: flex;\n              justify-content: flex-end;\n            `}\n          >\n            <FlatButton\n              onClick={() => toggle()}\n              isDisabled={props.isDisabled}\n              label={intl.formatMessage(\n                isOpen\n                  ? messagesMultilineInput.collapse\n                  : messagesMultilineInput.expand\n              )}\n              icon={\n                isOpen ? (\n                  <AngleUpIcon size=\"small\" />\n                ) : (\n                  <AngleDownIcon size=\"small\" />\n                )\n              }\n            />\n          </div>\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nMultilineTextInput.displayName = 'MultilineTextInput';\n\nMultilineTextInput.isEmpty = (value: TMultilineTextInputProps['value']) =>\n  !value || value.trim().length === 0;\nMultilineTextInput.defaultProps = defaultProps;\n\nexport default MultilineTextInput;\n"]} */"),
128
+ isCondensed: props.isCondensed,
129
+ maxRows: props.maxRows
130
+ }, utils.filterDataAttributes(props)), {}, {
131
+ /* ARIA */
132
+ "aria-invalid": props['aria-invalid'],
133
+ "aria-errormessage": props['aria-errormessage']
134
+ })), props.rightActionIcon && props.rightActionProps && jsxRuntime.jsx("div", {
135
+ css: getMultilineTextInputActionIconStyles(props),
136
+ children: jsxRuntime.jsx(SecondaryIconButton__default["default"], _objectSpread({
137
+ color: "info",
138
+ isDisabled: props.isDisabled || props.isReadOnly,
139
+ size: props.isCondensed ? '30' : '40',
140
+ icon: props.rightActionIcon
141
+ }, props.rightActionProps))
142
+ })]
143
+ }), shouldRenderToggleButton && jsxRuntime.jsx("div", {
105
144
  css: _ref,
106
145
  children: jsxRuntime.jsx(FlatButton__default["default"], {
107
146
  onClick: () => toggle(),
@@ -134,7 +173,11 @@ MultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
134
173
  placeholder: _pt__default["default"].string,
135
174
  hasError: _pt__default["default"].bool,
136
175
  hasWarning: _pt__default["default"].bool,
137
- horizontalConstraint: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
176
+ horizontalConstraint: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
177
+ rightActionIcon: _pt__default["default"].element,
178
+ rightActionProps: _pt__default["default"].any,
179
+ isCondensed: _pt__default["default"].bool,
180
+ maxRows: _pt__default["default"].number
138
181
  } : {};
139
182
  MultilineTextInput.displayName = 'MultilineTextInput';
140
183
  MultilineTextInput.isEmpty = value => !value || _trimInstanceProperty__default["default"](value).call(value).length === 0;
@@ -142,7 +185,7 @@ MultilineTextInput.defaultProps = defaultProps;
142
185
  var MultilineTextInput$1 = MultilineTextInput;
143
186
 
144
187
  // NOTE: This string will be replaced on build time with the package version.
145
- var version = "19.4.0";
188
+ var version = "19.6.0";
146
189
 
147
190
  exports["default"] = MultilineTextInput$1;
148
191
  exports.version = version;
@@ -14,16 +14,19 @@ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
15
  require('prop-types');
16
16
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
17
- var react = require('react');
17
+ var react$1 = require('react');
18
+ var SecondaryIconButton = require('@commercetools-uikit/secondary-icon-button');
18
19
  var reactIntl = require('react-intl');
19
- require('@emotion/react');
20
+ var react = require('@emotion/react');
20
21
  var icons = require('@commercetools-uikit/icons');
21
22
  var FlatButton = require('@commercetools-uikit/flat-button');
22
23
  var hooks = require('@commercetools-uikit/hooks');
23
24
  var utils = require('@commercetools-uikit/utils');
24
25
  var Stack = require('@commercetools-uikit/spacings-stack');
25
26
  var Constraints = require('@commercetools-uikit/constraints');
27
+ var designSystem = require('@commercetools-uikit/design-system');
26
28
  var inputUtils = require('@commercetools-uikit/input-utils');
29
+ var _styled = require('@emotion/styled/base');
27
30
  var jsxRuntime = require('@emotion/react/jsx-runtime');
28
31
 
29
32
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
@@ -37,9 +40,19 @@ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_O
37
40
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
38
41
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
39
42
  var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
43
+ var SecondaryIconButton__default = /*#__PURE__*/_interopDefault(SecondaryIconButton);
40
44
  var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
41
45
  var Stack__default = /*#__PURE__*/_interopDefault(Stack);
42
46
  var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
47
+ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
48
+
49
+ const getMultilineTextInputActionIconStyles = props => /*#__PURE__*/react.css("position:absolute;right:", designSystem.designTokens.spacing30, ";top:0;height:", props.isCondensed ? "".concat(designSystem.designTokens.heightForInputAsSmall) : "".concat(designSystem.designTokens.heightForInput), ";padding:0;display:flex;justify-content:center;align-items:center;" + ("" ), "" );
50
+ const MultilineInputWrapper = /*#__PURE__*/_styled__default["default"]("div", {
51
+ target: "eg1owae0"
52
+ } )({
53
+ name: "8sarsy",
54
+ styles: "position:relative;display:inline-block;width:100%"
55
+ } );
43
56
 
44
57
  function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
45
58
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
@@ -52,7 +65,7 @@ var _ref = {
52
65
  } ;
53
66
  const MultilineTextInput = props => {
54
67
  const intl = reactIntl.useIntl();
55
- const _useState = react.useState(false),
68
+ const _useState = react$1.useState(false),
56
69
  _useState2 = _slicedToArray(_useState, 2),
57
70
  shouldRenderToggleButton = _useState2[0],
58
71
  setShouldRenderToggleButton = _useState2[1];
@@ -61,40 +74,55 @@ const MultilineTextInput = props => {
61
74
  isOpen = _useToggleState2[0],
62
75
  toggle = _useToggleState2[1];
63
76
  const onFocus = props.onFocus;
64
- const handleFocus = react.useCallback(event => {
77
+ const handleFocus = react$1.useCallback(event => {
65
78
  if (!isOpen) toggle(true);
66
79
  if (onFocus) onFocus(event);
67
80
  }, [isOpen, onFocus, toggle]);
68
- const handleHeightChange = react.useCallback((_, rowCount) => {
81
+ const handleHeightChange = react$1.useCallback((_, rowCount) => {
69
82
  // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.
70
83
  // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.
71
84
  setShouldRenderToggleButton(rowCount > 1);
72
85
  }, [setShouldRenderToggleButton]);
86
+ if (props.rightActionIcon && !props.rightActionProps) ;
73
87
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
74
88
  max: props.horizontalConstraint,
75
89
  children: jsxRuntime.jsxs(Stack__default["default"], {
76
90
  scale: "xs",
77
- children: [jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread(_objectSpread({
78
- name: props.name,
79
- autoComplete: props.autoComplete,
80
- value: props.value,
81
- onChange: props.onChange,
82
- onHeightChange: handleHeightChange,
83
- id: props.id,
84
- onBlur: props.onBlur,
85
- onFocus: handleFocus,
86
- isDisabled: props.isDisabled,
87
- hasError: props.hasError,
88
- hasWarning: props.hasWarning,
89
- placeholder: props.placeholder,
90
- isReadOnly: props.isReadOnly,
91
- isAutofocussed: props.isAutofocussed,
92
- isOpen: isOpen
93
- }, utils.filterDataAttributes(props)), {}, {
94
- /* ARIA */
95
- "aria-invalid": props['aria-invalid'],
96
- "aria-errormessage": props['aria-errormessage']
97
- })), shouldRenderToggleButton && jsxRuntime.jsx("div", {
91
+ children: [jsxRuntime.jsxs(MultilineInputWrapper, {
92
+ children: [jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread(_objectSpread({
93
+ name: props.name,
94
+ autoComplete: props.autoComplete,
95
+ value: props.value,
96
+ onChange: props.onChange,
97
+ onHeightChange: handleHeightChange,
98
+ id: props.id,
99
+ onBlur: props.onBlur,
100
+ onFocus: handleFocus,
101
+ isDisabled: props.isDisabled,
102
+ hasError: props.hasError,
103
+ hasWarning: props.hasWarning,
104
+ placeholder: props.placeholder,
105
+ isReadOnly: props.isReadOnly,
106
+ isAutofocussed: props.isAutofocussed,
107
+ isOpen: isOpen,
108
+ cacheMeasurements: false,
109
+ css: /*#__PURE__*/react.css("padding-right:", props.rightActionIcon && props.rightActionProps && designSystem.designTokens.spacing50, ";" + ("" ), "" ),
110
+ isCondensed: props.isCondensed,
111
+ maxRows: props.maxRows
112
+ }, utils.filterDataAttributes(props)), {}, {
113
+ /* ARIA */
114
+ "aria-invalid": props['aria-invalid'],
115
+ "aria-errormessage": props['aria-errormessage']
116
+ })), props.rightActionIcon && props.rightActionProps && jsxRuntime.jsx("div", {
117
+ css: getMultilineTextInputActionIconStyles(props),
118
+ children: jsxRuntime.jsx(SecondaryIconButton__default["default"], _objectSpread({
119
+ color: "info",
120
+ isDisabled: props.isDisabled || props.isReadOnly,
121
+ size: props.isCondensed ? '30' : '40',
122
+ icon: props.rightActionIcon
123
+ }, props.rightActionProps))
124
+ })]
125
+ }), shouldRenderToggleButton && jsxRuntime.jsx("div", {
98
126
  css: _ref,
99
127
  children: jsxRuntime.jsx(FlatButton__default["default"], {
100
128
  onClick: () => toggle(),
@@ -117,7 +145,7 @@ MultilineTextInput.defaultProps = defaultProps;
117
145
  var MultilineTextInput$1 = MultilineTextInput;
118
146
 
119
147
  // NOTE: This string will be replaced on build time with the package version.
120
- var version = "19.4.0";
148
+ var version = "19.6.0";
121
149
 
122
150
  exports["default"] = MultilineTextInput$1;
123
151
  exports.version = version;
@@ -11,17 +11,37 @@ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
11
11
  import _pt from 'prop-types';
12
12
  import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
13
13
  import { useState, useCallback } from 'react';
14
+ import SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';
14
15
  import { useIntl } from 'react-intl';
15
- import '@emotion/react';
16
+ import { css } from '@emotion/react';
16
17
  import { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';
17
18
  import FlatButton from '@commercetools-uikit/flat-button';
18
19
  import { useToggleState } from '@commercetools-uikit/hooks';
19
- import { filterDataAttributes } from '@commercetools-uikit/utils';
20
+ import { warning, filterDataAttributes } from '@commercetools-uikit/utils';
20
21
  import Stack from '@commercetools-uikit/spacings-stack';
21
22
  import Constraints from '@commercetools-uikit/constraints';
23
+ import { designTokens } from '@commercetools-uikit/design-system';
22
24
  import { MultilineInput, messagesMultilineInput } from '@commercetools-uikit/input-utils';
25
+ import _styled from '@emotion/styled/base';
23
26
  import { jsx, jsxs } from '@emotion/react/jsx-runtime';
24
27
 
28
+ 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)."; }
29
+ const getMultilineTextInputActionIconStyles = props => /*#__PURE__*/css("position:absolute;right:", designTokens.spacing30, ";top:0;height:", props.isCondensed ? "".concat(designTokens.heightForInputAsSmall) : "".concat(designTokens.heightForInput), ";padding:0;display:flex;justify-content:center;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:getMultilineTextInputActionIconStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm11bHRpbGluZS10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPUSIsImZpbGUiOiJtdWx0aWxpbmUtdGV4dC1pbnB1dC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IHR5cGUgVE11bHRpbGluZVRleHRJbnB1dFByb3BzIH0gZnJvbSAnLi9tdWx0aWxpbmUtdGV4dC1pbnB1dCc7XG5cbmNvbnN0IGdldE11bHRpbGluZVRleHRJbnB1dEFjdGlvbkljb25TdHlsZXMgPSAoXG4gIHByb3BzOiBUTXVsdGlsaW5lVGV4dElucHV0UHJvcHNcbikgPT4gY3NzYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICB0b3A6IDA7XG4gIGhlaWdodDogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgID8gYCR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbH1gXG4gICAgOiBgJHtkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9YH07XG4gIHBhZGRpbmc6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgTXVsdGlsaW5lSW5wdXRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IHsgZ2V0TXVsdGlsaW5lVGV4dElucHV0QWN0aW9uSWNvblN0eWxlcywgTXVsdGlsaW5lSW5wdXRXcmFwcGVyIH07XG4iXX0= */");
30
+ const MultilineInputWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
31
+ target: "eg1owae0"
32
+ } : {
33
+ target: "eg1owae0",
34
+ label: "MultilineInputWrapper"
35
+ })(process.env.NODE_ENV === "production" ? {
36
+ name: "8sarsy",
37
+ styles: "position:relative;display:inline-block;width:100%"
38
+ } : {
39
+ name: "8sarsy",
40
+ styles: "position:relative;display:inline-block;width:100%",
41
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm11bHRpbGluZS10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQndDIiwiZmlsZSI6Im11bHRpbGluZS10ZXh0LWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHsgdHlwZSBUTXVsdGlsaW5lVGV4dElucHV0UHJvcHMgfSBmcm9tICcuL211bHRpbGluZS10ZXh0LWlucHV0JztcblxuY29uc3QgZ2V0TXVsdGlsaW5lVGV4dElucHV0QWN0aW9uSWNvblN0eWxlcyA9IChcbiAgcHJvcHM6IFRNdWx0aWxpbmVUZXh0SW5wdXRQcm9wc1xuKSA9PiBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmczMH07XG4gIHRvcDogMDtcbiAgaGVpZ2h0OiAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgPyBgJHtkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsfWBcbiAgICA6IGAke2Rlc2lnblRva2Vucy5oZWlnaHRGb3JJbnB1dH1gfTtcbiAgcGFkZGluZzogMDtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBNdWx0aWxpbmVJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgd2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgeyBnZXRNdWx0aWxpbmVUZXh0SW5wdXRBY3Rpb25JY29uU3R5bGVzLCBNdWx0aWxpbmVJbnB1dFdyYXBwZXIgfTtcbiJdfQ== */",
42
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
43
+ });
44
+
25
45
  function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
26
46
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
27
47
  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)."; }
@@ -34,7 +54,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
34
54
  } : {
35
55
  name: "7hlegj-MultilineTextInput",
36
56
  styles: "display:flex;justify-content:flex-end;label:MultilineTextInput;",
37
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm11bHRpbGluZS10ZXh0LWlucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtS29CIiwiZmlsZSI6Im11bHRpbGluZS10ZXh0LWlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHVzZVN0YXRlLFxuICB1c2VDYWxsYmFjayxcbiAgdHlwZSBDaGFuZ2VFdmVudEhhbmRsZXIsXG4gIHR5cGUgRm9jdXNFdmVudEhhbmRsZXIsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IEFuZ2xlVXBJY29uLCBBbmdsZURvd25JY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IEZsYXRCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZmxhdC1idXR0b24nO1xuaW1wb3J0IHsgdXNlVG9nZ2xlU3RhdGUgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9ob29rcyc7XG5pbXBvcnQgeyBmaWx0ZXJEYXRhQXR0cmlidXRlcyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3V0aWxzJztcbmltcG9ydCBTdGFjayBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zcGFjaW5ncy1zdGFjayc7XG5pbXBvcnQgQ29uc3RyYWludHMgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29uc3RyYWludHMnO1xuaW1wb3J0IHtcbiAgTXVsdGlsaW5lSW5wdXQsXG4gIG1lc3NhZ2VzTXVsdGlsaW5lSW5wdXQsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2lucHV0LXV0aWxzJztcblxuZXhwb3J0IHR5cGUgVE11bHRpbGluZVRleHRJbnB1dFByb3BzID0ge1xuICAvKipcbiAgICogVXNlZCBhcyBIVE1MIG5hbWUgb2YgdGhlIGlucHV0IGNvbXBvbmVudC4gcHJvcGVydHlcbiAgICovXG4gIG5hbWU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJbmRpY2F0ZSBpZiB0aGUgdmFsdWUgZW50ZXJlZCBpbiB0aGUgaW5wdXQgaXMgaW52YWxpZC5cbiAgICovXG4gICdhcmlhLWludmFsaWQnPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEhUTUwgSUQgb2YgYW4gZWxlbWVudCBjb250YWluaW5nIGFuIGVycm9yIG1lc3NhZ2UgcmVsYXRlZCB0byB0aGUgaW5wdXQuXG4gICAqL1xuICAnYXJpYS1lcnJvcm1lc3NhZ2UnPzogc3RyaW5nO1xuICAvKipcbiAgICogVXNlZCBhcyBIVE1MIGBhdXRvY29tcGxldGVgIHByb3BlcnR5XG4gICAqL1xuICBhdXRvQ29tcGxldGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBVc2VkIGFzIEhUTUwgaWQgcHJvcGVydHkuIEFuIGlkIGlzIGF1dG8tZ2VuZXJhdGVkIHdoZW4gaXQgaXMgbm90IHNwZWNpZmllZC5cbiAgICovXG4gIGlkPzogc3RyaW5nO1xuICAvKipcbiAgICogVmFsdWUgb2YgdGhlIGlucHV0IGNvbXBvbmVudC5cbiAgICovXG4gIHZhbHVlOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBDYWxsZWQgd2l0aCBhbiBldmVudCBjb250YWluaW5nIHRoZSBuZXcgdmFsdWUuIFJlcXVpcmVkIHdoZW4gaW5wdXQgaXMgbm90IHJlYWQgb25seS4gUGFyZW50IHNob3VsZCBwYXNzIGl0IGJhY2sgYXMgdmFsdWUuXG4gICAqL1xuICBvbkNoYW5nZT86IENoYW5nZUV2ZW50SGFuZGxlcjxIVE1MVGV4dEFyZWFFbGVtZW50PjtcbiAgLyoqXG4gICAqIENhbGxlZCB3aGVuIGlucHV0IGlzIGJsdXJyZWRcbiAgICovXG4gIG9uQmx1cj86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxUZXh0QXJlYUVsZW1lbnQ+O1xuICAvKipcbiAgICogQ2FsbGVkIHdoZW4gaW5wdXQgaXMgZm9jdXNlZFxuICAgKi9cbiAgb25Gb2N1cz86IEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxUZXh0QXJlYUVsZW1lbnQ+O1xuICAvKipcbiAgICogRm9jdXMgdGhlIGlucHV0IG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBpc0F1dG9mb2N1c3NlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBFeHBhbmRzIG11bHRpbGluZSB0ZXh0IGlucHV0IGluaXRpYWxseVxuICAgKi9cbiAgZGVmYXVsdEV4cGFuZE11bHRpbGluZVRleHQ/OiBib29sZWFuO1xuICAvKipcbiAgICogSW5kaWNhdGVzIHRoYXQgdGhlIGlucHV0IGNhbm5vdCBiZSBtb2RpZmllZCAoZS5nIG5vdCBhdXRob3JpemVkLCBvciBjaGFuZ2VzIGN1cnJlbnRseSBzYXZpbmcpLlxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgdGhhdCB0aGUgZmllbGQgaXMgZGlzcGxheWluZyByZWFkLW9ubHkgY29udGVudFxuICAgKi9cbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBQbGFjZWhvbGRlciB0ZXh0IGZvciB0aGUgaW5wdXRcbiAgICovXG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICAvKipcbiAgICogSW5kaWNhdGVzIHRoYXQgaW5wdXQgaGFzIGVycm9yc1xuICAgKi9cbiAgaGFzRXJyb3I/OiBib29sZWFuO1xuICAvKipcbiAgICogQ29udHJvbCB0byBpbmRpY2F0ZSBvbiB0aGUgaW5wdXQgaWYgdGhlcmUgYXJlIHNlbGVjdGVkIHZhbHVlcyB0aGF0IGFyZSBwb3RlbnRpYWxseSBpbnZhbGlkXG4gICAqL1xuICBoYXNXYXJuaW5nPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEhvcml6b250YWwgc2l6ZSBsaW1pdCBvZiB0aGUgaW5wdXQgZmllbGRzLlxuICAgKi9cbiAgaG9yaXpvbnRhbENvbnN0cmFpbnQ/OlxuICAgIHwgNlxuICAgIHwgN1xuICAgIHwgOFxuICAgIHwgOVxuICAgIHwgMTBcbiAgICB8IDExXG4gICAgfCAxMlxuICAgIHwgMTNcbiAgICB8IDE0XG4gICAgfCAxNVxuICAgIHwgMTZcbiAgICB8ICdzY2FsZSdcbiAgICB8ICdhdXRvJztcbn07XG5cbmNvbnN0IGRlZmF1bHRQcm9wczogUGljazxcbiAgVE11bHRpbGluZVRleHRJbnB1dFByb3BzLFxuICAnZGVmYXVsdEV4cGFuZE11bHRpbGluZVRleHQnXG4+ID0ge1xuICBkZWZhdWx0RXhwYW5kTXVsdGlsaW5lVGV4dDogZmFsc2UsXG59O1xuXG5jb25zdCBNdWx0aWxpbmVUZXh0SW5wdXQgPSAocHJvcHM6IFRNdWx0aWxpbmVUZXh0SW5wdXRQcm9wcykgPT4ge1xuICBjb25zdCBpbnRsID0gdXNlSW50bCgpO1xuICBjb25zdCBbc2hvdWxkUmVuZGVyVG9nZ2xlQnV0dG9uLCBzZXRTaG91bGRSZW5kZXJUb2dnbGVCdXR0b25dID1cbiAgICB1c2VTdGF0ZShmYWxzZSk7XG5cbiAgY29uc3QgW2lzT3BlbiwgdG9nZ2xlXSA9IHVzZVRvZ2dsZVN0YXRlKHByb3BzLmRlZmF1bHRFeHBhbmRNdWx0aWxpbmVUZXh0KTtcblxuICBjb25zdCB7IG9uRm9jdXMgfSA9IHByb3BzO1xuICBjb25zdCBoYW5kbGVGb2N1cyA9IHVzZUNhbGxiYWNrPEZvY3VzRXZlbnRIYW5kbGVyPEhUTUxUZXh0QXJlYUVsZW1lbnQ+PihcbiAgICAoZXZlbnQpID0+IHtcbiAgICAgIGlmICghaXNPcGVuKSB0b2dnbGUodHJ1ZSk7XG4gICAgICBpZiAob25Gb2N1cykgb25Gb2N1cyhldmVudCk7XG4gICAgfSxcbiAgICBbaXNPcGVuLCBvbkZvY3VzLCB0b2dnbGVdXG4gICk7XG5cbiAgY29uc3QgaGFuZGxlSGVpZ2h0Q2hhbmdlID0gdXNlQ2FsbGJhY2s8XG4gICAgKGhlaWdodDogbnVtYmVyLCByb3dDb3VudDogbnVtYmVyKSA9PiB2b2lkXG4gID4oXG4gICAgKF8sIHJvd0NvdW50KSA9PiB7XG4gICAgICAvLyBUaGlzIGNoZWNrcyBpZiB0aGUgY29udGVudCBpbiB0aGUgdGV4dGFyZWEgaXMgZ3JlYXRlciB0aGFuIG9uZSByb3cuIElmIGl0IGlzLCB0aGVuIHRoZSB0b2dnbGUgYnV0dG9uIHdpbGwgYmUgc2hvd24uXG4gICAgICAvLyBUaGlzIGlzIHRvIHByZXZlbnQgdGhlIHRvZ2dsZSBidXR0b24gZnJvbSBzaG93aW5nIHdoZW4gdGhlcmUgaXMgbm90IGVub3VnaCBjb250ZW50IHRvIGV4cGFuZC9jb2xsYXBzZS5cbiAgICAgIHNldFNob3VsZFJlbmRlclRvZ2dsZUJ1dHRvbihyb3dDb3VudCA+IDEpO1xuICAgIH0sXG4gICAgW3NldFNob3VsZFJlbmRlclRvZ2dsZUJ1dHRvbl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxDb25zdHJhaW50cy5Ib3Jpem9udGFsIG1heD17cHJvcHMuaG9yaXpvbnRhbENvbnN0cmFpbnR9PlxuICAgICAgPFN0YWNrIHNjYWxlPVwieHNcIj5cbiAgICAgICAgPE11bHRpbGluZUlucHV0XG4gICAgICAgICAgbmFtZT17cHJvcHMubmFtZX1cbiAgICAgICAgICBhdXRvQ29tcGxldGU9e3Byb3BzLmF1dG9Db21wbGV0ZX1cbiAgICAgICAgICB2YWx1ZT17cHJvcHMudmFsdWV9XG4gICAgICAgICAgb25DaGFuZ2U9e3Byb3BzLm9uQ2hhbmdlfVxuICAgICAgICAgIG9uSGVpZ2h0Q2hhbmdlPXtoYW5kbGVIZWlnaHRDaGFuZ2V9XG4gICAgICAgICAgaWQ9e3Byb3BzLmlkfVxuICAgICAgICAgIG9uQmx1cj17cHJvcHMub25CbHVyfVxuICAgICAgICAgIG9uRm9jdXM9e2hhbmRsZUZvY3VzfVxuICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgaGFzRXJyb3I9e3Byb3BzLmhhc0Vycm9yfVxuICAgICAgICAgIGhhc1dhcm5pbmc9e3Byb3BzLmhhc1dhcm5pbmd9XG4gICAgICAgICAgcGxhY2Vob2xkZXI9e3Byb3BzLnBsYWNlaG9sZGVyfVxuICAgICAgICAgIGlzUmVhZE9ubHk9e3Byb3BzLmlzUmVhZE9ubHl9XG4gICAgICAgICAgaXNBdXRvZm9jdXNzZWQ9e3Byb3BzLmlzQXV0b2ZvY3Vzc2VkfVxuICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgIHsuLi5maWx0ZXJEYXRhQXR0cmlidXRlcyhwcm9wcyl9XG4gICAgICAgICAgLyogQVJJQSAqL1xuICAgICAgICAgIGFyaWEtaW52YWxpZD17cHJvcHNbJ2FyaWEtaW52YWxpZCddfVxuICAgICAgICAgIGFyaWEtZXJyb3JtZXNzYWdlPXtwcm9wc1snYXJpYS1lcnJvcm1lc3NhZ2UnXX1cbiAgICAgICAgLz5cbiAgICAgICAge3Nob3VsZFJlbmRlclRvZ2dsZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPGRpdlxuICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxGbGF0QnV0dG9uXG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHRvZ2dsZSgpfVxuICAgICAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgICAgICBsYWJlbD17aW50bC5mb3JtYXRNZXNzYWdlKFxuICAgICAgICAgICAgICAgIGlzT3BlblxuICAgICAgICAgICAgICAgICAgPyBtZXNzYWdlc011bHRpbGluZUlucHV0LmNvbGxhcHNlXG4gICAgICAgICAgICAgICAgICA6IG1lc3NhZ2VzTXVsdGlsaW5lSW5wdXQuZXhwYW5kXG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgIGljb249e1xuICAgICAgICAgICAgICAgIGlzT3BlbiA/IChcbiAgICAgICAgICAgICAgICAgIDxBbmdsZVVwSWNvbiBzaXplPVwic21hbGxcIiAvPlxuICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICA8QW5nbGVEb3duSWNvbiBzaXplPVwic21hbGxcIiAvPlxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgKX1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9Db25zdHJhaW50cy5Ib3Jpem9udGFsPlxuICApO1xufTtcblxuTXVsdGlsaW5lVGV4dElucHV0LmRpc3BsYXlOYW1lID0gJ011bHRpbGluZVRleHRJbnB1dCc7XG5cbk11bHRpbGluZVRleHRJbnB1dC5pc0VtcHR5ID0gKHZhbHVlOiBUTXVsdGlsaW5lVGV4dElucHV0UHJvcHNbJ3ZhbHVlJ10pID0+XG4gICF2YWx1ZSB8fCB2YWx1ZS50cmltKCkubGVuZ3RoID09PSAwO1xuTXVsdGlsaW5lVGV4dElucHV0LmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgTXVsdGlsaW5lVGV4dElucHV0O1xuIl19 */",
57
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AA6NoB","file":"multiline-text-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  ReactElement,\n} from 'react';\nimport SecondaryIconButton, {\n  type TSecondaryButtonIconProps,\n} from '@commercetools-uikit/secondary-icon-button';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  MultilineInputWrapper,\n  getMultilineTextInputActionIconStyles,\n} from './multiline-text-input.styles';\n\nexport type TMultilineTextInputProps = {\n  /**\n   * Used as HTML name of the input component. property\n   */\n  name?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Value of the input component.\n   */\n  value: string;\n  /**\n   * Called with an event containing the new value. Required when input is not read only. Parent should pass it back as value.\n   */\n  onChange?: ChangeEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Expands multiline text input initially\n   */\n  defaultExpandMultilineText?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n\n  /**\n   * Custom action icon to be displayed on the right side of the input.\n   */\n  rightActionIcon?: ReactElement;\n  /**\n   * Props for the right-action icon-button. Required when rightActionIcon is provided.\n   * At least a `label` and an `onClick` prop/function need to be provided.\n   */\n  rightActionProps?: TSecondaryButtonIconProps;\n  /**\n   * Set this to `true` to reduce the paddings of the input allowing the input to display\n   * more data in less space.\n   *\n   */\n  isCondensed?: boolean;\n  /**\n   * Set this to value to determine the maximum text rows of the text area.\n   * Any text overflow past this row number would implement a scroll\n   */\n  maxRows?: number;\n};\n\nconst defaultProps: Pick<\n  TMultilineTextInputProps,\n  'defaultExpandMultilineText'\n> = {\n  defaultExpandMultilineText: false,\n};\n\nconst MultilineTextInput = (props: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(props.defaultExpandMultilineText);\n\n  const { onFocus } = props;\n  const handleFocus = useCallback<FocusEventHandler<HTMLTextAreaElement>>(\n    (event) => {\n      if (!isOpen) toggle(true);\n      if (onFocus) onFocus(event);\n    },\n    [isOpen, onFocus, toggle]\n  );\n\n  const handleHeightChange = useCallback<\n    (height: number, rowCount: number) => void\n  >(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setShouldRenderToggleButton(rowCount > 1);\n    },\n    [setShouldRenderToggleButton]\n  );\n\n  if (props.rightActionIcon && !props.rightActionProps) {\n    warning(\n      false,\n      'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <MultilineInputWrapper>\n          <MultilineInput\n            name={props.name}\n            autoComplete={props.autoComplete}\n            value={props.value}\n            onChange={props.onChange}\n            onHeightChange={handleHeightChange}\n            id={props.id}\n            onBlur={props.onBlur}\n            onFocus={handleFocus}\n            isDisabled={props.isDisabled}\n            hasError={props.hasError}\n            hasWarning={props.hasWarning}\n            placeholder={props.placeholder}\n            isReadOnly={props.isReadOnly}\n            isAutofocussed={props.isAutofocussed}\n            isOpen={isOpen}\n            cacheMeasurements={false}\n            css={css`\n              padding-right: ${props.rightActionIcon &&\n              props.rightActionProps &&\n              designTokens.spacing50};\n            `}\n            isCondensed={props.isCondensed}\n            maxRows={props.maxRows}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div css={getMultilineTextInputActionIconStyles(props)}>\n              <SecondaryIconButton\n                color=\"info\"\n                isDisabled={props.isDisabled || props.isReadOnly}\n                size={props.isCondensed ? '30' : '40'}\n                icon={props.rightActionIcon}\n                {...props.rightActionProps}\n              />\n            </div>\n          )}\n        </MultilineInputWrapper>\n        {shouldRenderToggleButton && (\n          <div\n            css={css`\n              display: flex;\n              justify-content: flex-end;\n            `}\n          >\n            <FlatButton\n              onClick={() => toggle()}\n              isDisabled={props.isDisabled}\n              label={intl.formatMessage(\n                isOpen\n                  ? messagesMultilineInput.collapse\n                  : messagesMultilineInput.expand\n              )}\n              icon={\n                isOpen ? (\n                  <AngleUpIcon size=\"small\" />\n                ) : (\n                  <AngleDownIcon size=\"small\" />\n                )\n              }\n            />\n          </div>\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nMultilineTextInput.displayName = 'MultilineTextInput';\n\nMultilineTextInput.isEmpty = (value: TMultilineTextInputProps['value']) =>\n  !value || value.trim().length === 0;\nMultilineTextInput.defaultProps = defaultProps;\n\nexport default MultilineTextInput;\n"]} */",
38
58
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
39
59
  };
40
60
  const MultilineTextInput = props => {
@@ -57,31 +77,48 @@ const MultilineTextInput = props => {
57
77
  // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.
58
78
  setShouldRenderToggleButton(rowCount > 1);
59
79
  }, [setShouldRenderToggleButton]);
80
+ if (props.rightActionIcon && !props.rightActionProps) {
81
+ process.env.NODE_ENV !== "production" ? warning(false, 'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.') : void 0;
82
+ }
60
83
  return jsx(Constraints.Horizontal, {
61
84
  max: props.horizontalConstraint,
62
85
  children: jsxs(Stack, {
63
86
  scale: "xs",
64
- children: [jsx(MultilineInput, _objectSpread(_objectSpread({
65
- name: props.name,
66
- autoComplete: props.autoComplete,
67
- value: props.value,
68
- onChange: props.onChange,
69
- onHeightChange: handleHeightChange,
70
- id: props.id,
71
- onBlur: props.onBlur,
72
- onFocus: handleFocus,
73
- isDisabled: props.isDisabled,
74
- hasError: props.hasError,
75
- hasWarning: props.hasWarning,
76
- placeholder: props.placeholder,
77
- isReadOnly: props.isReadOnly,
78
- isAutofocussed: props.isAutofocussed,
79
- isOpen: isOpen
80
- }, filterDataAttributes(props)), {}, {
81
- /* ARIA */
82
- "aria-invalid": props['aria-invalid'],
83
- "aria-errormessage": props['aria-errormessage']
84
- })), shouldRenderToggleButton && jsx("div", {
87
+ children: [jsxs(MultilineInputWrapper, {
88
+ children: [jsx(MultilineInput, _objectSpread(_objectSpread({
89
+ name: props.name,
90
+ autoComplete: props.autoComplete,
91
+ value: props.value,
92
+ onChange: props.onChange,
93
+ onHeightChange: handleHeightChange,
94
+ id: props.id,
95
+ onBlur: props.onBlur,
96
+ onFocus: handleFocus,
97
+ isDisabled: props.isDisabled,
98
+ hasError: props.hasError,
99
+ hasWarning: props.hasWarning,
100
+ placeholder: props.placeholder,
101
+ isReadOnly: props.isReadOnly,
102
+ isAutofocussed: props.isAutofocussed,
103
+ isOpen: isOpen,
104
+ cacheMeasurements: false,
105
+ css: /*#__PURE__*/css("padding-right:", props.rightActionIcon && props.rightActionProps && designTokens.spacing50, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MultilineTextInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AAmMoB","file":"multiline-text-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  ReactElement,\n} from 'react';\nimport SecondaryIconButton, {\n  type TSecondaryButtonIconProps,\n} from '@commercetools-uikit/secondary-icon-button';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  MultilineInputWrapper,\n  getMultilineTextInputActionIconStyles,\n} from './multiline-text-input.styles';\n\nexport type TMultilineTextInputProps = {\n  /**\n   * Used as HTML name of the input component. property\n   */\n  name?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Value of the input component.\n   */\n  value: string;\n  /**\n   * Called with an event containing the new value. Required when input is not read only. Parent should pass it back as value.\n   */\n  onChange?: ChangeEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: FocusEventHandler<HTMLTextAreaElement>;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Expands multiline text input initially\n   */\n  defaultExpandMultilineText?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates that input has errors\n   */\n  hasError?: boolean;\n  /**\n   * Control to indicate on the input if there are selected values that are potentially invalid\n   */\n  hasWarning?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n\n  /**\n   * Custom action icon to be displayed on the right side of the input.\n   */\n  rightActionIcon?: ReactElement;\n  /**\n   * Props for the right-action icon-button. Required when rightActionIcon is provided.\n   * At least a `label` and an `onClick` prop/function need to be provided.\n   */\n  rightActionProps?: TSecondaryButtonIconProps;\n  /**\n   * Set this to `true` to reduce the paddings of the input allowing the input to display\n   * more data in less space.\n   *\n   */\n  isCondensed?: boolean;\n  /**\n   * Set this to value to determine the maximum text rows of the text area.\n   * Any text overflow past this row number would implement a scroll\n   */\n  maxRows?: number;\n};\n\nconst defaultProps: Pick<\n  TMultilineTextInputProps,\n  'defaultExpandMultilineText'\n> = {\n  defaultExpandMultilineText: false,\n};\n\nconst MultilineTextInput = (props: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(props.defaultExpandMultilineText);\n\n  const { onFocus } = props;\n  const handleFocus = useCallback<FocusEventHandler<HTMLTextAreaElement>>(\n    (event) => {\n      if (!isOpen) toggle(true);\n      if (onFocus) onFocus(event);\n    },\n    [isOpen, onFocus, toggle]\n  );\n\n  const handleHeightChange = useCallback<\n    (height: number, rowCount: number) => void\n  >(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setShouldRenderToggleButton(rowCount > 1);\n    },\n    [setShouldRenderToggleButton]\n  );\n\n  if (props.rightActionIcon && !props.rightActionProps) {\n    warning(\n      false,\n      'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <MultilineInputWrapper>\n          <MultilineInput\n            name={props.name}\n            autoComplete={props.autoComplete}\n            value={props.value}\n            onChange={props.onChange}\n            onHeightChange={handleHeightChange}\n            id={props.id}\n            onBlur={props.onBlur}\n            onFocus={handleFocus}\n            isDisabled={props.isDisabled}\n            hasError={props.hasError}\n            hasWarning={props.hasWarning}\n            placeholder={props.placeholder}\n            isReadOnly={props.isReadOnly}\n            isAutofocussed={props.isAutofocussed}\n            isOpen={isOpen}\n            cacheMeasurements={false}\n            css={css`\n              padding-right: ${props.rightActionIcon &&\n              props.rightActionProps &&\n              designTokens.spacing50};\n            `}\n            isCondensed={props.isCondensed}\n            maxRows={props.maxRows}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div css={getMultilineTextInputActionIconStyles(props)}>\n              <SecondaryIconButton\n                color=\"info\"\n                isDisabled={props.isDisabled || props.isReadOnly}\n                size={props.isCondensed ? '30' : '40'}\n                icon={props.rightActionIcon}\n                {...props.rightActionProps}\n              />\n            </div>\n          )}\n        </MultilineInputWrapper>\n        {shouldRenderToggleButton && (\n          <div\n            css={css`\n              display: flex;\n              justify-content: flex-end;\n            `}\n          >\n            <FlatButton\n              onClick={() => toggle()}\n              isDisabled={props.isDisabled}\n              label={intl.formatMessage(\n                isOpen\n                  ? messagesMultilineInput.collapse\n                  : messagesMultilineInput.expand\n              )}\n              icon={\n                isOpen ? (\n                  <AngleUpIcon size=\"small\" />\n                ) : (\n                  <AngleDownIcon size=\"small\" />\n                )\n              }\n            />\n          </div>\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nMultilineTextInput.displayName = 'MultilineTextInput';\n\nMultilineTextInput.isEmpty = (value: TMultilineTextInputProps['value']) =>\n  !value || value.trim().length === 0;\nMultilineTextInput.defaultProps = defaultProps;\n\nexport default MultilineTextInput;\n"]} */"),
106
+ isCondensed: props.isCondensed,
107
+ maxRows: props.maxRows
108
+ }, filterDataAttributes(props)), {}, {
109
+ /* ARIA */
110
+ "aria-invalid": props['aria-invalid'],
111
+ "aria-errormessage": props['aria-errormessage']
112
+ })), props.rightActionIcon && props.rightActionProps && jsx("div", {
113
+ css: getMultilineTextInputActionIconStyles(props),
114
+ children: jsx(SecondaryIconButton, _objectSpread({
115
+ color: "info",
116
+ isDisabled: props.isDisabled || props.isReadOnly,
117
+ size: props.isCondensed ? '30' : '40',
118
+ icon: props.rightActionIcon
119
+ }, props.rightActionProps))
120
+ })]
121
+ }), shouldRenderToggleButton && jsx("div", {
85
122
  css: _ref,
86
123
  children: jsx(FlatButton, {
87
124
  onClick: () => toggle(),
@@ -114,7 +151,11 @@ MultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
114
151
  placeholder: _pt.string,
115
152
  hasError: _pt.bool,
116
153
  hasWarning: _pt.bool,
117
- horizontalConstraint: _pt.oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
154
+ horizontalConstraint: _pt.oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
155
+ rightActionIcon: _pt.element,
156
+ rightActionProps: _pt.any,
157
+ isCondensed: _pt.bool,
158
+ maxRows: _pt.number
118
159
  } : {};
119
160
  MultilineTextInput.displayName = 'MultilineTextInput';
120
161
  MultilineTextInput.isEmpty = value => !value || _trimInstanceProperty(value).call(value).length === 0;
@@ -122,6 +163,6 @@ MultilineTextInput.defaultProps = defaultProps;
122
163
  var MultilineTextInput$1 = MultilineTextInput;
123
164
 
124
165
  // NOTE: This string will be replaced on build time with the package version.
125
- var version = "19.4.0";
166
+ var version = "19.6.0";
126
167
 
127
168
  export { MultilineTextInput$1 as default, version };
@@ -1,4 +1,5 @@
1
- import { type ChangeEventHandler, type FocusEventHandler } from 'react';
1
+ import { type ChangeEventHandler, type FocusEventHandler, ReactElement } from 'react';
2
+ import { type TSecondaryButtonIconProps } from '@commercetools-uikit/secondary-icon-button';
2
3
  export type TMultilineTextInputProps = {
3
4
  name?: string;
4
5
  'aria-invalid'?: boolean;
@@ -17,11 +18,15 @@ export type TMultilineTextInputProps = {
17
18
  hasError?: boolean;
18
19
  hasWarning?: boolean;
19
20
  horizontalConstraint?: 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
21
+ rightActionIcon?: ReactElement;
22
+ rightActionProps?: TSecondaryButtonIconProps;
23
+ isCondensed?: boolean;
24
+ maxRows?: number;
20
25
  };
21
26
  declare const MultilineTextInput: {
22
27
  (props: TMultilineTextInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
23
28
  displayName: string;
24
- isEmpty(value: TMultilineTextInputProps['value']): boolean;
29
+ isEmpty(value: TMultilineTextInputProps["value"]): boolean;
25
30
  defaultProps: Pick<TMultilineTextInputProps, "defaultExpandMultilineText">;
26
31
  };
27
32
  export default MultilineTextInput;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/multiline-text-input",
3
3
  "description": "A controlled text input component for multi-line strings with validation states.",
4
- "version": "19.4.0",
4
+ "version": "19.6.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,16 +21,17 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "19.4.0",
25
- "@commercetools-uikit/design-system": "19.4.0",
26
- "@commercetools-uikit/flat-button": "19.4.0",
27
- "@commercetools-uikit/hooks": "19.4.0",
28
- "@commercetools-uikit/icons": "19.4.0",
29
- "@commercetools-uikit/input-utils": "19.4.0",
30
- "@commercetools-uikit/spacings-inline": "19.4.0",
31
- "@commercetools-uikit/spacings-stack": "19.4.0",
32
- "@commercetools-uikit/tooltip": "19.4.0",
33
- "@commercetools-uikit/utils": "19.4.0",
24
+ "@commercetools-uikit/constraints": "19.6.0",
25
+ "@commercetools-uikit/design-system": "19.6.0",
26
+ "@commercetools-uikit/flat-button": "19.6.0",
27
+ "@commercetools-uikit/hooks": "19.6.0",
28
+ "@commercetools-uikit/icons": "19.6.0",
29
+ "@commercetools-uikit/input-utils": "19.6.0",
30
+ "@commercetools-uikit/secondary-icon-button": "19.6.0",
31
+ "@commercetools-uikit/spacings-inline": "19.6.0",
32
+ "@commercetools-uikit/spacings-stack": "19.6.0",
33
+ "@commercetools-uikit/tooltip": "19.6.0",
34
+ "@commercetools-uikit/utils": "19.6.0",
34
35
  "@emotion/react": "^11.10.5",
35
36
  "@emotion/styled": "^11.10.5",
36
37
  "downshift": "6.1.12",