@frontify/fondue-components 18.0.0 → 18.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/dist/fondue-components.js +56 -54
  2. package/dist/fondue-components.js.map +1 -1
  3. package/dist/fondue-components10.js +28 -142
  4. package/dist/fondue-components10.js.map +1 -1
  5. package/dist/fondue-components11.js +141 -34
  6. package/dist/fondue-components11.js.map +1 -1
  7. package/dist/fondue-components12.js +36 -103
  8. package/dist/fondue-components12.js.map +1 -1
  9. package/dist/fondue-components13.js +103 -36
  10. package/dist/fondue-components13.js.map +1 -1
  11. package/dist/fondue-components14.js +30 -40
  12. package/dist/fondue-components14.js.map +1 -1
  13. package/dist/fondue-components15.js +47 -28
  14. package/dist/fondue-components15.js.map +1 -1
  15. package/dist/fondue-components16.js +28 -39
  16. package/dist/fondue-components16.js.map +1 -1
  17. package/dist/fondue-components17.js +34 -16
  18. package/dist/fondue-components17.js.map +1 -1
  19. package/dist/fondue-components18.js +21 -71
  20. package/dist/fondue-components18.js.map +1 -1
  21. package/dist/fondue-components19.js +71 -36
  22. package/dist/fondue-components19.js.map +1 -1
  23. package/dist/fondue-components20.js +34 -53
  24. package/dist/fondue-components20.js.map +1 -1
  25. package/dist/fondue-components21.js +54 -137
  26. package/dist/fondue-components21.js.map +1 -1
  27. package/dist/fondue-components22.js +136 -53
  28. package/dist/fondue-components22.js.map +1 -1
  29. package/dist/fondue-components23.js +54 -28
  30. package/dist/fondue-components23.js.map +1 -1
  31. package/dist/fondue-components24.js +28 -153
  32. package/dist/fondue-components24.js.map +1 -1
  33. package/dist/fondue-components25.js +151 -118
  34. package/dist/fondue-components25.js.map +1 -1
  35. package/dist/fondue-components26.js +120 -31
  36. package/dist/fondue-components26.js.map +1 -1
  37. package/dist/fondue-components27.js +32 -65
  38. package/dist/fondue-components27.js.map +1 -1
  39. package/dist/fondue-components28.js +65 -10
  40. package/dist/fondue-components28.js.map +1 -1
  41. package/dist/fondue-components29.js +10 -55
  42. package/dist/fondue-components29.js.map +1 -1
  43. package/dist/fondue-components3.js +1 -1
  44. package/dist/fondue-components30.js +55 -14
  45. package/dist/fondue-components30.js.map +1 -1
  46. package/dist/fondue-components31.js +15 -32
  47. package/dist/fondue-components31.js.map +1 -1
  48. package/dist/fondue-components32.js +7 -4
  49. package/dist/fondue-components32.js.map +1 -1
  50. package/dist/fondue-components33.js +7 -12
  51. package/dist/fondue-components33.js.map +1 -1
  52. package/dist/fondue-components34.js +32 -155
  53. package/dist/fondue-components34.js.map +1 -1
  54. package/dist/fondue-components35.js +5 -118
  55. package/dist/fondue-components35.js.map +1 -1
  56. package/dist/fondue-components36.js +10 -116
  57. package/dist/fondue-components36.js.map +1 -1
  58. package/dist/fondue-components37.js +147 -13
  59. package/dist/fondue-components37.js.map +1 -1
  60. package/dist/fondue-components38.js +116 -30
  61. package/dist/fondue-components38.js.map +1 -1
  62. package/dist/fondue-components39.js +118 -62
  63. package/dist/fondue-components39.js.map +1 -1
  64. package/dist/fondue-components4.js +56 -34
  65. package/dist/fondue-components4.js.map +1 -1
  66. package/dist/fondue-components40.js +20 -129
  67. package/dist/fondue-components40.js.map +1 -1
  68. package/dist/fondue-components41.js +32 -21
  69. package/dist/fondue-components41.js.map +1 -1
  70. package/dist/fondue-components42.js +62 -45
  71. package/dist/fondue-components42.js.map +1 -1
  72. package/dist/fondue-components43.js +129 -7
  73. package/dist/fondue-components43.js.map +1 -1
  74. package/dist/fondue-components44.js +21 -13
  75. package/dist/fondue-components44.js.map +1 -1
  76. package/dist/fondue-components45.js +45 -15
  77. package/dist/fondue-components45.js.map +1 -1
  78. package/dist/fondue-components46.js +8 -60
  79. package/dist/fondue-components46.js.map +1 -1
  80. package/dist/fondue-components47.js +13 -18
  81. package/dist/fondue-components47.js.map +1 -1
  82. package/dist/fondue-components48.js +12 -16
  83. package/dist/fondue-components48.js.map +1 -1
  84. package/dist/fondue-components49.js +60 -5
  85. package/dist/fondue-components49.js.map +1 -1
  86. package/dist/fondue-components5.js +32 -38
  87. package/dist/fondue-components5.js.map +1 -1
  88. package/dist/fondue-components50.js +18 -15
  89. package/dist/fondue-components50.js.map +1 -1
  90. package/dist/fondue-components51.js +18 -4
  91. package/dist/fondue-components51.js.map +1 -1
  92. package/dist/fondue-components52.js +3 -17
  93. package/dist/fondue-components52.js.map +1 -1
  94. package/dist/fondue-components53.js +15 -35
  95. package/dist/fondue-components53.js.map +1 -1
  96. package/dist/fondue-components54.js +4 -4
  97. package/dist/fondue-components55.js +17 -11
  98. package/dist/fondue-components55.js.map +1 -1
  99. package/dist/fondue-components56.js +35 -5
  100. package/dist/fondue-components56.js.map +1 -1
  101. package/dist/fondue-components57.js +4 -24
  102. package/dist/fondue-components57.js.map +1 -1
  103. package/dist/fondue-components58.js +12 -16
  104. package/dist/fondue-components58.js.map +1 -1
  105. package/dist/fondue-components59.js +4 -146
  106. package/dist/fondue-components59.js.map +1 -1
  107. package/dist/fondue-components6.js +42 -45
  108. package/dist/fondue-components6.js.map +1 -1
  109. package/dist/fondue-components60.js +25 -16
  110. package/dist/fondue-components60.js.map +1 -1
  111. package/dist/fondue-components61.js +16 -76
  112. package/dist/fondue-components61.js.map +1 -1
  113. package/dist/fondue-components62.js +147 -8
  114. package/dist/fondue-components62.js.map +1 -1
  115. package/dist/fondue-components63.js +16 -33
  116. package/dist/fondue-components63.js.map +1 -1
  117. package/dist/fondue-components64.js +75 -47
  118. package/dist/fondue-components64.js.map +1 -1
  119. package/dist/fondue-components65.js +8 -11
  120. package/dist/fondue-components65.js.map +1 -1
  121. package/dist/fondue-components66.js +32 -12
  122. package/dist/fondue-components66.js.map +1 -1
  123. package/dist/fondue-components67.js +48 -12
  124. package/dist/fondue-components67.js.map +1 -1
  125. package/dist/fondue-components68.js +10 -20
  126. package/dist/fondue-components68.js.map +1 -1
  127. package/dist/fondue-components69.js +13 -15
  128. package/dist/fondue-components69.js.map +1 -1
  129. package/dist/fondue-components7.js +46 -51
  130. package/dist/fondue-components7.js.map +1 -1
  131. package/dist/fondue-components70.js +12 -52
  132. package/dist/fondue-components70.js.map +1 -1
  133. package/dist/fondue-components71.js +20 -14
  134. package/dist/fondue-components71.js.map +1 -1
  135. package/dist/fondue-components72.js +15 -26
  136. package/dist/fondue-components72.js.map +1 -1
  137. package/dist/fondue-components73.js +55 -14
  138. package/dist/fondue-components73.js.map +1 -1
  139. package/dist/fondue-components74.js +14 -6
  140. package/dist/fondue-components74.js.map +1 -1
  141. package/dist/fondue-components75.js +23 -4
  142. package/dist/fondue-components75.js.map +1 -1
  143. package/dist/fondue-components76.js +15 -2
  144. package/dist/fondue-components76.js.map +1 -1
  145. package/dist/fondue-components77.js +5 -15
  146. package/dist/fondue-components77.js.map +1 -1
  147. package/dist/fondue-components78.js +6 -39
  148. package/dist/fondue-components78.js.map +1 -1
  149. package/dist/fondue-components79.js +5 -0
  150. package/dist/fondue-components79.js.map +1 -0
  151. package/dist/fondue-components8.js +46 -144
  152. package/dist/fondue-components8.js.map +1 -1
  153. package/dist/fondue-components80.js +8 -0
  154. package/dist/fondue-components80.js.map +1 -0
  155. package/dist/fondue-components81.js +8 -0
  156. package/dist/fondue-components81.js.map +1 -0
  157. package/dist/fondue-components82.js +20 -0
  158. package/dist/fondue-components82.js.map +1 -0
  159. package/dist/fondue-components83.js +43 -0
  160. package/dist/fondue-components83.js.map +1 -0
  161. package/dist/fondue-components9.js +146 -27
  162. package/dist/fondue-components9.js.map +1 -1
  163. package/dist/index.d.ts +70 -7
  164. package/dist/style.css +1 -1
  165. package/package.json +1 -1
