@commercetools-uikit/multiline-text-input 19.20.0 → 19.21.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.
@@ -12,6 +12,7 @@ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/ob
12
12
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
13
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
+ var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
15
16
  var _pt = require('prop-types');
16
17
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
17
18
  var react$1 = require('react');
@@ -64,28 +65,29 @@ const MultilineInputWrapper = /*#__PURE__*/_styled__default["default"]("div", pr
64
65
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
65
66
  });
66
67
 
68
+ const _excluded = ["defaultExpandMultilineText"];
67
69
  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; }
68
70
  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; }
69
71
  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)."; }
70
- const defaultProps = {
71
- defaultExpandMultilineText: false
72
- };
73
72
  var _ref = process.env.NODE_ENV === "production" ? {
74
73
  name: "skgbeu",
75
74
  styles: "display:flex;justify-content:flex-end"
76
75
  } : {
77
76
  name: "7hlegj-MultilineTextInput",
78
77
  styles: "display:flex;justify-content:flex-end;label:MultilineTextInput;",
79
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AA8NoB","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   * **Will only show**, if `rightActionProps` is provided.\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"]} */",
78
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AAkOoB","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   * **Will only show**, if `rightActionProps` is provided.\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 MultilineTextInput = ({\n  defaultExpandMultilineText = false,\n  ...props\n}: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(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({\n              defaultExpandMultilineText,\n              ...props,\n            })}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div\n              css={getMultilineTextInputActionIconStyles({\n                defaultExpandMultilineText,\n                ...props,\n              })}\n            >\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;\n\nexport default MultilineTextInput;\n"]} */",
80
79
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
81
80
  };
82
- const MultilineTextInput = props => {
81
+ const MultilineTextInput = _ref2 => {
82
+ let _ref2$defaultExpandMu = _ref2.defaultExpandMultilineText,
83
+ defaultExpandMultilineText = _ref2$defaultExpandMu === void 0 ? false : _ref2$defaultExpandMu,
84
+ props = _objectWithoutProperties(_ref2, _excluded);
83
85
  const intl = reactIntl.useIntl();
84
86
  const _useState = react$1.useState(false),
85
87
  _useState2 = _slicedToArray(_useState, 2),
86
88
  shouldRenderToggleButton = _useState2[0],
87
89
  setShouldRenderToggleButton = _useState2[1];
88
- const _useToggleState = hooks.useToggleState(props.defaultExpandMultilineText),
90
+ const _useToggleState = hooks.useToggleState(defaultExpandMultilineText),
89
91
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
90
92
  isOpen = _useToggleState2[0],
91
93
  toggle = _useToggleState2[1];
@@ -124,15 +126,19 @@ const MultilineTextInput = props => {
124
126
  isAutofocussed: props.isAutofocussed,
125
127
  isOpen: isOpen,
126
128
  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":"AAoMoB","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   * **Will only show**, if `rightActionProps` is provided.\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"]} */"),
129
+ 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":"AAgMoB","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   * **Will only show**, if `rightActionProps` is provided.\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 MultilineTextInput = ({\n  defaultExpandMultilineText = false,\n  ...props\n}: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(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({\n              defaultExpandMultilineText,\n              ...props,\n            })}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div\n              css={getMultilineTextInputActionIconStyles({\n                defaultExpandMultilineText,\n                ...props,\n              })}\n            >\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;\n\nexport default MultilineTextInput;\n"]} */"),
128
130
  isCondensed: props.isCondensed,
129
131
  maxRows: props.maxRows
130
- }, utils.filterDataAttributes(props)), {}, {
132
+ }, utils.filterDataAttributes(_objectSpread({
133
+ defaultExpandMultilineText
134
+ }, props))), {}, {
131
135
  /* ARIA */
132
136
  "aria-invalid": props['aria-invalid'],
133
137
  "aria-errormessage": props['aria-errormessage']
134
138
  })), props.rightActionIcon && props.rightActionProps && jsxRuntime.jsx("div", {
135
- css: getMultilineTextInputActionIconStyles(props),
139
+ css: getMultilineTextInputActionIconStyles(_objectSpread({
140
+ defaultExpandMultilineText
141
+ }, props)),
136
142
  children: jsxRuntime.jsx(SecondaryIconButton__default["default"], _objectSpread({
137
143
  color: "info",
138
144
  isDisabled: props.isDisabled || props.isReadOnly,
@@ -181,11 +187,10 @@ MultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
181
187
  } : {};
182
188
  MultilineTextInput.displayName = 'MultilineTextInput';
183
189
  MultilineTextInput.isEmpty = value => !value || _trimInstanceProperty__default["default"](value).call(value).length === 0;
184
- MultilineTextInput.defaultProps = defaultProps;
185
190
  var MultilineTextInput$1 = MultilineTextInput;
186
191
 
187
192
  // NOTE: This string will be replaced on build time with the package version.
188
- var version = "19.20.0";
193
+ var version = "19.21.0";
189
194
 
190
195
  exports["default"] = MultilineTextInput$1;
191
196
  exports.version = version;
@@ -12,6 +12,7 @@ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/ob
12
12
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
13
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
+ var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
15
16
  require('prop-types');
16
17
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
17
18
  var react$1 = require('react');
@@ -54,22 +55,23 @@ const MultilineInputWrapper = /*#__PURE__*/_styled__default["default"]("div", {
54
55
  styles: "position:relative;display:inline-block;width:100%"
55
56
  } );
56
57
 
58
+ const _excluded = ["defaultExpandMultilineText"];
57
59
  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; }
58
60
  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; }
59
- const defaultProps = {
60
- defaultExpandMultilineText: false
61
- };
62
61
  var _ref = {
63
62
  name: "skgbeu",
64
63
  styles: "display:flex;justify-content:flex-end"
65
64
  } ;
66
- const MultilineTextInput = props => {
65
+ const MultilineTextInput = _ref2 => {
66
+ let _ref2$defaultExpandMu = _ref2.defaultExpandMultilineText,
67
+ defaultExpandMultilineText = _ref2$defaultExpandMu === void 0 ? false : _ref2$defaultExpandMu,
68
+ props = _objectWithoutProperties(_ref2, _excluded);
67
69
  const intl = reactIntl.useIntl();
68
70
  const _useState = react$1.useState(false),
69
71
  _useState2 = _slicedToArray(_useState, 2),
70
72
  shouldRenderToggleButton = _useState2[0],
71
73
  setShouldRenderToggleButton = _useState2[1];
72
- const _useToggleState = hooks.useToggleState(props.defaultExpandMultilineText),
74
+ const _useToggleState = hooks.useToggleState(defaultExpandMultilineText),
73
75
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
74
76
  isOpen = _useToggleState2[0],
75
77
  toggle = _useToggleState2[1];
@@ -109,12 +111,16 @@ const MultilineTextInput = props => {
109
111
  css: /*#__PURE__*/react.css("padding-right:", props.rightActionIcon && props.rightActionProps && designSystem.designTokens.spacing50, ";" + ("" ), "" ),
110
112
  isCondensed: props.isCondensed,
111
113
  maxRows: props.maxRows
112
- }, utils.filterDataAttributes(props)), {}, {
114
+ }, utils.filterDataAttributes(_objectSpread({
115
+ defaultExpandMultilineText
116
+ }, props))), {}, {
113
117
  /* ARIA */
114
118
  "aria-invalid": props['aria-invalid'],
115
119
  "aria-errormessage": props['aria-errormessage']
116
120
  })), props.rightActionIcon && props.rightActionProps && jsxRuntime.jsx("div", {
117
- css: getMultilineTextInputActionIconStyles(props),
121
+ css: getMultilineTextInputActionIconStyles(_objectSpread({
122
+ defaultExpandMultilineText
123
+ }, props)),
118
124
  children: jsxRuntime.jsx(SecondaryIconButton__default["default"], _objectSpread({
119
125
  color: "info",
120
126
  isDisabled: props.isDisabled || props.isReadOnly,
@@ -141,11 +147,10 @@ const MultilineTextInput = props => {
141
147
  MultilineTextInput.propTypes = {};
142
148
  MultilineTextInput.displayName = 'MultilineTextInput';
143
149
  MultilineTextInput.isEmpty = value => !value || _trimInstanceProperty__default["default"](value).call(value).length === 0;
144
- MultilineTextInput.defaultProps = defaultProps;
145
150
  var MultilineTextInput$1 = MultilineTextInput;
146
151
 
147
152
  // NOTE: This string will be replaced on build time with the package version.
148
- var version = "19.20.0";
153
+ var version = "19.21.0";
149
154
 
150
155
  exports["default"] = MultilineTextInput$1;
151
156
  exports.version = version;
@@ -8,6 +8,7 @@ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/obje
8
8
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
10
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
11
+ import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
11
12
  import _pt from 'prop-types';
12
13
  import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
13
14
  import { useState, useCallback } from 'react';
@@ -42,28 +43,29 @@ const MultilineInputWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV =
42
43
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
43
44
  });
44
45
 
46
+ const _excluded = ["defaultExpandMultilineText"];
45
47
  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; }
46
48
  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; }
47
49
  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)."; }
48
- const defaultProps = {
49
- defaultExpandMultilineText: false
50
- };
51
50
  var _ref = process.env.NODE_ENV === "production" ? {
52
51
  name: "skgbeu",
53
52
  styles: "display:flex;justify-content:flex-end"
54
53
  } : {
55
54
  name: "7hlegj-MultilineTextInput",
56
55
  styles: "display:flex;justify-content:flex-end;label:MultilineTextInput;",
57
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AA8NoB","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   * **Will only show**, if `rightActionProps` is provided.\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"]} */",
56
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["multiline-text-input.tsx"],"names":[],"mappings":"AAkOoB","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   * **Will only show**, if `rightActionProps` is provided.\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 MultilineTextInput = ({\n  defaultExpandMultilineText = false,\n  ...props\n}: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(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({\n              defaultExpandMultilineText,\n              ...props,\n            })}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div\n              css={getMultilineTextInputActionIconStyles({\n                defaultExpandMultilineText,\n                ...props,\n              })}\n            >\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;\n\nexport default MultilineTextInput;\n"]} */",
58
57
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
58
  };
