@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 +23 -19
- package/dist/commercetools-uikit-multiline-text-input.cjs.dev.js +72 -29
- package/dist/commercetools-uikit-multiline-text-input.cjs.prod.js +55 -27
- package/dist/commercetools-uikit-multiline-text-input.esm.js +67 -26
- package/dist/declarations/src/multiline-text-input.d.ts +7 -2
- package/package.json +12 -11
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.
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
more data in less space. |
|
|
73
|
+
| `maxRows` | `number` | | | Set this to value to determine the maximum text rows of the text area.
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.
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
"aria-invalid": props['aria-invalid'],
|
|
103
|
-
|
|
104
|
-
|
|
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.
|
|
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.
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
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.
|
|
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: [
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
"aria-invalid": props['aria-invalid'],
|
|
83
|
-
|
|
84
|
-
|
|
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.
|
|
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[
|
|
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
|
+
"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.
|
|
25
|
-
"@commercetools-uikit/design-system": "19.
|
|
26
|
-
"@commercetools-uikit/flat-button": "19.
|
|
27
|
-
"@commercetools-uikit/hooks": "19.
|
|
28
|
-
"@commercetools-uikit/icons": "19.
|
|
29
|
-
"@commercetools-uikit/input-utils": "19.
|
|
30
|
-
"@commercetools-uikit/
|
|
31
|
-
"@commercetools-uikit/spacings-
|
|
32
|
-
"@commercetools-uikit/
|
|
33
|
-
"@commercetools-uikit/
|
|
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",
|