@@ -1,60 +1,62 @@
1
1
  /* empty css */
2
2
  import { Accordion as t } from "./fondue-components3.js";
3
- import { Box as m } from "./fondue-components4.js";
4
- import { Button as f } from "./fondue-components5.js";
5
- import { Checkbox as l } from "./fondue-components6.js";
6
- import { ColorPicker as d } from "./fondue-components7.js";
7
- import { Dialog as c } from "./fondue-components8.js";
8
- import { Divider as S } from "./fondue-components9.js";
9
- import { Dropdown as h } from "./fondue-components10.js";
10
- import { Flex as C } from "./fondue-components11.js";
11
- import { Flyout as B } from "./fondue-components12.js";
12
- import { Grid as F } from "./fondue-components13.js";
13
- import { Heading as k } from "./fondue-components14.js";
14
- import { Label as v } from "./fondue-components15.js";
15
- import { LoadingBar as A } from "./fondue-components16.js";
16
- import { LoadingCircle as y } from "./fondue-components17.js";
17
- import { ScrollArea as H } from "./fondue-components18.js";
18
- import { Section as j } from "./fondue-components19.js";
19
- import { SegmentedControl as z } from "./fondue-components20.js";
20
- import { Select as J } from "./fondue-components21.js";
21
- import { Slider as M } from "./fondue-components22.js";
22
- import { Switch as O } from "./fondue-components23.js";
23
- import { Table as R } from "./fondue-components24.js";
24
- import { Tabs as V } from "./fondue-components25.js";
25
- import { Text as X } from "./fondue-components26.js";
26
- import { TextInput as Z } from "./fondue-components27.js";
27
- import { ThemeContext as $, ThemeProvider as oo, useFondueTheme as ro } from "./fondue-components28.js";
28
- import { Tooltip as to } from "./fondue-components29.js";
3
+ import { Badge as m } from "./fondue-components4.js";
4
+ import { Box as f } from "./fondue-components5.js";
5
+ import { Button as l } from "./fondue-components6.js";
6
+ import { Checkbox as n } from "./fondue-components7.js";
7
+ import { ColorPicker as c } from "./fondue-components8.js";
8
+ import { Dialog as g } from "./fondue-components9.js";
9
+ import { Divider as h } from "./fondue-components10.js";
10
+ import { Dropdown as C } from "./fondue-components11.js";
11
+ import { Flex as B } from "./fondue-components12.js";
12
+ import { Flyout as F } from "./fondue-components13.js";
13
+ import { Grid as k } from "./fondue-components14.js";
14
+ import { Heading as v } from "./fondue-components15.js";
15
+ import { Label as A } from "./fondue-components16.js";
16
+ import { LoadingBar as y } from "./fondue-components17.js";
17
+ import { LoadingCircle as H } from "./fondue-components18.js";
18
+ import { ScrollArea as j } from "./fondue-components19.js";
19
+ import { Section as z } from "./fondue-components20.js";
20
+ import { SegmentedControl as J } from "./fondue-components21.js";
21
+ import { Select as M } from "./fondue-components22.js";
22
+ import { Slider as O } from "./fondue-components23.js";
23
+ import { Switch as R } from "./fondue-components24.js";
24
+ import { Table as V } from "./fondue-components25.js";
25
+ import { Tabs as X } from "./fondue-components26.js";
26
+ import { Text as Z } from "./fondue-components27.js";
27
+ import { TextInput as $ } from "./fondue-components28.js";
28
+ import { ThemeContext as ro, ThemeProvider as eo, useFondueTheme as to } from "./fondue-components29.js";
29
+ import { Tooltip as mo } from "./fondue-components30.js";
29
30
  export {
30
31
  t as Accordion,
31
- m as Box,
32
- f as Button,
33
- l as Checkbox,
34
- d as ColorPicker,
35
- c as Dialog,
36
- S as Divider,
37
- h as Dropdown,
38
- C as Flex,
39
- B as Flyout,
40
- F as Grid,
41
- k as Heading,
42
- v as Label,
43
- A as LoadingBar,
44
- y as LoadingCircle,
45
- H as ScrollArea,
46
- j as Section,
47
- z as SegmentedControl,
48
- J as Select,
49
- M as Slider,
50
- O as Switch,
51
- R as Table,
52
- V as Tabs,
53
- X as Text,
54
- Z as TextInput,
55
- $ as ThemeContext,
56
- oo as ThemeProvider,
57
- to as Tooltip,
58
- ro as useFondueTheme
32
+ m as Badge,
33
+ f as Box,
34
+ l as Button,
35
+ n as Checkbox,
36
+ c as ColorPicker,
37
+ g as Dialog,
38
+ h as Divider,
39
+ C as Dropdown,
40
+ B as Flex,
41
+ F as Flyout,
42
+ k as Grid,
43
+ v as Heading,
44
+ A as Label,
45
+ y as LoadingBar,
46
+ H as LoadingCircle,
47
+ j as ScrollArea,
48
+ z as Section,
49
+ J as SegmentedControl,
50
+ M as Select,
51
+ O as Slider,
52
+ R as Switch,
53
+ V as Table,
54
+ X as Tabs,
55
+ Z as Text,
56
+ $ as TextInput,
57
+ ro as ThemeContext,
58
+ eo as ThemeProvider,
59
+ mo as Tooltip,
60
+ to as useFondueTheme
59
61
  };
60
62
  //# sourceMappingURL=fondue-components.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"fondue-components.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,147 +1,33 @@