60
- const MultilineTextInput = props => {
59
+ const MultilineTextInput = _ref2 => {
60
+ let _ref2$defaultExpandMu = _ref2.defaultExpandMultilineText,
61
+ defaultExpandMultilineText = _ref2$defaultExpandMu === void 0 ? false : _ref2$defaultExpandMu,
62
+ props = _objectWithoutProperties(_ref2, _excluded);
61
63
  const intl = useIntl();
62
64
  const _useState = useState(false),
63
65
  _useState2 = _slicedToArray(_useState, 2),
64
66
  shouldRenderToggleButton = _useState2[0],
65
67
  setShouldRenderToggleButton = _useState2[1];
66
- const _useToggleState = useToggleState(props.defaultExpandMultilineText),
68
+ const _useToggleState = useToggleState(defaultExpandMultilineText),
67
69
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
68
70
  isOpen = _useToggleState2[0],
69
71
  toggle = _useToggleState2[1];
@@ -102,15 +104,19 @@ const MultilineTextInput = props => {
102
104
  isAutofocussed: props.isAutofocussed,
103
105
  isOpen: isOpen,
104
106
  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":"AAoMoB","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   * **Will only show**, if `rightActionProps` is provided.\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"]} */"),
107
+ 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":"AAgMoB","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   * **Will only show**, if `rightActionProps` is provided.\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 MultilineTextInput = ({\n  defaultExpandMultilineText = false,\n  ...props\n}: TMultilineTextInputProps) => {\n  const intl = useIntl();\n  const [shouldRenderToggleButton, setShouldRenderToggleButton] =\n    useState(false);\n\n  const [isOpen, toggle] = useToggleState(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({\n              defaultExpandMultilineText,\n              ...props,\n            })}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n          />\n          {props.rightActionIcon && props.rightActionProps && (\n            <div\n              css={getMultilineTextInputActionIconStyles({\n                defaultExpandMultilineText,\n                ...props,\n              })}\n            >\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;\n\nexport default MultilineTextInput;\n"]} */"),
106
108
  isCondensed: props.isCondensed,
107
109
  maxRows: props.maxRows
108
- }, filterDataAttributes(props)), {}, {
110
+ }, filterDataAttributes(_objectSpread({
111
+ defaultExpandMultilineText
112
+ }, props))), {}, {
109
113
  /* ARIA */
110
114
  "aria-invalid": props['aria-invalid'],
111
115
  "aria-errormessage": props['aria-errormessage']
112
116
  })), props.rightActionIcon && props.rightActionProps && jsx("div", {
113
- css: getMultilineTextInputActionIconStyles(props),
117
+ css: getMultilineTextInputActionIconStyles(_objectSpread({
118
+ defaultExpandMultilineText
119
+ }, props)),
114
120
  children: jsx(SecondaryIconButton, _objectSpread({
115
121
  color: "info",
116
122
  isDisabled: props.isDisabled || props.isReadOnly,
@@ -159,10 +165,9 @@ MultilineTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
159
165
  } : {};
160
166
  MultilineTextInput.displayName = 'MultilineTextInput';
161
167
  MultilineTextInput.isEmpty = value => !value || _trimInstanceProperty(value).call(value).length === 0;
162
- MultilineTextInput.defaultProps = defaultProps;
163
168
  var MultilineTextInput$1 = MultilineTextInput;
164
169
 
165
170
  // NOTE: This string will be replaced on build time with the package version.
166
- var version = "19.20.0";
171
+ var version = "19.21.0";
167
172
 
168
173
  export { MultilineTextInput$1 as default, version };
@@ -92,9 +92,8 @@ export type TMultilineTextInputProps = {
92
92
  maxRows?: number;
93
93
  };
94
94
  declare const MultilineTextInput: {
95
- (props: TMultilineTextInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
95
+ ({ defaultExpandMultilineText, ...props }: TMultilineTextInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
96
96
  displayName: string;
97
97
  isEmpty(value: TMultilineTextInputProps["value"]): boolean;
98
- defaultProps: Pick<TMultilineTextInputProps, "defaultExpandMultilineText">;
99
98
  };
100
99
  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.20.0",
4
+ "version": "19.21.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,17 +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.20.0",
25
- "@commercetools-uikit/design-system": "19.20.0",
26
- "@commercetools-uikit/flat-button": "19.20.0",
27
- "@commercetools-uikit/hooks": "19.20.0",
28
- "@commercetools-uikit/icons": "19.20.0",
29
- "@commercetools-uikit/input-utils": "19.20.0",
30
- "@commercetools-uikit/secondary-icon-button": "19.20.0",
31
- "@commercetools-uikit/spacings-inline": "19.20.0",
32
- "@commercetools-uikit/spacings-stack": "19.20.0",
33
- "@commercetools-uikit/tooltip": "19.20.0",
34
- "@commercetools-uikit/utils": "19.20.0",
24
+ "@commercetools-uikit/constraints": "19.21.0",
25
+ "@commercetools-uikit/design-system": "19.21.0",
26
+ "@commercetools-uikit/flat-button": "19.21.0",
27
+ "@commercetools-uikit/hooks": "19.21.0",
28
+ "@commercetools-uikit/icons": "19.21.0",
29
+ "@commercetools-uikit/input-utils": "19.21.0",
30
+ "@commercetools-uikit/secondary-icon-button": "19.21.0",
31
+ "@commercetools-uikit/spacings-inline": "19.21.0",
32
+ "@commercetools-uikit/spacings-stack": "19.21.0",
33
+ "@commercetools-uikit/tooltip": "19.21.0",
34
+ "@commercetools-uikit/utils": "19.21.0",
35
35
  "@emotion/react": "^11.10.5",
36
36
  "@emotion/styled": "^11.10.5",
37
37
  "downshift": "6.1.12",