@amboss/design-system 3.42.1 → 3.42.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -17,6 +17,7 @@ export type PromptTextAreaProps = TextareaHTMLAttributes<HTMLTextAreaElement> &
17
17
  /** Collapsed variant showing only single row text area */
18
18
  isNavBarVariant?: boolean;
19
19
  hasLeftIcon?: boolean;
20
+ rows?: number;
20
21
  };
21
22
  export declare const PromptTextArea: React.ForwardRefExoticComponent<TextareaHTMLAttributes<HTMLTextAreaElement> & {
22
23
  dataE2eTestId?: string;
@@ -30,4 +31,5 @@ export declare const PromptTextArea: React.ForwardRefExoticComponent<TextareaHTM
30
31
  /** Collapsed variant showing only single row text area */
31
32
  isNavBarVariant?: boolean;
32
33
  hasLeftIcon?: boolean;
34
+ rows?: number;
33
35
  } & React.RefAttributes<HTMLTextAreaElement>>;
@@ -1 +1 @@
1
- import React,{forwardRef,useEffect}from"react";import styled from"@emotion/styled";import{getInputTextPlaceholder}from"../../shared/mixins/TextInput/getInputTextPlaceholder";import{ScreenReaderText}from"../Utilities/ScreenReaderText/ScreenReaderText";import{getAutocompleteListId}from"./AutocompleteList";export const getPaddingHorizontal=theme=>theme.variables.size.spacing.m;export const getPaddingVertical=theme=>theme.variables.size.spacing.m;let StyledTextAreaContainer=styled("label",{target:"e1kr3gwl0",label:"StyledTextAreaContainer"})(({theme,maxTextAreaHeight,isCollapsed,isNavBarVariant,hasLeftIcon})=>{let paddingTop=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingBottom=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingRight=theme.variables.size.spacing.xxl,basePaddingLeft=getPaddingHorizontal(theme),paddingLeft=hasLeftIcon?`calc(${basePaddingLeft} + ${theme.variables.size.dimension.icon.m} + ${theme.variables.size.spacing.xs})`:basePaddingLeft;return{display:"grid",verticalAlign:"top",alignItems:"stretch",width:"100%",borderRadius:"inherit",position:"relative",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,...isCollapsed&&{backgroundColor:theme.values.color.canvas},"&::after":{content:"attr(data-value) ' '",boxSizing:"border-box",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,gridArea:"1 / 1",whiteSpace:"pre-wrap",visibility:"hidden",maxHeight:maxTextAreaHeight},textarea:{all:"unset",resize:"none",gridArea:"1 / 1",cursor:"text",color:theme.values.color.text.primary.default,...isCollapsed&&{overflow:"hidden"},...getInputTextPlaceholder({theme})},"textarea::placeholder":{whiteSpace:"nowrap",textOverflow:"ellipsis",overflow:"hidden"},"&::after, textarea":{minWidth:"0",overflowWrap:"break-word",padding:`${paddingTop} ${paddingRight} ${paddingBottom} ${paddingLeft}`,...!isCollapsed&&{paddingBottom:getPaddingVertical(theme)}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvUHJvbXB0VGV4dEFyZWEudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Qcm9tcHRJbnB1dC9Qcm9tcHRUZXh0QXJlYS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QsIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRQbGFjZWhvbGRlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zL1RleHRJbnB1dC9nZXRJbnB1dFRleHRQbGFjZWhvbGRlclwiO1xuaW1wb3J0IHsgU2NyZWVuUmVhZGVyVGV4dCB9IGZyb20gXCIuLi9VdGlsaXRpZXMvU2NyZWVuUmVhZGVyVGV4dC9TY3JlZW5SZWFkZXJUZXh0XCI7XG5pbXBvcnQgeyBnZXRBdXRvY29tcGxldGVMaXN0SWQgfSBmcm9tIFwiLi9BdXRvY29tcGxldGVMaXN0XCI7XG5pbXBvcnQgdHlwZSB7IEZsYXR0ZW5lZExpc3RJdGVtIH0gZnJvbSBcIi4vQ2F0ZWdvcnlMaXN0XCI7XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nSG9yaXpvbnRhbCA9ICh0aGVtZTogVGhlbWUpOiBzdHJpbmcgPT5cbiAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tO1xuZXhwb3J0IGNvbnN0IGdldFBhZGRpbmdWZXJ0aWNhbCA9ICh0aGVtZTogVGhlbWUpOiBzdHJpbmcgPT5cbiAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tO1xuXG5leHBvcnQgdHlwZSBQcm9tcHRUZXh0QXJlYVByb3BzID1cbiAgVGV4dGFyZWFIVE1MQXR0cmlidXRlczxIVE1MVGV4dEFyZWFFbGVtZW50PiAmIHtcbiAgICBkYXRhRTJlVGVzdElkPzogc3RyaW5nO1xuICAgIGxhYmVsOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHZhbHVlOiBzdHJpbmc7XG4gICAgbWF4VGV4dEFyZWFIZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gICAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICAgIGlzQXV0b2NvbXBsZXRlTGlzdE9wZW4/OiBib29sZWFuO1xuICAgIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgICAvKiogQ29sbGFwc2VkIHZhcmlhbnQgc2hvd2luZyBvbmx5IHNpbmdsZSByb3cgdGV4dCBhcmVhICovXG4gICAgaXNOYXZCYXJWYXJpYW50PzogYm9vbGVhbjtcbiAgICBoYXNMZWZ0SWNvbj86IGJvb2xlYW47XG4gIH07XG5cbnR5cGUgU3R5bGVkVGV4dEFyZWFDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFByb21wdFRleHRBcmVhUHJvcHMsXG4gIFwibWF4VGV4dEFyZWFIZWlnaHRcIiB8IFwiaXNDb2xsYXBzZWRcIiB8IFwiaXNOYXZCYXJWYXJpYW50XCIgfCBcImhhc0xlZnRJY29uXCJcbj47XG5cbi8vIFRleHRhcmVhIGF1dG8gZ3JvdyBpbXBsZW1lbnRlZCBhY2NvcmRpbmcgdG8gaHR0cHM6Ly9jc3MtdHJpY2tzLmNvbS90aGUtY2xlYW5lc3QtdHJpY2stZm9yLWF1dG9ncm93aW5nLXRleHRhcmVhcy9cblxuY29uc3QgU3R5bGVkVGV4dEFyZWFDb250YWluZXIgPSBzdHlsZWQubGFiZWw8U3R5bGVkVGV4dEFyZWFDb250YWluZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBtYXhUZXh0QXJlYUhlaWdodCwgaXNDb2xsYXBzZWQsIGlzTmF2QmFyVmFyaWFudCwgaGFzTGVmdEljb24gfSkgPT4ge1xuICAgIGNvbnN0IHBhZGRpbmdUb3AgPSBpc05hdkJhclZhcmlhbnRcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHNcbiAgICAgIDogZ2V0UGFkZGluZ1ZlcnRpY2FsKHRoZW1lKTtcbiAgICBjb25zdCBwYWRkaW5nQm90dG9tID0gaXNOYXZCYXJWYXJpYW50XG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IGdldFBhZGRpbmdWZXJ0aWNhbCh0aGVtZSk7XG4gICAgY29uc3QgcGFkZGluZ1JpZ2h0ID0gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eGw7XG4gICAgY29uc3QgYmFzZVBhZGRpbmdMZWZ0ID0gZ2V0UGFkZGluZ0hvcml6b250YWwodGhlbWUpO1xuICAgIGNvbnN0IHBhZGRpbmdMZWZ0ID0gaGFzTGVmdEljb25cbiAgICAgID8gYGNhbGMoJHtiYXNlUGFkZGluZ0xlZnR9ICsgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5kaW1lbnNpb24uaWNvbi5tfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30pYFxuICAgICAgOiBiYXNlUGFkZGluZ0xlZnQ7XG5cbiAgICByZXR1cm4ge1xuICAgICAgZGlzcGxheTogXCJncmlkXCIsXG4gICAgICB2ZXJ0aWNhbEFsaWduOiBcInRvcFwiLFxuICAgICAgYWxpZ25JdGVtczogXCJzdHJldGNoXCIsXG4gICAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgICBib3JkZXJSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54bCxcblxuICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICAgICAgfSksXG5cbiAgICAgIC8vIFRleHRhcmVhIGdyb3dzIGR1ZSB0byA6OmFmdGVyIGdyb3dzXG4gICAgICAvLyBpZiB5b3UgbmVlZCB0byBtYW5pcHVsYXRlIHdpdGggc2l6ZSBvZiB0ZXh0YXJlYSwgeW91IG5lZWQgdG8gbWFuaXB1bGF0ZSB3aXRoIDo6YWZ0ZXIgYWxzb1xuICAgICAgXCImOjphZnRlclwiOiB7XG4gICAgICAgIGNvbnRlbnQ6IFwiYXR0cihkYXRhLXZhbHVlKSAnICdcIiwgLy8gdGhlIGVtcHR5IHNwYWNlIHByZXZlbnRzIHRleHRhcmVhIGp1bXAgb24gZ3Jvd1xuICAgICAgICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxuICAgICAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgICBncmlkQXJlYTogXCIxIC8gMVwiLFxuICAgICAgICB3aGl0ZVNwYWNlOiBcInByZS13cmFwXCIsXG4gICAgICAgIHZpc2liaWxpdHk6IFwiaGlkZGVuXCIsXG4gICAgICAgIG1heEhlaWdodDogbWF4VGV4dEFyZWFIZWlnaHQsXG4gICAgICB9LFxuXG4gICAgICB0ZXh0YXJlYToge1xuICAgICAgICBhbGw6IFwidW5zZXRcIixcbiAgICAgICAgcmVzaXplOiBcIm5vbmVcIixcbiAgICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcbiAgICAgICAgY3Vyc29yOiBcInRleHRcIixcbiAgICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnByaW1hcnkuZGVmYXVsdCxcbiAgICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgICAgfSksXG4gICAgICAgIC4uLmdldElucHV0VGV4dFBsYWNlaG9sZGVyKHsgdGhlbWUgfSksXG4gICAgICB9LFxuICAgICAgXCJ0ZXh0YXJlYTo6cGxhY2Vob2xkZXJcIjoge1xuICAgICAgICB3aGl0ZVNwYWNlOiBcIm5vd3JhcFwiLFxuICAgICAgICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgICAgICAgb3ZlcmZsb3c6IFwiaGlkZGVuXCIsXG4gICAgICB9LFxuXG4gICAgICBcIiY6OmFmdGVyLCB0ZXh0YXJlYVwiOiB7XG4gICAgICAgIC8vIG1pbldpZHRoIGNvbWVzIHRvZ2V0aGVyIHdpdGggb3ZlcmZsb3dXcmFwIHRvIGFjaGlldmUgYnJlYWstd29yZFxuICAgICAgICAvLyBpdCBzaG91bGQgYmUgYXBwbGllZCBmb3IgOjphZnRlciBhbmQgdGV4dGFyZWFcbiAgICAgICAgbWluV2lkdGg6IFwiMFwiLFxuICAgICAgICBvdmVyZmxvd1dyYXA6IFwiYnJlYWstd29yZFwiLFxuICAgICAgICBwYWRkaW5nOiBgJHtwYWRkaW5nVG9wfSAke3BhZGRpbmdSaWdodH0gJHtwYWRkaW5nQm90dG9tfSAke3BhZGRpbmdMZWZ0fWAsXG5cbiAgICAgICAgLi4uKCFpc0NvbGxhcHNlZCAmJiB7XG4gICAgICAgICAgcGFkZGluZ0JvdHRvbTogZ2V0UGFkZGluZ1ZlcnRpY2FsKHRoZW1lKSxcbiAgICAgICAgfSksXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBQcm9tcHRUZXh0QXJlYSA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBkYXRhRTJlVGVzdElkLFxuICAgICAgbGFiZWwsXG4gICAgICBuYW1lLFxuICAgICAgdmFsdWUsXG4gICAgICBwbGFjZWhvbGRlcixcbiAgICAgIG1heFRleHRBcmVhSGVpZ2h0ID0gXCIyMDBweFwiLFxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgICAgIGlzQXV0b2NvbXBsZXRlTGlzdE9wZW4sXG4gICAgICBpc0NvbGxhcHNlZCxcbiAgICAgIGlzTmF2QmFyVmFyaWFudCxcbiAgICAgIGhhc0xlZnRJY29uLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICAuLi5yZXN0XG4gICAgfTogUHJvbXB0VGV4dEFyZWFQcm9wcyxcbiAgICByZWY6IFJlZk9iamVjdDxIVE1MVGV4dEFyZWFFbGVtZW50PlxuICApID0+IHtcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgY29uc3QgdGV4dEFyZWEgPSByZWYuY3VycmVudDtcblxuICAgICAgaWYgKGlzQ29sbGFwc2VkKSB7XG4gICAgICAgICh0ZXh0QXJlYS5wYXJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnZhbHVlID0gXCJcIjtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIFNldCB0aGUgdmFsdWUgb2YgdGhlIDo6YWZ0ZXIgcHN1ZWRvIGVsZW1lbnQgc28gdGhhdCB0aGUgVGV4dEFyZWEgcmVzaXplcyBhY2NvcmRpbmdseSBhcyB0aGUgZ3JpZCBzdHJldGNoZXMuXG4gICAgICAgICh0ZXh0QXJlYS5wYXJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnZhbHVlID0gdmFsdWU7XG4gICAgICB9XG4gICAgfSwgW3ZhbHVlLCByZWYsIGlzQ29sbGFwc2VkXSk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZFRleHRBcmVhQ29udGFpbmVyXG4gICAgICAgIG1heFRleHRBcmVhSGVpZ2h0PXttYXhUZXh0QXJlYUhlaWdodH1cbiAgICAgICAgaXNDb2xsYXBzZWQ9e2lzQ29sbGFwc2VkfVxuICAgICAgICBpc05hdkJhclZhcmlhbnQ9e2lzTmF2QmFyVmFyaWFudH1cbiAgICAgICAgaGFzTGVmdEljb249e2hhc0xlZnRJY29ufVxuICAgICAgPlxuICAgICAgICA8U2NyZWVuUmVhZGVyVGV4dD57bGFiZWx9PC9TY3JlZW5SZWFkZXJUZXh0PlxuICAgICAgICA8dGV4dGFyZWFcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgcm93cz17MX1cbiAgICAgICAgICByb2xlPVwiY29tYm9ib3hcIlxuICAgICAgICAgIGFyaWEtYXV0b2NvbXBsZXRlPVwibGlzdFwiXG4gICAgICAgICAgYXJpYS1jb250cm9scz17XG4gICAgICAgICAgICBpc0F1dG9jb21wbGV0ZUxpc3RPcGVuID8gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWUpIDogXCJcIlxuICAgICAgICAgIH1cbiAgICAgICAgICBhcmlhLWFjdGl2ZWRlc2NlbmRhbnQ9e3NlbGVjdGVkTGlzdEl0ZW0gPyBzZWxlY3RlZExpc3RJdGVtLmlkIDogXCJcIn1cbiAgICAgICAgICBhcmlhLWV4cGFuZGVkPXtpc0F1dG9jb21wbGV0ZUxpc3RPcGVufVxuICAgICAgICAvPlxuICAgICAgPC9TdHlsZWRUZXh0QXJlYUNvbnRhaW5lcj5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDZ0MifQ== */");export const PromptTextArea=forwardRef(({dataE2eTestId,label,name,value,placeholder,maxTextAreaHeight="200px",selectedListItem,isAutocompleteListOpen,isCollapsed,isNavBarVariant,hasLeftIcon,onChange,...rest},ref)=>(useEffect(()=>{let textArea=ref.current;isCollapsed?textArea.parentNode.dataset.value="":textArea.parentNode.dataset.value=value},[value,ref,isCollapsed]),React.createElement(StyledTextAreaContainer,{maxTextAreaHeight:maxTextAreaHeight,isCollapsed:isCollapsed,isNavBarVariant:isNavBarVariant,hasLeftIcon:hasLeftIcon},React.createElement(ScreenReaderText,null,label),React.createElement("textarea",{...rest,"data-e2e-test-id":dataE2eTestId,ref:ref,name:name,value:value,placeholder:placeholder,onChange:onChange,rows:1,role:"combobox","aria-autocomplete":"list","aria-controls":isAutocompleteListOpen?getAutocompleteListId(name):"","aria-activedescendant":selectedListItem?selectedListItem.id:"","aria-expanded":isAutocompleteListOpen}))));
1
+ import React,{forwardRef,useEffect}from"react";import styled from"@emotion/styled";import{getInputTextPlaceholder}from"../../shared/mixins/TextInput/getInputTextPlaceholder";import{ScreenReaderText}from"../Utilities/ScreenReaderText/ScreenReaderText";import{getAutocompleteListId}from"./AutocompleteList";export const getPaddingHorizontal=theme=>theme.variables.size.spacing.m;export const getPaddingVertical=theme=>theme.variables.size.spacing.m;let StyledTextAreaContainer=styled("label",{target:"ezuj8j20",label:"StyledTextAreaContainer"})(({theme,maxTextAreaHeight,isCollapsed,isNavBarVariant,hasLeftIcon})=>{let paddingTop=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingBottom=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingRight=theme.variables.size.spacing.xxl,basePaddingLeft=getPaddingHorizontal(theme),paddingLeft=hasLeftIcon?`calc(${basePaddingLeft} + ${theme.variables.size.dimension.icon.m} + ${theme.variables.size.spacing.xs})`:basePaddingLeft;return{display:"grid",verticalAlign:"top",alignItems:"stretch",width:"100%",borderRadius:"inherit",position:"relative",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,...isCollapsed&&{backgroundColor:theme.values.color.canvas},"&::after":{content:"attr(data-value) ' '",boxSizing:"border-box",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,gridArea:"1 / 1",whiteSpace:"pre-wrap",visibility:"hidden",maxHeight:maxTextAreaHeight},textarea:{all:"unset",resize:"none",gridArea:"1 / 1",cursor:"text",color:theme.values.color.text.primary.default,...isCollapsed&&{overflow:"hidden"},...getInputTextPlaceholder({theme})},"textarea::placeholder":{whiteSpace:"nowrap",textOverflow:"ellipsis",overflow:"hidden"},"&::after, textarea":{minWidth:"0",overflowWrap:"break-word",padding:`${paddingTop} ${paddingRight} ${paddingBottom} ${paddingLeft}`,...!isCollapsed&&{paddingBottom:getPaddingVertical(theme)}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptTextArea.tsx","sources":["src/components/PromptInput/PromptTextArea.tsx"],"sourcesContent":["import type { RefObject, TextareaHTMLAttributes } from \"react\";\nimport React, { forwardRef, useEffect } from \"react\";\nimport type { Theme } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport { getInputTextPlaceholder } from \"../../shared/mixins/TextInput/getInputTextPlaceholder\";\nimport { ScreenReaderText } from \"../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { getAutocompleteListId } from \"./AutocompleteList\";\nimport type { FlattenedListItem } from \"./CategoryList\";\n\nexport const getPaddingHorizontal = (theme: Theme): string =>\n  theme.variables.size.spacing.m;\nexport const getPaddingVertical = (theme: Theme): string =>\n  theme.variables.size.spacing.m;\n\nexport type PromptTextAreaProps =\n  TextareaHTMLAttributes<HTMLTextAreaElement> & {\n    dataE2eTestId?: string;\n    label: string;\n    name: string;\n    value: string;\n    maxTextAreaHeight?: Property.Height;\n    selectedListItem?: FlattenedListItem;\n    isAutocompleteListOpen?: boolean;\n    isCollapsed?: boolean;\n    /** Collapsed variant showing only single row text area */\n    isNavBarVariant?: boolean;\n    hasLeftIcon?: boolean;\n    rows?: number;\n  };\n\ntype StyledTextAreaContainerProps = Pick<\n  PromptTextAreaProps,\n  \"maxTextAreaHeight\" | \"isCollapsed\" | \"isNavBarVariant\" | \"hasLeftIcon\"\n>;\n\n// Textarea auto grow implemented according to https://css-tricks.com/the-cleanest-trick-for-autogrowing-textareas/\n\nconst StyledTextAreaContainer = styled.label<StyledTextAreaContainerProps>(\n  ({ theme, maxTextAreaHeight, isCollapsed, isNavBarVariant, hasLeftIcon }) => {\n    const paddingTop = isNavBarVariant\n      ? theme.variables.size.spacing.xxs\n      : getPaddingVertical(theme);\n    const paddingBottom = isNavBarVariant\n      ? theme.variables.size.spacing.xxs\n      : getPaddingVertical(theme);\n    const paddingRight = theme.variables.size.spacing.xxl;\n    const basePaddingLeft = getPaddingHorizontal(theme);\n    const paddingLeft = hasLeftIcon\n      ? `calc(${basePaddingLeft} + ${theme.variables.size.dimension.icon.m} + ${theme.variables.size.spacing.xs})`\n      : basePaddingLeft;\n\n    return {\n      display: \"grid\",\n      verticalAlign: \"top\",\n      alignItems: \"stretch\",\n      width: \"100%\",\n      borderRadius: \"inherit\",\n      position: \"relative\",\n      fontFamily: theme.variables.fontFamily.lato,\n      fontSize: theme.variables.size.font.m,\n      lineHeight: theme.variables.size.lineHeight.xl,\n\n      ...(isCollapsed && {\n        backgroundColor: theme.values.color.canvas,\n      }),\n\n      // Textarea grows due to ::after grows\n      // if you need to manipulate with size of textarea, you need to manipulate with ::after also\n      \"&::after\": {\n        content: \"attr(data-value) ' '\", // the empty space prevents textarea jump on grow\n        boxSizing: \"border-box\",\n        fontFamily: theme.variables.fontFamily.lato,\n        fontSize: theme.variables.size.font.m,\n        gridArea: \"1 / 1\",\n        whiteSpace: \"pre-wrap\",\n        visibility: \"hidden\",\n        maxHeight: maxTextAreaHeight,\n      },\n\n      textarea: {\n        all: \"unset\",\n        resize: \"none\",\n        gridArea: \"1 / 1\",\n        cursor: \"text\",\n        color: theme.values.color.text.primary.default,\n        ...(isCollapsed && {\n          overflow: \"hidden\",\n        }),\n        ...getInputTextPlaceholder({ theme }),\n      },\n      \"textarea::placeholder\": {\n        whiteSpace: \"nowrap\",\n        textOverflow: \"ellipsis\",\n        overflow: \"hidden\",\n      },\n\n      \"&::after, textarea\": {\n        // minWidth comes together with overflowWrap to achieve break-word\n        // it should be applied for ::after and textarea\n        minWidth: \"0\",\n        overflowWrap: \"break-word\",\n        padding: `${paddingTop} ${paddingRight} ${paddingBottom} ${paddingLeft}`,\n\n        ...(!isCollapsed && {\n          paddingBottom: getPaddingVertical(theme),\n        }),\n      },\n    };\n  }\n);\n\nexport const PromptTextArea = forwardRef(\n  (\n    {\n      dataE2eTestId,\n      label,\n      name,\n      value,\n      placeholder,\n      maxTextAreaHeight = \"200px\",\n      selectedListItem,\n      isAutocompleteListOpen,\n      isCollapsed,\n      isNavBarVariant,\n      hasLeftIcon,\n      rows = 1,\n      onChange,\n      ...rest\n    }: PromptTextAreaProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ) => {\n    useEffect(() => {\n      const textArea = ref.current;\n\n      if (isCollapsed) {\n        (textArea.parentNode as HTMLElement).dataset.value = \"\";\n      } else {\n        // Set the value of the ::after psuedo element so that the TextArea resizes accordingly as the grid stretches.\n        (textArea.parentNode as HTMLElement).dataset.value = value;\n      }\n    }, [value, ref, isCollapsed]);\n\n    return (\n      <StyledTextAreaContainer\n        maxTextAreaHeight={maxTextAreaHeight}\n        isCollapsed={isCollapsed}\n        isNavBarVariant={isNavBarVariant}\n        hasLeftIcon={hasLeftIcon}\n      >\n        <ScreenReaderText>{label}</ScreenReaderText>\n        <textarea\n          {...rest}\n          data-e2e-test-id={dataE2eTestId}\n          ref={ref}\n          name={name}\n          value={value}\n          placeholder={placeholder}\n          onChange={onChange}\n          rows={rows}\n          role=\"combobox\"\n          aria-autocomplete=\"list\"\n          aria-controls={\n            isAutocompleteListOpen ? getAutocompleteListId(name) : \"\"\n          }\n          aria-activedescendant={selectedListItem ? selectedListItem.id : \"\"}\n          aria-expanded={isAutocompleteListOpen}\n        />\n      </StyledTextAreaContainer>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsCgC"} */");export const PromptTextArea=forwardRef(({dataE2eTestId,label,name,value,placeholder,maxTextAreaHeight="200px",selectedListItem,isAutocompleteListOpen,isCollapsed,isNavBarVariant,hasLeftIcon,rows=1,onChange,...rest},ref)=>(useEffect(()=>{let textArea=ref.current;isCollapsed?textArea.parentNode.dataset.value="":textArea.parentNode.dataset.value=value},[value,ref,isCollapsed]),React.createElement(StyledTextAreaContainer,{maxTextAreaHeight:maxTextAreaHeight,isCollapsed:isCollapsed,isNavBarVariant:isNavBarVariant,hasLeftIcon:hasLeftIcon},React.createElement(ScreenReaderText,null,label),React.createElement("textarea",{...rest,"data-e2e-test-id":dataE2eTestId,ref:ref,name:name,value:value,placeholder:placeholder,onChange:onChange,rows:rows,role:"combobox","aria-autocomplete":"list","aria-controls":isAutocompleteListOpen?getAutocompleteListId(name):"","aria-activedescendant":selectedListItem?selectedListItem.id:"","aria-expanded":isAutocompleteListOpen}))));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.42.1",
3
+ "version": "3.42.2",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",