1
- import { jsx as n, jsxs as g } from "react/jsx-runtime";
2
- import { IconCaretRight as M } from "@frontify/fondue-icons";
3
- import * as d from "@radix-ui/react-dropdown-menu";
4
- import { forwardRef as i, useMemo as G, Children as A, useRef as v } from "react";
5
- import { useFondueTheme as D, ThemeProvider as b } from "./fondue-components28.js";
6
- import { useProcessedChildren as h } from "./fondue-components47.js";
7
- import s from "./fondue-components48.js";
8
- const N = ({
9
- children: o,
10
- open: t,
11
- modal: e = !1,
12
- onOpenChange: r,
13
- "data-test-id": a = "fondue-dropdown"
14
- }) => /* @__PURE__ */ n(d.Root, { open: t, modal: e, onOpenChange: r, "data-test-id": a, children: o });
15
- N.displayName = "Dropdown.Root";
16
- const S = ({
17
- asChild: o = !0,
18
- children: t,
19
- "data-test-id": e = "fondue-dropdown-trigger",
20
- ...r
21
- }, a) => /* @__PURE__ */ n(d.Trigger, { asChild: o, "data-test-id": e, ref: a, ...r, children: t });
22
- S.displayName = "Dropdown.Trigger";
23
- const x = {
24
- compact: 8,
25
- comfortable: 12,
26
- spacious: 16
27
- }, O = {
28
- compact: 8,
29
- spacious: 24
30
- }, C = ({
31
- side: o = "bottom",
32
- align: t = "start",
33
- triggerOffset: e = "compact",
34
- children: r,
35
- preventTriggerFocusOnClose: a,
36
- viewportCollisionPadding: u = "compact",
37
- "data-test-id": p = "fondue-dropdown-content"
38
- }, l) => {
39
- const m = D();
40
- return /* @__PURE__ */ n(d.Portal, { children: /* @__PURE__ */ n(b, { theme: m, children: /* @__PURE__ */ n(
41
- d.Content,
1
+ import { jsx as d } from "react/jsx-runtime";
2
+ import * as m from "@radix-ui/react-separator";
3
+ import { forwardRef as s } from "react";
4
+ import { cn as f } from "./fondue-components36.js";
5
+ import { dividerStyles as p } from "./fondue-components49.js";
6
+ const n = s(
7
+ ({
8
+ "data-test-id": r = "fondue-divider",
9
+ direction: o = "horizontal",
10
+ className: t,
11
+ variant: i,
12
+ ...e
13
+ }, a) => /* @__PURE__ */ d(
14
+ m.Root,
42
15
  {
43
- align: t,
44
- collisionPadding: O[u],
45
- sideOffset: x[e],
46
- side: o,
47
- className: s.content,
48
- "data-test-id": p,
49
- ref: l,
50
- onCloseAutoFocus: (w) => {
51
- a && w.preventDefault();
52
- },
53
- children: r
16
+ ref: a,
17
+ className: f(
18
+ p({
19
+ direction: o,
20
+ variant: i,
21
+ ...e
22
+ }),
23
+ t
24
+ ),
25
+ "data-test-id": r
54
26
  }
55
- ) }) });
56
- };
57
- C.displayName = "Dropdown.Content";
58
- const R = ({ children: o, heading: t, "data-test-id": e = "fondue-dropdown-group" }, r) => G(
59
- () => A.toArray(o).filter((u) => u !== null).length > 0,
60
- [o]
61
- ) ? /* @__PURE__ */ g(d.Group, { className: s.group, "data-test-id": e, ref: r, children: [
62
- t ? /* @__PURE__ */ n("div", { className: s.groupHeading, children: /* @__PURE__ */ n("span", { "aria-label": t, children: t }) }) : null,
63
- o
64
- ] }) : null;
65
- R.displayName = "Dropdown.Group";
66
- const T = ({
67
- children: o,
68
- "data-test-id": t = "fondue-dropdown-submenu"
69
- }) => /* @__PURE__ */ n(d.Sub, { "data-test-id": t, children: o });
70
- T.displayName = "Dropdown.SubMenu";
71
- const I = ({ children: o, "data-test-id": t = "fondue-dropdown-subtrigger" }, e) => {
72
- const { content: r } = h(o);
73
- return /* @__PURE__ */ g(d.SubTrigger, { className: s.subTrigger, "data-test-id": t, ref: e, children: [
74
- r,
75
- /* @__PURE__ */ n(M, { className: s.subMenuIndicator, size: 16 })
76
- ] });
77
- };
78
- I.displayName = "Dropdown.SubTrigger";
79
- const F = ({ children: o, "data-test-id": t = "fondue-dropdown-subcontent" }, e) => {
80
- const r = D();
81
- return /* @__PURE__ */ n(d.Portal, { children: /* @__PURE__ */ n(b, { theme: r, children: /* @__PURE__ */ n(d.SubContent, { className: s.subContent, "data-test-id": t, ref: e, children: o }) }) });
82
- };
83
- F.displayName = "Dropdown.SubContent";
84
- const y = ({
85
- children: o,
86
- disabled: t,
87
- textValue: e,
88
- onSelect: r,
89
- emphasis: a = "default",
90
- asChild: u = !1,
91
- "data-test-id": p = "fondue-dropdown-subtrigger",
92
- ...l
93
- }, m) => {
94
- const { content: w } = h(o), c = v(!1);
95
- return /* @__PURE__ */ n(
96
- d.Item,
97
- {
98
- onSelect: r,
99
- className: s.item,
100
- textValue: e,
101
- "data-test-id": p,
102
- "data-emphasis": a,
103
- ref: m,
104
- disabled: t,
105
- asChild: u,
106
- "data-show-focus-ring": c.current,
107
- onMouseEnter: () => {
108
- c.current = !0;
109
- },
110
- onFocus: (f) => {
111
- c.current || (f.target.dataset.showFocusRing = "true");
112
- },
113
- onBlur: (f) => {
114
- f.target.dataset.showFocusRing = "false", c.current = !1;
115
- },
116
- ...l,
117
- children: w
118
- }
119
- );
120
- };
121
- y.displayName = "Dropdown.Item";
122
- const P = ({ children: o, name: t, "data-test-id": e = "fondue-dropdown-slot" }, r) => /* @__PURE__ */ n("div", { "data-name": t, className: s.slot, "data-test-id": e, ref: r, children: o });
123
- P.displayName = "Dropdown.Slot";
124
- const _ = i(S), j = i(C), E = i(R), L = i(I), z = i(F), B = i(y), H = i(P), Q = {
125
- Root: N,
126
- Trigger: _,
127
- Content: j,
128
- Group: E,
129
- SubMenu: T,
130
- SubTrigger: L,
131
- SubContent: z,
132
- Item: B,
133
- Slot: H
134
- };
27
+ )
28
+ );
29
+ n.displayName = "Divider";
135
30
  export {
136
- Q as Dropdown,
137
- C as DropdownContent,
138
- R as DropdownGroup,
139
- y as DropdownItem,
140
- N as DropdownRoot,
141
- P as DropdownSlot,
142
- F as DropdownSubContent,
143
- T as DropdownSubMenu,
144
- I as DropdownSubTrigger,
145
- S as DropdownTrigger
31
+ n as Divider
146
32
  };
