@commercetools-uikit/multiline-text-input 19.10.0 → 19.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -67,7 +67,7 @@ export default Example;
67
67
  | `hasError` | `boolean` | | | Indicates that input has errors |
68
68
  | `hasWarning` | `boolean` | | | Control to indicate on the input if there are selected values that are potentially invalid |
69
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. |
70
+ | `rightActionIcon` | `ReactElement` | | | Custom action icon to be displayed on the right side of the input.&#xA;**Will only show**, if `rightActionProps` is provided. |
71
71
  | `rightActionProps` | `TSecondaryButtonIconProps` | | | Props for the right-action icon-button. Required when rightActionIcon is provided.&#xA;At least a `label` and an `onClick` prop/function need to be provided. |
72
72
  | `isCondensed` | `boolean` | | | Set this to `true` to reduce the paddings of the input allowing the input to display&#xA;more data in less space. |
73
73
  | `maxRows` | `number` | | | Set this to value to determine the maximum text rows of the text area.&#xA;Any text overflow past this row number would implement a scroll |
@@ -48,7 +48,7 @@ var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
48
48
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
49
49
 
50
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= */");
51
+ const getMultilineTextInputActionIconStyles = props => /*#__PURE__*/react.css("position:absolute;right:", designSystem.designTokens.spacing30, ";top:0;height:", props.isCondensed ? `${designSystem.designTokens.heightForInputAsSmall}` : `${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
52
  const MultilineInputWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
53
53
  target: "eg1owae0"
54
54
  } : {
@@ -76,7 +76,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
76
76
  } : {
77
77
  name: "7hlegj-MultilineTextInput",
78
78
  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":"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"]} */",
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"]} */",
80
80
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
81
81
  };
82
82
  const MultilineTextInput = props => {
@@ -124,7 +124,7 @@ const MultilineTextInput = props => {
124
124
  isAutofocussed: props.isAutofocussed,
125
125
  isOpen: isOpen,
126
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"]} */"),
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"]} */"),
128
128
  isCondensed: props.isCondensed,
129
129
  maxRows: props.maxRows
130
130
  }, utils.filterDataAttributes(props)), {}, {
@@ -185,7 +185,7 @@ MultilineTextInput.defaultProps = defaultProps;
185
185
  var MultilineTextInput$1 = MultilineTextInput;
186
186
 
187
187
  // NOTE: This string will be replaced on build time with the package version.
188
- var version = "19.10.0";
188
+ var version = "19.11.0";
189
189
 
190
190
  exports["default"] = MultilineTextInput$1;
191
191
  exports.version = version;
@@ -46,7 +46,7 @@ var Stack__default = /*#__PURE__*/_interopDefault(Stack);
46
46
  var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
47
47
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
48
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;" + ("" ), "" );
49
+ const getMultilineTextInputActionIconStyles = props => /*#__PURE__*/react.css("position:absolute;right:", designSystem.designTokens.spacing30, ";top:0;height:", props.isCondensed ? `${designSystem.designTokens.heightForInputAsSmall}` : `${designSystem.designTokens.heightForInput}`, ";padding:0;display:flex;justify-content:center;align-items:center;" + ("" ), "" );
50
50
  const MultilineInputWrapper = /*#__PURE__*/_styled__default["default"]("div", {
51
51
  target: "eg1owae0"
52
52
  } )({
@@ -145,7 +145,7 @@ MultilineTextInput.defaultProps = defaultProps;
145
145
  var MultilineTextInput$1 = MultilineTextInput;
146
146
 
147
147
  // NOTE: This string will be replaced on build time with the package version.
148
- var version = "19.10.0";
148
+ var version = "19.11.0";
149
149
 
150
150
  exports["default"] = MultilineTextInput$1;
151
151
  exports.version = version;
@@ -26,7 +26,7 @@ import _styled from '@emotion/styled/base';
26
26
  import { jsx, jsxs } from '@emotion/react/jsx-runtime';
27
27
 
28
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= */");
29
+ const getMultilineTextInputActionIconStyles = props => /*#__PURE__*/css("position:absolute;right:", designTokens.spacing30, ";top:0;height:", props.isCondensed ? `${designTokens.heightForInputAsSmall}` : `${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
30
  const MultilineInputWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
31
31
  target: "eg1owae0"
32
32
  } : {
@@ -54,7 +54,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
54
54
  } : {
55
55
  name: "7hlegj-MultilineTextInput",
56
56
  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":"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"]} */",
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"]} */",
58
58
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
59
  };
60
60
  const MultilineTextInput = props => {
@@ -102,7 +102,7 @@ const MultilineTextInput = props => {
102
102
  isAutofocussed: props.isAutofocussed,
103
103
  isOpen: isOpen,
104
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"]} */"),
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"]} */"),
106
106
  isCondensed: props.isCondensed,
107
107
  maxRows: props.maxRows
108
108
  }, filterDataAttributes(props)), {}, {
@@ -163,6 +163,6 @@ MultilineTextInput.defaultProps = defaultProps;
163
163
  var MultilineTextInput$1 = MultilineTextInput;
164
164
 
165
165
  // NOTE: This string will be replaced on build time with the package version.
166
- var version = "19.10.0";
166
+ var version = "19.11.0";
167
167
 
168
168
  export { MultilineTextInput$1 as default, version };
@@ -71,6 +71,7 @@ export type TMultilineTextInputProps = {
71
71
  horizontalConstraint?: 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
72
72
  /**
73
73
  * Custom action icon to be displayed on the right side of the input.
74
+ * **Will only show**, if `rightActionProps` is provided.
74
75
  */
75
76
  rightActionIcon?: ReactElement;
76
77
  /**
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.10.0",
4
+ "version": "19.12.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.10.0",
25
- "@commercetools-uikit/design-system": "19.10.0",
26
- "@commercetools-uikit/flat-button": "19.10.0",
27
- "@commercetools-uikit/hooks": "19.10.0",
28
- "@commercetools-uikit/icons": "19.10.0",
29
- "@commercetools-uikit/input-utils": "19.10.0",
30
- "@commercetools-uikit/secondary-icon-button": "19.10.0",
31
- "@commercetools-uikit/spacings-inline": "19.10.0",
32
- "@commercetools-uikit/spacings-stack": "19.10.0",
33
- "@commercetools-uikit/tooltip": "19.10.0",
34
- "@commercetools-uikit/utils": "19.10.0",
24
+ "@commercetools-uikit/constraints": "19.12.0",
25
+ "@commercetools-uikit/design-system": "19.12.0",
26
+ "@commercetools-uikit/flat-button": "19.12.0",
27
+ "@commercetools-uikit/hooks": "19.12.0",
28
+ "@commercetools-uikit/icons": "19.12.0",
29
+ "@commercetools-uikit/input-utils": "19.12.0",
30
+ "@commercetools-uikit/secondary-icon-button": "19.12.0",
31
+ "@commercetools-uikit/spacings-inline": "19.12.0",
32
+ "@commercetools-uikit/spacings-stack": "19.12.0",
33
+ "@commercetools-uikit/tooltip": "19.12.0",
34
+ "@commercetools-uikit/utils": "19.12.0",
35
35
  "@emotion/react": "^11.10.5",
36
36
  "@emotion/styled": "^11.10.5",
37
37
  "downshift": "6.1.12",