@laerdal/life-react-components 6.0.6 → 6.0.8-dev.3.full

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.
@@ -71,7 +71,7 @@ const VerticalCardTopSectionCheckboxContainer = exports.VerticalCardTopSectionCh
71
71
  position: absolute;
72
72
  top: 0;
73
73
  right: 0;
74
- z-index: 1;
74
+ z-index: 120;
75
75
 
76
76
  .checkbox-icon {
77
77
  background-color: ${props => _index.COLORS.getColor('white', props.theme)};
@@ -1 +1 @@
1
- {"version":3,"file":"VerticalCardTopSection.cjs","names":["React","_interopRequireWildcard","require","_styledComponents","_typography","_Checkbox","_interopRequireDefault","_Tag","_index","_Image","_jsxRuntime","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","VerticalCardTopSectionImageContainer","exports","styled","div","VerticalCardTopSectionTagContainer","VerticalCardTopSectionContainer","props","disabled","VerticalCardTopSectionRibbonContainer","$backgroundColor","$color","VerticalCardTopSectionCheckboxContainer","COLORS","getColor","theme","VerticalCardTopSection","forwardRef","_ref","ref","selected","setSelected","image","tagLabel","tagIcon","tagVariant","highlightRibbonIcon","highlightRibbonText","highlightRibbonContentColor","highlightRibbonBgColor","useTheme","jsxs","style","height","children","jsx","role","ImageWithFallbacks","fallbacks","fallbackSrc","src","alt","loader","width","select","Tag","label","variant","icon","generateToken","componentType","state","ComponentS","color","isOnFill","textStyle","ComponentTextStyle","Regular","propTypes","_propTypes","bool","func","string","node","shape","isRequired","_default"],"sources":["../../../src/Card/VerticalCard/VerticalCardTopSection.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {ComponentS, ComponentTextStyle} from '../../styles/typography';\r\nimport Checkbox from '../../InputFields/Checkbox';\r\nimport {Tag, TagVariants} from '../../Tag';\r\n\r\nimport {COLORS} from '../../index';\r\nimport {ImageWithFallbacks} from \"../../Image\";\r\n\r\nexport interface VerticalCardTopSectionProps {\r\n /** Sets initial state of select Checkbox. */\r\n selected?: boolean;\r\n /** If this action is provided, then Checkbox will be shown on the top-right corner of the Card. */\r\n setSelected?: (arg0: boolean) => void;\r\n /** Label shown in the tag in the top-left corner of the Card. */\r\n tagLabel?: string;\r\n /** Icon shown in the tag in the top-left corner of the Card. */\r\n tagIcon?: React.ReactNode;\r\n /** Tag variant shown in the tag in the top-left corner of the Card. */\r\n tagVariant?: TagVariants;\r\n /** Text shown in the Ribbon, under the Image. */\r\n highlightRibbonText?: string;\r\n /** Icon shown in the Ribbon, under the Image. */\r\n highlightRibbonIcon?: React.ReactNode;\r\n /** Content color (text and image) of the Ribbon, under the Image. */\r\n highlightRibbonContentColor?: string;\r\n /** Background color of the Ribbon, shown under the Image. */\r\n highlightRibbonBgColor?: string;\r\n /** Details of the Image shown in the section. */\r\n image?: { src: string; fallbackSrc?: string; alt: string, height?: string; width?: string; loader?: boolean };\r\n /** This property is automatically set in the Card itself and is based on 'disabled' flag of CardProps. */\r\n disabled?: boolean;\r\n}\r\n\r\nexport const VerticalCardTopSectionImageContainer = styled.div`\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n height: 100%;\r\n width: 100%;\r\n img{\r\n object-fit: cover;\r\n width: 100%;\r\n height: 100%;\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionTagContainer = styled.div`\r\n position: absolute;\r\n\r\n top: 16px;\r\n left: 16px;\r\n width: calc(100% - 32px);\r\n`;\r\n\r\nexport const VerticalCardTopSectionContainer = styled.div<{ disabled?: boolean }>`\r\n position: relative;\r\n width: 100%;\r\n overflow: visible;\r\n\r\n ${props => props.disabled ? `\r\n img, svg {\r\n filter: grayscale(100%);\r\n }` : ''}\r\n`;\r\n\r\nexport const VerticalCardTopSectionRibbonContainer = styled.div<{ $color: string; $backgroundColor: string }>`\r\n min-height: calc(40px - 16px);\r\n background-color: ${props => props.$backgroundColor};\r\n width: calc(100% - 32px);\r\n position: absolute;\r\n bottom: 0px;\r\n left: 0px;\r\n padding: 8px 16px 8px 16px;\r\n display: flex;\r\n flex-direction: row;\r\n align-items: center;\r\n gap: 8px;\r\n\r\n svg {\r\n color: ${props => props.$color};\r\n width: 24px;\r\n height: 24px;\r\n flex-grow: 0;\r\n flex-shrink: 0;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionCheckboxContainer = styled.div`\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n z-index: 1;\r\n\r\n .checkbox-icon {\r\n background-color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n`;\r\n\r\nconst VerticalCardTopSection = React.forwardRef(({\r\n selected,\r\n setSelected,\r\n image,\r\n tagLabel,\r\n tagIcon,\r\n tagVariant = 'positive',\r\n highlightRibbonIcon,\r\n highlightRibbonText,\r\n highlightRibbonContentColor,\r\n highlightRibbonBgColor,\r\n disabled\r\n }: VerticalCardTopSectionProps, ref: React.Ref<HTMLDivElement>) => {\r\n\r\n const theme = useTheme();\r\n return (\r\n <VerticalCardTopSectionContainer disabled={disabled} data-testid={'card-topSection'} style={{height: image?.height ?? 200}}>\r\n {\r\n image &&\r\n <VerticalCardTopSectionImageContainer role=\"none\" aria-hidden=\"true\">\r\n <ImageWithFallbacks fallbacks={image.fallbackSrc ?? ''} src={image.src} alt=\"\" loader={image.loader ?? false} width={image.width} height={image.height}/>\r\n </VerticalCardTopSectionImageContainer>\r\n }\r\n {(!!selected || !!setSelected) && (\r\n <VerticalCardTopSectionCheckboxContainer data-testid={'card-topSection-checkbox'}>\r\n <Checkbox ref={ref}\r\n disabled={disabled}\r\n select={(selected: boolean) => setSelected && setSelected(selected)}\r\n selected={selected || false}/>\r\n </VerticalCardTopSectionCheckboxContainer>\r\n )}\r\n {(tagLabel || tagIcon) && (\r\n <VerticalCardTopSectionTagContainer>\r\n <Tag label={tagLabel} variant={tagVariant} icon={tagIcon}/>\r\n </VerticalCardTopSectionTagContainer>\r\n )}\r\n {(highlightRibbonIcon || highlightRibbonText) && (\r\n <VerticalCardTopSectionRibbonContainer data-testid={'card-topSection-ribbon'} $color={highlightRibbonContentColor ?? ''}\r\n $backgroundColor={disabled ? COLORS.generateToken({componentType:'bg-fill', state:'disabled'}, theme) : highlightRibbonBgColor ?? ''}>\r\n {highlightRibbonIcon}\r\n {highlightRibbonText && (\r\n <ComponentS color={disabled ? COLORS.generateToken({componentType:'text', isOnFill: true, state:'disabled'}, theme) : highlightRibbonContentColor ?? ''} textStyle={ComponentTextStyle.Regular}>\r\n {highlightRibbonText}\r\n </ComponentS>\r\n )}\r\n </VerticalCardTopSectionRibbonContainer>\r\n )}\r\n </VerticalCardTopSectionContainer>\r\n );\r\n});\r\n\r\nexport default VerticalCardTopSection;\r\n"],"mappings":";;;;;;;;AAAA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAF,uBAAA,CAAAC,OAAA;AACA,IAAAE,WAAA,GAAAF,OAAA;AACA,IAAAG,SAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,IAAA,GAAAL,OAAA;AAEA,IAAAM,MAAA,GAAAN,OAAA;AACA,IAAAO,MAAA,GAAAP,OAAA;AAA+C,IAAAQ,WAAA,GAAAR,OAAA;AAAA,SAAAS,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAX,wBAAAW,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AA2BxC,MAAMW,oCAAoC,GAAAC,OAAA,CAAAD,oCAAA,GAAGE,yBAAM,CAACC,GAAG;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAEM,MAAMC,kCAAkC,GAAAH,OAAA,CAAAG,kCAAA,GAAGF,yBAAM,CAACC,GAAG;AAC5D;AACA;AACA;AACA;AACA;AACA,CAAC;AAEM,MAAME,+BAA+B,GAAAJ,OAAA,CAAAI,+BAAA,GAAGH,yBAAM,CAACC,GAA2B;AACjF;AACA;AACA;AACA;AACA,IAAIG,KAAK,IAAIA,KAAK,CAACC,QAAQ,GAAG;AAC9B;AACA;AACA,IAAI,GAAG,EAAE;AACT,CAAC;AAEM,MAAMC,qCAAqC,GAAAP,OAAA,CAAAO,qCAAA,GAAGN,yBAAM,CAACC,GAAiD;AAC7G;AACA,sBAAsBG,KAAK,IAAIA,KAAK,CAACG,gBAAgB;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAaH,KAAK,IAAIA,KAAK,CAACI,MAAM;AAClC;AACA;AACA;AACA;AACA;AACA,CAAC;AAEM,MAAMC,uCAAuC,GAAAV,OAAA,CAAAU,uCAAA,GAAGT,yBAAM,CAACC,GAAG;AACjE;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwBG,KAAK,IAAIM,aAAM,CAACC,QAAQ,CAAC,OAAO,EAAEP,KAAK,CAACQ,KAAK,CAAC;AACtE;AACA,CAAC;AAED,MAAMC,sBAAsB,gBAAG9C,KAAK,CAAC+C,UAAU,CAAC,CAAAC,IAAA,EAYyBC,GAA8B,KAAK;EAAA,IAZ3D;IACNC,QAAQ;IACRC,WAAW;IACXC,KAAK;IACLC,QAAQ;IACRC,OAAO;IACPC,UAAU,GAAG,UAAU;IACvBC,mBAAmB;IACnBC,mBAAmB;IACnBC,2BAA2B;IAC3BC,sBAAsB;IACtBrB;EAC2B,CAAC,GAAAU,IAAA;EAErE,MAAMH,KAAK,GAAG,IAAAe,0BAAQ,EAAC,CAAC;EACxB,oBACE,IAAAlD,WAAA,CAAAmD,IAAA,EAACzB,+BAA+B;IAACE,QAAQ,EAAEA,QAAS;IAAC,eAAa,iBAAkB;IAACwB,KAAK,EAAE;MAACC,MAAM,EAAEX,KAAK,EAAEW,MAAM,IAAI;IAAG,CAAE;IAAAC,QAAA,GAEvHZ,KAAK,iBACL,IAAA1C,WAAA,CAAAuD,GAAA,EAAClC,oCAAoC;MAACmC,IAAI,EAAC,MAAM;MAAC,eAAY,MAAM;MAAAF,QAAA,eAChE,IAAAtD,WAAA,CAAAuD,GAAA,EAACxD,MAAA,CAAA0D,kBAAkB;QAACC,SAAS,EAAEhB,KAAK,CAACiB,WAAW,IAAI,EAAG;QAACC,GAAG,EAAElB,KAAK,CAACkB,GAAI;QAACC,GAAG,EAAC,EAAE;QAACC,MAAM,EAAEpB,KAAK,CAACoB,MAAM,IAAI,KAAM;QAACC,KAAK,EAAErB,KAAK,CAACqB,KAAM;QAACV,MAAM,EAAEX,KAAK,CAACW;MAAO,CAAC;IAAC,CACvH,CAAC,EAExC,CAAC,CAAC,CAACb,QAAQ,IAAI,CAAC,CAACC,WAAW,kBAC3B,IAAAzC,WAAA,CAAAuD,GAAA,EAACvB,uCAAuC;MAAC,eAAa,0BAA2B;MAAAsB,QAAA,eAC/E,IAAAtD,WAAA,CAAAuD,GAAA,EAAC5D,SAAA,CAAAY,OAAQ;QAACgC,GAAG,EAAEA,GAAI;QACTX,QAAQ,EAAEA,QAAS;QACnBoC,MAAM,EAAGxB,QAAiB,IAAKC,WAAW,IAAIA,WAAW,CAACD,QAAQ,CAAE;QACpEA,QAAQ,EAAEA,QAAQ,IAAI;MAAM,CAAC;IAAC,CACD,CAC1C,EACA,CAACG,QAAQ,IAAIC,OAAO,kBACnB,IAAA5C,WAAA,CAAAuD,GAAA,EAAC9B,kCAAkC;MAAA6B,QAAA,eACjC,IAAAtD,WAAA,CAAAuD,GAAA,EAAC1D,IAAA,CAAAoE,GAAG;QAACC,KAAK,EAAEvB,QAAS;QAACwB,OAAO,EAAEtB,UAAW;QAACuB,IAAI,EAAExB;MAAQ,CAAC;IAAC,CACzB,CACrC,EACA,CAACE,mBAAmB,IAAIC,mBAAmB,kBAC1C,IAAA/C,WAAA,CAAAmD,IAAA,EAACtB,qCAAqC;MAAC,eAAa,wBAAyB;MAACE,MAAM,EAAEiB,2BAA2B,IAAI,EAAG;MACnGlB,gBAAgB,EAAEF,QAAQ,GAAGK,aAAM,CAACoC,aAAa,CAAC;QAACC,aAAa,EAAC,SAAS;QAAEC,KAAK,EAAC;MAAU,CAAC,EAAEpC,KAAK,CAAC,GAAGc,sBAAsB,IAAI,EAAG;MAAAK,QAAA,GACvJR,mBAAmB,EACnBC,mBAAmB,iBAClB,IAAA/C,WAAA,CAAAuD,GAAA,EAAC7D,WAAA,CAAA8E,UAAU;QAACC,KAAK,EAAE7C,QAAQ,GAAGK,aAAM,CAACoC,aAAa,CAAC;UAACC,aAAa,EAAC,MAAM;UAAEI,QAAQ,EAAE,IAAI;UAAEH,KAAK,EAAC;QAAU,CAAC,EAAEpC,KAAK,CAAC,GAAGa,2BAA2B,IAAI,EAAG;QAAC2B,SAAS,EAAEC,8BAAkB,CAACC,OAAQ;QAAAvB,QAAA,EAC5LP;MAAmB,CACV,CACb;IAAA,CACoC,CACxC;EAAA,CAC8B,CAAC;AAEtC,CAAC,CAAC;AAACX,sBAAA,CAAA0C,SAAA;EA1IDtC,QAAQ,EAAAuC,UAAA,CAAAxE,OAAA,CAAAyE,IAAA;EAERvC,WAAW,EAAAsC,UAAA,CAAAxE,OAAA,CAAA0E,IAAA;EAEXtC,QAAQ,EAAAoC,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;EAERtC,OAAO,EAAAmC,UAAA,CAAAxE,OAAA,CAAA4E,IAAA;EAIPpC,mBAAmB,EAAAgC,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;EAEnBpC,mBAAmB,EAAAiC,UAAA,CAAAxE,OAAA,CAAA4E,IAAA;EAEnBnC,2BAA2B,EAAA+B,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;EAE3BjC,sBAAsB,EAAA8B,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;EAEtBxC,KAAK,EAAAqC,UAAA,CAAAxE,OAAA,CAAA6E,KAAA;IAAKxB,GAAG,EAAAmB,UAAA,CAAAxE,OAAA,CAAA2E,MAAA,CAAAG,UAAA;IAAU1B,WAAW,EAAAoB,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;IAAWrB,GAAG,EAAAkB,UAAA,CAAAxE,OAAA,CAAA2E,MAAA,CAAAG,UAAA;IAAUhC,MAAM,EAAA0B,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;IAAWnB,KAAK,EAAAgB,UAAA,CAAAxE,OAAA,CAAA2E,MAAA;IAAWpB,MAAM,EAAAiB,UAAA,CAAAxE,OAAA,CAAAyE;EAAA;EAEjGpD,QAAQ,EAAAmD,UAAA,CAAAxE,OAAA,CAAAyE;AAAA;AAAA,IAAAM,QAAA,GAAAhE,OAAA,CAAAf,OAAA,GAwHK6B,sBAAsB","ignoreList":[]}
1
+ {"version":3,"file":"VerticalCardTopSection.cjs","names":["React","_interopRequireWildcard","require","_styledComponents","_typography","_Checkbox","_interopRequireDefault","_Tag","_index","_Image","_jsxRuntime","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","VerticalCardTopSectionImageContainer","exports","styled","div","VerticalCardTopSectionTagContainer","VerticalCardTopSectionContainer","props","disabled","VerticalCardTopSectionRibbonContainer","$backgroundColor","$color","VerticalCardTopSectionCheckboxContainer","COLORS","getColor","theme","VerticalCardTopSection","forwardRef","_ref","ref","selected","setSelected","image","tagLabel","tagIcon","tagVariant","highlightRibbonIcon","highlightRibbonText","highlightRibbonContentColor","highlightRibbonBgColor","useTheme","jsxs","style","height","children","jsx","role","ImageWithFallbacks","fallbacks","fallbackSrc","src","alt","loader","width","select","Tag","label","variant","icon","generateToken","componentType","state","ComponentS","color","isOnFill","textStyle","ComponentTextStyle","Regular","propTypes","_propTypes","bool","func","string","node","shape","isRequired","_default"],"sources":["../../../src/Card/VerticalCard/VerticalCardTopSection.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {ComponentS, ComponentTextStyle} from '../../styles/typography';\r\nimport Checkbox from '../../InputFields/Checkbox';\r\nimport {Tag, TagVariants} from '../../Tag';\r\n\r\nimport {COLORS} from '../../index';\r\nimport {ImageWithFallbacks} from \"../../Image\";\r\n\r\nexport interface VerticalCardTopSectionProps {\r\n /** Sets initial state of select Checkbox. */\r\n selected?: boolean;\r\n /** If this action is provided, then Checkbox will be shown on the top-right corner of the Card. */\r\n setSelected?: (arg0: boolean) => void;\r\n /** Label shown in the tag in the top-left corner of the Card. */\r\n tagLabel?: string;\r\n /** Icon shown in the tag in the top-left corner of the Card. */\r\n tagIcon?: React.ReactNode;\r\n /** Tag variant shown in the tag in the top-left corner of the Card. */\r\n tagVariant?: TagVariants;\r\n /** Text shown in the Ribbon, under the Image. */\r\n highlightRibbonText?: string;\r\n /** Icon shown in the Ribbon, under the Image. */\r\n highlightRibbonIcon?: React.ReactNode;\r\n /** Content color (text and image) of the Ribbon, under the Image. */\r\n highlightRibbonContentColor?: string;\r\n /** Background color of the Ribbon, shown under the Image. */\r\n highlightRibbonBgColor?: string;\r\n /** Details of the Image shown in the section. */\r\n image?: { src: string; fallbackSrc?: string; alt: string, height?: string; width?: string; loader?: boolean };\r\n /** This property is automatically set in the Card itself and is based on 'disabled' flag of CardProps. */\r\n disabled?: boolean;\r\n}\r\n\r\nexport const VerticalCardTopSectionImageContainer = styled.div`\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n height: 100%;\r\n width: 100%;\r\n img{\r\n object-fit: cover;\r\n width: 100%;\r\n height: 100%;\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionTagContainer = styled.div`\r\n position: absolute;\r\n\r\n top: 16px;\r\n left: 16px;\r\n width: calc(100% - 32px);\r\n`;\r\n\r\nexport const VerticalCardTopSectionContainer = styled.div<{ disabled?: boolean }>`\r\n position: relative;\r\n width: 100%;\r\n overflow: visible;\r\n\r\n ${props => props.disabled ? `\r\n img, svg {\r\n filter: grayscale(100%);\r\n }` : ''}\r\n`;\r\n\r\nexport const VerticalCardTopSectionRibbonContainer = styled.div<{ $color: string; $backgroundColor: string }>`\r\n min-height: calc(40px - 16px);\r\n background-color: ${props => props.$backgroundColor};\r\n width: calc(100% - 32px);\r\n position: absolute;\r\n bottom: 0px;\r\n left: 0px;\r\n padding: 8px 16px 8px 16px;\r\n display: flex;\r\n flex-direction: row;\r\n align-items: center;\r\n gap: 8px;\r\n\r\n svg {\r\n color: ${props => props.$color};\r\n width: 24px;\r\n height: 24px;\r\n flex-grow: 0;\r\n flex-shrink: 0;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionCheckboxContainer = styled.div`\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n z-index: 120;\r\n\r\n .checkbox-icon {\r\n background-color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n`;\r\n\r\nconst VerticalCardTopSection = React.forwardRef(({\r\n selected,\r\n setSelected,\r\n image,\r\n tagLabel,\r\n tagIcon,\r\n tagVariant = 'positive',\r\n highlightRibbonIcon,\r\n highlightRibbonText,\r\n highlightRibbonContentColor,\r\n highlightRibbonBgColor,\r\n disabled\r\n }: VerticalCardTopSectionProps, ref: React.Ref<HTMLDivElement>) => {\r\n\r\n const theme = useTheme();\r\n return (\r\n <VerticalCardTopSectionContainer disabled={disabled} data-testid={'card-topSection'} style={{height: image?.height ?? 200}}>\r\n {\r\n image &&\r\n <VerticalCardTopSectionImageContainer role=\"none\" aria-hidden=\"true\">\r\n <ImageWithFallbacks fallbacks={image.fallbackSrc ?? ''} src={image.src} alt=\"\" loader={image.loader ?? false} width={image.width} height={image.height}/>\r\n </VerticalCardTopSectionImageContainer>\r\n }\r\n {(!!selected || !!setSelected) && (\r\n <VerticalCardTopSectionCheckboxContainer data-testid={'card-topSection-checkbox'}>\r\n <Checkbox ref={ref}\r\n disabled={disabled}\r\n select={(selected: boolean) => setSelected && setSelected(selected)}\r\n selected={selected || false}/>\r\n </VerticalCardTopSectionCheckboxContainer>\r\n )}\r\n {(tagLabel || tagIcon) && (\r\n <VerticalCardTopSectionTagContainer>\r\n <Tag label={tagLabel} variant={tagVariant} icon={tagIcon}/>\r\n </VerticalCardTopSectionTagContainer>\r\n )}\r\n {(highlightRibbonIcon || highlightRibbonText) && (\r\n <VerticalCardTopSectionRibbonContainer data-testid={'card-topSection-ribbon'} $color={highlightRibbonContentColor ?? ''}\r\n $backgroundColor={disabled ? COLORS.generateToken({componentType:'bg-fill', state:'disabled'}, theme) : highlightRibbonBgColor ?? ''}>\r\n {highlightRibbonIcon}\r\n {highlightRibbonText && (\r\n <ComponentS color={disabled ? COLORS.generateToken({componentType:'text', isOnFill: true, state:'disabled'}, theme) : highlightRibbonContentColor ?? ''} textStyle={ComponentTextStyle.Regular}>\r\n {highlightRibbonText}\r\n </ComponentS>\r\n )}\r\n </VerticalCardTopSectionRibbonContainer>\r\n )}\r\n </VerticalCardTopSectionContainer>\r\n );\r\n});\r\n\r\nexport default VerticalCardTopSection;\r\n"],"mappings":"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","ignoreList":[]}
@@ -62,7 +62,7 @@ export const VerticalCardTopSectionCheckboxContainer = styled.div`
62
62
  position: absolute;
63
63
  top: 0;
64
64
  right: 0;
65
- z-index: 1;
65
+ z-index: 120;
66
66
 
67
67
  .checkbox-icon {
68
68
  background-color: ${props => COLORS.getColor('white', props.theme)};
@@ -1 +1 @@
1
- {"version":3,"file":"VerticalCardTopSection.js","names":["React","styled","useTheme","ComponentS","ComponentTextStyle","Checkbox","Tag","COLORS","ImageWithFallbacks","jsx","_jsx","jsxs","_jsxs","VerticalCardTopSectionImageContainer","div","VerticalCardTopSectionTagContainer","VerticalCardTopSectionContainer","props","disabled","VerticalCardTopSectionRibbonContainer","$backgroundColor","$color","VerticalCardTopSectionCheckboxContainer","getColor","theme","VerticalCardTopSection","forwardRef","_ref","ref","selected","setSelected","image","tagLabel","tagIcon","tagVariant","highlightRibbonIcon","highlightRibbonText","highlightRibbonContentColor","highlightRibbonBgColor","style","height","children","role","fallbacks","fallbackSrc","src","alt","loader","width","select","label","variant","icon","generateToken","componentType","state","color","isOnFill","textStyle","Regular","propTypes","_pt","bool","func","string","node","shape","isRequired"],"sources":["../../../src/Card/VerticalCard/VerticalCardTopSection.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {ComponentS, ComponentTextStyle} from '../../styles/typography';\r\nimport Checkbox from '../../InputFields/Checkbox';\r\nimport {Tag, TagVariants} from '../../Tag';\r\n\r\nimport {COLORS} from '../../index';\r\nimport {ImageWithFallbacks} from \"../../Image\";\r\n\r\nexport interface VerticalCardTopSectionProps {\r\n /** Sets initial state of select Checkbox. */\r\n selected?: boolean;\r\n /** If this action is provided, then Checkbox will be shown on the top-right corner of the Card. */\r\n setSelected?: (arg0: boolean) => void;\r\n /** Label shown in the tag in the top-left corner of the Card. */\r\n tagLabel?: string;\r\n /** Icon shown in the tag in the top-left corner of the Card. */\r\n tagIcon?: React.ReactNode;\r\n /** Tag variant shown in the tag in the top-left corner of the Card. */\r\n tagVariant?: TagVariants;\r\n /** Text shown in the Ribbon, under the Image. */\r\n highlightRibbonText?: string;\r\n /** Icon shown in the Ribbon, under the Image. */\r\n highlightRibbonIcon?: React.ReactNode;\r\n /** Content color (text and image) of the Ribbon, under the Image. */\r\n highlightRibbonContentColor?: string;\r\n /** Background color of the Ribbon, shown under the Image. */\r\n highlightRibbonBgColor?: string;\r\n /** Details of the Image shown in the section. */\r\n image?: { src: string; fallbackSrc?: string; alt: string, height?: string; width?: string; loader?: boolean };\r\n /** This property is automatically set in the Card itself and is based on 'disabled' flag of CardProps. */\r\n disabled?: boolean;\r\n}\r\n\r\nexport const VerticalCardTopSectionImageContainer = styled.div`\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n height: 100%;\r\n width: 100%;\r\n img{\r\n object-fit: cover;\r\n width: 100%;\r\n height: 100%;\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionTagContainer = styled.div`\r\n position: absolute;\r\n\r\n top: 16px;\r\n left: 16px;\r\n width: calc(100% - 32px);\r\n`;\r\n\r\nexport const VerticalCardTopSectionContainer = styled.div<{ disabled?: boolean }>`\r\n position: relative;\r\n width: 100%;\r\n overflow: visible;\r\n\r\n ${props => props.disabled ? `\r\n img, svg {\r\n filter: grayscale(100%);\r\n }` : ''}\r\n`;\r\n\r\nexport const VerticalCardTopSectionRibbonContainer = styled.div<{ $color: string; $backgroundColor: string }>`\r\n min-height: calc(40px - 16px);\r\n background-color: ${props => props.$backgroundColor};\r\n width: calc(100% - 32px);\r\n position: absolute;\r\n bottom: 0px;\r\n left: 0px;\r\n padding: 8px 16px 8px 16px;\r\n display: flex;\r\n flex-direction: row;\r\n align-items: center;\r\n gap: 8px;\r\n\r\n svg {\r\n color: ${props => props.$color};\r\n width: 24px;\r\n height: 24px;\r\n flex-grow: 0;\r\n flex-shrink: 0;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionCheckboxContainer = styled.div`\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n z-index: 1;\r\n\r\n .checkbox-icon {\r\n background-color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n`;\r\n\r\nconst VerticalCardTopSection = React.forwardRef(({\r\n selected,\r\n setSelected,\r\n image,\r\n tagLabel,\r\n tagIcon,\r\n tagVariant = 'positive',\r\n highlightRibbonIcon,\r\n highlightRibbonText,\r\n highlightRibbonContentColor,\r\n highlightRibbonBgColor,\r\n disabled\r\n }: VerticalCardTopSectionProps, ref: React.Ref<HTMLDivElement>) => {\r\n\r\n const theme = useTheme();\r\n return (\r\n <VerticalCardTopSectionContainer disabled={disabled} data-testid={'card-topSection'} style={{height: image?.height ?? 200}}>\r\n {\r\n image &&\r\n <VerticalCardTopSectionImageContainer role=\"none\" aria-hidden=\"true\">\r\n <ImageWithFallbacks fallbacks={image.fallbackSrc ?? ''} src={image.src} alt=\"\" loader={image.loader ?? false} width={image.width} height={image.height}/>\r\n </VerticalCardTopSectionImageContainer>\r\n }\r\n {(!!selected || !!setSelected) && (\r\n <VerticalCardTopSectionCheckboxContainer data-testid={'card-topSection-checkbox'}>\r\n <Checkbox ref={ref}\r\n disabled={disabled}\r\n select={(selected: boolean) => setSelected && setSelected(selected)}\r\n selected={selected || false}/>\r\n </VerticalCardTopSectionCheckboxContainer>\r\n )}\r\n {(tagLabel || tagIcon) && (\r\n <VerticalCardTopSectionTagContainer>\r\n <Tag label={tagLabel} variant={tagVariant} icon={tagIcon}/>\r\n </VerticalCardTopSectionTagContainer>\r\n )}\r\n {(highlightRibbonIcon || highlightRibbonText) && (\r\n <VerticalCardTopSectionRibbonContainer data-testid={'card-topSection-ribbon'} $color={highlightRibbonContentColor ?? ''}\r\n $backgroundColor={disabled ? COLORS.generateToken({componentType:'bg-fill', state:'disabled'}, theme) : highlightRibbonBgColor ?? ''}>\r\n {highlightRibbonIcon}\r\n {highlightRibbonText && (\r\n <ComponentS color={disabled ? COLORS.generateToken({componentType:'text', isOnFill: true, state:'disabled'}, theme) : highlightRibbonContentColor ?? ''} textStyle={ComponentTextStyle.Regular}>\r\n {highlightRibbonText}\r\n </ComponentS>\r\n )}\r\n </VerticalCardTopSectionRibbonContainer>\r\n )}\r\n </VerticalCardTopSectionContainer>\r\n );\r\n});\r\n\r\nexport default VerticalCardTopSection;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"VerticalCardTopSection.js","names":["React","styled","useTheme","ComponentS","ComponentTextStyle","Checkbox","Tag","COLORS","ImageWithFallbacks","jsx","_jsx","jsxs","_jsxs","VerticalCardTopSectionImageContainer","div","VerticalCardTopSectionTagContainer","VerticalCardTopSectionContainer","props","disabled","VerticalCardTopSectionRibbonContainer","$backgroundColor","$color","VerticalCardTopSectionCheckboxContainer","getColor","theme","VerticalCardTopSection","forwardRef","_ref","ref","selected","setSelected","image","tagLabel","tagIcon","tagVariant","highlightRibbonIcon","highlightRibbonText","highlightRibbonContentColor","highlightRibbonBgColor","style","height","children","role","fallbacks","fallbackSrc","src","alt","loader","width","select","label","variant","icon","generateToken","componentType","state","color","isOnFill","textStyle","Regular","propTypes","_pt","bool","func","string","node","shape","isRequired"],"sources":["../../../src/Card/VerticalCard/VerticalCardTopSection.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {ComponentS, ComponentTextStyle} from '../../styles/typography';\r\nimport Checkbox from '../../InputFields/Checkbox';\r\nimport {Tag, TagVariants} from '../../Tag';\r\n\r\nimport {COLORS} from '../../index';\r\nimport {ImageWithFallbacks} from \"../../Image\";\r\n\r\nexport interface VerticalCardTopSectionProps {\r\n /** Sets initial state of select Checkbox. */\r\n selected?: boolean;\r\n /** If this action is provided, then Checkbox will be shown on the top-right corner of the Card. */\r\n setSelected?: (arg0: boolean) => void;\r\n /** Label shown in the tag in the top-left corner of the Card. */\r\n tagLabel?: string;\r\n /** Icon shown in the tag in the top-left corner of the Card. */\r\n tagIcon?: React.ReactNode;\r\n /** Tag variant shown in the tag in the top-left corner of the Card. */\r\n tagVariant?: TagVariants;\r\n /** Text shown in the Ribbon, under the Image. */\r\n highlightRibbonText?: string;\r\n /** Icon shown in the Ribbon, under the Image. */\r\n highlightRibbonIcon?: React.ReactNode;\r\n /** Content color (text and image) of the Ribbon, under the Image. */\r\n highlightRibbonContentColor?: string;\r\n /** Background color of the Ribbon, shown under the Image. */\r\n highlightRibbonBgColor?: string;\r\n /** Details of the Image shown in the section. */\r\n image?: { src: string; fallbackSrc?: string; alt: string, height?: string; width?: string; loader?: boolean };\r\n /** This property is automatically set in the Card itself and is based on 'disabled' flag of CardProps. */\r\n disabled?: boolean;\r\n}\r\n\r\nexport const VerticalCardTopSectionImageContainer = styled.div`\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n height: 100%;\r\n width: 100%;\r\n img{\r\n object-fit: cover;\r\n width: 100%;\r\n height: 100%;\r\n border-top-right-radius: 8px;\r\n border-top-left-radius: 8px;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionTagContainer = styled.div`\r\n position: absolute;\r\n\r\n top: 16px;\r\n left: 16px;\r\n width: calc(100% - 32px);\r\n`;\r\n\r\nexport const VerticalCardTopSectionContainer = styled.div<{ disabled?: boolean }>`\r\n position: relative;\r\n width: 100%;\r\n overflow: visible;\r\n\r\n ${props => props.disabled ? `\r\n img, svg {\r\n filter: grayscale(100%);\r\n }` : ''}\r\n`;\r\n\r\nexport const VerticalCardTopSectionRibbonContainer = styled.div<{ $color: string; $backgroundColor: string }>`\r\n min-height: calc(40px - 16px);\r\n background-color: ${props => props.$backgroundColor};\r\n width: calc(100% - 32px);\r\n position: absolute;\r\n bottom: 0px;\r\n left: 0px;\r\n padding: 8px 16px 8px 16px;\r\n display: flex;\r\n flex-direction: row;\r\n align-items: center;\r\n gap: 8px;\r\n\r\n svg {\r\n color: ${props => props.$color};\r\n width: 24px;\r\n height: 24px;\r\n flex-grow: 0;\r\n flex-shrink: 0;\r\n }\r\n`;\r\n\r\nexport const VerticalCardTopSectionCheckboxContainer = styled.div`\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n z-index: 120;\r\n\r\n .checkbox-icon {\r\n background-color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n`;\r\n\r\nconst VerticalCardTopSection = React.forwardRef(({\r\n selected,\r\n setSelected,\r\n image,\r\n tagLabel,\r\n tagIcon,\r\n tagVariant = 'positive',\r\n highlightRibbonIcon,\r\n highlightRibbonText,\r\n highlightRibbonContentColor,\r\n highlightRibbonBgColor,\r\n disabled\r\n }: VerticalCardTopSectionProps, ref: React.Ref<HTMLDivElement>) => {\r\n\r\n const theme = useTheme();\r\n return (\r\n <VerticalCardTopSectionContainer disabled={disabled} data-testid={'card-topSection'} style={{height: image?.height ?? 200}}>\r\n {\r\n image &&\r\n <VerticalCardTopSectionImageContainer role=\"none\" aria-hidden=\"true\">\r\n <ImageWithFallbacks fallbacks={image.fallbackSrc ?? ''} src={image.src} alt=\"\" loader={image.loader ?? false} width={image.width} height={image.height}/>\r\n </VerticalCardTopSectionImageContainer>\r\n }\r\n {(!!selected || !!setSelected) && (\r\n <VerticalCardTopSectionCheckboxContainer data-testid={'card-topSection-checkbox'}>\r\n <Checkbox ref={ref}\r\n disabled={disabled}\r\n select={(selected: boolean) => setSelected && setSelected(selected)}\r\n selected={selected || false}/>\r\n </VerticalCardTopSectionCheckboxContainer>\r\n )}\r\n {(tagLabel || tagIcon) && (\r\n <VerticalCardTopSectionTagContainer>\r\n <Tag label={tagLabel} variant={tagVariant} icon={tagIcon}/>\r\n </VerticalCardTopSectionTagContainer>\r\n )}\r\n {(highlightRibbonIcon || highlightRibbonText) && (\r\n <VerticalCardTopSectionRibbonContainer data-testid={'card-topSection-ribbon'} $color={highlightRibbonContentColor ?? ''}\r\n $backgroundColor={disabled ? COLORS.generateToken({componentType:'bg-fill', state:'disabled'}, theme) : highlightRibbonBgColor ?? ''}>\r\n {highlightRibbonIcon}\r\n {highlightRibbonText && (\r\n <ComponentS color={disabled ? COLORS.generateToken({componentType:'text', isOnFill: true, state:'disabled'}, theme) : highlightRibbonContentColor ?? ''} textStyle={ComponentTextStyle.Regular}>\r\n {highlightRibbonText}\r\n </ComponentS>\r\n )}\r\n </VerticalCardTopSectionRibbonContainer>\r\n )}\r\n </VerticalCardTopSectionContainer>\r\n );\r\n});\r\n\r\nexport default VerticalCardTopSection;\r\n"],"mappings":"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","ignoreList":[]}
@@ -71,6 +71,21 @@ const DropdownContentContainer = exports.DropdownContentContainer = _styledCompo
71
71
  border-radius: ${props => props.$size == _types.Size.Large ? '10px' : props.$size == _types.Size.Medium ? '8px' : '6px'};
72
72
 
73
73
  max-height: ${props => !props.$scrollable ? 'auto' : props.$maxHeight ? props.$maxHeight : props.$size == _types.Size.Large ? '320px' : props.$size == _types.Size.Medium ? '280px' : '240px'};
74
+
75
+ /* Mobile-specific responsive adjustments */
76
+ @media (max-width: 767px) {
77
+ min-width: ${props => props.$size == _types.Size.Large ? '260px' : props.$size == _types.Size.Medium ? '220px' : '180px'};
78
+ max-width: calc(100vw - 16px); /* Prevent overflow on mobile */
79
+
80
+ /* Override positioning for mobile to prevent overflow */
81
+ &.show {
82
+ &.down,
83
+ &.up {
84
+ /* Use transform only for vertical positioning on mobile */
85
+ transform: translate(0, ${props => props.$offsetTop}) !important;
86
+ }
87
+ }
88
+ }
74
89
  `;
75
90
  const DropdownContentItemsContainer = exports.DropdownContentItemsContainer = _styledComponents.default.div`
76
91
  > *:hover {
@@ -229,12 +244,32 @@ const DropdownContent = /*#__PURE__*/_react.default.forwardRef((_ref, ref) => {
229
244
  const options = customizationProps.items;
230
245
  const rect = containerRef.current.getBoundingClientRect();
231
246
  const windowHeight = window.innerHeight;
247
+ const windowWidth = window.innerWidth;
248
+
249
+ // Mobile-specific adjustments
250
+ const isMobile = windowWidth < 768;
232
251
  const menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);
233
252
  const instOffsetWithMenu = rect.top + rect.height + menuHeight;
234
253
  const up = instOffsetWithMenu >= windowHeight;
254
+
255
+ // Mobile-specific positioning
256
+ let leftOffset = alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`;
257
+ if (isMobile) {
258
+ // Ensure dropdown doesn't go off-screen on mobile
259
+ const dropdownWidth = size == _types.Size.Large ? 320 : size == _types.Size.Medium ? 280 : 240;
260
+ const rightEdge = rect.right + (alignLeft ? 0 : dropdownWidth);
261
+ if (rightEdge > windowWidth) {
262
+ leftOffset = `calc(-${rect.width}px - ${rightEdge - windowWidth + 8}px)`;
263
+ }
264
+
265
+ // If still going off-screen, align to the right edge of viewport
266
+ if (rect.left + dropdownWidth > windowWidth) {
267
+ leftOffset = `calc(-${dropdownWidth}px + ${windowWidth - rect.right}px)`;
268
+ }
269
+ }
235
270
  setOffset({
236
271
  top: up ? `calc(-100% - ${rect.height}px ${isButton ? '' : '- 8px'})` : '0',
237
- left: alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`
272
+ left: leftOffset
238
273
  });
239
274
  setIsUp(up);
240
275
  setLocationDefined(true);
@@ -539,7 +574,16 @@ const DropdownContent = /*#__PURE__*/_react.default.forwardRef((_ref, ref) => {
539
574
  const calculateOffset = () => {
540
575
  const rect = containerRef?.current?.getBoundingClientRect();
541
576
  if (rect) {
542
- dropdownContentRef.current.style.width = width ?? `${rect.width}px`;
577
+ const isMobile = window.innerWidth < 768;
578
+
579
+ // On mobile, ensure dropdown width doesn't exceed viewport
580
+ if (isMobile) {
581
+ const maxWidth = Math.min(width ? parseInt(width) : rect.width, window.innerWidth - 32 // Leave some padding
582
+ );
583
+ dropdownContentRef.current.style.width = `${maxWidth}px`;
584
+ } else {
585
+ dropdownContentRef.current.style.width = width ?? `${rect.width}px`;
586
+ }
543
587
  }
544
588
  determineDropUp();
545
589
  };
@@ -1 +1 @@
1
- {"version":3,"file":"DropdownContent.cjs","names":["_react","_interopRequireDefault","require","_styledComponents","_TextButton","_types","_CommonStyling","_typography","_styles","_InputFields","_zIndexes","_MenuItem","_jsxRuntime","MAX_MENU_HEIGHT","AVG_OPTION_HEIGHT","OFFSET_BEFORE_SHOW","DropdownContentContainer","exports","styled","div","props","COLORS","generateToken","componentType","defaultVariant","theme","Z_INDEXES","dropdown","$isButton","$offsetLeft","$offsetTop","DropdownContentButtonStyling","$size","Size","Large","Medium","$scrollable","$maxHeight","DropdownContentItemsContainer","hover","active","focus","DropdownContentListContainer","$itemsType","scrollBarStyling","Small","DropdownContentMenuContentContainer","ComponentXLStyling","ComponentTextStyle","Bold","ComponentLStyling","ComponentMStyling","Regular","ComponentSStyling","DividerContainer","DropdownContentTopItemContainer","DropdownContentActionButtonContainer","Overlay","modal","DropdownContent","React","forwardRef","_ref","ref","id","customizationProps","alignLeft","isButton","size","isOpen","width","setIsOpen","filter","focused","setFocused","selectedValues","setSelectedValues","messageOnNoResults","outline","containerRef","onActiveDescendantChanged","ariaRolesType","isUp","setIsUp","useState","locationDefined","setLocationDefined","offset","setOffset","top","left","dropdownContentRef","useRef","itemsType","itemsListRef","actionButtonRef","determineDropUp","options","items","rect","current","getBoundingClientRect","windowHeight","window","innerHeight","menuHeight","Math","min","length","instOffsetWithMenu","height","up","setNewFocusedElement","index","newFocusedElement","elRefs","oldFocusedElement","classList","remove","add","scrollIntoView","block","inline","getFilteredItems","filtrationString","toUpperCase","x","value","includes","displayLabel","findNextActiveIndex","direction","i","disabled","handleKeyDown","e","key","preventDefault","focusedNow","arrLength","haveTopItem","undefined","target","focusedElement","click","useEffect","document","addEventListener","removeEventListener","scrollPosition","handleScroll","scrollTop","useLayoutEffect","getCorrectRef","createRef","setElRefs","Array","fill","map","_","pinTopItem","multiSelect","getSuggestions","suggestion","elRef","blur","observer","IntersectionObserver","entries","isIntersecting","activeElement","threshold","rootMargin","observe","calculateOffset","disconnect","handleItemClick","selected","item","newValue","onValueUpdate","getTopItem","visibleItems","allSelected","some","y","showTopItem","suggestions","find","c","selectedFirst","jsxs","children","jsx","RadioButton","role","iconPointerEventsTransparent","onFocus","tabIndexVal","className","select","label","Checkbox","newValues","semiSelected","Fragment","default","tabIndex","onClickHandler","stopPropagation","getElements","customContent","style","cls","$alignLeft","scrollable","maxHeight","onScroll","$outline","menuContent","action","actionLabel","icon","actionIcon","loading","actionLoading","actionDisabled","variant","actionVariant","onClick","propTypes","_propTypes","bool","isRequired","shape","oneOf","node","string","func","arrayOf","noteLabel","showDividerAbove","locked","oneOfType","number","_default"],"sources":["../../src/Dropdown/DropdownContent.tsx"],"sourcesContent":["import React, { MutableRefObject, useCallback } from 'react';\r\nimport styled, { css } from 'styled-components';\r\nimport TextButton from '../Button/TextButton';\r\nimport { Size } from '../types';\r\nimport { DropdownContentButtonStyling } from './CommonStyling';\r\nimport { ComponentLStyling, ComponentXLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\nimport { COLORS, focusStyles, scrollBarStyling } from '../styles';\r\nimport { Checkbox, RadioButton } from '../InputFields';\r\nimport { Z_INDEXES } from '../styles/z-indexes';\r\nimport MenuItem from '../MenuItem/MenuItem';\r\nimport { defaultOnMouseDownHandler } from '../common';\r\n\r\nconst MAX_MENU_HEIGHT = 240;\r\nconst AVG_OPTION_HEIGHT = 48;\r\nconst OFFSET_BEFORE_SHOW = 1000000;\r\n\r\nexport const DropdownContentContainer = styled.div<{ $offsetTop: string; $offsetLeft: string; $isButton: boolean; $alignLeft?: boolean; $size?: Size; $scrollable?: boolean; $maxHeight?: string }>`\r\n display: none;\r\n pointer-events: auto;\r\n position: absolute;\r\n background-color: ${props => COLORS.generateToken({componentType:'bg-surface', defaultVariant:'default'}, props.theme)};\r\n\r\n z-index: ${Z_INDEXES.dropdown};\r\n margin: ${(props) => (props.$isButton ? '-4px' : '4px 0px')};\r\n\r\n inset: 0px auto auto 100%;\r\n\r\n &.show {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n &.down,\r\n &.up {\r\n ${(props) => `transform: translate(${props.$offsetLeft}, ${props.$offsetTop});`}\r\n }\r\n }\r\n\r\n &.outline:focus:after {\r\n content: '';\r\n pointer-events: none;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n outline: 4px solid black;\r\n outline-offset: 2px;\r\n border-radius: 2px;\r\n }\r\n\r\n &:focus {\r\n outline: none;\r\n }\r\n\r\n ${(props) => (props.$isButton ? DropdownContentButtonStyling : '')};\r\n\r\n box-sizing: border-box;\r\n box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.15);\r\n padding: 4px 0px;\r\n\r\n min-width: ${(props) => (props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n border-radius: ${(props) => (props.$size == Size.Large ? '10px' : props.$size == Size.Medium ? '8px' : '6px')};\r\n\r\n max-height: ${(props) => (!props.$scrollable ? 'auto' : props.$maxHeight ? props.$maxHeight : props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n`;\r\n\r\nexport const DropdownContentItemsContainer = styled.div<{ $size?: Size }>`\r\n > *:hover {\r\n z-index: ${Z_INDEXES.hover};\r\n }\r\n\r\n > *:active,\r\n > *.active {\r\n z-index: ${Z_INDEXES.active};\r\n }\r\n\r\n > *:focus {\r\n z-index: ${Z_INDEXES.focus};\r\n }\r\n`;\r\n\r\nexport const DropdownContentListContainer = styled.div<{ $scrollable?: boolean; $size?: Size; $itemsType?: string; $outline?: boolean }>`\r\n ${(props) => (props.$scrollable ? 'overflow-y: scroll;' : '')}\r\n ${(props) => (props.$scrollable ? 'margin-right: 6px;' : '')}\r\n ${(props) => (props.$scrollable ? 'padding-right: 6px;' : '')}\r\n ${(props) => (props.$itemsType != 'normal' ? 'margin-left: 4px;' : '')}\r\n div.divider {\r\n display: block;\r\n width: calc(100% - 40px);\r\n margin-left: 16px;\r\n border-top: 1px solid #e5e5e5;\r\n position: absolute;\r\n top: 0px;\r\n }\r\n\r\n ${DropdownContentItemsContainer} {\r\n padding-top: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n padding-bottom: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n\r\n word-break: break-word;\r\n }\r\n\r\n *:focus {\r\n outline: none !important;\r\n }\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n`;\r\n\r\nconst DropdownContentMenuContentContainer = styled.div<{ $size?: Size }>`\r\n h1,\r\n h2,\r\n h3 {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentXLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentMStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '10px 16px 6px' : props.$size == Size.Medium ? '16px 24px 8px' : '16px 32px 8px')};\r\n }\r\n\r\n p {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentLStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '8px 16px' : props.$size == Size.Medium ? '12px 24px' : '16px 32px')};\r\n }\r\n`;\r\n\r\nconst DividerContainer = styled.div<{ $size?: Size }>`\r\n position: relative;\r\n\r\n margin-top: ${(props) => (props.$size == Size.Large ? '16px' : props.$size == Size.Medium ? '12px' : props.$size == Size.Small || !props.$size ? '8px' : '6px')};\r\n\r\n div.divider {\r\n width: 100%;\r\n margin: 0px;\r\n }\r\n`;\r\n\r\nconst DropdownContentTopItemContainer = styled.div<{ $size?: Size }>`\r\n border-bottom-style: solid;\r\n border-bottom-color: ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n border-bottom-width: 1px;\r\n margin-right: 22px;\r\n`;\r\n\r\nconst DropdownContentActionButtonContainer = styled.div<{ $size?: Size; $scrollable?: boolean }>`\r\n ${(props) => (props.$scrollable ? `border-top: 1px solid ${COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};` : '')}\r\n ${(props) => (props.$scrollable ? 'margin-top: 4px;' : '')}\r\n\r\n padding: ${(props) => (props.$size === Size.Small || !props.$size ? '4px 16px 0px' : props.$size === Size.Medium ? '12px 16px 8px' : '16px 16px 12px')};\r\n\r\n button {\r\n width: 100%;\r\n }\r\n`;\r\n\r\nconst Overlay = styled.div`\r\n position: relative;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n pointer-events: none;\r\n z-index: ${Z_INDEXES.modal};\r\n`;\r\n\r\nexport interface DropdownItem {\r\n /** Required. Value of the DropdownItem. */\r\n value: string;\r\n /** Optional. Display label to show in the MenuItem. If not provided then 'value' will be used as label. */\r\n displayLabel?: string;\r\n /** Optional. Note label to be shown under the Display label in the MenuItem. */\r\n noteLabel?: string;\r\n /** */\r\n suggestion?: boolean;\r\n /** Optional. Show dividing line on the top of the item. */\r\n showDividerAbove?: boolean;\r\n /** Optional. If disabled user can not interact with the item. */\r\n disabled?: boolean;\r\n /** Optional. If item is locked then user can not interact with the item and 'lock' icon is shown on the right side of the item. */\r\n locked?: boolean;\r\n /** Optional. Icon to be shown on the left side of the menu item */\r\n icon?: React.ReactNode;\r\n /** */\r\n customContent?: React.ReactNode;\r\n}\r\n\r\nexport interface DropdownCustomizationProps {\r\n itemsType?: 'radio' | 'checkbox' | 'normal';\r\n menuContent?: React.ReactNode;\r\n scrollable?: boolean;\r\n multiSelect?: boolean;\r\n maxHeight?: string;\r\n actionLabel?: string;\r\n actionVariant?: 'primary' | 'secondary' | 'tertiary' | undefined;\r\n actionIcon?: React.ReactNode;\r\n actionLoading?: boolean;\r\n actionDisabled?: boolean;\r\n action: () => boolean | void | undefined;\r\n pinTopItem?: boolean;\r\n onValueUpdate: (values: string[]) => boolean | void | undefined;\r\n items: DropdownItem[];\r\n}\r\n\r\nexport interface DropdownProps {\r\n isButton: boolean;\r\n customizationProps: DropdownCustomizationProps;\r\n alignLeft?: boolean;\r\n isOpen: boolean;\r\n setIsOpen: (open: boolean) => void;\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n id: string;\r\n filter: string;\r\n width?: string;\r\n onActiveDescendantChanged?: (descendantId?: string) => void;\r\n selectedValues: string[];\r\n setSelectedValues: (val: string[]) => void;\r\n messageOnNoResults: string;\r\n focused: number | null;\r\n setFocused: (focused: number | null) => void;\r\n outline?: boolean;\r\n containerRef: React.RefObject<HTMLDivElement | null>;\r\n ariaRolesType?: 'input' | 'menu';\r\n}\r\n\r\nconst DropdownContent = React.forwardRef<HTMLDivElement, DropdownProps>(\r\n (\r\n {\r\n id,\r\n customizationProps,\r\n alignLeft,\r\n isButton,\r\n size,\r\n isOpen,\r\n width,\r\n setIsOpen,\r\n filter,\r\n focused,\r\n setFocused,\r\n selectedValues,\r\n setSelectedValues,\r\n messageOnNoResults,\r\n outline,\r\n containerRef,\r\n onActiveDescendantChanged,\r\n ariaRolesType = 'menu',\r\n },\r\n ref,\r\n ) => {\r\n const [isUp, setIsUp] = React.useState<boolean>(false);\r\n const [locationDefined, setLocationDefined] = React.useState<boolean>(false);\r\n const [offset, setOffset] = React.useState<{ top: string; left: string }>({ top: '0', left: '0' });\r\n\r\n const dropdownContentRef = (ref as MutableRefObject<HTMLDivElement>) ?? React.useRef<HTMLDivElement>(null);\r\n\r\n if (!customizationProps.itemsType) customizationProps.itemsType = 'normal';\r\n if (!size) size = Size.Small;\r\n\r\n const itemsListRef = React.useRef<HTMLDivElement>(null);\r\n const actionButtonRef = React.useRef<HTMLButtonElement>(null);\r\n\r\n const determineDropUp = () => {\r\n const options = customizationProps.items;\r\n\r\n const rect = containerRef.current!.getBoundingClientRect();\r\n\r\n const windowHeight = window.innerHeight;\r\n const menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);\r\n const instOffsetWithMenu = rect.top + rect.height + menuHeight;\r\n\r\n const up = instOffsetWithMenu >= windowHeight;\r\n\r\n setOffset({\r\n top: up ? `calc(-100% - ${rect.height}px ${isButton ? '' : '- 8px'})` : '0',\r\n left: alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`,\r\n });\r\n\r\n setIsUp(up);\r\n setLocationDefined(true);\r\n };\r\n\r\n const setNewFocusedElement = (index: number) => {\r\n if (outline) dropdownContentRef.current?.focus();\r\n\r\n const newFocusedElement = elRefs[index];\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(index == 0 ? `${id}_topitem` : `${id}_${index}`);\r\n\r\n const oldFocusedElement = focused || focused === 0 ? elRefs[focused] : null;\r\n if (newFocusedElement && newFocusedElement !== oldFocusedElement) {\r\n setFocused(index);\r\n oldFocusedElement?.current?.classList.remove('dropdown-hover');\r\n\r\n newFocusedElement.current?.classList.add('dropdown-hover');\r\n newFocusedElement.current?.scrollIntoView({\r\n block: 'nearest',\r\n inline: 'nearest',\r\n });\r\n }\r\n };\r\n\r\n const getFilteredItems = () => {\r\n const filtrationString = (filter ?? '').toUpperCase();\r\n return customizationProps.items.filter((x) => x?.value?.toUpperCase().includes(filtrationString) || x?.displayLabel?.toUpperCase().includes(filtrationString));\r\n };\r\n\r\n const findNextActiveIndex = (index: number, direction: number, items: DropdownItem[]) => {\r\n for (let i = index + direction; i > 0 && i <= items.length; i += direction) {\r\n if (!items[i - 1]?.disabled) {\r\n return i;\r\n }\r\n }\r\n\r\n return index;\r\n };\r\n\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (isOpen) {\r\n if (e.key === 'ArrowUp' || e.key === 'Up') {\r\n e.preventDefault();\r\n let focusedNow = focused || focused === 0 ? focused : arrLength + 1;\r\n if (!!focusedNow) {\r\n focusedNow = focusedNow === 1 && haveTopItem() ? 0 : findNextActiveIndex(focusedNow, -1, getFilteredItems());\r\n\r\n setNewFocusedElement(focusedNow);\r\n }\r\n } else if (e.key === 'ArrowDown' || e.key === 'Down') {\r\n e.preventDefault();\r\n let focusedNow = focused;\r\n\r\n focusedNow = !!focusedNow || focusedNow === 0 ? findNextActiveIndex(focusedNow, 1, getFilteredItems()) : haveTopItem() ? 0 : 1;\r\n\r\n setNewFocusedElement(focusedNow);\r\n } else if (e.key === 'Escape' || e.key === 'Esc') {\r\n setIsOpen(false);\r\n setFocused(null);\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n } else if ((e.key === 'Enter' || e.key === ' ') && focused !== null && e.target !== actionButtonRef?.current) {\r\n e.preventDefault();\r\n const focusedElement = elRefs[focused];\r\n if (focusedElement) {\r\n focusedElement.current?.click();\r\n }\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n }\r\n }\r\n };\r\n\r\n React.useEffect(() => {\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => {\r\n document.removeEventListener('keydown', handleKeyDown);\r\n };\r\n });\r\n\r\n const scrollPosition = React.useRef<number | undefined>(0);\r\n const handleScroll = () => {\r\n scrollPosition.current = itemsListRef.current?.scrollTop;\r\n };\r\n React.useLayoutEffect(() => {\r\n if (itemsListRef.current) itemsListRef.current.scrollTop = scrollPosition.current ?? 0;\r\n }, [selectedValues]);\r\n\r\n const getCorrectRef = (ref: React.RefObject<HTMLElement | null>): React.RefObject<HTMLElement | null> => {\r\n switch (customizationProps.itemsType) {\r\n case 'normal':\r\n return (ref as React.RefObject<HTMLButtonElement | null>) || React.createRef<HTMLButtonElement>();\r\n default:\r\n return (ref as React.RefObject<HTMLDivElement | null>) || React.createRef<HTMLDivElement>();\r\n }\r\n };\r\n\r\n const arrLength = getFilteredItems().length;\r\n const [elRefs, setElRefs] = React.useState<React.RefObject<HTMLElement | null>[]>([]);\r\n\r\n React.useEffect(() => {\r\n if (elRefs?.length !== arrLength) {\r\n setFocused(null);\r\n }\r\n\r\n setElRefs((elRefs) =>\r\n Array(arrLength + 1)\r\n .fill(null)\r\n .map((_, i) => getCorrectRef(elRefs[i])),\r\n );\r\n }, [isOpen, arrLength]);\r\n\r\n React.useLayoutEffect(() => {\r\n isOpen && !locationDefined && determineDropUp();\r\n }, [isOpen, locationDefined]);\r\n\r\n const haveTopItem = () => {\r\n if (!customizationProps.pinTopItem) return false;\r\n\r\n if (customizationProps.itemsType === 'radio' && selectedValues && selectedValues?.length > 0) return true;\r\n else if (customizationProps.itemsType === 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) return true;\r\n else if (customizationProps.itemsType === 'normal' && getSuggestions()?.length > 0) return true;\r\n return false;\r\n };\r\n\r\n const getSuggestions = () => {\r\n return getFilteredItems().filter((x) => x.suggestion);\r\n };\r\n\r\n /**\r\n * when dropdown opens set correct position of focused item\r\n * */\r\n React.useLayoutEffect(() => {\r\n if (isOpen && (focused || focused === 0)) {\r\n setNewFocusedElement(focused === 0 && !haveTopItem() ? 1 : focused);\r\n }\r\n }, [isOpen, focused]);\r\n\r\n /**\r\n * Reset dropdown content state on close\r\n * */\r\n React.useEffect(() => {\r\n if (!isOpen) {\r\n setLocationDefined(false);\r\n for (let elRef of elRefs) {\r\n elRef.current?.classList.remove('dropdown-hover');\r\n }\r\n setFocused(null);\r\n if(onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n dropdownContentRef.current?.classList.remove('outline');\r\n dropdownContentRef.current?.blur();\r\n } else {\r\n if (outline) {\r\n dropdownContentRef.current?.classList.add('outline');\r\n dropdownContentRef.current?.focus();\r\n }\r\n }\r\n }, [isOpen, dropdownContentRef, focused, outline]);\r\n\r\n /**\r\n * Scroll item container to top when dropdown opens\r\n * */\r\n React.useEffect(() => {\r\n if (isOpen && itemsListRef.current) {\r\n itemsListRef.current.scrollTop = 0;\r\n }\r\n }, [isOpen]);\r\n\r\n React.useEffect(() => {\r\n if (isOpen) {\r\n const observer = new IntersectionObserver(function (entries) {\r\n if (!entries[0].isIntersecting) {\r\n setIsOpen(false);\r\n //@ts-ignore\r\n document?.activeElement?.blur();\r\n }\r\n }, {threshold: [0], rootMargin: '8px'});\r\n\r\n observer.observe(containerRef.current!);\r\n\r\n calculateOffset();\r\n window.addEventListener('scroll', calculateOffset, true);\r\n window.addEventListener('resize', calculateOffset);\r\n\r\n return () => {\r\n observer.disconnect();\r\n window.removeEventListener('scroll', calculateOffset, true);\r\n window.removeEventListener('resize', calculateOffset);\r\n }\r\n }\r\n return () => {};\r\n }, [isOpen]);\r\n\r\n const handleItemClick = (selected: boolean, item: DropdownItem) => {\r\n let newValue: string[] = [];\r\n if (customizationProps.multiSelect) {\r\n if (selected) newValue = [...selectedValues, item.value];\r\n else newValue = selectedValues.filter((x) => x != item.value);\r\n } else newValue = selected ? [item.value] : [];\r\n\r\n setSelectedValues(newValue);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValue)) {\r\n setIsOpen(false);\r\n }\r\n };\r\n\r\n const getTopItem = () => {\r\n if (!customizationProps.pinTopItem) return;\r\n const visibleItems = getFilteredItems();\r\n const allSelected = selectedValues?.filter((x) => visibleItems.some((y) => y.value == x)).length == visibleItems.length;\r\n let showTopItem = false;\r\n const suggestions = getSuggestions();\r\n const displayLabel = selectedValues[0] ? customizationProps.items?.find((c) => c.value === selectedValues[0])?.displayLabel : undefined;\r\n if (customizationProps.itemsType == 'radio' && selectedValues && selectedValues?.length > 0) showTopItem = true;\r\n else if (customizationProps.itemsType == 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) showTopItem = true;\r\n else if (customizationProps.itemsType == 'normal' && suggestions.length > 0) showTopItem = true;\r\n\r\n if (!showTopItem) return;\r\n\r\n const selectedFirst = selectedValues.length > 0 ? visibleItems.find((x) => x.value == selectedValues[0]) : null;\r\n\r\n return (\r\n <DropdownContentTopItemContainer $size={size}>\r\n {customizationProps.itemsType === 'radio' && (\r\n <RadioButton\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemradio'\r\n iconPointerEventsTransparent={true}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={() => {}}\r\n label={selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n size={size}\r\n id={`${id}_topitem`}\r\n selected={true}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'checkbox' && (\r\n <Checkbox\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemcheckbox'\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={(selected: boolean) => {\r\n if (!customizationProps.multiSelect) return;\r\n\r\n const newValues = selected ? visibleItems.map((x) => x.value) : [];\r\n setSelectedValues(newValues);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValues)) setIsOpen(false);\r\n }}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n iconPointerEventsTransparent={true}\r\n semiSelected={customizationProps.multiSelect && !allSelected && selectedValues?.length > 0}\r\n size={size}\r\n id={`${id}_checkbox_selectall`}\r\n label={customizationProps.multiSelect ? 'Select all' : selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n selected={!customizationProps.multiSelect || allSelected}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'normal' && (\r\n <>\r\n {suggestions.map((x) => (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`${id}_topitem_${x.value}`}\r\n item={x}\r\n size={size}\r\n active={false}\r\n tabIndex={-1}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[0] as React.RefObject<HTMLButtonElement | null>}\r\n id={`${id}_topitem`}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([x.value]);\r\n setSelectedValues([x.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n ))}\r\n </>\r\n )}\r\n </DropdownContentTopItemContainer>\r\n );\r\n };\r\n\r\n const getElements = (messageOnNoResults: string, size: Size.Small | Size.Medium | Size.Large) => {\r\n if (getFilteredItems().length === 0) {\r\n return <MenuItem item={{ value: messageOnNoResults, disabled: true }} size={size} id=\"noResultsFound\" active={false} onClickHandler={(e) => {}} />;\r\n }\r\n return (\r\n <DropdownContentItemsContainer $size={size}>\r\n {getFilteredItems()\r\n .filter((x) => x && (customizationProps.itemsType != 'normal' || !x.suggestion))\r\n .map((item, index) => {\r\n return (\r\n <React.Fragment key={`key_${id}_${item.value}`}>\r\n {item.customContent}\r\n {!item.customContent && customizationProps.itemsType == 'radio' && (\r\n <RadioButton\r\n role='menuitemradio'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && customizationProps.itemsType == 'checkbox' && (\r\n <Checkbox\r\n role='menuitemcheckbox'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && (customizationProps.itemsType == 'normal' || !customizationProps.itemsType) && (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`key_${id}_${index + 1}`}\r\n id={`${id}_${index + 1}`}\r\n item={item}\r\n tabIndex={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n size={size}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n active={selectedValues?.includes(item.value)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLButtonElement | null>}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([item.value]);\r\n setSelectedValues([item.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n )}\r\n </React.Fragment>\r\n );\r\n })}\r\n </DropdownContentItemsContainer>\r\n );\r\n };\r\n\r\n const calculateOffset = () => {\r\n const rect = containerRef?.current?.getBoundingClientRect();\r\n if (rect) {\r\n dropdownContentRef.current.style.width = width ?? `${rect.width}px`;\r\n }\r\n determineDropUp();\r\n };\r\n\r\n const cls = `${isOpen ? 'show' : ''} ${isOpen && outline ? 'outline' : ''} ${locationDefined ? (isUp ? 'up' : 'down') : ''}`;\r\n\r\n return (\r\n <Overlay>\r\n <DropdownContentContainer\r\n role={ariaRolesType == \"menu\" ? \"menu\" : \"optionlist\"}\r\n ref={dropdownContentRef}\r\n $size={size}\r\n $offsetTop={offset.top}\r\n id={id}\r\n $offsetLeft={offset.left}\r\n tabIndex={-1}\r\n $isButton={isButton}\r\n $alignLeft={alignLeft}\r\n $scrollable={customizationProps.scrollable}\r\n $maxHeight={customizationProps.maxHeight}\r\n className={cls}>\r\n <DropdownContentListContainer\r\n tabIndex={-1}\r\n role=\"group\"\r\n $size={size}\r\n $itemsType={customizationProps.itemsType}\r\n onScroll={handleScroll}\r\n ref={itemsListRef}\r\n $outline={outline}\r\n $scrollable={customizationProps.scrollable}>\r\n {customizationProps.menuContent && (\r\n <DropdownContentMenuContentContainer $size={size}>\r\n {customizationProps.menuContent}\r\n <DividerContainer $size={size}>\r\n <div className=\"divider\" />\r\n </DividerContainer>\r\n </DropdownContentMenuContentContainer>\r\n )}\r\n {customizationProps.pinTopItem && getTopItem()}\r\n {getElements(messageOnNoResults, size)}\r\n </DropdownContentListContainer>\r\n {customizationProps.action && customizationProps.actionLabel && (\r\n <DropdownContentActionButtonContainer $size={size} $scrollable={customizationProps.scrollable}>\r\n <TextButton\r\n width=\"100%\"\r\n role=\"menuitem\"\r\n icon={customizationProps.actionIcon}\r\n ref={actionButtonRef}\r\n loading={customizationProps.actionLoading}\r\n disabled={customizationProps.actionDisabled}\r\n variant={customizationProps.actionVariant ?? 'primary'}\r\n size={size}\r\n onClick={() => customizationProps.action() && setIsOpen(false)}>\r\n {customizationProps.actionLabel}\r\n </TextButton>\r\n </DropdownContentActionButtonContainer>\r\n )}\r\n </DropdownContentContainer>\r\n </Overlay>\r\n );\r\n },\r\n);\r\n\r\nexport default DropdownContent;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"DropdownContent.cjs","names":["_react","_interopRequireDefault","require","_styledComponents","_TextButton","_types","_CommonStyling","_typography","_styles","_InputFields","_zIndexes","_MenuItem","_jsxRuntime","MAX_MENU_HEIGHT","AVG_OPTION_HEIGHT","OFFSET_BEFORE_SHOW","DropdownContentContainer","exports","styled","div","props","COLORS","generateToken","componentType","defaultVariant","theme","Z_INDEXES","dropdown","$isButton","$offsetLeft","$offsetTop","DropdownContentButtonStyling","$size","Size","Large","Medium","$scrollable","$maxHeight","DropdownContentItemsContainer","hover","active","focus","DropdownContentListContainer","$itemsType","scrollBarStyling","Small","DropdownContentMenuContentContainer","ComponentXLStyling","ComponentTextStyle","Bold","ComponentLStyling","ComponentMStyling","Regular","ComponentSStyling","DividerContainer","DropdownContentTopItemContainer","DropdownContentActionButtonContainer","Overlay","modal","DropdownContent","React","forwardRef","_ref","ref","id","customizationProps","alignLeft","isButton","size","isOpen","width","setIsOpen","filter","focused","setFocused","selectedValues","setSelectedValues","messageOnNoResults","outline","containerRef","onActiveDescendantChanged","ariaRolesType","isUp","setIsUp","useState","locationDefined","setLocationDefined","offset","setOffset","top","left","dropdownContentRef","useRef","itemsType","itemsListRef","actionButtonRef","determineDropUp","options","items","rect","current","getBoundingClientRect","windowHeight","window","innerHeight","windowWidth","innerWidth","isMobile","menuHeight","Math","min","length","instOffsetWithMenu","height","up","leftOffset","dropdownWidth","rightEdge","right","setNewFocusedElement","index","newFocusedElement","elRefs","oldFocusedElement","classList","remove","add","scrollIntoView","block","inline","getFilteredItems","filtrationString","toUpperCase","x","value","includes","displayLabel","findNextActiveIndex","direction","i","disabled","handleKeyDown","e","key","preventDefault","focusedNow","arrLength","haveTopItem","undefined","target","focusedElement","click","useEffect","document","addEventListener","removeEventListener","scrollPosition","handleScroll","scrollTop","useLayoutEffect","getCorrectRef","createRef","setElRefs","Array","fill","map","_","pinTopItem","multiSelect","getSuggestions","suggestion","elRef","blur","observer","IntersectionObserver","entries","isIntersecting","activeElement","threshold","rootMargin","observe","calculateOffset","disconnect","handleItemClick","selected","item","newValue","onValueUpdate","getTopItem","visibleItems","allSelected","some","y","showTopItem","suggestions","find","c","selectedFirst","jsxs","children","jsx","RadioButton","role","iconPointerEventsTransparent","onFocus","tabIndexVal","className","select","label","Checkbox","newValues","semiSelected","Fragment","default","tabIndex","onClickHandler","stopPropagation","getElements","customContent","maxWidth","parseInt","style","cls","$alignLeft","scrollable","maxHeight","onScroll","$outline","menuContent","action","actionLabel","icon","actionIcon","loading","actionLoading","actionDisabled","variant","actionVariant","onClick","propTypes","_propTypes","bool","isRequired","shape","oneOf","node","string","func","arrayOf","noteLabel","showDividerAbove","locked","oneOfType","number","_default"],"sources":["../../src/Dropdown/DropdownContent.tsx"],"sourcesContent":["import React, { MutableRefObject, useCallback } from 'react';\r\nimport styled, { css } from 'styled-components';\r\nimport TextButton from '../Button/TextButton';\r\nimport { Size } from '../types';\r\nimport { DropdownContentButtonStyling } from './CommonStyling';\r\nimport { ComponentLStyling, ComponentXLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\nimport { COLORS, focusStyles, scrollBarStyling } from '../styles';\r\nimport { Checkbox, RadioButton } from '../InputFields';\r\nimport { Z_INDEXES } from '../styles/z-indexes';\r\nimport MenuItem from '../MenuItem/MenuItem';\r\nimport { defaultOnMouseDownHandler } from '../common';\r\n\r\nconst MAX_MENU_HEIGHT = 240;\r\nconst AVG_OPTION_HEIGHT = 48;\r\nconst OFFSET_BEFORE_SHOW = 1000000;\r\n\r\nexport const DropdownContentContainer = styled.div<{ $offsetTop: string; $offsetLeft: string; $isButton: boolean; $alignLeft?: boolean; $size?: Size; $scrollable?: boolean; $maxHeight?: string }>`\r\n display: none;\r\n pointer-events: auto;\r\n position: absolute;\r\n background-color: ${props => COLORS.generateToken({componentType:'bg-surface', defaultVariant:'default'}, props.theme)};\r\n\r\n z-index: ${Z_INDEXES.dropdown};\r\n margin: ${(props) => (props.$isButton ? '-4px' : '4px 0px')};\r\n\r\n inset: 0px auto auto 100%;\r\n\r\n &.show {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n &.down,\r\n &.up {\r\n ${(props) => `transform: translate(${props.$offsetLeft}, ${props.$offsetTop});`}\r\n }\r\n }\r\n\r\n &.outline:focus:after {\r\n content: '';\r\n pointer-events: none;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n outline: 4px solid black;\r\n outline-offset: 2px;\r\n border-radius: 2px;\r\n }\r\n\r\n &:focus {\r\n outline: none;\r\n }\r\n\r\n ${(props) => (props.$isButton ? DropdownContentButtonStyling : '')};\r\n\r\n box-sizing: border-box;\r\n box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.15);\r\n padding: 4px 0px;\r\n\r\n min-width: ${(props) => (props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n border-radius: ${(props) => (props.$size == Size.Large ? '10px' : props.$size == Size.Medium ? '8px' : '6px')};\r\n\r\n max-height: ${(props) => (!props.$scrollable ? 'auto' : props.$maxHeight ? props.$maxHeight : props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n\r\n /* Mobile-specific responsive adjustments */\r\n @media (max-width: 767px) {\r\n min-width: ${(props) => (props.$size == Size.Large ? '260px' : props.$size == Size.Medium ? '220px' : '180px')};\r\n max-width: calc(100vw - 16px); /* Prevent overflow on mobile */\r\n \r\n /* Override positioning for mobile to prevent overflow */\r\n &.show {\r\n &.down,\r\n &.up {\r\n /* Use transform only for vertical positioning on mobile */\r\n transform: translate(0, ${props => props.$offsetTop}) !important;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nexport const DropdownContentItemsContainer = styled.div<{ $size?: Size }>`\r\n > *:hover {\r\n z-index: ${Z_INDEXES.hover};\r\n }\r\n\r\n > *:active,\r\n > *.active {\r\n z-index: ${Z_INDEXES.active};\r\n }\r\n\r\n > *:focus {\r\n z-index: ${Z_INDEXES.focus};\r\n }\r\n`;\r\n\r\nexport const DropdownContentListContainer = styled.div<{ $scrollable?: boolean; $size?: Size; $itemsType?: string; $outline?: boolean }>`\r\n ${(props) => (props.$scrollable ? 'overflow-y: scroll;' : '')}\r\n ${(props) => (props.$scrollable ? 'margin-right: 6px;' : '')}\r\n ${(props) => (props.$scrollable ? 'padding-right: 6px;' : '')}\r\n ${(props) => (props.$itemsType != 'normal' ? 'margin-left: 4px;' : '')}\r\n div.divider {\r\n display: block;\r\n width: calc(100% - 40px);\r\n margin-left: 16px;\r\n border-top: 1px solid #e5e5e5;\r\n position: absolute;\r\n top: 0px;\r\n }\r\n\r\n ${DropdownContentItemsContainer} {\r\n padding-top: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n padding-bottom: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n\r\n word-break: break-word;\r\n }\r\n\r\n *:focus {\r\n outline: none !important;\r\n }\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n`;\r\n\r\nconst DropdownContentMenuContentContainer = styled.div<{ $size?: Size }>`\r\n h1,\r\n h2,\r\n h3 {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentXLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentMStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '10px 16px 6px' : props.$size == Size.Medium ? '16px 24px 8px' : '16px 32px 8px')};\r\n }\r\n\r\n p {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentLStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '8px 16px' : props.$size == Size.Medium ? '12px 24px' : '16px 32px')};\r\n }\r\n`;\r\n\r\nconst DividerContainer = styled.div<{ $size?: Size }>`\r\n position: relative;\r\n\r\n margin-top: ${(props) => (props.$size == Size.Large ? '16px' : props.$size == Size.Medium ? '12px' : props.$size == Size.Small || !props.$size ? '8px' : '6px')};\r\n\r\n div.divider {\r\n width: 100%;\r\n margin: 0px;\r\n }\r\n`;\r\n\r\nconst DropdownContentTopItemContainer = styled.div<{ $size?: Size }>`\r\n border-bottom-style: solid;\r\n border-bottom-color: ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n border-bottom-width: 1px;\r\n margin-right: 22px;\r\n`;\r\n\r\nconst DropdownContentActionButtonContainer = styled.div<{ $size?: Size; $scrollable?: boolean }>`\r\n ${(props) => (props.$scrollable ? `border-top: 1px solid ${COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};` : '')}\r\n ${(props) => (props.$scrollable ? 'margin-top: 4px;' : '')}\r\n\r\n padding: ${(props) => (props.$size === Size.Small || !props.$size ? '4px 16px 0px' : props.$size === Size.Medium ? '12px 16px 8px' : '16px 16px 12px')};\r\n\r\n button {\r\n width: 100%;\r\n }\r\n`;\r\n\r\nconst Overlay = styled.div`\r\n position: relative;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n pointer-events: none;\r\n z-index: ${Z_INDEXES.modal};\r\n`;\r\n\r\nexport interface DropdownItem {\r\n /** Required. Value of the DropdownItem. */\r\n value: string;\r\n /** Optional. Display label to show in the MenuItem. If not provided then 'value' will be used as label. */\r\n displayLabel?: string;\r\n /** Optional. Note label to be shown under the Display label in the MenuItem. */\r\n noteLabel?: string;\r\n /** */\r\n suggestion?: boolean;\r\n /** Optional. Show dividing line on the top of the item. */\r\n showDividerAbove?: boolean;\r\n /** Optional. If disabled user can not interact with the item. */\r\n disabled?: boolean;\r\n /** Optional. If item is locked then user can not interact with the item and 'lock' icon is shown on the right side of the item. */\r\n locked?: boolean;\r\n /** Optional. Icon to be shown on the left side of the menu item */\r\n icon?: React.ReactNode;\r\n /** */\r\n customContent?: React.ReactNode;\r\n}\r\n\r\nexport interface DropdownCustomizationProps {\r\n itemsType?: 'radio' | 'checkbox' | 'normal';\r\n menuContent?: React.ReactNode;\r\n scrollable?: boolean;\r\n multiSelect?: boolean;\r\n maxHeight?: string;\r\n actionLabel?: string;\r\n actionVariant?: 'primary' | 'secondary' | 'tertiary' | undefined;\r\n actionIcon?: React.ReactNode;\r\n actionLoading?: boolean;\r\n actionDisabled?: boolean;\r\n action: () => boolean | void | undefined;\r\n pinTopItem?: boolean;\r\n onValueUpdate: (values: string[]) => boolean | void | undefined;\r\n items: DropdownItem[];\r\n}\r\n\r\nexport interface DropdownProps {\r\n isButton: boolean;\r\n customizationProps: DropdownCustomizationProps;\r\n alignLeft?: boolean;\r\n isOpen: boolean;\r\n setIsOpen: (open: boolean) => void;\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n id: string;\r\n filter: string;\r\n width?: string;\r\n onActiveDescendantChanged?: (descendantId?: string) => void;\r\n selectedValues: string[];\r\n setSelectedValues: (val: string[]) => void;\r\n messageOnNoResults: string;\r\n focused: number | null;\r\n setFocused: (focused: number | null) => void;\r\n outline?: boolean;\r\n containerRef: React.RefObject<HTMLDivElement | null>;\r\n ariaRolesType?: 'input' | 'menu';\r\n}\r\n\r\nconst DropdownContent = React.forwardRef<HTMLDivElement, DropdownProps>(\r\n (\r\n {\r\n id,\r\n customizationProps,\r\n alignLeft,\r\n isButton,\r\n size,\r\n isOpen,\r\n width,\r\n setIsOpen,\r\n filter,\r\n focused,\r\n setFocused,\r\n selectedValues,\r\n setSelectedValues,\r\n messageOnNoResults,\r\n outline,\r\n containerRef,\r\n onActiveDescendantChanged,\r\n ariaRolesType = 'menu',\r\n },\r\n ref,\r\n ) => {\r\n const [isUp, setIsUp] = React.useState<boolean>(false);\r\n const [locationDefined, setLocationDefined] = React.useState<boolean>(false);\r\n const [offset, setOffset] = React.useState<{ top: string; left: string }>({ top: '0', left: '0' });\r\n\r\n const dropdownContentRef = (ref as MutableRefObject<HTMLDivElement>) ?? React.useRef<HTMLDivElement>(null);\r\n\r\n if (!customizationProps.itemsType) customizationProps.itemsType = 'normal';\r\n if (!size) size = Size.Small;\r\n\r\n const itemsListRef = React.useRef<HTMLDivElement>(null);\r\n const actionButtonRef = React.useRef<HTMLButtonElement>(null);\r\n\r\n const determineDropUp = () => {\r\n const options = customizationProps.items;\r\n\r\n const rect = containerRef.current!.getBoundingClientRect();\r\n\r\n const windowHeight = window.innerHeight;\r\n const windowWidth = window.innerWidth;\r\n \r\n // Mobile-specific adjustments\r\n const isMobile = windowWidth < 768;\r\n const menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);\r\n const instOffsetWithMenu = rect.top + rect.height + menuHeight;\r\n\r\n const up = instOffsetWithMenu >= windowHeight;\r\n\r\n // Mobile-specific positioning\r\n let leftOffset = alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`;\r\n \r\n if (isMobile) {\r\n // Ensure dropdown doesn't go off-screen on mobile\r\n const dropdownWidth = size == Size.Large ? 320 : size == Size.Medium ? 280 : 240;\r\n const rightEdge = rect.right + (alignLeft ? 0 : dropdownWidth);\r\n if (rightEdge > windowWidth) {\r\n leftOffset = `calc(-${rect.width}px - ${rightEdge - windowWidth + 8}px)`;\r\n }\r\n \r\n // If still going off-screen, align to the right edge of viewport\r\n if (rect.left + dropdownWidth > windowWidth) {\r\n leftOffset = `calc(-${dropdownWidth}px + ${windowWidth - rect.right}px)`;\r\n }\r\n }\r\n\r\n setOffset({\r\n top: up ? `calc(-100% - ${rect.height}px ${isButton ? '' : '- 8px'})` : '0',\r\n left: leftOffset,\r\n });\r\n\r\n setIsUp(up);\r\n setLocationDefined(true);\r\n };\r\n\r\n const setNewFocusedElement = (index: number) => {\r\n if (outline) dropdownContentRef.current?.focus();\r\n\r\n const newFocusedElement = elRefs[index];\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(index == 0 ? `${id}_topitem` : `${id}_${index}`);\r\n\r\n const oldFocusedElement = focused || focused === 0 ? elRefs[focused] : null;\r\n if (newFocusedElement && newFocusedElement !== oldFocusedElement) {\r\n setFocused(index);\r\n oldFocusedElement?.current?.classList.remove('dropdown-hover');\r\n\r\n newFocusedElement.current?.classList.add('dropdown-hover');\r\n newFocusedElement.current?.scrollIntoView({\r\n block: 'nearest',\r\n inline: 'nearest',\r\n });\r\n }\r\n };\r\n\r\n const getFilteredItems = () => {\r\n const filtrationString = (filter ?? '').toUpperCase();\r\n return customizationProps.items.filter((x) => x?.value?.toUpperCase().includes(filtrationString) || x?.displayLabel?.toUpperCase().includes(filtrationString));\r\n };\r\n\r\n const findNextActiveIndex = (index: number, direction: number, items: DropdownItem[]) => {\r\n for (let i = index + direction; i > 0 && i <= items.length; i += direction) {\r\n if (!items[i - 1]?.disabled) {\r\n return i;\r\n }\r\n }\r\n\r\n return index;\r\n };\r\n\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (isOpen) {\r\n if (e.key === 'ArrowUp' || e.key === 'Up') {\r\n e.preventDefault();\r\n let focusedNow = focused || focused === 0 ? focused : arrLength + 1;\r\n if (!!focusedNow) {\r\n focusedNow = focusedNow === 1 && haveTopItem() ? 0 : findNextActiveIndex(focusedNow, -1, getFilteredItems());\r\n\r\n setNewFocusedElement(focusedNow);\r\n }\r\n } else if (e.key === 'ArrowDown' || e.key === 'Down') {\r\n e.preventDefault();\r\n let focusedNow = focused;\r\n\r\n focusedNow = !!focusedNow || focusedNow === 0 ? findNextActiveIndex(focusedNow, 1, getFilteredItems()) : haveTopItem() ? 0 : 1;\r\n\r\n setNewFocusedElement(focusedNow);\r\n } else if (e.key === 'Escape' || e.key === 'Esc') {\r\n setIsOpen(false);\r\n setFocused(null);\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n } else if ((e.key === 'Enter' || e.key === ' ') && focused !== null && e.target !== actionButtonRef?.current) {\r\n e.preventDefault();\r\n const focusedElement = elRefs[focused];\r\n if (focusedElement) {\r\n focusedElement.current?.click();\r\n }\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n }\r\n }\r\n };\r\n\r\n React.useEffect(() => {\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => {\r\n document.removeEventListener('keydown', handleKeyDown);\r\n };\r\n });\r\n\r\n const scrollPosition = React.useRef<number | undefined>(0);\r\n const handleScroll = () => {\r\n scrollPosition.current = itemsListRef.current?.scrollTop;\r\n };\r\n React.useLayoutEffect(() => {\r\n if (itemsListRef.current) itemsListRef.current.scrollTop = scrollPosition.current ?? 0;\r\n }, [selectedValues]);\r\n\r\n const getCorrectRef = (ref: React.RefObject<HTMLElement | null>): React.RefObject<HTMLElement | null> => {\r\n switch (customizationProps.itemsType) {\r\n case 'normal':\r\n return (ref as React.RefObject<HTMLButtonElement | null>) || React.createRef<HTMLButtonElement>();\r\n default:\r\n return (ref as React.RefObject<HTMLDivElement | null>) || React.createRef<HTMLDivElement>();\r\n }\r\n };\r\n\r\n const arrLength = getFilteredItems().length;\r\n const [elRefs, setElRefs] = React.useState<React.RefObject<HTMLElement | null>[]>([]);\r\n\r\n React.useEffect(() => {\r\n if (elRefs?.length !== arrLength) {\r\n setFocused(null);\r\n }\r\n\r\n setElRefs((elRefs) =>\r\n Array(arrLength + 1)\r\n .fill(null)\r\n .map((_, i) => getCorrectRef(elRefs[i])),\r\n );\r\n }, [isOpen, arrLength]);\r\n\r\n React.useLayoutEffect(() => {\r\n isOpen && !locationDefined && determineDropUp();\r\n }, [isOpen, locationDefined]);\r\n\r\n const haveTopItem = () => {\r\n if (!customizationProps.pinTopItem) return false;\r\n\r\n if (customizationProps.itemsType === 'radio' && selectedValues && selectedValues?.length > 0) return true;\r\n else if (customizationProps.itemsType === 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) return true;\r\n else if (customizationProps.itemsType === 'normal' && getSuggestions()?.length > 0) return true;\r\n return false;\r\n };\r\n\r\n const getSuggestions = () => {\r\n return getFilteredItems().filter((x) => x.suggestion);\r\n };\r\n\r\n /**\r\n * when dropdown opens set correct position of focused item\r\n * */\r\n React.useLayoutEffect(() => {\r\n if (isOpen && (focused || focused === 0)) {\r\n setNewFocusedElement(focused === 0 && !haveTopItem() ? 1 : focused);\r\n }\r\n }, [isOpen, focused]);\r\n\r\n /**\r\n * Reset dropdown content state on close\r\n * */\r\n React.useEffect(() => {\r\n if (!isOpen) {\r\n setLocationDefined(false);\r\n for (let elRef of elRefs) {\r\n elRef.current?.classList.remove('dropdown-hover');\r\n }\r\n setFocused(null);\r\n if(onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n dropdownContentRef.current?.classList.remove('outline');\r\n dropdownContentRef.current?.blur();\r\n } else {\r\n if (outline) {\r\n dropdownContentRef.current?.classList.add('outline');\r\n dropdownContentRef.current?.focus();\r\n }\r\n }\r\n }, [isOpen, dropdownContentRef, focused, outline]);\r\n\r\n /**\r\n * Scroll item container to top when dropdown opens\r\n * */\r\n React.useEffect(() => {\r\n if (isOpen && itemsListRef.current) {\r\n itemsListRef.current.scrollTop = 0;\r\n }\r\n }, [isOpen]);\r\n\r\n React.useEffect(() => {\r\n if (isOpen) {\r\n const observer = new IntersectionObserver(function (entries) {\r\n if (!entries[0].isIntersecting) {\r\n setIsOpen(false);\r\n //@ts-ignore\r\n document?.activeElement?.blur();\r\n }\r\n }, {threshold: [0], rootMargin: '8px'});\r\n\r\n observer.observe(containerRef.current!);\r\n\r\n calculateOffset();\r\n window.addEventListener('scroll', calculateOffset, true);\r\n window.addEventListener('resize', calculateOffset);\r\n\r\n return () => {\r\n observer.disconnect();\r\n window.removeEventListener('scroll', calculateOffset, true);\r\n window.removeEventListener('resize', calculateOffset);\r\n }\r\n }\r\n return () => {};\r\n }, [isOpen]);\r\n\r\n const handleItemClick = (selected: boolean, item: DropdownItem) => {\r\n let newValue: string[] = [];\r\n if (customizationProps.multiSelect) {\r\n if (selected) newValue = [...selectedValues, item.value];\r\n else newValue = selectedValues.filter((x) => x != item.value);\r\n } else newValue = selected ? [item.value] : [];\r\n\r\n setSelectedValues(newValue);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValue)) {\r\n setIsOpen(false);\r\n }\r\n };\r\n\r\n const getTopItem = () => {\r\n if (!customizationProps.pinTopItem) return;\r\n const visibleItems = getFilteredItems();\r\n const allSelected = selectedValues?.filter((x) => visibleItems.some((y) => y.value == x)).length == visibleItems.length;\r\n let showTopItem = false;\r\n const suggestions = getSuggestions();\r\n const displayLabel = selectedValues[0] ? customizationProps.items?.find((c) => c.value === selectedValues[0])?.displayLabel : undefined;\r\n if (customizationProps.itemsType == 'radio' && selectedValues && selectedValues?.length > 0) showTopItem = true;\r\n else if (customizationProps.itemsType == 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) showTopItem = true;\r\n else if (customizationProps.itemsType == 'normal' && suggestions.length > 0) showTopItem = true;\r\n\r\n if (!showTopItem) return;\r\n\r\n const selectedFirst = selectedValues.length > 0 ? visibleItems.find((x) => x.value == selectedValues[0]) : null;\r\n\r\n return (\r\n <DropdownContentTopItemContainer $size={size}>\r\n {customizationProps.itemsType === 'radio' && (\r\n <RadioButton\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemradio'\r\n iconPointerEventsTransparent={true}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={() => {}}\r\n label={selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n size={size}\r\n id={`${id}_topitem`}\r\n selected={true}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'checkbox' && (\r\n <Checkbox\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemcheckbox'\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={(selected: boolean) => {\r\n if (!customizationProps.multiSelect) return;\r\n\r\n const newValues = selected ? visibleItems.map((x) => x.value) : [];\r\n setSelectedValues(newValues);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValues)) setIsOpen(false);\r\n }}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n iconPointerEventsTransparent={true}\r\n semiSelected={customizationProps.multiSelect && !allSelected && selectedValues?.length > 0}\r\n size={size}\r\n id={`${id}_checkbox_selectall`}\r\n label={customizationProps.multiSelect ? 'Select all' : selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n selected={!customizationProps.multiSelect || allSelected}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'normal' && (\r\n <>\r\n {suggestions.map((x) => (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`${id}_topitem_${x.value}`}\r\n item={x}\r\n size={size}\r\n active={false}\r\n tabIndex={-1}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[0] as React.RefObject<HTMLButtonElement | null>}\r\n id={`${id}_topitem`}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([x.value]);\r\n setSelectedValues([x.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n ))}\r\n </>\r\n )}\r\n </DropdownContentTopItemContainer>\r\n );\r\n };\r\n\r\n const getElements = (messageOnNoResults: string, size: Size.Small | Size.Medium | Size.Large) => {\r\n if (getFilteredItems().length === 0) {\r\n return <MenuItem item={{ value: messageOnNoResults, disabled: true }} size={size} id=\"noResultsFound\" active={false} onClickHandler={(e) => {}} />;\r\n }\r\n return (\r\n <DropdownContentItemsContainer $size={size}>\r\n {getFilteredItems()\r\n .filter((x) => x && (customizationProps.itemsType != 'normal' || !x.suggestion))\r\n .map((item, index) => {\r\n return (\r\n <React.Fragment key={`key_${id}_${item.value}`}>\r\n {item.customContent}\r\n {!item.customContent && customizationProps.itemsType == 'radio' && (\r\n <RadioButton\r\n role='menuitemradio'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && customizationProps.itemsType == 'checkbox' && (\r\n <Checkbox\r\n role='menuitemcheckbox'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && (customizationProps.itemsType == 'normal' || !customizationProps.itemsType) && (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`key_${id}_${index + 1}`}\r\n id={`${id}_${index + 1}`}\r\n item={item}\r\n tabIndex={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n size={size}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n active={selectedValues?.includes(item.value)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLButtonElement | null>}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([item.value]);\r\n setSelectedValues([item.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n )}\r\n </React.Fragment>\r\n );\r\n })}\r\n </DropdownContentItemsContainer>\r\n );\r\n };\r\n\r\n const calculateOffset = () => {\r\n const rect = containerRef?.current?.getBoundingClientRect();\r\n if (rect) {\r\n const isMobile = window.innerWidth < 768;\r\n \r\n // On mobile, ensure dropdown width doesn't exceed viewport\r\n if (isMobile) {\r\n const maxWidth = Math.min(\r\n width ? parseInt(width) : rect.width,\r\n window.innerWidth - 32 // Leave some padding\r\n );\r\n dropdownContentRef.current.style.width = `${maxWidth}px`;\r\n } else {\r\n dropdownContentRef.current.style.width = width ?? `${rect.width}px`;\r\n }\r\n }\r\n determineDropUp();\r\n };\r\n\r\n const cls = `${isOpen ? 'show' : ''} ${isOpen && outline ? 'outline' : ''} ${locationDefined ? (isUp ? 'up' : 'down') : ''}`;\r\n\r\n return (\r\n <Overlay>\r\n <DropdownContentContainer\r\n role={ariaRolesType == \"menu\" ? \"menu\" : \"optionlist\"}\r\n ref={dropdownContentRef}\r\n $size={size}\r\n $offsetTop={offset.top}\r\n id={id}\r\n $offsetLeft={offset.left}\r\n tabIndex={-1}\r\n $isButton={isButton}\r\n $alignLeft={alignLeft}\r\n $scrollable={customizationProps.scrollable}\r\n $maxHeight={customizationProps.maxHeight}\r\n className={cls}>\r\n <DropdownContentListContainer\r\n tabIndex={-1}\r\n role=\"group\"\r\n $size={size}\r\n $itemsType={customizationProps.itemsType}\r\n onScroll={handleScroll}\r\n ref={itemsListRef}\r\n $outline={outline}\r\n $scrollable={customizationProps.scrollable}>\r\n {customizationProps.menuContent && (\r\n <DropdownContentMenuContentContainer $size={size}>\r\n {customizationProps.menuContent}\r\n <DividerContainer $size={size}>\r\n <div className=\"divider\" />\r\n </DividerContainer>\r\n </DropdownContentMenuContentContainer>\r\n )}\r\n {customizationProps.pinTopItem && getTopItem()}\r\n {getElements(messageOnNoResults, size)}\r\n </DropdownContentListContainer>\r\n {customizationProps.action && customizationProps.actionLabel && (\r\n <DropdownContentActionButtonContainer $size={size} $scrollable={customizationProps.scrollable}>\r\n <TextButton\r\n width=\"100%\"\r\n role=\"menuitem\"\r\n icon={customizationProps.actionIcon}\r\n ref={actionButtonRef}\r\n loading={customizationProps.actionLoading}\r\n disabled={customizationProps.actionDisabled}\r\n variant={customizationProps.actionVariant ?? 'primary'}\r\n size={size}\r\n onClick={() => customizationProps.action() && setIsOpen(false)}>\r\n {customizationProps.actionLabel}\r\n </TextButton>\r\n </DropdownContentActionButtonContainer>\r\n )}\r\n </DropdownContentContainer>\r\n </Overlay>\r\n );\r\n },\r\n);\r\n\r\nexport default DropdownContent;\r\n"],"mappings":"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","ignoreList":[]}
@@ -64,6 +64,21 @@ export const DropdownContentContainer = styled.div`
64
64
  border-radius: ${props => props.$size == Size.Large ? '10px' : props.$size == Size.Medium ? '8px' : '6px'};
65
65
 
66
66
  max-height: ${props => !props.$scrollable ? 'auto' : props.$maxHeight ? props.$maxHeight : props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px'};
67
+
68
+ /* Mobile-specific responsive adjustments */
69
+ @media (max-width: 767px) {
70
+ min-width: ${props => props.$size == Size.Large ? '260px' : props.$size == Size.Medium ? '220px' : '180px'};
71
+ max-width: calc(100vw - 16px); /* Prevent overflow on mobile */
72
+
73
+ /* Override positioning for mobile to prevent overflow */
74
+ &.show {
75
+ &.down,
76
+ &.up {
77
+ /* Use transform only for vertical positioning on mobile */
78
+ transform: translate(0, ${props => props.$offsetTop}) !important;
79
+ }
80
+ }
81
+ }
67
82
  `;
68
83
  export const DropdownContentItemsContainer = styled.div`
69
84
  > *:hover {
@@ -222,12 +237,32 @@ const DropdownContent = /*#__PURE__*/React.forwardRef((_ref, ref) => {
222
237
  const options = customizationProps.items;
223
238
  const rect = containerRef.current.getBoundingClientRect();
224
239
  const windowHeight = window.innerHeight;
240
+ const windowWidth = window.innerWidth;
241
+
242
+ // Mobile-specific adjustments
243
+ const isMobile = windowWidth < 768;
225
244
  const menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);
226
245
  const instOffsetWithMenu = rect.top + rect.height + menuHeight;
227
246
  const up = instOffsetWithMenu >= windowHeight;
247
+
248
+ // Mobile-specific positioning
249
+ let leftOffset = alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`;
250
+ if (isMobile) {
251
+ // Ensure dropdown doesn't go off-screen on mobile
252
+ const dropdownWidth = size == Size.Large ? 320 : size == Size.Medium ? 280 : 240;
253
+ const rightEdge = rect.right + (alignLeft ? 0 : dropdownWidth);
254
+ if (rightEdge > windowWidth) {
255
+ leftOffset = `calc(-${rect.width}px - ${rightEdge - windowWidth + 8}px)`;
256
+ }
257
+
258
+ // If still going off-screen, align to the right edge of viewport
259
+ if (rect.left + dropdownWidth > windowWidth) {
260
+ leftOffset = `calc(-${dropdownWidth}px + ${windowWidth - rect.right}px)`;
261
+ }
262
+ }
228
263
  setOffset({
229
264
  top: up ? `calc(-100% - ${rect.height}px ${isButton ? '' : '- 8px'})` : '0',
230
- left: alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`
265
+ left: leftOffset
231
266
  });
232
267
  setIsUp(up);
233
268
  setLocationDefined(true);
@@ -532,7 +567,16 @@ const DropdownContent = /*#__PURE__*/React.forwardRef((_ref, ref) => {
532
567
  const calculateOffset = () => {
533
568
  const rect = containerRef?.current?.getBoundingClientRect();
534
569
  if (rect) {
535
- dropdownContentRef.current.style.width = width ?? `${rect.width}px`;
570
+ const isMobile = window.innerWidth < 768;
571
+
572
+ // On mobile, ensure dropdown width doesn't exceed viewport
573
+ if (isMobile) {
574
+ const maxWidth = Math.min(width ? parseInt(width) : rect.width, window.innerWidth - 32 // Leave some padding
575
+ );
576
+ dropdownContentRef.current.style.width = `${maxWidth}px`;
577
+ } else {
578
+ dropdownContentRef.current.style.width = width ?? `${rect.width}px`;
579
+ }
536
580
  }
537
581
  determineDropUp();
538
582
  };