147
33
  //# sourceMappingURL=fondue-components10.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components10.js","sources":["../src/components/Dropdown/Dropdown.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { IconCaretRight } from '@frontify/fondue-icons';\nimport * as RadixDropdown from '@radix-ui/react-dropdown-menu';\nimport { Children, forwardRef, useMemo, useRef, type ForwardedRef, type ReactNode } from 'react';\n\nimport { ThemeProvider, useFondueTheme } from '../ThemeProvider/ThemeProvider';\n\nimport { useProcessedChildren } from './hooks/useProcessedChildren';\nimport styles from './styles/dropdown.module.scss';\n\nexport type DropdownRootProps = {\n children?: ReactNode;\n /**\n * When set to true, interaction with outside elements will be disabled and only menu content will be visible to screen readers.\n * @default false\n */\n modal?: boolean;\n /**\n * Controls the open state of the dropdown.\n */\n open?: boolean;\n /**\n * Callback that is called when the open state of the dropdown changes.\n */\n onOpenChange?: (open: boolean) => void;\n\n 'data-test-id'?: string;\n};\n\nexport const DropdownRoot = ({\n children,\n open,\n modal = false,\n onOpenChange,\n 'data-test-id': dataTestId = 'fondue-dropdown',\n}: DropdownRootProps) => {\n return (\n <RadixDropdown.Root open={open} modal={modal} onOpenChange={onOpenChange} data-test-id={dataTestId}>\n {children}\n </RadixDropdown.Root>\n );\n};\nDropdownRoot.displayName = 'Dropdown.Root';\n\nexport type DropdownTriggerProps = {\n /**\n * Change the default rendered element for the one passed as a child, merging their props and behavior.\n * @default true\n */\n asChild?: boolean;\n children?: ReactNode;\n 'data-test-id'?: string;\n};\n\nexport const DropdownTrigger = (\n {\n asChild = true,\n children,\n 'data-test-id': dataTestId = 'fondue-dropdown-trigger',\n ...props\n }: DropdownTriggerProps,\n ref: ForwardedRef<HTMLButtonElement>,\n) => {\n return (\n <RadixDropdown.Trigger asChild={asChild} data-test-id={dataTestId} ref={ref} {...props}>\n {children}\n </RadixDropdown.Trigger>\n );\n};\nDropdownTrigger.displayName = 'Dropdown.Trigger';\n\ntype DropdownSpacing = 'compact' | 'comfortable' | 'spacious';\ntype DropdownViewportCollisionPadding = 'compact' | 'spacious';\nexport type DropdownContentProps = {\n children?: ReactNode;\n 'data-test-id'?: string;\n /**\n * Defines the alignment of the dropdown.\n * @default \"start\"\n */\n align?: 'start' | 'center' | 'end';\n /**\n * Defines the preferred side of the dropdown. It will not be respected if there are collisions with the viewport.\n * @default \"bottom\"\n */\n side?: 'top' | 'right' | 'bottom' | 'left';\n /**\n * Defines the spacing between the dropdown and its trigger.\n * @default 'compact'\n */\n triggerOffset?: DropdownSpacing;\n /**\n * Prevents the focus from being set on the trigger when the dropdown is closed.\n */\n preventTriggerFocusOnClose?: boolean;\n /**\n * Define the minimum distance between the dropdown and the viewport edge\n * @default 'compact'\n */\n viewportCollisionPadding?: DropdownViewportCollisionPadding;\n};\n\nconst SPACING_MAP: Record<DropdownSpacing, number> = {\n compact: 8,\n comfortable: 12,\n spacious: 16,\n};\n\nconst VIEWPORT_COLLISION_PADDING_MAP: Record<DropdownViewportCollisionPadding, number> = {\n compact: 8,\n spacious: 24,\n};\n\nexport const DropdownContent = (\n {\n side = 'bottom',\n align = 'start',\n triggerOffset = 'compact',\n children,\n preventTriggerFocusOnClose,\n viewportCollisionPadding = 'compact',\n 'data-test-id': dataTestId = 'fondue-dropdown-content',\n }: DropdownContentProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const theme = useFondueTheme();\n\n return (\n <RadixDropdown.Portal>\n <ThemeProvider theme={theme}>\n <RadixDropdown.Content\n align={align}\n collisionPadding={VIEWPORT_COLLISION_PADDING_MAP[viewportCollisionPadding]}\n sideOffset={SPACING_MAP[triggerOffset]}\n side={side}\n className={styles.content}\n data-test-id={dataTestId}\n ref={ref}\n onCloseAutoFocus={(event) => {\n if (preventTriggerFocusOnClose) {\n event.preventDefault();\n }\n }}\n >\n {children}\n </RadixDropdown.Content>\n </ThemeProvider>\n </RadixDropdown.Portal>\n );\n};\nDropdownContent.displayName = 'Dropdown.Content';\n\nexport type DropdownGroupProps = { children: ReactNode; heading?: string; 'data-test-id'?: string };\n\nexport const DropdownGroup = (\n { children, heading, 'data-test-id': dataTestId = 'fondue-dropdown-group' }: DropdownGroupProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const hasChildren = useMemo(\n () => Children.toArray(children).filter((child) => child !== null).length > 0,\n [children],\n );\n\n if (!hasChildren) {\n return null;\n }\n\n return (\n <RadixDropdown.Group className={styles.group} data-test-id={dataTestId} ref={ref}>\n {heading ? (\n <div className={styles.groupHeading}>\n <span aria-label={heading}>{heading}</span>\n </div>\n ) : null}\n {children}\n </RadixDropdown.Group>\n );\n};\nDropdownGroup.displayName = 'Dropdown.Group';\n\nexport type DropdownSubMenuProps = { children: ReactNode; 'data-test-id'?: string };\n\nexport const DropdownSubMenu = ({\n children,\n 'data-test-id': dataTestId = 'fondue-dropdown-submenu',\n}: DropdownSubMenuProps) => {\n return <RadixDropdown.Sub data-test-id={dataTestId}>{children}</RadixDropdown.Sub>;\n};\nDropdownSubMenu.displayName = 'Dropdown.SubMenu';\n\nexport type DropdownSubTriggerProps = { children: ReactNode; 'data-test-id'?: string };\n\nexport const DropdownSubTrigger = (\n { children, 'data-test-id': dataTestId = 'fondue-dropdown-subtrigger' }: DropdownSubTriggerProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const { content } = useProcessedChildren(children);\n return (\n <RadixDropdown.SubTrigger className={styles.subTrigger} data-test-id={dataTestId} ref={ref}>\n {content}\n <IconCaretRight className={styles.subMenuIndicator} size={16} />\n </RadixDropdown.SubTrigger>\n );\n};\nDropdownSubTrigger.displayName = 'Dropdown.SubTrigger';\n\nexport type DropdownSubContentProps = {\n children: ReactNode;\n 'data-test-id'?: string;\n};\n\nexport const DropdownSubContent = (\n { children, 'data-test-id': dataTestId = 'fondue-dropdown-subcontent' }: DropdownSubContentProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const theme = useFondueTheme();\n return (\n <RadixDropdown.Portal>\n <ThemeProvider theme={theme}>\n <RadixDropdown.SubContent className={styles.subContent} data-test-id={dataTestId} ref={ref}>\n {children}\n </RadixDropdown.SubContent>\n </ThemeProvider>\n </RadixDropdown.Portal>\n );\n};\nDropdownSubContent.displayName = 'Dropdown.SubContent';\n\nexport type DropdownItemProps = {\n children: ReactNode;\n /**\n * Disables the item.\n */\n disabled?: boolean;\n /**\n * The text value of the item that is passed to the onSelect callback.\n */\n textValue?: string;\n /**\n * The style of the item.\n * @default \"default\"\n */\n emphasis?: 'default' | 'danger';\n /**\n * Callback that is called when the item is selected.\n */\n onSelect?: (event: Event) => void;\n /**\n * If true, the item props will be passed to the child element.\n * @default false\n */\n asChild?: boolean;\n 'data-test-id'?: string;\n};\n\nexport const DropdownItem = (\n {\n children,\n disabled,\n textValue,\n onSelect,\n emphasis = 'default',\n asChild = false,\n 'data-test-id': dataTestId = 'fondue-dropdown-subtrigger',\n ...props\n }: DropdownItemProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const { content } = useProcessedChildren(children);\n const wasMouseInteracted = useRef(false);\n\n return (\n <RadixDropdown.Item\n onSelect={onSelect}\n className={styles.item}\n textValue={textValue}\n data-test-id={dataTestId}\n data-emphasis={emphasis}\n ref={ref}\n disabled={disabled}\n asChild={asChild}\n data-show-focus-ring={wasMouseInteracted.current}\n onMouseEnter={() => {\n wasMouseInteracted.current = true;\n }}\n onFocus={(focusEvent) => {\n if (!wasMouseInteracted.current) {\n focusEvent.target.dataset.showFocusRing = 'true';\n }\n }}\n onBlur={(blurEvent) => {\n blurEvent.target.dataset.showFocusRing = 'false';\n wasMouseInteracted.current = false;\n }}\n {...props}\n >\n {content}\n </RadixDropdown.Item>\n );\n};\nDropdownItem.displayName = 'Dropdown.Item';\n\nexport type DropdownSlotProps = { children: ReactNode; name?: 'left' | 'right'; 'data-test-id'?: string };\n\nexport const DropdownSlot = (\n { children, name, 'data-test-id': dataTestId = 'fondue-dropdown-slot' }: DropdownSlotProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n return (\n <div data-name={name} className={styles.slot} data-test-id={dataTestId} ref={ref}>\n {children}\n </div>\n );\n};\nDropdownSlot.displayName = 'Dropdown.Slot';\n\nconst ForwardedRefDropdownTrigger = forwardRef<HTMLButtonElement, DropdownTriggerProps>(DropdownTrigger);\nconst ForwardedRefDropdownContent = forwardRef<HTMLDivElement, DropdownContentProps>(DropdownContent);\nconst ForwardedRefDropdownGroup = forwardRef<HTMLDivElement, DropdownGroupProps>(DropdownGroup);\nconst ForwardedRefDropdownSubTrigger = forwardRef<HTMLDivElement, DropdownSubTriggerProps>(DropdownSubTrigger);\nconst ForwardedRefDropdownSubContent = forwardRef<HTMLDivElement, DropdownSubContentProps>(DropdownSubContent);\nconst ForwardedRefDropdownItem = forwardRef<HTMLDivElement, DropdownItemProps>(DropdownItem);\nconst ForwardedRefDropdownSlot = forwardRef<HTMLDivElement, DropdownSlotProps>(DropdownSlot);\n\nexport const Dropdown = {\n Root: DropdownRoot,\n Trigger: ForwardedRefDropdownTrigger,\n Content: ForwardedRefDropdownContent,\n Group: ForwardedRefDropdownGroup,\n SubMenu: DropdownSubMenu,\n SubTrigger: ForwardedRefDropdownSubTrigger,\n SubContent: ForwardedRefDropdownSubContent,\n Item: ForwardedRefDropdownItem,\n Slot: ForwardedRefDropdownSlot,\n};\n"],"names":["DropdownRoot","children","open","modal","onOpenChange","dataTestId","jsx","RadixDropdown","DropdownTrigger","asChild","props","ref","SPACING_MAP","VIEWPORT_COLLISION_PADDING_MAP","DropdownContent","side","align","triggerOffset","preventTriggerFocusOnClose","viewportCollisionPadding","theme","useFondueTheme","ThemeProvider","styles","event","DropdownGroup","heading","useMemo","Children","child","jsxs","DropdownSubMenu","DropdownSubTrigger","content","useProcessedChildren","IconCaretRight","DropdownSubContent","DropdownItem","disabled","textValue","onSelect","emphasis","wasMouseInteracted","useRef","focusEvent","blurEvent","DropdownSlot","name","ForwardedRefDropdownTrigger","forwardRef","ForwardedRefDropdownContent","ForwardedRefDropdownGroup","ForwardedRefDropdownSubTrigger","ForwardedRefDropdownSubContent","ForwardedRefDropdownItem","ForwardedRefDropdownSlot","Dropdown"],"mappings":"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"}
