@helsenorge/designsystem-react 7.0.0-beta.1 → 7.0.0-beta.5

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.
Files changed (99) hide show
  1. package/CHANGELOG.md +29 -0
  2. package/__mocks__/usePseudoClasses.d.ts +1 -0
  3. package/__mocks__/usePseudoClasses.js +5 -0
  4. package/__mocks__/usePseudoClasses.js.map +1 -0
  5. package/components/AnchorLink/AnchorLink.d.ts +2 -1
  6. package/components/AnchorLink/AnchorLink.js.map +1 -1
  7. package/components/Badge/Badge.stories.d.ts +1 -1
  8. package/components/Button/Button.d.ts +2 -1
  9. package/components/Button/Button.js +88 -88
  10. package/components/Button/Button.js.map +1 -1
  11. package/components/Button/Button.stories.d.ts +1 -0
  12. package/components/Button/styles.module.scss +4 -0
  13. package/components/Button/styles.module.scss.d.ts +1 -0
  14. package/components/Checkbox/Checkbox.d.ts +2 -0
  15. package/components/Checkbox/Checkbox.js +72 -70
  16. package/components/Checkbox/Checkbox.js.map +1 -1
  17. package/components/Dropdown/Dropdown.d.ts +2 -0
  18. package/components/Dropdown/Dropdown.js +32 -31
  19. package/components/Dropdown/Dropdown.js.map +1 -1
  20. package/components/ErrorWrapper/ErrorWrapper.d.ts +4 -2
  21. package/components/ErrorWrapper/ErrorWrapper.js +7 -7
  22. package/components/ErrorWrapper/ErrorWrapper.js.map +1 -1
  23. package/components/Expander/Expander.d.ts +2 -0
  24. package/components/Expander/Expander.js +30 -29
  25. package/components/Expander/Expander.js.map +1 -1
  26. package/components/ExpanderHierarchy/expander.module.scss +0 -20
  27. package/components/ExpanderHierarchy/expander.module.scss.d.ts +0 -1
  28. package/components/ExpanderList/ExpanderList.d.ts +4 -0
  29. package/components/ExpanderList/ExpanderList.js +78 -75
  30. package/components/ExpanderList/ExpanderList.js.map +1 -1
  31. package/components/ExpanderList/ExpanderList.stories.d.ts +1 -1
  32. package/components/FormExample/FormExample.js +136 -216
  33. package/components/FormExample/FormExample.js.map +1 -1
  34. package/components/FormGroup/FormGroup.d.ts +2 -0
  35. package/components/FormGroup/FormGroup.js +62 -48
  36. package/components/FormGroup/FormGroup.js.map +1 -1
  37. package/components/FormGroup/FormGroup.stories.d.ts +1 -0
  38. package/components/FormLayout/styles.module.scss +1 -2
  39. package/components/GridExample/GridExample.js +1 -1
  40. package/components/GridExample/GridExample.js.map +1 -1
  41. package/components/HelpQuestion/styles.module.scss +3 -3
  42. package/components/Icon/Icon.stories.d.ts +5 -2
  43. package/components/Input/Input.d.ts +2 -0
  44. package/components/Input/Input.js +75 -74
  45. package/components/Input/Input.js.map +1 -1
  46. package/components/Input/Input.stories.d.ts +2 -2
  47. package/components/LinkList/LinkList.stories.d.ts +1 -1
  48. package/components/Loader/Loader.stories.d.ts +1 -1
  49. package/components/Logo/Logo.stories.d.ts +1 -1
  50. package/components/NotificationPanel/DetailButton/styles.module.scss +1 -1
  51. package/components/PopMenu/PopMenu.js +73 -61
  52. package/components/PopMenu/PopMenu.js.map +1 -1
  53. package/components/PopOver/PopOver.d.ts +2 -0
  54. package/components/PopOver/PopOver.js +37 -36
  55. package/components/PopOver/PopOver.js.map +1 -1
  56. package/components/RadioButton/RadioButton.d.ts +2 -0
  57. package/components/RadioButton/RadioButton.js +62 -60
  58. package/components/RadioButton/RadioButton.js.map +1 -1
  59. package/components/Select/Select.d.ts +2 -0
  60. package/components/Select/Select.js +40 -39
  61. package/components/Select/Select.js.map +1 -1
  62. package/components/SharingStatus/styles.module.scss +2 -0
  63. package/components/Textarea/Textarea.d.ts +4 -0
  64. package/components/Textarea/Textarea.js +70 -67
  65. package/components/Textarea/Textarea.js.map +1 -1
  66. package/components/Trigger/styles.module.scss +24 -4
  67. package/components/Validation/ErrorList.d.ts +7 -0
  68. package/components/Validation/ErrorList.js +8 -0
  69. package/components/Validation/ErrorList.js.map +1 -0
  70. package/components/Validation/ErrorListItem.d.ts +8 -0
  71. package/components/Validation/ErrorListItem.js +12 -0
  72. package/components/Validation/ErrorListItem.js.map +1 -0
  73. package/components/Validation/Validation.d.ts +9 -1
  74. package/components/Validation/Validation.js +15 -13
  75. package/components/Validation/Validation.js.map +1 -1
  76. package/components/Validation/ValidationSummary.d.ts +15 -0
  77. package/components/Validation/ValidationSummary.js +17 -0
  78. package/components/Validation/ValidationSummary.js.map +1 -0
  79. package/components/Validation/styles.module.scss +13 -5
  80. package/components/Validation/styles.module.scss.d.ts +4 -1
  81. package/components/Validation/types.d.ts +9 -0
  82. package/constants.d.ts +1 -0
  83. package/constants.js +1 -1
  84. package/constants.js.map +1 -1
  85. package/fonts/source-sans-pro-200-extralight.woff +0 -0
  86. package/fonts/source-sans-pro-200-extralight.woff2 +0 -0
  87. package/fonts/source-sans-pro-300-light.woff +0 -0
  88. package/fonts/source-sans-pro-300-light.woff2 +0 -0
  89. package/fonts/source-sans-pro-400-regular.woff +0 -0
  90. package/fonts/source-sans-pro-400-regular.woff2 +0 -0
  91. package/fonts/source-sans-pro-600-semibold.woff +0 -0
  92. package/fonts/source-sans-pro-600-semibold.woff2 +0 -0
  93. package/fonts/source-sans-pro-700-bold.woff +0 -0
  94. package/fonts/source-sans-pro-700-bold.woff2 +0 -0
  95. package/fonts/source-sans-pro-900-black.woff +0 -0
  96. package/fonts/source-sans-pro-900-black.woff2 +0 -0
  97. package/package.json +3 -3
  98. package/scss/_icon.scss +8 -0
  99. package/utils/tests/setup-test.d.ts +1 -0
@@ -1,30 +1,31 @@
1
1
  import r, { useRef as N } from "react";
2
2
  import d from "classnames";
3
- import { ZIndex as A, AnalyticsId as C, IconSize as p } from "../../constants.js";
4
- import { useExpand as D } from "../../hooks/useExpand.js";
5
- import { useHover as O } from "../../hooks/useHover.js";
6
- import { useSticky as U } from "../../hooks/useSticky.js";
7
- import Z from "../Button/Button.js";
3
+ import { ZIndex as D, AnalyticsId as C, IconSize as p } from "../../constants.js";
4
+ import { useExpand as O } from "../../hooks/useExpand.js";
5
+ import { useHover as U } from "../../hooks/useHover.js";
6
+ import { useSticky as Z } from "../../hooks/useSticky.js";
7
+ import j from "../Button/Button.js";
8
8
  import { Icon as _ } from "../Icon/Icon.js";
9
9
  import b from "../Icons/ChevronDown.js";
10
10
  import h from "../Icons/ChevronUp.js";
11
- import j from "../LazyIcon/LazyIcon.js";
11
+ import q from "../LazyIcon/LazyIcon.js";
12
12
  import e from "./styles.module.scss";