1
+ {"version":3,"file":"fondue-components10.js","sources":["../src/components/Divider/Divider.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport * as Separator from '@radix-ui/react-separator';\nimport { forwardRef, type ForwardedRef, type ReactElement } from 'react';\n\nimport { cn } from '#/utilities/styleUtilities';\n\nimport { dividerStyles } from './styles/dividerStyles';\n\ntype DividerStyle = 'noline' | 'dashed' | 'solid';\ntype DividerPadding = 'none' | 'small' | 'medium' | 'large';\ntype DividerDirection = 'horizontal' | 'vertical';\ntype DividerColor = 'weak' | 'default' | 'strong' | 'x-strong';\n\nexport type DividerProps = {\n /**\n * The style of the divider\n * @default \"solid\"\n */\n variant?: DividerStyle;\n /**\n * The padding of the divider\n * @default \"medium\"\n */\n padding?: DividerPadding;\n /**\n * The color of the divider\n * @default \"default\"\n */\n color?: DividerColor;\n /**\n * The direction of the divider\n * @default \"horizontal\"\n */\n direction?: DividerDirection;\n 'data-test-id'?: string;\n className?: string;\n};\n\nexport const Divider = forwardRef<HTMLDivElement, DividerProps>(\n (\n {\n 'data-test-id': dataTestId = 'fondue-divider',\n direction = 'horizontal',\n className,\n variant,\n ...props\n }: DividerProps,\n ref: ForwardedRef<HTMLDivElement | null>,\n ): ReactElement => {\n return (\n <Separator.Root\n ref={ref}\n className={cn(\n dividerStyles({\n direction,\n variant,\n ...props,\n }),\n className,\n )}\n data-test-id={dataTestId}\n />\n );\n },\n);\n\nDivider.displayName = 'Divider';\n"],"names":["Divider","forwardRef","dataTestId","direction","className","variant","props","ref","jsx","Separator","cn","dividerStyles"],"mappings":";;;;;AAuCO,MAAMA,IAAUC;AAAA,EACnB,CACI;AAAA,IACI,gBAAgBC,IAAa;AAAA,IAC7B,WAAAC,IAAY;AAAA,IACZ,WAAAC;AAAA,IACA,SAAAC;AAAA,IACA,GAAGC;AAAA,KAEPC,MAGI,gBAAAC;AAAA,IAACC,EAAU;AAAA,IAAV;AAAA,MACG,KAAAF;AAAA,MACA,WAAWG;AAAA,QACPC,EAAc;AAAA,UACV,WAAAR;AAAA,UACA,SAAAE;AAAA,UACA,GAAGC;AAAA,QAAA,CACN;AAAA,QACDF;AAAA,MACJ;AAAA,MACA,gBAAcF;AAAA,IAAA;AAAA,EAClB;AAGZ;AAEAF,EAAQ,cAAc;"}
@@ -1,40 +1,147 @@
1
- import { jsx as m } from "react/jsx-runtime";
2
- import { forwardRef as n } from "react";
3
- import { propsToCssVariables as y } from "./fondue-components31.js";
4
- import x from "./fondue-components49.js";
5
- const u = n(
6
- ({
7
- as: a = "div",
8
- "data-test-id": e = "fondue-flex",
9
- children: r,
10
- role: i,
11
- "aria-label": d,
12
- "aria-hidden": s,
13
- "aria-describedby": t,
14
- "aria-labelledby": o,
15
- "aria-expanded": l,
16
- "aria-haspopup": p,
17
- ...b
18
- }, f) => /* @__PURE__ */ m(
19
- a,
1
+ import { jsx as n, jsxs as g } from "react/jsx-runtime";
2
+ import { IconCaretRight as M } from "@frontify/fondue-icons";
3
+ import * as d from "@radix-ui/react-dropdown-menu";
4
+ import { forwardRef as i, useMemo as G, Children as A, useRef as v } from "react";
5
+ import { useFondueTheme as D, ThemeProvider as b } from "./fondue-components29.js";
6
+ import { useProcessedChildren as h } from "./fondue-components50.js";
7
+ import s from "./fondue-components51.js";
8
+ const N = ({
9
+ children: o,
10
+ open: t,
11
+ modal: e = !1,
12
+ onOpenChange: r,
13
+ "data-test-id": a = "fondue-dropdown"
14
+ }) => /* @__PURE__ */ n(d.Root, { open: t, modal: e, onOpenChange: r, "data-test-id": a, children: o });
15
+ N.displayName = "Dropdown.Root";
16
+ const S = ({
17
+ asChild: o = !0,
18
+ children: t,
19
+ "data-test-id": e = "fondue-dropdown-trigger",
20
+ ...r
21
+ }, a) => /* @__PURE__ */ n(d.Trigger, { asChild: o, "data-test-id": e, ref: a, ...r, children: t });
22
+ S.displayName = "Dropdown.Trigger";
23
+ const x = {
24
+ compact: 8,
25
+ comfortable: 12,
26
+ spacious: 16
27
+ }, O = {
28
+ compact: 8,
29
+ spacious: 24
30
+ }, C = ({
31
+ side: o = "bottom",
32
+ align: t = "start",
33
+ triggerOffset: e = "compact",
34
+ children: r,
35
+ preventTriggerFocusOnClose: a,
36
+ viewportCollisionPadding: u = "compact",
37
+ "data-test-id": p = "fondue-dropdown-content"
38
+ }, l) => {
39
+ const m = D();
40
+ return /* @__PURE__ */ n(d.Portal, { children: /* @__PURE__ */ n(b, { theme: m, children: /* @__PURE__ */ n(
41
+ d.Content,
20
42
  {
21
- className: x.root,
22
- "data-test-id": e,
23
- style: y(b, { justify: "justify-content" }),
24
- role: i,
25
- "aria-label": d,
26
- "aria-hidden": s,
27
- "aria-describedby": t,
28
- "aria-labelledby": o,
29
- "aria-expanded": l,
30
- "aria-haspopup": p,
31
- ref: f,
43
+ align: t,
44
+ collisionPadding: O[u],
45
+ sideOffset: x[e],
46
+ side: o,
47
+ className: s.content,
48
+ "data-test-id": p,
49
+ ref: l,
50
+ onCloseAutoFocus: (w) => {
51
+ a && w.preventDefault();
52
+ },
32
53
  children: r
33
54
  }
34
- )
35
- );
36
- u.displayName = "Flex";
55
+ ) }) });
56
+ };
57
+ C.displayName = "Dropdown.Content";
58
+ const R = ({ children: o, heading: t, "data-test-id": e = "fondue-dropdown-group" }, r) => G(
59
+ () => A.toArray(o).filter((u) => u !== null).length > 0,
60
+ [o]
61
+ ) ? /* @__PURE__ */ g(d.Group, { className: s.group, "data-test-id": e, ref: r, children: [
62
+ t ? /* @__PURE__ */ n("div", { className: s.groupHeading, children: /* @__PURE__ */ n("span", { "aria-label": t, children: t }) }) : null,
63
+ o
64
+ ] }) : null;
65
+ R.displayName = "Dropdown.Group";
66
+ const T = ({
67
+ children: o,
68
+ "data-test-id": t = "fondue-dropdown-submenu"
69
+ }) => /* @__PURE__ */ n(d.Sub, { "data-test-id": t, children: o });
70
+ T.displayName = "Dropdown.SubMenu";
71
+ const I = ({ children: o, "data-test-id": t = "fondue-dropdown-subtrigger" }, e) => {
72
+ const { content: r } = h(o);
73
+ return /* @__PURE__ */ g(d.SubTrigger, { className: s.subTrigger, "data-test-id": t, ref: e, children: [
74
+ r,
75
+ /* @__PURE__ */ n(M, { className: s.subMenuIndicator, size: 16 })
76
+ ] });
77
+ };
78
+ I.displayName = "Dropdown.SubTrigger";
79
+ const F = ({ children: o, "data-test-id": t = "fondue-dropdown-subcontent" }, e) => {
80
+ const r = D();
81
+ return /* @__PURE__ */ n(d.Portal, { children: /* @__PURE__ */ n(b, { theme: r, children: /* @__PURE__ */ n(d.SubContent, { className: s.subContent, "data-test-id": t, ref: e, children: o }) }) });
82
+ };
83
+ F.displayName = "Dropdown.SubContent";
84
+ const y = ({
85
+ children: o,
86
+ disabled: t,
87
+ textValue: e,
88
+ onSelect: r,
89
+ emphasis: a = "default",
90
+ asChild: u = !1,
91
+ "data-test-id": p = "fondue-dropdown-subtrigger",
92
+ ...l
93
+ }, m) => {
94
+ const { content: w } = h(o), c = v(!1);
95
+ return /* @__PURE__ */ n(
96
+ d.Item,
97
+ {
98
+ onSelect: r,
99
+ className: s.item,
100
+ textValue: e,
101
+ "data-test-id": p,
102
+ "data-emphasis": a,
103
+ ref: m,
104
+ disabled: t,
105
+ asChild: u,
106
+ "data-show-focus-ring": c.current,
107
+ onMouseEnter: () => {
108
+ c.current = !0;
109
+ },
110
+ onFocus: (f) => {
111
+ c.current || (f.target.dataset.showFocusRing = "true");
112
+ },
113
+ onBlur: (f) => {
114
+ f.target.dataset.showFocusRing = "false", c.current = !1;
115
+ },
116
+ ...l,
117
+ children: w
118
+ }
119
+ );
120
+ };
121
+ y.displayName = "Dropdown.Item";
122
+ const P = ({ children: o, name: t, "data-test-id": e = "fondue-dropdown-slot" }, r) => /* @__PURE__ */ n("div", { "data-name": t, className: s.slot, "data-test-id": e, ref: r, children: o });
123
+ P.displayName = "Dropdown.Slot";
124
+ const _ = i(S), j = i(C), E = i(R), L = i(I), z = i(F), B = i(y), H = i(P), Q = {
125
+ Root: N,
126
+ Trigger: _,
127
+ Content: j,
128
+ Group: E,
129
+ SubMenu: T,
130
+ SubTrigger: L,
131
+ SubContent: z,
132
+ Item: B,
133
+ Slot: H
134
+ };
37
135
  export {
38
- u as Flex
136
+ Q as Dropdown,
137
+ C as DropdownContent,
138
+ R as DropdownGroup,
139
+ y as DropdownItem,
140
+ N as DropdownRoot,
141
+ P as DropdownSlot,
142
+ F as DropdownSubContent,
143
+ T as DropdownSubMenu,
144
+ I as DropdownSubTrigger,
145
+ S as DropdownTrigger
39
146
  };
40
147
  //# sourceMappingURL=fondue-components11.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fondue-components11.js","sources":["../src/components/Flex/Flex.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { forwardRef, type ReactNode } from 'react';\n\nimport { type CommonAriaProps } from '#/helpers/aria';\nimport { type Responsive, type SizeValue, type LayoutComponentProps } from '#/helpers/layout';\nimport { propsToCssVariables } from '#/helpers/propsToCssVariables';\n\nimport styles from './styles/flex.module.scss';\n\nexport type FlexProps = LayoutComponentProps & {\n /**\n * The element to render the Flex component as.\n * @default 'div'\n */\n as?: 'div' | 'span';\n /**\n * The display property.\n * @default 'flex'\n */\n display?: Responsive<'none' | 'flex' | 'inline-flex'>;\n /**\n * The direction of the children.\n * @default 'row'\n */\n direction?: Responsive<'row' | 'row-reverse' | 'column' | 'column-reverse'>;\n /**\n * The alignment of the children.\n */\n align?: Responsive<'flex-start' | 'center' | 'flex-end' | 'stretch' | 'baseline'>;\n /**\n * The justification of the children.\n */\n justify?: Responsive<'flex-start' | 'center' | 'flex-end' | 'space-between' | 'space-around' | 'space-evenly'>;\n /**\n * The wrap property.\n */\n wrap?: Responsive<'nowrap' | 'wrap' | 'wrap-reverse'>;\n /**\n * The gap between the children.\n */\n gap?: Responsive<SizeValue>;\n /**\n * The horizontal gap between the children.\n */\n gapX?: Responsive<SizeValue>;\n /**\n * The vertical gap between the children.\n */\n gapY?: Responsive<SizeValue>;\n\n children?: ReactNode;\n 'data-test-id'?: string;\n} & CommonAriaProps;\n\nexport const Flex = forwardRef<HTMLDivElement, FlexProps>(\n (\n {\n as: Component = 'div',\n 'data-test-id': dataTestId = 'fondue-flex',\n children,\n role,\n 'aria-label': ariaLabel,\n 'aria-hidden': ariaHidden,\n 'aria-describedby': ariaDescribedBy,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-expanded': ariaExpanded,\n 'aria-haspopup': ariaHasPopup,\n ...props\n },\n ref,\n ) => {\n return (\n <Component\n className={styles.root}\n data-test-id={dataTestId}\n style={propsToCssVariables(props, { justify: 'justify-content' })}\n role={role}\n aria-label={ariaLabel}\n aria-hidden={ariaHidden}\n aria-describedby={ariaDescribedBy}\n aria-labelledby={ariaLabelledBy}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n ref={ref}\n >\n {children}\n </Component>\n );\n },\n);\nFlex.displayName = 'Flex';\n"],"names":["Flex","forwardRef","Component","dataTestId","children","role","ariaLabel","ariaHidden","ariaDescribedBy","ariaLabelledBy","ariaExpanded","ariaHasPopup","props","ref","jsx","styles","propsToCssVariables"],"mappings":";;;;AAuDO,MAAMA,IAAOC;AAAA,EAChB,CACI;AAAA,IACI,IAAIC,IAAY;AAAA,IAChB,gBAAgBC,IAAa;AAAA,IAC7B,UAAAC;AAAA,IACA,MAAAC;AAAA,IACA,cAAcC;AAAA,IACd,eAAeC;AAAA,IACf,oBAAoBC;AAAA,IACpB,mBAAmBC;AAAA,IACnB,iBAAiBC;AAAA,IACjB,iBAAiBC;AAAA,IACjB,GAAGC;AAAA,KAEPC,MAGI,gBAAAC;AAAA,IAACZ;AAAA,IAAA;AAAA,MACG,WAAWa,EAAO;AAAA,MAClB,gBAAcZ;AAAA,MACd,OAAOa,EAAoBJ,GAAO,EAAE,SAAS,mBAAmB;AAAA,MAChE,MAAAP;AAAA,MACA,cAAYC;AAAA,MACZ,eAAaC;AAAA,MACb,oBAAkBC;AAAA,MAClB,mBAAiBC;AAAA,MACjB,iBAAeC;AAAA,MACf,iBAAeC;AAAA,MACf,KAAAE;AAAA,MAEC,UAAAT;AAAA,IAAA;AAAA,EACL;AAGZ;AACAJ,EAAK,cAAc;"}