13
- var q = /* @__PURE__ */ ((s) => (s.small = "small", s.large = "large", s))(q || {});
14
- const F = (s) => {
13
+ var F = /* @__PURE__ */ ((s) => (s.small = "small", s.large = "large", s))(F || {});
14
+ const G = (s) => {
15
15
  const {
16
16
  title: x,
17
- children: $,
17
+ children: z,
18
18
  size: n = "small",
19
19
  color: g,
20
20
  svgIcon: o,
21
- expanded: k = !1,
22
- noNestedLine: z = !1,
21
+ expanded: $ = !1,
22
+ noNestedLine: k = !1,
23
23
  sticky: S = !1,
24
24
  testId: f,
25
25
  onExpand: w,
26
- renderChildrenWhenClosed: R = !1
27
- } = s, [t, u] = D(k, w), E = N(null), l = N(null), { isHovered: i } = O(l), { isOutsideWindow: W, isLeavingWindow: c, offsetHeight: v, contentWidth: y } = U(E, l), a = S && t && W, I = (m) => /* @__PURE__ */ r.createElement("span", { className: d(e.expander__icon, e[`expander__icon--${m}`]) }, /* @__PURE__ */ r.createElement(_, { svgIcon: t ? h : b, size: p.XSmall, isHovered: i })), X = d(
26
+ renderChildrenWhenClosed: R = !1,
27
+ zIndex: W = D.ExpanderTrigger
28
+ } = s, [t, u] = O($, w), E = N(null), l = N(null), { isHovered: i } = U(l), { isOutsideWindow: X, isLeavingWindow: c, offsetHeight: v, contentWidth: y } = Z(E, l), a = S && t && X, I = (m) => /* @__PURE__ */ r.createElement("span", { className: d(e.expander__icon, e[`expander__icon--${m}`]) }, /* @__PURE__ */ r.createElement(_, { svgIcon: t ? h : b, size: p.XSmall, isHovered: i })), H = d(
28
29
  e.expander__trigger,
29
30
  n === "large" && e[`expander__trigger--${n}`],
30
31
  n === "large" && e[`expander__trigger--${g || "neutral"}`],
@@ -32,13 +33,13 @@ const F = (s) => {
32
33
  t && e["expander__trigger--expanded"],
33
34
  a && !c && e["expander__trigger--sticky"],
34
35
  a && c && e["expander__trigger--absolute"]
35
- ), H = () => /* @__PURE__ */ r.createElement(
36
+ ), L = () => /* @__PURE__ */ r.createElement(
36
37
  "button",
37
38
  {
38
39
  type: "button",
39
- className: X,
40
+ className: H,
40
41
  style: {
41
- zIndex: i || a ? A.ExpanderTrigger : void 0,
42
+ zIndex: i || a ? W : void 0,
42
43
  width: a && y ? `${y}px` : void 0
43
44
  },
44
45
  "aria-expanded": t,
@@ -48,19 +49,19 @@ const F = (s) => {
48
49
  "data-analyticsid": C.Expander
49
50
  },
50
51
  n === "small" && I("left"),
51
- o && /* @__PURE__ */ r.createElement("span", { className: d(e.expander__icon, e["expander__icon--left"]) }, typeof o == "string" ? /* @__PURE__ */ r.createElement(j, { iconName: o, size: p.XSmall, isHovered: i }) : /* @__PURE__ */ r.createElement(_, { svgIcon: o, size: p.XSmall, isHovered: i })),
52
+ o && /* @__PURE__ */ r.createElement("span", { className: d(e.expander__icon, e["expander__icon--left"]) }, typeof o == "string" ? /* @__PURE__ */ r.createElement(q, { iconName: o, size: p.XSmall, isHovered: i }) : /* @__PURE__ */ r.createElement(_, { svgIcon: o, size: p.XSmall, isHovered: i })),
52
53
  x,
53
54
  n === "large" && I("right")
54
- ), L = d(
55
+ ), T = d(
55
56
  e.expander__button,
56
57
  t && e["expander__button--expanded"],
57
58
  a && !c && e["expander__button--sticky"],
58
59
  a && c && e["expander__button--absolute"]
59
- ), T = () => /* @__PURE__ */ r.createElement(
60
- Z,
60
+ ), B = () => /* @__PURE__ */ r.createElement(
61
+ j,
61
62
  {
62
63
  variant: "borderless",
63
- className: L,
64
+ className: T,
64
65
  "aria-expanded": t,
65
66
  ref: l,
66
67
  onClick: () => u(!t),
@@ -69,7 +70,7 @@ const F = (s) => {
69
70
  },
70
71
  /* @__PURE__ */ r.createElement(_, { svgIcon: t ? h : b, size: p.XSmall }),
71
72
  x
72
- ), B = () => {
73
+ ), A = () => {
73
74
  if (!R && !t)
74
75
  return null;
75
76
  const m = d(
@@ -78,9 +79,9 @@ const F = (s) => {
78
79
  n === "large" && e[`expander__content--${g || "neutral"}`],
79
80
  n === "large" && o && e["expander__content--icon"],
80
81
  t && e["expander__content--expanded"],
81
- n === "small" && !z && e["expander__content--nested-line"]
82
+ n === "small" && !k && e["expander__content--nested-line"]
82
83
  );
83
- return /* @__PURE__ */ r.createElement("div", { className: m }, $);
84
+ return /* @__PURE__ */ r.createElement("div", { className: m }, z);
84
85
  };
85
86
  return /* @__PURE__ */ r.createElement(
86
87
  "div",
@@ -89,12 +90,12 @@ const F = (s) => {
89
90
  ref: E,
90
91
  style: { paddingTop: a && v ? `${v}px` : void 0 }
91
92
  },
92
- n === "large" ? H() : T(),
93
- B()
93
+ n === "large" ? L() : B(),
94
+ A()
94
95
  );
95
- }, ae = F;
96
+ }, oe = G;
96
97
  export {
97
- q as ExpanderSize,
98
- ae as default
98
+ F as ExpanderSize,
99
+ oe as default
99
100
  };
100
101
  //# sourceMappingURL=Expander.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Expander.js","sources":["../../../src/components/Expander/Expander.tsx"],"sourcesContent":["import React, { useRef } from 'react';\n\nimport classNames from 'classnames';\n\nimport { AnalyticsId, ZIndex } from '../../constants';\nimport { useExpand } from '../../hooks/useExpand';\nimport { useHover } from '../../hooks/useHover';\nimport { useSticky } from '../../hooks/useSticky';\nimport { PaletteNames } from '../../theme/palette';\nimport Button from '../Button';\nimport Icon, { IconSize, SvgIcon } from '../Icon';\nimport ChevronDown from '../Icons/ChevronDown';\nimport ChevronUp from '../Icons/ChevronUp';\nimport { IconName } from '../Icons/IconNames';\nimport LazyIcon from '../LazyIcon';\n\nimport styles from './styles.module.scss';\n\nexport enum ExpanderSize {\n small = 'small',\n large = 'large',\n}\n\nexport type ExpanderColors = Extract<PaletteNames, 'banana' | 'blueberry' | 'cherry' | 'kiwi' | 'neutral' | 'plum' | 'white'>;\n\nexport interface ExpanderProps {\n /** Sets the trigger title */\n title: string;\n /** Sets the expanded content */\n children?: React.ReactNode;\n /** Sets the size of the expander. Default: ExpanderSize.small */\n size?: ExpanderSize;\n /** Sets the background of the expander. Requires size=ExpanderSize.large. */\n color?: ExpanderColors;\n /** Adds an icon to the expander trigger. Requires size=ExpanderSize.large. */\n svgIcon?: SvgIcon | IconName;\n /** Opens or closes the expander */\n expanded?: boolean;\n /** Removes border to the left of the content. Requires size=ExpanderSize.small. */\n noNestedLine?: boolean;\n /** Stick expander trigger to top of screen while scrolling down */\n sticky?: boolean;\n /** Called when expander is open/closed. */\n onExpand?: (isExpanded: boolean) => void;\n /** Whether to render children when closed (in which case they are hidden with CSS). Default: false */\n renderChildrenWhenClosed?: boolean;\n /** Sets the data-testid attribute on the expander button. */\n testId?: string;\n}\n\nconst Expander: React.FC<ExpanderProps> = props => {\n const {\n title,\n children,\n size = ExpanderSize.small,\n color,\n svgIcon: icon,\n expanded = false,\n noNestedLine = false,\n sticky = false,\n testId,\n onExpand,\n renderChildrenWhenClosed = false,\n } = props;\n const [isExpanded, setIsExpanded] = useExpand(expanded, onExpand);\n const expanderRef = useRef<HTMLDivElement>(null);\n const triggerRef = useRef<HTMLButtonElement>(null);\n const { isHovered } = useHover(triggerRef);\n const { isOutsideWindow, isLeavingWindow, offsetHeight, contentWidth } = useSticky(expanderRef, triggerRef);\n\n const isSticky = sticky && isExpanded && isOutsideWindow;\n\n const renderChevron = (align: 'left' | 'right') => (\n <span className={classNames(styles['expander__icon'], styles[`expander__icon--${align}`])}>\n <Icon svgIcon={isExpanded ? ChevronUp : ChevronDown} size={IconSize.XSmall} isHovered={isHovered} />\n </span>\n );\n\n const triggerClassName = classNames(\n styles['expander__trigger'],\n size === ExpanderSize.large && styles[`expander__trigger--${size}`],\n size === ExpanderSize.large && styles[`expander__trigger--${color || 'neutral'}`],\n size === ExpanderSize.large && icon && styles['expander__trigger--icon'],\n isExpanded && styles['expander__trigger--expanded'],\n isSticky && !isLeavingWindow && styles['expander__trigger--sticky'],\n isSticky && isLeavingWindow && styles['expander__trigger--absolute']\n );\n\n const renderTrigger = () => (\n <button\n type=\"button\"\n className={triggerClassName}\n style={{\n zIndex: isHovered || isSticky ? ZIndex.ExpanderTrigger : undefined,\n width: isSticky && contentWidth ? `${contentWidth}px` : undefined,\n }}\n aria-expanded={isExpanded}\n ref={triggerRef}\n onClick={() => setIsExpanded(!isExpanded)}\n data-testid={testId}\n data-analyticsid={AnalyticsId.Expander}\n >\n {size === ExpanderSize.small && renderChevron('left')}\n {icon && (\n <span className={classNames(styles['expander__icon'], styles['expander__icon--left'])}>\n {typeof icon === 'string' ? (\n <LazyIcon iconName={icon} size={IconSize.XSmall} isHovered={isHovered} />\n ) : (\n <Icon svgIcon={icon} size={IconSize.XSmall} isHovered={isHovered} />\n )}\n </span>\n )}\n {title}\n {size === ExpanderSize.large && renderChevron('right')}\n </button>\n );\n\n const buttonClassName = classNames(\n styles['expander__button'],\n isExpanded && styles['expander__button--expanded'],\n isSticky && !isLeavingWindow && styles['expander__button--sticky'],\n isSticky && isLeavingWindow && styles['expander__button--absolute']\n );\n\n const renderButton = () => (\n <Button\n variant=\"borderless\"\n className={buttonClassName}\n aria-expanded={isExpanded}\n ref={triggerRef}\n onClick={() => setIsExpanded(!isExpanded)}\n testId={testId}\n data-analyticsid={AnalyticsId.Expander}\n >\n <Icon svgIcon={isExpanded ? ChevronUp : ChevronDown} size={IconSize.XSmall} />\n {title}\n </Button>\n );\n\n const renderContent = () => {\n if (!renderChildrenWhenClosed && !isExpanded) {\n return null;\n }\n\n const contentClassName = classNames(\n styles['expander__content'],\n styles[`expander__content--${size}`],\n size === ExpanderSize.large && styles[`expander__content--${color || 'neutral'}`],\n size === ExpanderSize.large && icon && styles['expander__content--icon'],\n isExpanded && styles['expander__content--expanded'],\n size === ExpanderSize.small && !noNestedLine && styles['expander__content--nested-line']\n );\n\n return <div className={contentClassName}>{children}</div>;\n };\n\n return (\n <div\n className={styles['expander']}\n ref={expanderRef}\n style={{ paddingTop: isSticky && offsetHeight ? `${offsetHeight}px` : undefined }}\n >\n {size === ExpanderSize.large ? renderTrigger() : renderButton()}\n {renderContent()}\n </div>\n );\n};\n\nexport default Expander;\n"],"names":["ExpanderSize","Expander","props","title","children","size","color","icon","expanded","noNestedLine","sticky","testId","onExpand","renderChildrenWhenClosed","isExpanded","setIsExpanded","useExpand","expanderRef","useRef","triggerRef","isHovered","useHover","isOutsideWindow","isLeavingWindow","offsetHeight","contentWidth","useSticky","isSticky","renderChevron","align","React","classNames","styles","Icon","ChevronUp","ChevronDown","IconSize","triggerClassName","renderTrigger","ZIndex","AnalyticsId","LazyIcon","buttonClassName","renderButton","Button","renderContent","contentClassName","Expander$1"],"mappings":";;;;;;;;;;;;AAkBY,IAAAA,sBAAAA,OACVA,EAAA,QAAQ,SACRA,EAAA,QAAQ,SAFEA,IAAAA,KAAA,CAAA,CAAA;AAgCZ,MAAMC,IAAoC,CAASC,MAAA;AAC3C,QAAA;AAAA,IACJ,OAAAC;AAAA,IACA,UAAAC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,OAAAC;AAAA,IACA,SAASC;AAAA,IACT,UAAAC,IAAW;AAAA,IACX,cAAAC,IAAe;AAAA,IACf,QAAAC,IAAS;AAAA,IACT,QAAAC;AAAA,IACA,UAAAC;AAAA,IACA,0BAAAC,IAA2B;AAAA,EACzB,IAAAX,GACE,CAACY,GAAYC,CAAa,IAAIC,EAAUR,GAAUI,CAAQ,GAC1DK,IAAcC,EAAuB,IAAI,GACzCC,IAAaD,EAA0B,IAAI,GAC3C,EAAE,WAAAE,EAAA,IAAcC,EAASF,CAAU,GACnC,EAAE,iBAAAG,GAAiB,iBAAAC,GAAiB,cAAAC,GAAc,cAAAC,MAAiBC,EAAUT,GAAaE,CAAU,GAEpGQ,IAAWjB,KAAUI,KAAcQ,GAEnCM,IAAgB,CAACC,MACpBC,gBAAAA,EAAA,cAAA,QAAA,EAAK,WAAWC,EAAWC,EAAO,gBAAmBA,EAAO,mBAAmBH,CAAK,EAAE,CAAC,EAAA,GACrFC,gBAAAA,EAAA,cAAAG,GAAA,EAAK,SAASnB,IAAaoB,IAAYC,GAAa,MAAMC,EAAS,QAAQ,WAAAhB,EAAA,CAAsB,CACpG,GAGIiB,IAAmBN;AAAA,IACvBC,EAAO;AAAA,IACP3B,MAAS,WAAsB2B,EAAO,sBAAsB3B,CAAI,EAAE;AAAA,IAClEA,MAAS,WAAsB2B,EAAO,sBAAsB1B,KAAS,SAAS,EAAE;AAAA,IAChFD,MAAS,WAAsBE,KAAQyB,EAAO,yBAAyB;AAAA,IACvElB,KAAckB,EAAO,6BAA6B;AAAA,IAClDL,KAAY,CAACJ,KAAmBS,EAAO,2BAA2B;AAAA,IAClEL,KAAYJ,KAAmBS,EAAO,6BAA6B;AAAA,EAAA,GAG/DM,IAAgB,MACpBR,gBAAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,WAAWO;AAAA,MACX,OAAO;AAAA,QACL,QAAQjB,KAAaO,IAAWY,EAAO,kBAAkB;AAAA,QACzD,OAAOZ,KAAYF,IAAe,GAAGA,CAAY,OAAO;AAAA,MAC1D;AAAA,MACA,iBAAeX;AAAA,MACf,KAAKK;AAAA,MACL,SAAS,MAAMJ,EAAc,CAACD,CAAU;AAAA,MACxC,eAAaH;AAAA,MACb,oBAAkB6B,EAAY;AAAA,IAAA;AAAA,IAE7BnC,MAAS,WAAsBuB,EAAc,MAAM;AAAA,IACnDrB,KACCuB,gBAAAA,EAAA,cAAC,QAAK,EAAA,WAAWC,EAAWC,EAAO,gBAAmBA,EAAO,sBAAsB,CAAC,EACjF,GAAA,OAAOzB,KAAS,WACfuB,gBAAAA,EAAA,cAACW,GAAS,EAAA,UAAUlC,GAAM,MAAM6B,EAAS,QAAQ,WAAAhB,GAAsB,IAEvEU,gBAAAA,EAAA,cAACG,GAAK,EAAA,SAAS1B,GAAM,MAAM6B,EAAS,QAAQ,WAAAhB,GAAsB,CAEtE;AAAA,IAEDjB;AAAA,IACAE,MAAS,WAAsBuB,EAAc,OAAO;AAAA,EAAA,GAInDc,IAAkBX;AAAA,IACtBC,EAAO;AAAA,IACPlB,KAAckB,EAAO,4BAA4B;AAAA,IACjDL,KAAY,CAACJ,KAAmBS,EAAO,0BAA0B;AAAA,IACjEL,KAAYJ,KAAmBS,EAAO,4BAA4B;AAAA,EAAA,GAG9DW,IAAe,MACnBb,gBAAAA,EAAA;AAAA,IAACc;AAAA,IAAA;AAAA,MACC,SAAQ;AAAA,MACR,WAAWF;AAAA,MACX,iBAAe5B;AAAA,MACf,KAAKK;AAAA,MACL,SAAS,MAAMJ,EAAc,CAACD,CAAU;AAAA,MACxC,QAAAH;AAAA,MACA,oBAAkB6B,EAAY;AAAA,IAAA;AAAA,IAE9BV,gBAAAA,EAAA,cAACG,KAAK,SAASnB,IAAaoB,IAAYC,GAAa,MAAMC,EAAS,OAAQ,CAAA;AAAA,IAC3EjC;AAAA,EAAA,GAIC0C,IAAgB,MAAM;AACtB,QAAA,CAAChC,KAA4B,CAACC;AACzB,aAAA;AAGT,UAAMgC,IAAmBf;AAAA,MACvBC,EAAO;AAAA,MACPA,EAAO,sBAAsB3B,CAAI,EAAE;AAAA,MACnCA,MAAS,WAAsB2B,EAAO,sBAAsB1B,KAAS,SAAS,EAAE;AAAA,MAChFD,MAAS,WAAsBE,KAAQyB,EAAO,yBAAyB;AAAA,MACvElB,KAAckB,EAAO,6BAA6B;AAAA,MAClD3B,MAAS,WAAsB,CAACI,KAAgBuB,EAAO,gCAAgC;AAAA,IAAA;AAGzF,WAAQF,gBAAAA,EAAA,cAAA,OAAA,EAAI,WAAWgB,EAAA,GAAmB1C,CAAS;AAAA,EAAA;AAInD,SAAA0B,gBAAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWE,EAAO;AAAA,MAClB,KAAKf;AAAA,MACL,OAAO,EAAE,YAAYU,KAAYH,IAAe,GAAGA,CAAY,OAAO,OAAU;AAAA,IAAA;AAAA,IAE/EnB,MAAS,UAAqBiC,EAAc,IAAIK,EAAa;AAAA,IAC7DE,EAAc;AAAA,EAAA;AAGrB,GAEAE,KAAe9C;"}
1
+ {"version":3,"file":"Expander.js","sources":["../../../src/components/Expander/Expander.tsx"],"sourcesContent":["import React, { useRef } from 'react';\n\nimport classNames from 'classnames';\n\nimport { AnalyticsId, ZIndex } from '../../constants';\nimport { useExpand } from '../../hooks/useExpand';\nimport { useHover } from '../../hooks/useHover';\nimport { useSticky } from '../../hooks/useSticky';\nimport { PaletteNames } from '../../theme/palette';\nimport Button from '../Button';\nimport Icon, { IconSize, SvgIcon } from '../Icon';\nimport ChevronDown from '../Icons/ChevronDown';\nimport ChevronUp from '../Icons/ChevronUp';\nimport { IconName } from '../Icons/IconNames';\nimport LazyIcon from '../LazyIcon';\n\nimport styles from './styles.module.scss';\n\nexport enum ExpanderSize {\n small = 'small',\n large = 'large',\n}\n\nexport type ExpanderColors = Extract<PaletteNames, 'banana' | 'blueberry' | 'cherry' | 'kiwi' | 'neutral' | 'plum' | 'white'>;\n\nexport interface ExpanderProps {\n /** Sets the trigger title */\n title: string;\n /** Sets the expanded content */\n children?: React.ReactNode;\n /** Sets the size of the expander. Default: ExpanderSize.small */\n size?: ExpanderSize;\n /** Sets the background of the expander. Requires size=ExpanderSize.large. */\n color?: ExpanderColors;\n /** Adds an icon to the expander trigger. Requires size=ExpanderSize.large. */\n svgIcon?: SvgIcon | IconName;\n /** Opens or closes the expander */\n expanded?: boolean;\n /** Removes border to the left of the content. Requires size=ExpanderSize.small. */\n noNestedLine?: boolean;\n /** Stick expander trigger to top of screen while scrolling down */\n sticky?: boolean;\n /** Called when expander is open/closed. */\n onExpand?: (isExpanded: boolean) => void;\n /** Whether to render children when closed (in which case they are hidden with CSS). Default: false */\n renderChildrenWhenClosed?: boolean;\n /** Sets the data-testid attribute on the expander button. */\n testId?: string;\n /** Overrides the default z-index of the expander header */\n zIndex?: number;\n}\n\nconst Expander: React.FC<ExpanderProps> = props => {\n const {\n title,\n children,\n size = ExpanderSize.small,\n color,\n svgIcon: icon,\n expanded = false,\n noNestedLine = false,\n sticky = false,\n testId,\n onExpand,\n renderChildrenWhenClosed = false,\n zIndex = ZIndex.ExpanderTrigger,\n } = props;\n const [isExpanded, setIsExpanded] = useExpand(expanded, onExpand);\n const expanderRef = useRef<HTMLDivElement>(null);\n const triggerRef = useRef<HTMLButtonElement>(null);\n const { isHovered } = useHover(triggerRef);\n const { isOutsideWindow, isLeavingWindow, offsetHeight, contentWidth } = useSticky(expanderRef, triggerRef);\n\n const isSticky = sticky && isExpanded && isOutsideWindow;\n\n const renderChevron = (align: 'left' | 'right'): React.ReactNode => (\n <span className={classNames(styles['expander__icon'], styles[`expander__icon--${align}`])}>\n <Icon svgIcon={isExpanded ? ChevronUp : ChevronDown} size={IconSize.XSmall} isHovered={isHovered} />\n </span>\n );\n\n const triggerClassName = classNames(\n styles['expander__trigger'],\n size === ExpanderSize.large && styles[`expander__trigger--${size}`],\n size === ExpanderSize.large && styles[`expander__trigger--${color || 'neutral'}`],\n size === ExpanderSize.large && icon && styles['expander__trigger--icon'],\n isExpanded && styles['expander__trigger--expanded'],\n isSticky && !isLeavingWindow && styles['expander__trigger--sticky'],\n isSticky && isLeavingWindow && styles['expander__trigger--absolute']\n );\n\n const renderTrigger = (): React.ReactNode => (\n <button\n type=\"button\"\n className={triggerClassName}\n style={{\n zIndex: isHovered || isSticky ? zIndex : undefined,\n width: isSticky && contentWidth ? `${contentWidth}px` : undefined,\n }}\n aria-expanded={isExpanded}\n ref={triggerRef}\n onClick={(): void => setIsExpanded(!isExpanded)}\n data-testid={testId}\n data-analyticsid={AnalyticsId.Expander}\n >\n {size === ExpanderSize.small && renderChevron('left')}\n {icon && (\n <span className={classNames(styles['expander__icon'], styles['expander__icon--left'])}>\n {typeof icon === 'string' ? (\n <LazyIcon iconName={icon} size={IconSize.XSmall} isHovered={isHovered} />\n ) : (\n <Icon svgIcon={icon} size={IconSize.XSmall} isHovered={isHovered} />\n )}\n </span>\n )}\n {title}\n {size === ExpanderSize.large && renderChevron('right')}\n </button>\n );\n\n const buttonClassName = classNames(\n styles['expander__button'],\n isExpanded && styles['expander__button--expanded'],\n isSticky && !isLeavingWindow && styles['expander__button--sticky'],\n isSticky && isLeavingWindow && styles['expander__button--absolute']\n );\n\n const renderButton = (): React.ReactNode => (\n <Button\n variant=\"borderless\"\n className={buttonClassName}\n aria-expanded={isExpanded}\n ref={triggerRef}\n onClick={(): void => setIsExpanded(!isExpanded)}\n testId={testId}\n data-analyticsid={AnalyticsId.Expander}\n >\n <Icon svgIcon={isExpanded ? ChevronUp : ChevronDown} size={IconSize.XSmall} />\n {title}\n </Button>\n );\n\n const renderContent = (): React.ReactNode => {\n if (!renderChildrenWhenClosed && !isExpanded) {\n return null;\n }\n\n const contentClassName = classNames(\n styles['expander__content'],\n styles[`expander__content--${size}`],\n size === ExpanderSize.large && styles[`expander__content--${color || 'neutral'}`],\n size === ExpanderSize.large && icon && styles['expander__content--icon'],\n isExpanded && styles['expander__content--expanded'],\n size === ExpanderSize.small && !noNestedLine && styles['expander__content--nested-line']\n );\n\n return <div className={contentClassName}>{children}</div>;\n };\n\n return (\n <div\n className={styles['expander']}\n ref={expanderRef}\n style={{ paddingTop: isSticky && offsetHeight ? `${offsetHeight}px` : undefined }}\n >\n {size === ExpanderSize.large ? renderTrigger() : renderButton()}\n {renderContent()}\n </div>\n );\n};\n\nexport default Expander;\n"],"names":["ExpanderSize","Expander","props","title","children","size","color","icon","expanded","noNestedLine","sticky","testId","onExpand","renderChildrenWhenClosed","zIndex","ZIndex","isExpanded","setIsExpanded","useExpand","expanderRef","useRef","triggerRef","isHovered","useHover","isOutsideWindow","isLeavingWindow","offsetHeight","contentWidth","useSticky","isSticky","renderChevron","align","React","classNames","styles","Icon","ChevronUp","ChevronDown","IconSize","triggerClassName","renderTrigger","AnalyticsId","LazyIcon","buttonClassName","renderButton","Button","renderContent","contentClassName","Expander$1"],"mappings":"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"}
@@ -7,10 +7,6 @@
7
7
  .expander {
8
8
  $item: &;
9
9
 
10
- @media (prefers-reduced-motion: no-preference) {
11
- animation: fade-in 150ms linear forwards;
12
- }
13
-
14
10
  &:first-of-type {
15
11
  border-top: 1px solid $neutral500;
16
12
  }
@@ -141,19 +137,3 @@
141
137
  }
142
138
  }
143
139
  }
144
-
145
- @keyframes fade-in {
146
- 0% {
147
- opacity: 0;
148
- max-height: 0;
149
- }
150
-
151
- 99% {
152
- max-height: 24rem;
153
- }
154
-
155
- 100% {
156
- opacity: 1;
157
- max-height: none;
158
- }
159
- }
@@ -17,7 +17,6 @@ export type Styles = {
17
17
  'expander__title--4-and-lower': string;
18
18
  'expander__title--expanded': string;
19
19
  'expander__title--print': string;
20
- 'fade-in': string;
21
20
  };
22
21
 
23
22
  export type ClassNames = keyof Styles;
@@ -31,6 +31,8 @@ interface ExpanderListProps {
31
31
  testId?: string;
32
32
  /** Sets visual priority */
33
33
  variant?: ExpanderListVariant;
34
+ /** Overrides the default z-index of the expander header */
35
+ zIndex?: number;
34
36
  }
35
37
  type Modify<T, R> = Omit<T, keyof R> & R;
36
38
  type ExpanderProps = Modify<React.HTMLAttributes<HTMLButtonElement>, {
@@ -49,6 +51,8 @@ type ExpanderProps = Modify<React.HTMLAttributes<HTMLButtonElement>, {
49
51
  handleExpanderClick?: (event: React.MouseEvent<HTMLElement, MouseEvent>) => void;
50
52
  /** Called when expander is open/closed. */
51
53
  onExpand?: (isExpanded: boolean) => void;
54
+ /** Overrides the default z-index of the expander header */
55
+ zIndex?: number;
52
56
  }> & Pick<ExpanderListProps, 'renderChildrenWhenClosed' | 'sticky' | 'variant'>;
53
57
  export declare const ExpanderList: ExpanderListCompound;
54
58
  export default ExpanderList;
@@ -1,62 +1,63 @@
1
1
  import s, { useRef as A, useState as T, useEffect as V } from "react";
2
- import g from "classnames";
3
- import { AnalyticsId as U, ZIndex as P } from "../../constants.js";
4
- import { useExpand as Z } from "../../hooks/useExpand.js";
5
- import { useHover as j } from "../../hooks/useHover.js";
6
- import { useSticky as q } from "../../hooks/useSticky.js";
7
- import { useUuid as B } from "../../hooks/useUuid.js";
8
- import { mergeRefs as F } from "../../utils/refs.js";
9
- import { isElementInViewport as G } from "../../utils/viewport.js";
10
- import J from "../Icons/ChevronDown.js";
11
- import K from "../Icons/ChevronUp.js";
12
- import { renderListHeader as Q } from "../ListHeader/ListHeader.js";
2
+ import C from "classnames";
3
+ import { AnalyticsId as U, ZIndex as Z } from "../../constants.js";
4
+ import { useExpand as j } from "../../hooks/useExpand.js";
5
+ import { useHover as q } from "../../hooks/useHover.js";
6
+ import { useSticky as B } from "../../hooks/useSticky.js";
7
+ import { useUuid as F } from "../../hooks/useUuid.js";
8
+ import { mergeRefs as G } from "../../utils/refs.js";
9
+ import { isElementInViewport as J } from "../../utils/viewport.js";
10
+ import K from "../Icons/ChevronDown.js";
11
+ import Q from "../Icons/ChevronUp.js";
12
+ import { renderListHeader as X } from "../ListHeader/ListHeader.js";
13
13
  import r from "./styles.module.scss";
14
- const H = s.forwardRef((d, y) => {
14
+ const W = s.forwardRef((l, g) => {
15
15
  const {
16
16
  id: x,
17
- children: h,
18
- padding: _ = !0,
17
+ children: y,
18
+ padding: h = !0,
19
19
  color: E = "neutral",
20
- className: L = "",
21
- icon: N,
22
- large: l = !1,
23
- title: w,
24
- titleHtmlMarkup: $ = "span",
25
- expanded: I = !1,
26
- sticky: o,
27
- testId: k,
28
- handleExpanderClick: p,
29
- onExpand: R,
30
- renderChildrenWhenClosed: C,
31
- variant: c = "line"
32
- } = d, [a] = Z(I, R), f = A(null), t = A(null), { isHovered: n } = j(t), { isOutsideWindow: e, isLeavingWindow: i, offsetHeight: m, contentWidth: b } = q(f, t), u = o && a && e, z = g(
33
- L,
34
- (c === "line" || c === "outline") && r[`expander-list__item--${c}`]
35
- ), D = g(
20
+ className: _ = "",
21
+ icon: L,
22
+ large: o = !1,
23
+ title: I,
24
+ titleHtmlMarkup: N = "span",
25
+ expanded: w = !1,
26
+ sticky: $,
27
+ testId: p,
28
+ handleExpanderClick: k,
29
+ onExpand: c,
30
+ renderChildrenWhenClosed: R,
31
+ variant: d = "line",
32
+ zIndex: H
33
+ } = l, [a] = j(w, c), f = A(null), t = A(null), { isHovered: n } = q(t), { isOutsideWindow: e, isLeavingWindow: i, offsetHeight: m, contentWidth: z } = B(f, t), u = $ && a && e, D = C(
34
+ _,
35
+ (d === "line" || d === "outline") && r[`expander-list__item--${d}`]
36
+ ), M = C(
36
37
  r["expander-list-link"],
37
38
  E !== "black" && r[`expander-list-link--${E}`],
38
39
  {
39
- [r["expander-list-link--fill"]]: c === "fill",
40
+ [r["expander-list-link--fill"]]: d === "fill",
40
41
  [r["expander-list-link--closed"]]: !a,
41
- [r["expander-list-link--large"]]: l,
42
+ [r["expander-list-link--large"]]: o,
42
43
  [r["expander-list-link--sticky"]]: u && !i,
43
44
  [r["expander-list-link--absolute"]]: u && i
44
45
  }
45
- ), M = () => {
46
- if (!C && !a)
46
+ ), O = () => {
47
+ if (!R && !a)
47
48
  return null;
48
- const O = g(
49
+ const P = C(
49
50
  r["expander-list-link__main-content"],
50
51
  a && r["expander-list-link__main-content--expanded"],
51
- _ ? r["expander-list-link__main-content--padding"] : ""
52
+ h ? r["expander-list-link__main-content--padding"] : ""
52
53
  );
53
- return /* @__PURE__ */ s.createElement("div", { className: O }, h);
54
+ return /* @__PURE__ */ s.createElement("div", { className: P }, y);
54
55
  };
55
56
  return /* @__PURE__ */ s.createElement(
56
57
  "li",
57
58
  {
58
- className: z,
59
- ref: F([y, f]),
59
+ className: D,
60
+ ref: G([g, f]),
60
61
  style: { paddingTop: u && m ? `${m}px` : void 0 }
61
62
  },
62
63
  /* @__PURE__ */ s.createElement(
@@ -64,74 +65,76 @@ const H = s.forwardRef((d, y) => {
64
65
  {
65
66
  type: "button",
66
67
  id: x,
67
- onClick: p,
68
- "data-testid": k,
68
+ onClick: k,
69
+ "data-testid": p,
69
70
  "data-analyticsid": U.ExpanderListExpander,
70
- className: D,
71
+ className: M,
71
72
  ref: t,
72
73
  "aria-expanded": a,
73
74
  style: {
74
- zIndex: n || u ? P.ExpanderTrigger : void 0,
75
- width: u && b ? `${b}px` : void 0
75
+ zIndex: n || u ? H : void 0,
76
+ width: u && z ? `${z}px` : void 0
76
77
  }
77
78
  },
78
- Q(w, $, n, l ? "large" : "medium", a ? K : J, N)
79
+ X(I, N, n, o ? "large" : "medium", a ? Q : K, L)
79
80
  ),
80
- M()
81
+ O()
81
82
  );
82
- }), v = (d) => s.isValidElement(d) && d.type === H, W = s.forwardRef((d, y) => {
83
+ }), v = (l) => s.isValidElement(l) && l.type === W, b = s.forwardRef((l, g) => {
83
84
  const {
84
85
  children: x,
85
- childPadding: h = !0,
86
- large: _,
86
+ childPadding: y = !0,
87
+ large: h,
87
88
  renderChildrenWhenClosed: E = !1,
88
- color: L,
89
- className: N = "",
90
- accordion: l = !1,
91
- sticky: w = !1,
92
- testId: $,
93
- variant: I
94
- } = d, [o, k] = T(), [p, R] = T(), C = B(), c = g(r["expander-list"], N);
89
+ color: _,
90
+ className: L = "",
91
+ accordion: o = !1,
92
+ sticky: I = !1,
93
+ testId: N,
94
+ variant: w,
95
+ zIndex: $ = Z.ExpanderTrigger
96
+ } = l, [p, k] = T(), [c, R] = T(), d = F(), H = C(r["expander-list"], L);
95
97
  function a(t, n) {
96
- k((e) => l ? { [n]: !(e != null && e[n]) } : { ...e, [n]: !(e != null && e[n]) }), R(t.currentTarget);
98
+ k((e) => o ? { [n]: !(e != null && e[n]) } : { ...e, [n]: !(e != null && e[n]) }), R(t.currentTarget);
97
99
  }
98
- const f = (t) => `${C}-${t}`;
100
+ const f = (t) => `${d}-${t}`;
99
101
  return V(() => {
100
- l && p && !G(p) && p.scrollIntoView();
101
- }, [l, p]), V(() => {
102
+ o && c && !J(c) && c.scrollIntoView();
103
+ }, [o, c]), V(() => {
102
104
  var n;
103
105
  const t = (n = s.Children.map(x, (e) => {
104
106
  if (v(e))
105
107
  return e;
106
108
  })) == null ? void 0 : n.reduce((e, i, m) => (typeof i.props.expanded < "u" && (e[f(m)] = i.props.expanded), e), {});
107
- k({ ...o, ...t });
108
- }, [x]), /* @__PURE__ */ s.createElement("ul", { className: c, ref: y, "data-testid": $, "data-analyticsid": U.ExpanderList }, s.Children.map(x, (t, n) => {
109
+ k({ ...p, ...t });
110
+ }, [x]), /* @__PURE__ */ s.createElement("ul", { className: H, ref: g, "data-testid": N, "data-analyticsid": U.ExpanderList }, s.Children.map(x, (t, n) => {
109
111
  if (v(t)) {
110
- const e = f(n), i = o == null ? void 0 : o[e];
112
+ const e = f(n), i = p == null ? void 0 : p[e];
111
113
  return s.cloneElement(t, {
112
114
  id: e,
113
115
  key: n,
114
116
  expanded: i,
115
- padding: h,
116
- color: L,
117
- large: _,
118
- sticky: w,
117
+ padding: y,
118
+ color: _,
119
+ large: h,
120
+ sticky: I,
119
121
  "aria-expanded": i,
120
122
  className: r["expander-list__item"],
121
- handleExpanderClick: (m) => a(m, `${C}-${n}`),
123
+ handleExpanderClick: (m) => a(m, `${d}-${n}`),
122
124
  renderChildrenWhenClosed: E,
123
- variant: I
125
+ variant: w,
126
+ zIndex: $
124
127
  });
125
128
  }
126
129
  return t;
127
130
  }));
128
131
  });
129
- W.displayName = "ExpanderList";
130
- W.Expander = H;
131
- H.displayName = "ExpanderList.Expander";
132
- const pe = W;
132
+ b.displayName = "ExpanderList";
133
+ b.Expander = W;
134
+ W.displayName = "ExpanderList.Expander";
135
+ const ce = b;
133
136
  export {
134
- W as ExpanderList,
135
- pe as default
137
+ b as ExpanderList,
138
+ ce as default
136
139
  };
137
140
  //# sourceMappingURL=ExpanderList.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ExpanderList.js","sources":["../../../src/components/ExpanderList/ExpanderList.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\n\nimport classNames from 'classnames';\n\nimport { AnalyticsId, ZIndex } from '../../constants';\nimport { useExpand } from '../../hooks/useExpand';\nimport { useHover } from '../../hooks/useHover';\nimport { useSticky } from '../../hooks/useSticky';\nimport { useUuid } from '../../hooks/useUuid';\nimport { PaletteNames } from '../../theme/palette';\nimport { mergeRefs } from '../../utils/refs';\nimport { isElementInViewport } from '../../utils/viewport';\nimport ChevronDown from '../Icons/ChevronDown';\nimport ChevronUp from '../Icons/ChevronUp';\nimport { ListHeaderType, renderListHeader } from '../ListHeader/ListHeader';\nimport { TitleTags } from '../Title';\n\nimport expanderListStyles from './styles.module.scss';\n\nexport type ExpanderListColors = PaletteNames;\nexport interface ExpanderType extends React.ForwardRefExoticComponent<ExpanderProps & React.RefAttributes<HTMLLIElement>> {\n ListHeader?: ListHeaderType;\n}\n\nexport interface ExpanderListCompound extends React.ForwardRefExoticComponent<ExpanderListProps & React.RefAttributes<HTMLUListElement>> {\n Expander: ExpanderType;\n}\n\nexport type ExpanderListVariant = 'line' | 'outline' | 'fill';\n\ninterface ExpanderListProps {\n /** Toggles accordion functionality for the expanders. */\n accordion?: boolean;\n /** Items in the ExpanderList */\n children: React.ReactNode;\n /** Toggles padding of child elements */\n childPadding?: boolean;\n /** Adds custom classes to the element. */\n className?: string;\n /** Changes the link list background color on hover. */\n color?: ExpanderListColors;\n /** Changes the font size. */\n large?: boolean;\n /** Whether to render children when closed (in which case they are hidden with CSS). Default: false */\n renderChildrenWhenClosed?: boolean;\n /** Stick expander trigger to top of screen while scrolling down */\n sticky?: boolean;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Sets visual priority */\n variant?: ExpanderListVariant;\n}\n\ntype Modify<T, R> = Omit<T, keyof R> & R;\n\ntype ExpanderProps = Modify<\n React.HTMLAttributes<HTMLButtonElement>,\n {\n id?: string;\n title: JSX.Element | string;\n /** Changes the underlying element of the title. Default: span*/\n titleHtmlMarkup?: TitleTags;\n children: React.ReactNode;\n className?: string;\n color?: ExpanderListColors;\n icon?: React.ReactElement;\n padding?: boolean;\n expanded?: boolean;\n large?: boolean;\n testId?: string;\n handleExpanderClick?: (event: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n /** Called when expander is open/closed. */\n onExpand?: (isExpanded: boolean) => void;\n }\n> &\n Pick<ExpanderListProps, 'renderChildrenWhenClosed' | 'sticky' | 'variant'>;\n\nconst Expander: ExpanderType = React.forwardRef<HTMLLIElement, ExpanderProps>((props, ref) => {\n const {\n id,\n children,\n padding = true,\n color = 'neutral',\n className = '',\n icon,\n large = false,\n title,\n titleHtmlMarkup = 'span',\n expanded = false,\n sticky,\n testId,\n handleExpanderClick,\n onExpand,\n renderChildrenWhenClosed,\n variant = 'line',\n } = props;\n const [isExpanded] = useExpand(expanded, onExpand);\n const expanderRef = useRef<HTMLLIElement>(null);\n const triggerRef = useRef<HTMLButtonElement>(null);\n const { isHovered } = useHover(triggerRef);\n\n const { isOutsideWindow, isLeavingWindow, offsetHeight, contentWidth } = useSticky(expanderRef, triggerRef);\n const isSticky = sticky && isExpanded && isOutsideWindow;\n\n const itemClasses = classNames(\n className,\n (variant === 'line' || variant === 'outline') && expanderListStyles[`expander-list__item--${variant}`]\n );\n\n const expanderClasses = classNames(\n expanderListStyles['expander-list-link'],\n color !== 'black' && expanderListStyles[`expander-list-link--${color}`],\n {\n [expanderListStyles['expander-list-link--fill']]: variant === 'fill',\n [expanderListStyles['expander-list-link--closed']]: !isExpanded,\n [expanderListStyles['expander-list-link--large']]: large,\n [expanderListStyles['expander-list-link--sticky']]: isSticky && !isLeavingWindow,\n [expanderListStyles['expander-list-link--absolute']]: isSticky && isLeavingWindow,\n }\n );\n\n const renderContent = () => {\n if (!renderChildrenWhenClosed && !isExpanded) {\n return null;\n }\n\n const mainContentClasses = classNames(\n expanderListStyles['expander-list-link__main-content'],\n isExpanded && expanderListStyles['expander-list-link__main-content--expanded'],\n padding ? expanderListStyles['expander-list-link__main-content--padding'] : ''\n );\n\n return <div className={mainContentClasses}>{children}</div>;\n };\n\n return (\n <li\n className={itemClasses}\n ref={mergeRefs([ref, expanderRef])}\n style={{ paddingTop: isSticky && offsetHeight ? `${offsetHeight}px` : undefined }}\n >\n <button\n type=\"button\"\n id={id}\n onClick={handleExpanderClick}\n data-testid={testId}\n data-analyticsid={AnalyticsId.ExpanderListExpander}\n className={expanderClasses}\n ref={triggerRef}\n aria-expanded={isExpanded}\n style={{\n zIndex: isHovered || isSticky ? ZIndex.ExpanderTrigger : undefined,\n width: isSticky && contentWidth ? `${contentWidth}px` : undefined,\n }}\n >\n {renderListHeader(title, titleHtmlMarkup, isHovered, large ? 'large' : 'medium', isExpanded ? ChevronUp : ChevronDown, icon)}\n </button>\n {renderContent()}\n </li>\n );\n});\n\ntype ActiveExpander = Record<string, boolean>;\n\nconst isExpanderComponent = (element: {} | null | undefined): element is React.ReactElement<ExpanderProps> =>\n React.isValidElement<ExpanderProps>(element) && (element as React.ReactElement).type === Expander;\n\nexport const ExpanderList = React.forwardRef((props: ExpanderListProps, ref: React.Ref<HTMLUListElement>) => {\n const {\n children,\n childPadding = true,\n large,\n renderChildrenWhenClosed = false,\n color,\n className = '',\n accordion = false,\n sticky = false,\n testId,\n variant,\n } = props;\n const [activeExpander, setActiveExpander] = useState<ActiveExpander>();\n const [latestExpander, setLatestExpander] = useState<HTMLElement>();\n const uuid = useUuid();\n const expanderListClasses = classNames(expanderListStyles['expander-list'], className);\n\n function handleExpanderClick(event: React.MouseEvent<HTMLElement, MouseEvent>, id: string): void {\n setActiveExpander(prevState => (accordion ? { [id]: !prevState?.[id] } : { ...prevState, [id]: !prevState?.[id] }));\n setLatestExpander(event.currentTarget);\n }\n\n const getExpanderId = (index: number) => `${uuid}-${index}`;\n\n useEffect(() => {\n if (accordion && latestExpander && !isElementInViewport(latestExpander)) {\n latestExpander.scrollIntoView();\n }\n }, [accordion, latestExpander]);\n\n useEffect(() => {\n const newActiveExpander = React.Children.map(children, child => {\n if (isExpanderComponent(child)) {\n return child;\n }\n })?.reduce((acc, child, index) => {\n // Expanded-status skal bare settes dersom prop er satt av den som bruker komponenten\n if (typeof child.props.expanded !== 'undefined') {\n acc[getExpanderId(index)] = child.props.expanded;\n }\n return acc;\n }, {} as ActiveExpander);\n\n setActiveExpander({ ...activeExpander, ...newActiveExpander });\n }, [children]);\n\n return (\n <ul className={expanderListClasses} ref={ref} data-testid={testId} data-analyticsid={AnalyticsId.ExpanderList}>\n {React.Children.map(children, (child, index) => {\n if (isExpanderComponent(child)) {\n const id = getExpanderId(index);\n const expanded = activeExpander?.[id];\n\n return React.cloneElement(child as React.ReactElement<ExpanderProps>, {\n id,\n key: index,\n expanded,\n padding: childPadding,\n color,\n large,\n sticky,\n 'aria-expanded': expanded,\n className: expanderListStyles['expander-list__item'],\n handleExpanderClick: (event: React.MouseEvent<HTMLElement>) => handleExpanderClick(event, `${uuid}-${index}`),\n renderChildrenWhenClosed,\n variant,\n });\n }\n return child;\n })}\n </ul>\n );\n}) as ExpanderListCompound;\n\nExpanderList.displayName = 'ExpanderList';\nExpanderList.Expander = Expander;\nExpander.displayName = 'ExpanderList.Expander';\n\nexport default ExpanderList;\n"],"names":["Expander","React","props","ref","id","children","padding","color","className","icon","large","title","titleHtmlMarkup","expanded","sticky","testId","handleExpanderClick","onExpand","renderChildrenWhenClosed","variant","isExpanded","useExpand","expanderRef","useRef","triggerRef","isHovered","useHover","isOutsideWindow","isLeavingWindow","offsetHeight","contentWidth","useSticky","isSticky","itemClasses","classNames","expanderListStyles","expanderClasses","renderContent","mainContentClasses","mergeRefs","AnalyticsId","ZIndex","renderListHeader","ChevronUp","ChevronDown","isExpanderComponent","element","ExpanderList","childPadding","accordion","activeExpander","setActiveExpander","useState","latestExpander","setLatestExpander","uuid","useUuid","expanderListClasses","event","prevState","getExpanderId","index","useEffect","isElementInViewport","newActiveExpander","child","acc","ExpanderList$1"],"mappings":"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"}
1
+ {"version":3,"file":"ExpanderList.js","sources":["../../../src/components/ExpanderList/ExpanderList.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\n\nimport classNames from 'classnames';\n\nimport { AnalyticsId, ZIndex } from '../../constants';\nimport { useExpand } from '../../hooks/useExpand';\nimport { useHover } from '../../hooks/useHover';\nimport { useSticky } from '../../hooks/useSticky';\nimport { useUuid } from '../../hooks/useUuid';\nimport { PaletteNames } from '../../theme/palette';\nimport { mergeRefs } from '../../utils/refs';\nimport { isElementInViewport } from '../../utils/viewport';\nimport ChevronDown from '../Icons/ChevronDown';\nimport ChevronUp from '../Icons/ChevronUp';\nimport { ListHeaderType, renderListHeader } from '../ListHeader/ListHeader';\nimport { TitleTags } from '../Title';\n\nimport expanderListStyles from './styles.module.scss';\n\nexport type ExpanderListColors = PaletteNames;\nexport interface ExpanderType extends React.ForwardRefExoticComponent<ExpanderProps & React.RefAttributes<HTMLLIElement>> {\n ListHeader?: ListHeaderType;\n}\n\nexport interface ExpanderListCompound extends React.ForwardRefExoticComponent<ExpanderListProps & React.RefAttributes<HTMLUListElement>> {\n Expander: ExpanderType;\n}\n\nexport type ExpanderListVariant = 'line' | 'outline' | 'fill';\n\ninterface ExpanderListProps {\n /** Toggles accordion functionality for the expanders. */\n accordion?: boolean;\n /** Items in the ExpanderList */\n children: React.ReactNode;\n /** Toggles padding of child elements */\n childPadding?: boolean;\n /** Adds custom classes to the element. */\n className?: string;\n /** Changes the link list background color on hover. */\n color?: ExpanderListColors;\n /** Changes the font size. */\n large?: boolean;\n /** Whether to render children when closed (in which case they are hidden with CSS). Default: false */\n renderChildrenWhenClosed?: boolean;\n /** Stick expander trigger to top of screen while scrolling down */\n sticky?: boolean;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** Sets visual priority */\n variant?: ExpanderListVariant;\n /** Overrides the default z-index of the expander header */\n zIndex?: number;\n}\n\ntype Modify<T, R> = Omit<T, keyof R> & R;\n\ntype ExpanderProps = Modify<\n React.HTMLAttributes<HTMLButtonElement>,\n {\n id?: string;\n title: JSX.Element | string;\n /** Changes the underlying element of the title. Default: span*/\n titleHtmlMarkup?: TitleTags;\n children: React.ReactNode;\n className?: string;\n color?: ExpanderListColors;\n icon?: React.ReactElement;\n padding?: boolean;\n expanded?: boolean;\n large?: boolean;\n testId?: string;\n handleExpanderClick?: (event: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n /** Called when expander is open/closed. */\n onExpand?: (isExpanded: boolean) => void;\n /** Overrides the default z-index of the expander header */\n zIndex?: number;\n }\n> &\n Pick<ExpanderListProps, 'renderChildrenWhenClosed' | 'sticky' | 'variant'>;\n\nconst Expander: ExpanderType = React.forwardRef<HTMLLIElement, ExpanderProps>((props, ref) => {\n const {\n id,\n children,\n padding = true,\n color = 'neutral',\n className = '',\n icon,\n large = false,\n title,\n titleHtmlMarkup = 'span',\n expanded = false,\n sticky,\n testId,\n handleExpanderClick,\n onExpand,\n renderChildrenWhenClosed,\n variant = 'line',\n zIndex,\n } = props;\n const [isExpanded] = useExpand(expanded, onExpand);\n const expanderRef = useRef<HTMLLIElement>(null);\n const triggerRef = useRef<HTMLButtonElement>(null);\n const { isHovered } = useHover(triggerRef);\n\n const { isOutsideWindow, isLeavingWindow, offsetHeight, contentWidth } = useSticky(expanderRef, triggerRef);\n const isSticky = sticky && isExpanded && isOutsideWindow;\n\n const itemClasses = classNames(\n className,\n (variant === 'line' || variant === 'outline') && expanderListStyles[`expander-list__item--${variant}`]\n );\n\n const expanderClasses = classNames(\n expanderListStyles['expander-list-link'],\n color !== 'black' && expanderListStyles[`expander-list-link--${color}`],\n {\n [expanderListStyles['expander-list-link--fill']]: variant === 'fill',\n [expanderListStyles['expander-list-link--closed']]: !isExpanded,\n [expanderListStyles['expander-list-link--large']]: large,\n [expanderListStyles['expander-list-link--sticky']]: isSticky && !isLeavingWindow,\n [expanderListStyles['expander-list-link--absolute']]: isSticky && isLeavingWindow,\n }\n );\n\n const renderContent = (): React.ReactNode => {\n if (!renderChildrenWhenClosed && !isExpanded) {\n return null;\n }\n\n const mainContentClasses = classNames(\n expanderListStyles['expander-list-link__main-content'],\n isExpanded && expanderListStyles['expander-list-link__main-content--expanded'],\n padding ? expanderListStyles['expander-list-link__main-content--padding'] : ''\n );\n\n return <div className={mainContentClasses}>{children}</div>;\n };\n\n return (\n <li\n className={itemClasses}\n ref={mergeRefs([ref, expanderRef])}\n style={{ paddingTop: isSticky && offsetHeight ? `${offsetHeight}px` : undefined }}\n >\n <button\n type=\"button\"\n id={id}\n onClick={handleExpanderClick}\n data-testid={testId}\n data-analyticsid={AnalyticsId.ExpanderListExpander}\n className={expanderClasses}\n ref={triggerRef}\n aria-expanded={isExpanded}\n style={{\n zIndex: isHovered || isSticky ? zIndex : undefined,\n width: isSticky && contentWidth ? `${contentWidth}px` : undefined,\n }}\n >\n {renderListHeader(title, titleHtmlMarkup, isHovered, large ? 'large' : 'medium', isExpanded ? ChevronUp : ChevronDown, icon)}\n </button>\n {renderContent()}\n </li>\n );\n});\n\ntype ActiveExpander = Record<string, boolean>;\n\nconst isExpanderComponent = (element: {} | null | undefined): element is React.ReactElement<ExpanderProps> =>\n React.isValidElement<ExpanderProps>(element) && (element as React.ReactElement).type === Expander;\n\nexport const ExpanderList = React.forwardRef((props: ExpanderListProps, ref: React.Ref<HTMLUListElement>) => {\n const {\n children,\n childPadding = true,\n large,\n renderChildrenWhenClosed = false,\n color,\n className = '',\n accordion = false,\n sticky = false,\n testId,\n variant,\n zIndex = ZIndex.ExpanderTrigger,\n } = props;\n const [activeExpander, setActiveExpander] = useState<ActiveExpander>();\n const [latestExpander, setLatestExpander] = useState<HTMLElement>();\n const uuid = useUuid();\n const expanderListClasses = classNames(expanderListStyles['expander-list'], className);\n\n function handleExpanderClick(event: React.MouseEvent<HTMLElement, MouseEvent>, id: string): void {\n setActiveExpander(prevState => (accordion ? { [id]: !prevState?.[id] } : { ...prevState, [id]: !prevState?.[id] }));\n setLatestExpander(event.currentTarget);\n }\n\n const getExpanderId = (index: number): string => `${uuid}-${index}`;\n\n useEffect(() => {\n if (accordion && latestExpander && !isElementInViewport(latestExpander)) {\n latestExpander.scrollIntoView();\n }\n }, [accordion, latestExpander]);\n\n useEffect(() => {\n const newActiveExpander = React.Children.map(children, child => {\n if (isExpanderComponent(child)) {\n return child;\n }\n })?.reduce((acc, child, index) => {\n // Expanded-status skal bare settes dersom prop er satt av den som bruker komponenten\n if (typeof child.props.expanded !== 'undefined') {\n acc[getExpanderId(index)] = child.props.expanded;\n }\n return acc;\n }, {} as ActiveExpander);\n\n setActiveExpander({ ...activeExpander, ...newActiveExpander });\n }, [children]);\n\n return (\n <ul className={expanderListClasses} ref={ref} data-testid={testId} data-analyticsid={AnalyticsId.ExpanderList}>\n {React.Children.map(children, (child, index) => {\n if (isExpanderComponent(child)) {\n const id = getExpanderId(index);\n const expanded = activeExpander?.[id];\n\n return React.cloneElement(child as React.ReactElement<ExpanderProps>, {\n id,\n key: index,\n expanded,\n padding: childPadding,\n color,\n large,\n sticky,\n 'aria-expanded': expanded,\n className: expanderListStyles['expander-list__item'],\n handleExpanderClick: (event: React.MouseEvent<HTMLElement>) => handleExpanderClick(event, `${uuid}-${index}`),\n renderChildrenWhenClosed,\n variant,\n zIndex: zIndex,\n });\n }\n return child;\n })}\n </ul>\n );\n}) as ExpanderListCompound;\n\nExpanderList.displayName = 'ExpanderList';\nExpanderList.Expander = Expander;\nExpander.displayName = 'ExpanderList.Expander';\n\nexport default ExpanderList;\n"],"names":["Expander","React","props","ref","id","children","padding","color","className","icon","large","title","titleHtmlMarkup","expanded","sticky","testId","handleExpanderClick","onExpand","renderChildrenWhenClosed","variant","zIndex","isExpanded","useExpand","expanderRef","useRef","triggerRef","isHovered","useHover","isOutsideWindow","isLeavingWindow","offsetHeight","contentWidth","useSticky","isSticky","itemClasses","classNames","expanderListStyles","expanderClasses","renderContent","mainContentClasses","mergeRefs","AnalyticsId","renderListHeader","ChevronUp","ChevronDown","isExpanderComponent","element","ExpanderList","childPadding","accordion","ZIndex","activeExpander","setActiveExpander","useState","latestExpander","setLatestExpander","uuid","useUuid","expanderListClasses","event","prevState","getExpanderId","index","useEffect","isElementInViewport","newActiveExpander","child","acc","ExpanderList$1"],"mappings":"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"}
@@ -30,7 +30,7 @@ declare const meta: {
30
30
  };
31
31
  color: {
32
32
  control: string;
33
- options: import("./ExpanderList").ExpanderListColors[];
33
+ options: import("../../theme/palette").PaletteNames[];
34
34
  };
35
35
  sticky: {
36
36
  control: string;