1
+ {"version":3,"file":"fondue-components11.js","sources":["../src/components/Dropdown/Dropdown.tsx"],"sourcesContent":["/* (c) Copyright Frontify Ltd., all rights reserved. */\n\nimport { IconCaretRight } from '@frontify/fondue-icons';\nimport * as RadixDropdown from '@radix-ui/react-dropdown-menu';\nimport { Children, forwardRef, useMemo, useRef, type ForwardedRef, type ReactNode } from 'react';\n\nimport { ThemeProvider, useFondueTheme } from '../ThemeProvider/ThemeProvider';\n\nimport { useProcessedChildren } from './hooks/useProcessedChildren';\nimport styles from './styles/dropdown.module.scss';\n\nexport type DropdownRootProps = {\n children?: ReactNode;\n /**\n * When set to true, interaction with outside elements will be disabled and only menu content will be visible to screen readers.\n * @default false\n */\n modal?: boolean;\n /**\n * Controls the open state of the dropdown.\n */\n open?: boolean;\n /**\n * Callback that is called when the open state of the dropdown changes.\n */\n onOpenChange?: (open: boolean) => void;\n\n 'data-test-id'?: string;\n};\n\nexport const DropdownRoot = ({\n children,\n open,\n modal = false,\n onOpenChange,\n 'data-test-id': dataTestId = 'fondue-dropdown',\n}: DropdownRootProps) => {\n return (\n <RadixDropdown.Root open={open} modal={modal} onOpenChange={onOpenChange} data-test-id={dataTestId}>\n {children}\n </RadixDropdown.Root>\n );\n};\nDropdownRoot.displayName = 'Dropdown.Root';\n\nexport type DropdownTriggerProps = {\n /**\n * Change the default rendered element for the one passed as a child, merging their props and behavior.\n * @default true\n */\n asChild?: boolean;\n children?: ReactNode;\n 'data-test-id'?: string;\n};\n\nexport const DropdownTrigger = (\n {\n asChild = true,\n children,\n 'data-test-id': dataTestId = 'fondue-dropdown-trigger',\n ...props\n }: DropdownTriggerProps,\n ref: ForwardedRef<HTMLButtonElement>,\n) => {\n return (\n <RadixDropdown.Trigger asChild={asChild} data-test-id={dataTestId} ref={ref} {...props}>\n {children}\n </RadixDropdown.Trigger>\n );\n};\nDropdownTrigger.displayName = 'Dropdown.Trigger';\n\ntype DropdownSpacing = 'compact' | 'comfortable' | 'spacious';\ntype DropdownViewportCollisionPadding = 'compact' | 'spacious';\nexport type DropdownContentProps = {\n children?: ReactNode;\n 'data-test-id'?: string;\n /**\n * Defines the alignment of the dropdown.\n * @default \"start\"\n */\n align?: 'start' | 'center' | 'end';\n /**\n * Defines the preferred side of the dropdown. It will not be respected if there are collisions with the viewport.\n * @default \"bottom\"\n */\n side?: 'top' | 'right' | 'bottom' | 'left';\n /**\n * Defines the spacing between the dropdown and its trigger.\n * @default 'compact'\n */\n triggerOffset?: DropdownSpacing;\n /**\n * Prevents the focus from being set on the trigger when the dropdown is closed.\n */\n preventTriggerFocusOnClose?: boolean;\n /**\n * Define the minimum distance between the dropdown and the viewport edge\n * @default 'compact'\n */\n viewportCollisionPadding?: DropdownViewportCollisionPadding;\n};\n\nconst SPACING_MAP: Record<DropdownSpacing, number> = {\n compact: 8,\n comfortable: 12,\n spacious: 16,\n};\n\nconst VIEWPORT_COLLISION_PADDING_MAP: Record<DropdownViewportCollisionPadding, number> = {\n compact: 8,\n spacious: 24,\n};\n\nexport const DropdownContent = (\n {\n side = 'bottom',\n align = 'start',\n triggerOffset = 'compact',\n children,\n preventTriggerFocusOnClose,\n viewportCollisionPadding = 'compact',\n 'data-test-id': dataTestId = 'fondue-dropdown-content',\n }: DropdownContentProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const theme = useFondueTheme();\n\n return (\n <RadixDropdown.Portal>\n <ThemeProvider theme={theme}>\n <RadixDropdown.Content\n align={align}\n collisionPadding={VIEWPORT_COLLISION_PADDING_MAP[viewportCollisionPadding]}\n sideOffset={SPACING_MAP[triggerOffset]}\n side={side}\n className={styles.content}\n data-test-id={dataTestId}\n ref={ref}\n onCloseAutoFocus={(event) => {\n if (preventTriggerFocusOnClose) {\n event.preventDefault();\n }\n }}\n >\n {children}\n </RadixDropdown.Content>\n </ThemeProvider>\n </RadixDropdown.Portal>\n );\n};\nDropdownContent.displayName = 'Dropdown.Content';\n\nexport type DropdownGroupProps = { children: ReactNode; heading?: string; 'data-test-id'?: string };\n\nexport const DropdownGroup = (\n { children, heading, 'data-test-id': dataTestId = 'fondue-dropdown-group' }: DropdownGroupProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const hasChildren = useMemo(\n () => Children.toArray(children).filter((child) => child !== null).length > 0,\n [children],\n );\n\n if (!hasChildren) {\n return null;\n }\n\n return (\n <RadixDropdown.Group className={styles.group} data-test-id={dataTestId} ref={ref}>\n {heading ? (\n <div className={styles.groupHeading}>\n <span aria-label={heading}>{heading}</span>\n </div>\n ) : null}\n {children}\n </RadixDropdown.Group>\n );\n};\nDropdownGroup.displayName = 'Dropdown.Group';\n\nexport type DropdownSubMenuProps = { children: ReactNode; 'data-test-id'?: string };\n\nexport const DropdownSubMenu = ({\n children,\n 'data-test-id': dataTestId = 'fondue-dropdown-submenu',\n}: DropdownSubMenuProps) => {\n return <RadixDropdown.Sub data-test-id={dataTestId}>{children}</RadixDropdown.Sub>;\n};\nDropdownSubMenu.displayName = 'Dropdown.SubMenu';\n\nexport type DropdownSubTriggerProps = { children: ReactNode; 'data-test-id'?: string };\n\nexport const DropdownSubTrigger = (\n { children, 'data-test-id': dataTestId = 'fondue-dropdown-subtrigger' }: DropdownSubTriggerProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const { content } = useProcessedChildren(children);\n return (\n <RadixDropdown.SubTrigger className={styles.subTrigger} data-test-id={dataTestId} ref={ref}>\n {content}\n <IconCaretRight className={styles.subMenuIndicator} size={16} />\n </RadixDropdown.SubTrigger>\n );\n};\nDropdownSubTrigger.displayName = 'Dropdown.SubTrigger';\n\nexport type DropdownSubContentProps = {\n children: ReactNode;\n 'data-test-id'?: string;\n};\n\nexport const DropdownSubContent = (\n { children, 'data-test-id': dataTestId = 'fondue-dropdown-subcontent' }: DropdownSubContentProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const theme = useFondueTheme();\n return (\n <RadixDropdown.Portal>\n <ThemeProvider theme={theme}>\n <RadixDropdown.SubContent className={styles.subContent} data-test-id={dataTestId} ref={ref}>\n {children}\n </RadixDropdown.SubContent>\n </ThemeProvider>\n </RadixDropdown.Portal>\n );\n};\nDropdownSubContent.displayName = 'Dropdown.SubContent';\n\nexport type DropdownItemProps = {\n children: ReactNode;\n /**\n * Disables the item.\n */\n disabled?: boolean;\n /**\n * The text value of the item that is passed to the onSelect callback.\n */\n textValue?: string;\n /**\n * The style of the item.\n * @default \"default\"\n */\n emphasis?: 'default' | 'danger';\n /**\n * Callback that is called when the item is selected.\n */\n onSelect?: (event: Event) => void;\n /**\n * If true, the item props will be passed to the child element.\n * @default false\n */\n asChild?: boolean;\n 'data-test-id'?: string;\n};\n\nexport const DropdownItem = (\n {\n children,\n disabled,\n textValue,\n onSelect,\n emphasis = 'default',\n asChild = false,\n 'data-test-id': dataTestId = 'fondue-dropdown-subtrigger',\n ...props\n }: DropdownItemProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n const { content } = useProcessedChildren(children);\n const wasMouseInteracted = useRef(false);\n\n return (\n <RadixDropdown.Item\n onSelect={onSelect}\n className={styles.item}\n textValue={textValue}\n data-test-id={dataTestId}\n data-emphasis={emphasis}\n ref={ref}\n disabled={disabled}\n asChild={asChild}\n data-show-focus-ring={wasMouseInteracted.current}\n onMouseEnter={() => {\n wasMouseInteracted.current = true;\n }}\n onFocus={(focusEvent) => {\n if (!wasMouseInteracted.current) {\n focusEvent.target.dataset.showFocusRing = 'true';\n }\n }}\n onBlur={(blurEvent) => {\n blurEvent.target.dataset.showFocusRing = 'false';\n wasMouseInteracted.current = false;\n }}\n {...props}\n >\n {content}\n </RadixDropdown.Item>\n );\n};\nDropdownItem.displayName = 'Dropdown.Item';\n\nexport type DropdownSlotProps = { children: ReactNode; name?: 'left' | 'right'; 'data-test-id'?: string };\n\nexport const DropdownSlot = (\n { children, name, 'data-test-id': dataTestId = 'fondue-dropdown-slot' }: DropdownSlotProps,\n ref: ForwardedRef<HTMLDivElement>,\n) => {\n return (\n <div data-name={name} className={styles.slot} data-test-id={dataTestId} ref={ref}>\n {children}\n </div>\n );\n};\nDropdownSlot.displayName = 'Dropdown.Slot';\n\nconst ForwardedRefDropdownTrigger = forwardRef<HTMLButtonElement, DropdownTriggerProps>(DropdownTrigger);\nconst ForwardedRefDropdownContent = forwardRef<HTMLDivElement, DropdownContentProps>(DropdownContent);\nconst ForwardedRefDropdownGroup = forwardRef<HTMLDivElement, DropdownGroupProps>(DropdownGroup);\nconst ForwardedRefDropdownSubTrigger = forwardRef<HTMLDivElement, DropdownSubTriggerProps>(DropdownSubTrigger);\nconst ForwardedRefDropdownSubContent = forwardRef<HTMLDivElement, DropdownSubContentProps>(DropdownSubContent);\nconst ForwardedRefDropdownItem = forwardRef<HTMLDivElement, DropdownItemProps>(DropdownItem);\nconst ForwardedRefDropdownSlot = forwardRef<HTMLDivElement, DropdownSlotProps>(DropdownSlot);\n\nexport const Dropdown = {\n Root: DropdownRoot,\n Trigger: ForwardedRefDropdownTrigger,\n Content: ForwardedRefDropdownContent,\n Group: ForwardedRefDropdownGroup,\n SubMenu: DropdownSubMenu,\n SubTrigger: ForwardedRefDropdownSubTrigger,\n SubContent: ForwardedRefDropdownSubContent,\n Item: ForwardedRefDropdownItem,\n Slot: ForwardedRefDropdownSlot,\n};\n"],"names":["DropdownRoot","children","open","modal","onOpenChange","dataTestId","jsx","RadixDropdown","DropdownTrigger","asChild","props","ref","SPACING_MAP","VIEWPORT_COLLISION_PADDING_MAP","DropdownContent","side","align","triggerOffset","preventTriggerFocusOnClose","viewportCollisionPadding","theme","useFondueTheme","ThemeProvider","styles","event","DropdownGroup","heading","useMemo","Children","child","jsxs","DropdownSubMenu","DropdownSubTrigger","content","useProcessedChildren","IconCaretRight","DropdownSubContent","DropdownItem","disabled","textValue","onSelect","emphasis","wasMouseInteracted","useRef","focusEvent","blurEvent","DropdownSlot","name","ForwardedRefDropdownTrigger","forwardRef","ForwardedRefDropdownContent","ForwardedRefDropdownGroup","ForwardedRefDropdownSubTrigger","ForwardedRefDropdownSubContent","ForwardedRefDropdownItem","ForwardedRefDropdownSlot","Dropdown"],"mappings":"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"}