@alfadocs/ui-kit-debug 0.17.1 → 0.17.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/dist/_chunks/{accordion-DOmxGEWU.js → accordion-CNcodXuO.js} +6 -6
  2. package/dist/_chunks/{accordion-DOmxGEWU.js.map → accordion-CNcodXuO.js.map} +1 -1
  3. package/dist/_chunks/{ai-prompt-input-DEiQwIMn.js → ai-prompt-input-B-w5Rx3V.js} +184 -181
  4. package/dist/_chunks/ai-prompt-input-B-w5Rx3V.js.map +1 -0
  5. package/dist/_chunks/{alert-pgdXrEO5.js → alert-DBnawbmf.js} +64 -59
  6. package/dist/_chunks/alert-DBnawbmf.js.map +1 -0
  7. package/dist/_chunks/{audio-recorder-CRh4uyFL.js → audio-recorder-DNkQLW1G.js} +3 -3
  8. package/dist/_chunks/{audio-recorder-CRh4uyFL.js.map → audio-recorder-DNkQLW1G.js.map} +1 -1
  9. package/dist/_chunks/{autocomplete-mOg7WLOh.js → autocomplete-BxfabhZ8.js} +167 -164
  10. package/dist/_chunks/autocomplete-BxfabhZ8.js.map +1 -0
  11. package/dist/_chunks/{balance-cell-renderer-DWWtX-VM.js → balance-cell-renderer-DJB6WDPe.js} +2 -2
  12. package/dist/_chunks/{balance-cell-renderer-DWWtX-VM.js.map → balance-cell-renderer-DJB6WDPe.js.map} +1 -1
  13. package/dist/_chunks/{chat-input-UK-bXU7u.js → chat-input-B3XmFGDw.js} +123 -122
  14. package/dist/_chunks/chat-input-B3XmFGDw.js.map +1 -0
  15. package/dist/_chunks/checkbox-group-Bwmt1ovQ.js +213 -0
  16. package/dist/_chunks/checkbox-group-Bwmt1ovQ.js.map +1 -0
  17. package/dist/_chunks/{checkbox-D5EHnB14.js → checkbox-mwbrPZDY.js} +75 -70
  18. package/dist/_chunks/checkbox-mwbrPZDY.js.map +1 -0
  19. package/dist/_chunks/{collapsible-CuxUBoHJ.js → collapsible-hHiyZp0b.js} +61 -63
  20. package/dist/_chunks/collapsible-hHiyZp0b.js.map +1 -0
  21. package/dist/_chunks/{color-picker-BPfcByHH.js → color-picker-Bm-gzpsh.js} +2 -2
  22. package/dist/_chunks/{color-picker-BPfcByHH.js.map → color-picker-Bm-gzpsh.js.map} +1 -1
  23. package/dist/_chunks/{combobox-D5tWe0t_.js → combobox-Da9eq00i.js} +214 -211
  24. package/dist/_chunks/combobox-Da9eq00i.js.map +1 -0
  25. package/dist/_chunks/{copy-field-BCHAZ8QV.js → copy-field-BAF4mt9h.js} +95 -132
  26. package/dist/_chunks/copy-field-BAF4mt9h.js.map +1 -0
  27. package/dist/_chunks/{date-picker-BlhtBhPo.js → date-picker-BIoSLRly.js} +222 -219
  28. package/dist/_chunks/{date-picker-BlhtBhPo.js.map → date-picker-BIoSLRly.js.map} +1 -1
  29. package/dist/_chunks/{date-range-picker-C2hRu_Ke.js → date-range-picker-9gANFNG9.js} +81 -78
  30. package/dist/_chunks/date-range-picker-9gANFNG9.js.map +1 -0
  31. package/dist/_chunks/{date-time-picker-B67mPZmP.js → date-time-picker-DG7BiGdb.js} +98 -95
  32. package/dist/_chunks/date-time-picker-DG7BiGdb.js.map +1 -0
  33. package/dist/_chunks/{dialog-DRp6Dejy.js → dialog-DUomPCRS.js} +69 -71
  34. package/dist/_chunks/dialog-DUomPCRS.js.map +1 -0
  35. package/dist/_chunks/{dropdown-menu-dyV7gHh_.js → dropdown-menu-DZxwF23X.js} +108 -110
  36. package/dist/_chunks/dropdown-menu-DZxwF23X.js.map +1 -0
  37. package/dist/_chunks/{freemium-paywall-BTEiVkes.js → freemium-paywall-DXc7XlGE.js} +98 -97
  38. package/dist/_chunks/freemium-paywall-DXc7XlGE.js.map +1 -0
  39. package/dist/_chunks/{leo-sidebar-D3TuyH5_.js → leo-sidebar-DIsiTju3.js} +2 -2
  40. package/dist/_chunks/{leo-sidebar-D3TuyH5_.js.map → leo-sidebar-DIsiTju3.js.map} +1 -1
  41. package/dist/_chunks/{list-DcjV0m5B.js → list-BdvDctBz.js} +184 -180
  42. package/dist/_chunks/list-BdvDctBz.js.map +1 -0
  43. package/dist/_chunks/{message-tray-Fsend-du.js → message-tray-BNAS8al4.js} +111 -111
  44. package/dist/_chunks/message-tray-BNAS8al4.js.map +1 -0
  45. package/dist/_chunks/{multi-select-DooDzQIp.js → multi-select-CyspR5ZF.js} +157 -154
  46. package/dist/_chunks/multi-select-CyspR5ZF.js.map +1 -0
  47. package/dist/_chunks/{navigation-menu-DdufF-_4.js → navigation-menu-CyS1fBJ7.js} +85 -87
  48. package/dist/_chunks/navigation-menu-CyS1fBJ7.js.map +1 -0
  49. package/dist/_chunks/{notification-tray-C3dYdLAF.js → notification-tray-D_69dXFY.js} +114 -114
  50. package/dist/_chunks/notification-tray-D_69dXFY.js.map +1 -0
  51. package/dist/_chunks/{number-input-DH00o0DN.js → number-input-BZXu6bPY.js} +92 -89
  52. package/dist/_chunks/number-input-BZXu6bPY.js.map +1 -0
  53. package/dist/_chunks/{otp-input-BBXYvLx5.js → otp-input-BDF_iNpa.js} +92 -93
  54. package/dist/_chunks/otp-input-BDF_iNpa.js.map +1 -0
  55. package/dist/_chunks/{pagination-F1ei4khE.js → pagination-BWaXF7W0.js} +194 -211
  56. package/dist/_chunks/pagination-BWaXF7W0.js.map +1 -0
  57. package/dist/_chunks/{patient-shell-BE0CdPOJ.js → patient-shell-BOOaWZA9.js} +3 -3
  58. package/dist/_chunks/{patient-shell-BE0CdPOJ.js.map → patient-shell-BOOaWZA9.js.map} +1 -1
  59. package/dist/_chunks/{payment-form-CI77oIx1.js → payment-form-BjkuQeqR.js} +2 -2
  60. package/dist/_chunks/{payment-form-CI77oIx1.js.map → payment-form-BjkuQeqR.js.map} +1 -1
  61. package/dist/_chunks/{pdf-viewer-CnEJvmXC.js → pdf-viewer-BG_nsFT5.js} +2 -2
  62. package/dist/_chunks/{pdf-viewer-CnEJvmXC.js.map → pdf-viewer-BG_nsFT5.js.map} +1 -1
  63. package/dist/_chunks/{radio-group-Cz1a4QCA.js → radio-group-BHZOxrIK.js} +4 -4
  64. package/dist/_chunks/{radio-group-Cz1a4QCA.js.map → radio-group-BHZOxrIK.js.map} +1 -1
  65. package/dist/_chunks/{select-Ca6ibiDL.js → select-C92AT_OZ.js} +7 -7
  66. package/dist/_chunks/{select-Ca6ibiDL.js.map → select-C92AT_OZ.js.map} +1 -1
  67. package/dist/_chunks/{sidebar-D8Lq065m.js → sidebar-BqzlRBvC.js} +271 -291
  68. package/dist/_chunks/sidebar-BqzlRBvC.js.map +1 -0
  69. package/dist/_chunks/{slider-CkR6CLun.js → slider-CfEzeseL.js} +4 -4
  70. package/dist/_chunks/{slider-CkR6CLun.js.map → slider-CfEzeseL.js.map} +1 -1
  71. package/dist/_chunks/{tabs-CRCyPpJo.js → tabs-aEQfQV3x.js} +8 -8
  72. package/dist/_chunks/{tabs-CRCyPpJo.js.map → tabs-aEQfQV3x.js.map} +1 -1
  73. package/dist/_chunks/{theme-toggle-B3meAb3y.js → theme-toggle-BswYl0Yp.js} +2 -2
  74. package/dist/_chunks/{theme-toggle-B3meAb3y.js.map → theme-toggle-BswYl0Yp.js.map} +1 -1
  75. package/dist/_chunks/use-controllable-state-BiY4xTzM.js +23 -0
  76. package/dist/_chunks/use-controllable-state-BiY4xTzM.js.map +1 -0
  77. package/dist/_chunks/use-copy-to-clipboard-Cyfc_dlv.js +43 -0
  78. package/dist/_chunks/use-copy-to-clipboard-Cyfc_dlv.js.map +1 -0
  79. package/dist/_chunks/use-debounced-callback-BisrB-Fq.js.map +1 -1
  80. package/dist/_chunks/use-direction-D6rvvG9G.js.map +1 -1
  81. package/dist/_chunks/use-persistent-state-i23OWy6G.js +24 -0
  82. package/dist/_chunks/use-persistent-state-i23OWy6G.js.map +1 -0
  83. package/dist/_chunks/{warning-stack-CeRihME9.js → warning-stack-CDH9TudY.js} +2 -2
  84. package/dist/_chunks/{warning-stack-CeRihME9.js.map → warning-stack-CDH9TudY.js.map} +1 -1
  85. package/dist/_chunks/{workflow-map-D3MvrsZV.js → workflow-map-BeKe23uw.js} +3 -3
  86. package/dist/_chunks/{workflow-map-D3MvrsZV.js.map → workflow-map-BeKe23uw.js.map} +1 -1
  87. package/dist/agent-catalog.json +1 -1
  88. package/dist/components/_shared/use-debounced-callback.d.ts +1 -5
  89. package/dist/components/_shared/use-debounced-callback.d.ts.map +1 -1
  90. package/dist/components/_shared/use-direction.d.ts +1 -18
  91. package/dist/components/_shared/use-direction.d.ts.map +1 -1
  92. package/dist/components/_shared/use-focus-trap.d.ts +1 -31
  93. package/dist/components/_shared/use-focus-trap.d.ts.map +1 -1
  94. package/dist/components/accordion/index.js +1 -1
  95. package/dist/components/ai-prompt-input/ai-prompt-input.d.ts.map +1 -1
  96. package/dist/components/ai-prompt-input/index.js +1 -1
  97. package/dist/components/alert/alert.d.ts.map +1 -1
  98. package/dist/components/alert/index.js +1 -1
  99. package/dist/components/audio-recorder/index.js +1 -1
  100. package/dist/components/autocomplete/autocomplete.d.ts.map +1 -1
  101. package/dist/components/autocomplete/index.js +1 -1
  102. package/dist/components/chat-input/chat-input.d.ts.map +1 -1
  103. package/dist/components/chat-input/index.js +1 -1
  104. package/dist/components/checkbox/checkbox.d.ts.map +1 -1
  105. package/dist/components/checkbox/index.js +1 -1
  106. package/dist/components/checkbox-group/checkbox-group.d.ts.map +1 -1
  107. package/dist/components/checkbox-group/index.js +1 -1
  108. package/dist/components/collapsible/collapsible.d.ts.map +1 -1
  109. package/dist/components/collapsible/index.js +1 -1
  110. package/dist/components/color-picker/index.js +1 -1
  111. package/dist/components/combobox/combobox.d.ts.map +1 -1
  112. package/dist/components/combobox/index.js +1 -1
  113. package/dist/components/command-palette/command-palette.d.ts +1 -1
  114. package/dist/components/copy-field/index.js +1 -1
  115. package/dist/components/data-table/index.js +1 -1
  116. package/dist/components/date-picker/date-picker.d.ts.map +1 -1
  117. package/dist/components/date-picker/index.js +1 -1
  118. package/dist/components/date-range-picker/date-range-picker.d.ts.map +1 -1
  119. package/dist/components/date-range-picker/index.js +1 -1
  120. package/dist/components/date-time-picker/date-time-picker.d.ts.map +1 -1
  121. package/dist/components/date-time-picker/index.js +1 -1
  122. package/dist/components/dialog/dialog.d.ts.map +1 -1
  123. package/dist/components/dialog/index.js +1 -1
  124. package/dist/components/dropdown-menu/dropdown-menu.d.ts.map +1 -1
  125. package/dist/components/dropdown-menu/index.js +1 -1
  126. package/dist/components/freemium-paywall/freemium-paywall.d.ts.map +1 -1
  127. package/dist/components/freemium-paywall/index.js +1 -1
  128. package/dist/components/icon-button-group/icon-button-group.d.ts +14 -14
  129. package/dist/components/list/index.js +1 -1
  130. package/dist/components/list/list.d.ts.map +1 -1
  131. package/dist/components/message-tray/index.js +1 -1
  132. package/dist/components/message-tray/message-tray.d.ts.map +1 -1
  133. package/dist/components/multi-select/index.js +1 -1
  134. package/dist/components/multi-select/multi-select.d.ts.map +1 -1
  135. package/dist/components/navigation-menu/index.js +1 -1
  136. package/dist/components/navigation-menu/navigation-menu.d.ts.map +1 -1
  137. package/dist/components/notification-tray/index.js +1 -1
  138. package/dist/components/notification-tray/notification-tray.d.ts.map +1 -1
  139. package/dist/components/number-input/index.js +1 -1
  140. package/dist/components/number-input/number-input.d.ts.map +1 -1
  141. package/dist/components/otp-input/index.js +1 -1
  142. package/dist/components/otp-input/otp-input.d.ts.map +1 -1
  143. package/dist/components/pagination/index.js +1 -1
  144. package/dist/components/payment-form/index.js +1 -1
  145. package/dist/components/pdf-viewer/index.js +1 -1
  146. package/dist/components/radio-group/index.js +1 -1
  147. package/dist/components/select/index.js +1 -1
  148. package/dist/components/sidebar/index.js +8 -7
  149. package/dist/components/sidebar/index.js.map +1 -1
  150. package/dist/components/sidebar/sidebar.d.ts +1 -1
  151. package/dist/components/sidebar/sidebar.d.ts.map +1 -1
  152. package/dist/components/slider/index.js +1 -1
  153. package/dist/components/tabs/index.js +1 -1
  154. package/dist/components/theme-toggle/index.js +1 -1
  155. package/dist/components/warning-stack/index.js +1 -1
  156. package/dist/components/workflow/index.js +1 -1
  157. package/dist/hooks/index.d.ts +8 -0
  158. package/dist/hooks/index.d.ts.map +1 -1
  159. package/dist/hooks/index.js +98 -15
  160. package/dist/hooks/index.js.map +1 -1
  161. package/dist/hooks/use-debounced-callback.d.ts +19 -0
  162. package/dist/hooks/use-debounced-callback.d.ts.map +1 -0
  163. package/dist/hooks/use-debounced-value.d.ts +16 -0
  164. package/dist/hooks/use-debounced-value.d.ts.map +1 -0
  165. package/dist/hooks/use-direction.d.ts +19 -0
  166. package/dist/hooks/use-direction.d.ts.map +1 -0
  167. package/dist/hooks/use-focus-trap.d.ts +32 -0
  168. package/dist/hooks/use-focus-trap.d.ts.map +1 -0
  169. package/dist/hooks/use-isomorphic-layout-effect.d.ts +13 -0
  170. package/dist/hooks/use-isomorphic-layout-effect.d.ts.map +1 -0
  171. package/dist/hooks/use-persistent-state.d.ts +16 -0
  172. package/dist/hooks/use-persistent-state.d.ts.map +1 -0
  173. package/dist/index.js +493 -492
  174. package/dist/index.js.map +1 -1
  175. package/dist/patterns/leo-assistant/index.js +1 -1
  176. package/dist/patterns/patient-shell/index.js +1 -1
  177. package/dist/tokens.css +1 -1
  178. package/package.json +4 -2
  179. package/dist/_chunks/ai-prompt-input-DEiQwIMn.js.map +0 -1
  180. package/dist/_chunks/alert-pgdXrEO5.js.map +0 -1
  181. package/dist/_chunks/autocomplete-mOg7WLOh.js.map +0 -1
  182. package/dist/_chunks/chat-input-UK-bXU7u.js.map +0 -1
  183. package/dist/_chunks/checkbox-D5EHnB14.js.map +0 -1
  184. package/dist/_chunks/checkbox-group-Qkm3Rg1S.js +0 -208
  185. package/dist/_chunks/checkbox-group-Qkm3Rg1S.js.map +0 -1
  186. package/dist/_chunks/collapsible-CuxUBoHJ.js.map +0 -1
  187. package/dist/_chunks/combobox-D5tWe0t_.js.map +0 -1
  188. package/dist/_chunks/copy-field-BCHAZ8QV.js.map +0 -1
  189. package/dist/_chunks/date-range-picker-C2hRu_Ke.js.map +0 -1
  190. package/dist/_chunks/date-time-picker-B67mPZmP.js.map +0 -1
  191. package/dist/_chunks/dialog-DRp6Dejy.js.map +0 -1
  192. package/dist/_chunks/dropdown-menu-dyV7gHh_.js.map +0 -1
  193. package/dist/_chunks/freemium-paywall-BTEiVkes.js.map +0 -1
  194. package/dist/_chunks/list-DcjV0m5B.js.map +0 -1
  195. package/dist/_chunks/message-tray-Fsend-du.js.map +0 -1
  196. package/dist/_chunks/multi-select-DooDzQIp.js.map +0 -1
  197. package/dist/_chunks/navigation-menu-DdufF-_4.js.map +0 -1
  198. package/dist/_chunks/notification-tray-C3dYdLAF.js.map +0 -1
  199. package/dist/_chunks/number-input-DH00o0DN.js.map +0 -1
  200. package/dist/_chunks/otp-input-BBXYvLx5.js.map +0 -1
  201. package/dist/_chunks/pagination-F1ei4khE.js.map +0 -1
  202. package/dist/_chunks/sidebar-D8Lq065m.js.map +0 -1
@@ -1,12 +1,13 @@
1
- import { jsx as s, jsxs as y } from "react/jsx-runtime";
2
- import { useState as k, useRef as z, useEffect as E, useCallback as I, useMemo as O, forwardRef as d, useContext as B, createContext as S } from "react";
1
+ import { jsx as s, jsxs as v } from "react/jsx-runtime";
2
+ import { useRef as R, useEffect as T, useMemo as O, forwardRef as d, useContext as j, createContext as z } from "react";
3
3
  import * as t from "@radix-ui/react-dialog";
4
- import { c as A } from "./index-D2ZczOXr.js";
5
- import { useTranslation as H } from "react-i18next";
6
- import { I as F } from "./icon-button-C4CGcYuz.js";
7
- import { u as L } from "./registry-C9nwlNyL.js";
8
- import { X as V } from "./x-CCcI3eJp.js";
9
- const $ = {
4
+ import { c as k } from "./index-D2ZczOXr.js";
5
+ import { useTranslation as E } from "react-i18next";
6
+ import { I } from "./icon-button-C4CGcYuz.js";
7
+ import { u as B } from "./use-controllable-state-BiY4xTzM.js";
8
+ import { u as S } from "./registry-C9nwlNyL.js";
9
+ import { X as A } from "./x-CCcI3eJp.js";
10
+ const H = {
10
11
  id: "dialog",
11
12
  capabilities: ["open", "close", "dismiss"],
12
13
  state: {
@@ -47,14 +48,14 @@ const $ = {
47
48
  description: "Sourced from the id prop on Dialog.Root."
48
49
  }
49
50
  }
50
- }, P = [
51
+ }, V = [
51
52
  "ds:fixed ds:inset-0 ds:z-[var(--z-modal-backdrop)]",
52
53
  "ds:bg-[var(--background)]/[var(--opacity-70)]",
53
54
  "ds:backdrop-blur-sm",
54
55
  "ds:data-[state=open]:animate-in ds:data-[state=open]:fade-in-0",
55
56
  "ds:data-[state=closed]:animate-out ds:data-[state=closed]:fade-out-0",
56
57
  "ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none"
57
- ].join(" "), _ = [
58
+ ].join(" "), F = [
58
59
  "ds:fixed ds:z-[var(--z-modal)]",
59
60
  "ds:bg-[var(--popover)] ds:text-[var(--popover-foreground)]",
60
61
  "ds:shadow-[var(--shadow-xl)]",
@@ -63,86 +64,83 @@ const $ = {
63
64
  "ds:data-[state=open]:animate-in ds:data-[state=open]:fade-in-0 ds:data-[state=open]:zoom-in-95",
64
65
  "ds:data-[state=closed]:animate-out ds:data-[state=closed]:fade-out-0 ds:data-[state=closed]:zoom-out-95",
65
66
  "ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none"
66
- ].join(" "), u = "ds:start-1/2 ds:top-1/2 ds:-translate-x-1/2 ds:-translate-y-1/2 ds:w-[calc(100%-var(--spacing-lg)*2)]", M = A(_, {
67
+ ].join(" "), g = "ds:start-1/2 ds:top-1/2 ds:-translate-x-1/2 ds:-translate-y-1/2 ds:w-[calc(100%-var(--spacing-lg)*2)]", L = k(F, {
67
68
  variants: {
68
69
  size: {
69
- sm: `${u} ds:max-w-[448px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,
70
- md: `${u} ds:max-w-[560px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,
71
- lg: `${u} ds:max-w-[720px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,
70
+ sm: `${g} ds:max-w-[448px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,
71
+ md: `${g} ds:max-w-[560px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,
72
+ lg: `${g} ds:max-w-[720px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,
72
73
  fullscreen: "ds:start-0 ds:top-0 ds:w-[100dvw] ds:h-[100dvh] ds:max-w-none ds:rounded-none ds:overflow-y-auto"
73
74
  }
74
75
  },
75
76
  defaultVariants: { size: "md" }
76
- }), D = S(void 0), v = ({
77
+ }), f = z(void 0), u = ({
77
78
  children: o,
78
79
  id: e,
79
80
  open: a,
80
81
  defaultOpen: r,
81
- onOpenChange: i,
82
+ onOpenChange: c,
82
83
  ...p
83
84
  }) => {
84
- const l = a !== void 0, [m, g] = k(
85
- r ?? !1
86
- ), n = l ? !!a : m, f = z(n);
87
- E(() => {
88
- f.current = n;
89
- }, [n]);
90
- const c = I(
91
- (x) => {
92
- l || g(x), i == null || i(x);
93
- },
94
- [l, i]
95
- ), j = O(
85
+ const [m, n] = B({
86
+ value: a,
87
+ defaultValue: r ?? !1,
88
+ onChange: c
89
+ }), i = m ?? !1, l = R(i);
90
+ T(() => {
91
+ l.current = i;
92
+ }, [i]);
93
+ const N = O(
96
94
  () => ({
97
- getIsOpen: () => f.current,
98
- open: () => c(!0),
99
- close: () => c(!1)
95
+ getIsOpen: () => l.current,
96
+ open: () => n(!0),
97
+ close: () => n(!1)
100
98
  }),
101
- [c]
99
+ [n]
102
100
  );
103
- return L($, j, e), /* @__PURE__ */ s(D.Provider, { value: e, children: /* @__PURE__ */ s(t.Root, { open: n, onOpenChange: c, ...p, children: o }) });
101
+ return S(H, N, e), /* @__PURE__ */ s(f.Provider, { value: e, children: /* @__PURE__ */ s(t.Root, { open: i, onOpenChange: n, ...p, children: o }) });
104
102
  };
105
- v.displayName = "Dialog.Root";
103
+ u.displayName = "Dialog.Root";
106
104
  const h = d(({ children: o, ...e }, a) => /* @__PURE__ */ s(t.Trigger, { ref: a, ...e, children: o }));
107
105
  h.displayName = "Dialog.Trigger";
108
- const b = d(({ children: o, ...e }, a) => /* @__PURE__ */ s(t.Close, { ref: a, ...e, children: o }));
109
- b.displayName = "Dialog.Close";
110
- const N = d(
106
+ const x = d(({ children: o, ...e }, a) => /* @__PURE__ */ s(t.Close, { ref: a, ...e, children: o }));
107
+ x.displayName = "Dialog.Close";
108
+ const y = d(
111
109
  ({
112
110
  size: o = "md",
113
111
  variant: e = "default",
114
112
  hideCloseButton: a = !0,
115
113
  className: r,
116
- children: i,
114
+ children: c,
117
115
  ...p
118
- }, l) => {
119
- const { t: m } = H(), g = B(D), n = e === "alert" ? { role: "alertdialog" } : {};
120
- return /* @__PURE__ */ y(t.Portal, { children: [
116
+ }, m) => {
117
+ const { t: n } = E(), i = j(f), l = e === "alert" ? { role: "alertdialog" } : {};
118
+ return /* @__PURE__ */ v(t.Portal, { children: [
121
119
  /* @__PURE__ */ s(
122
120
  t.Overlay,
123
121
  {
124
122
  "data-component": "dialog-overlay",
125
- className: P
123
+ className: V
126
124
  }
127
125
  ),
128
- /* @__PURE__ */ y(
126
+ /* @__PURE__ */ v(
129
127
  t.Content,
130
128
  {
131
- ref: l,
132
- ...n,
129
+ ref: m,
130
+ ...l,
133
131
  "data-component": "dialog",
134
- "data-component-id": g,
135
- className: M({ size: o, className: r }),
132
+ "data-component-id": i,
133
+ className: L({ size: o, className: r }),
136
134
  ...p,
137
135
  children: [
138
- i,
136
+ c,
139
137
  !a && /* @__PURE__ */ s("div", { className: "ds:absolute ds:end-[var(--spacing-md)] ds:top-[var(--spacing-md)]", children: /* @__PURE__ */ s(t.Close, { asChild: !0, children: /* @__PURE__ */ s(
140
- F,
138
+ I,
141
139
  {
142
- icon: /* @__PURE__ */ s(V, {}),
140
+ icon: /* @__PURE__ */ s(A, {}),
143
141
  intent: "ghost",
144
142
  size: "sm",
145
- "aria-label": m("common.close", "Close")
143
+ "aria-label": n("common.close", "Close")
146
144
  }
147
145
  ) }) })
148
146
  ]
@@ -151,8 +149,8 @@ const N = d(
151
149
  ] });
152
150
  }
153
151
  );
154
- N.displayName = "Dialog.Content";
155
- const w = d(
152
+ y.displayName = "Dialog.Content";
153
+ const D = d(
156
154
  ({ className: o, ...e }, a) => /* @__PURE__ */ s(
157
155
  "div",
158
156
  {
@@ -165,8 +163,8 @@ const w = d(
165
163
  }
166
164
  )
167
165
  );
168
- w.displayName = "Dialog.Header";
169
- const C = d(({ className: o, ...e }, a) => /* @__PURE__ */ s(
166
+ D.displayName = "Dialog.Header";
167
+ const b = d(({ className: o, ...e }, a) => /* @__PURE__ */ s(
170
168
  t.Title,
171
169
  {
172
170
  ref: a,
@@ -174,8 +172,8 @@ const C = d(({ className: o, ...e }, a) => /* @__PURE__ */ s(
174
172
  ...e
175
173
  }
176
174
  ));
177
- C.displayName = "Dialog.Title";
178
- const R = d(({ className: o, ...e }, a) => /* @__PURE__ */ s(
175
+ b.displayName = "Dialog.Title";
176
+ const C = d(({ className: o, ...e }, a) => /* @__PURE__ */ s(
179
177
  t.Description,
180
178
  {
181
179
  ref: a,
@@ -183,8 +181,8 @@ const R = d(({ className: o, ...e }, a) => /* @__PURE__ */ s(
183
181
  ...e
184
182
  }
185
183
  ));
186
- R.displayName = "Dialog.Description";
187
- const T = d(
184
+ C.displayName = "Dialog.Description";
185
+ const w = d(
188
186
  ({ className: o, divider: e = !1, ...a }, r) => /* @__PURE__ */ s(
189
187
  "div",
190
188
  {
@@ -199,19 +197,19 @@ const T = d(
199
197
  }
200
198
  )
201
199
  );
202
- T.displayName = "Dialog.Footer";
203
- const U = Object.assign(v, {
204
- Root: v,
200
+ w.displayName = "Dialog.Footer";
201
+ const J = Object.assign(u, {
202
+ Root: u,
205
203
  Trigger: h,
206
- Content: N,
207
- Header: w,
208
- Title: C,
209
- Description: R,
210
- Footer: T,
211
- Close: b
204
+ Content: y,
205
+ Header: D,
206
+ Title: b,
207
+ Description: C,
208
+ Footer: w,
209
+ Close: x
212
210
  });
213
211
  export {
214
- U as D,
215
- $ as d
212
+ J as D,
213
+ H as d
216
214
  };
217
- //# sourceMappingURL=dialog-DRp6Dejy.js.map
215
+ //# sourceMappingURL=dialog-DUomPCRS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dialog-DUomPCRS.js","sources":["../../src/components/dialog/dialog.agent.ts","../../src/components/dialog/dialog.tsx"],"sourcesContent":["import type { AgentAdapter } from '../../agent/types';\nimport type { DialogHandle } from './dialog';\n\n/**\n * Dialog wraps Radix Dialog. The curated handle (`DialogHandle`) bridges the\n * Radix controlled-or-uncontrolled `open` state so an agent can observe and\n * drive the dialog without owning the React state itself.\n */\nexport const dialogAgent: AgentAdapter<DialogHandle> = {\n id: 'dialog',\n capabilities: ['open', 'close', 'dismiss'],\n state: {\n isOpen: {\n type: 'boolean',\n description: 'True when the dialog is currently open.',\n read: (handle) => handle.getIsOpen(),\n },\n },\n actions: {\n open: {\n safety: 'read',\n description: 'Open the dialog.',\n invoke: (handle) => {\n handle.open();\n },\n },\n close: {\n safety: 'write',\n description: 'Close the dialog. Reversible by reopening.',\n invoke: (handle) => {\n handle.close();\n },\n },\n dismiss: {\n safety: 'destructive',\n description:\n 'Dismiss the dialog. Loses any in-progress input that has not been committed.',\n invoke: (handle) => {\n handle.close();\n },\n },\n },\n domHooks: {\n root: { attr: 'data-component', value: 'dialog' },\n instanceId: {\n attr: 'data-component-id',\n sourceProp: 'id',\n description: 'Sourced from the id prop on Dialog.Root.',\n },\n },\n};\n","import {\n createContext,\n forwardRef,\n useContext,\n useEffect,\n useMemo,\n useRef,\n type ComponentPropsWithoutRef,\n type HTMLAttributes,\n type ReactNode,\n} from 'react';\nimport * as RadixDialog from '@radix-ui/react-dialog';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { X } from 'lucide-react';\nimport { IconButton } from '../button/icon-button';\nimport { useControllableState } from '../../hooks/use-controllable-state';\nimport { useAgentRegistration } from '../../agent';\nimport { dialogAgent } from './dialog.agent';\n\nconst OVERLAY_CLASSES = [\n 'ds:fixed ds:inset-0 ds:z-[var(--z-modal-backdrop)]',\n 'ds:bg-[var(--background)]/[var(--opacity-70)]',\n 'ds:backdrop-blur-sm',\n 'ds:data-[state=open]:animate-in ds:data-[state=open]:fade-in-0',\n 'ds:data-[state=closed]:animate-out ds:data-[state=closed]:fade-out-0',\n 'ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n].join(' ');\n\nconst CONTENT_BASE = [\n 'ds:fixed ds:z-[var(--z-modal)]',\n 'ds:bg-[var(--popover)] ds:text-[var(--popover-foreground)]',\n 'ds:shadow-[var(--shadow-xl)]',\n 'ds:p-[var(--spacing-lg)]',\n 'ds:focus-visible:outline-none',\n 'ds:data-[state=open]:animate-in ds:data-[state=open]:fade-in-0 ds:data-[state=open]:zoom-in-95',\n 'ds:data-[state=closed]:animate-out ds:data-[state=closed]:fade-out-0 ds:data-[state=closed]:zoom-out-95',\n 'ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n].join(' ');\n\nconst CENTERED =\n 'ds:start-1/2 ds:top-1/2 ds:-translate-x-1/2 ds:-translate-y-1/2 ds:w-[calc(100%-var(--spacing-lg)*2)]';\n\nconst contentVariants = cva(CONTENT_BASE, {\n variants: {\n size: {\n sm: `${CENTERED} ds:max-w-[448px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,\n md: `${CENTERED} ds:max-w-[560px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,\n lg: `${CENTERED} ds:max-w-[720px] ds:rounded-[var(--radius-lg)] ds:overflow-y-auto ds:max-h-[85dvh]`,\n fullscreen:\n 'ds:start-0 ds:top-0 ds:w-[100dvw] ds:h-[100dvh] ds:max-w-none ds:rounded-none ds:overflow-y-auto',\n },\n },\n defaultVariants: { size: 'md' },\n});\n\n// Curated agent-readiness handle — see dialog.agent.ts.\nexport interface DialogHandle {\n getIsOpen: () => boolean;\n open: () => void;\n close: () => void;\n}\n\nexport interface DialogRootProps extends ComponentPropsWithoutRef<\n typeof RadixDialog.Root\n> {\n /** Opaque instance id — forwarded to Dialog.Content as `data-component-id`. */\n id?: string;\n}\n\nconst DialogIdContext = createContext<string | undefined>(undefined);\n\nconst DialogRoot = ({\n children,\n id,\n open: openProp,\n defaultOpen,\n onOpenChange,\n ...props\n}: DialogRootProps) => {\n const [openRaw, setOpen] = useControllableState<boolean>({\n value: openProp,\n defaultValue: defaultOpen ?? false,\n onChange: onOpenChange,\n });\n const open = openRaw ?? false;\n\n const openRef = useRef(open);\n useEffect(() => {\n openRef.current = open;\n }, [open]);\n\n const handle = useMemo<DialogHandle>(\n () => ({\n getIsOpen: () => openRef.current,\n open: () => setOpen(true),\n close: () => setOpen(false),\n }),\n [setOpen],\n );\n useAgentRegistration(dialogAgent, handle, id);\n\n return (\n <DialogIdContext.Provider value={id}>\n <RadixDialog.Root open={open} onOpenChange={setOpen} {...props}>\n {children}\n </RadixDialog.Root>\n </DialogIdContext.Provider>\n );\n};\nDialogRoot.displayName = 'Dialog.Root';\n\nconst DialogTrigger = forwardRef<\n HTMLButtonElement,\n ComponentPropsWithoutRef<typeof RadixDialog.Trigger>\n>(({ children, ...props }, ref) => (\n <RadixDialog.Trigger ref={ref} {...props}>\n {children}\n </RadixDialog.Trigger>\n));\nDialogTrigger.displayName = 'Dialog.Trigger';\n\nconst DialogClose = forwardRef<\n HTMLButtonElement,\n ComponentPropsWithoutRef<typeof RadixDialog.Close>\n>(({ children, ...props }, ref) => (\n <RadixDialog.Close ref={ref} {...props}>\n {children}\n </RadixDialog.Close>\n));\nDialogClose.displayName = 'Dialog.Close';\n\nexport interface DialogContentProps\n extends\n Omit<ComponentPropsWithoutRef<typeof RadixDialog.Content>, 'role'>,\n VariantProps<typeof contentVariants> {\n size?: 'sm' | 'md' | 'lg' | 'fullscreen';\n variant?: 'default' | 'alert' | 'confirmation';\n hideCloseButton?: boolean;\n className?: string;\n children: ReactNode;\n}\n\nconst DialogContent = forwardRef<HTMLDivElement, DialogContentProps>(\n (\n {\n size = 'md',\n variant = 'default',\n hideCloseButton = true,\n className,\n children,\n ...props\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const instanceId = useContext(DialogIdContext);\n // Only forward `role` when we actually need to override Radix's default\n // (`role=\"dialog\"`). Passing `role={undefined}` explicitly wins over\n // Radix's internal assignment and strips the attribute entirely.\n const roleOverride =\n variant === 'alert' ? { role: 'alertdialog' as const } : {};\n\n return (\n <RadixDialog.Portal>\n <RadixDialog.Overlay\n data-component=\"dialog-overlay\"\n className={OVERLAY_CLASSES}\n />\n <RadixDialog.Content\n ref={ref}\n {...roleOverride}\n data-component=\"dialog\"\n data-component-id={instanceId}\n className={contentVariants({ size, className })}\n {...props}\n >\n {children}\n\n {!hideCloseButton && (\n <div className=\"ds:absolute ds:end-[var(--spacing-md)] ds:top-[var(--spacing-md)]\">\n <RadixDialog.Close asChild>\n <IconButton\n icon={<X />}\n intent=\"ghost\"\n size=\"sm\"\n aria-label={t('common.close', 'Close')}\n />\n </RadixDialog.Close>\n </div>\n )}\n </RadixDialog.Content>\n </RadixDialog.Portal>\n );\n },\n);\nDialogContent.displayName = 'Dialog.Content';\n\nconst DialogHeader = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={[\n 'ds:flex ds:flex-col ds:gap-[var(--spacing-xs)] ds:pe-[var(--spacing-xl)]',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n ),\n);\nDialogHeader.displayName = 'Dialog.Header';\n\nconst DialogTitle = forwardRef<\n HTMLHeadingElement,\n ComponentPropsWithoutRef<typeof RadixDialog.Title>\n>(({ className, ...props }, ref) => (\n <RadixDialog.Title\n ref={ref}\n className={['type-title-card ds:break-words', className]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n));\nDialogTitle.displayName = 'Dialog.Title';\n\nconst DialogDescription = forwardRef<\n HTMLParagraphElement,\n ComponentPropsWithoutRef<typeof RadixDialog.Description>\n>(({ className, ...props }, ref) => (\n <RadixDialog.Description\n ref={ref}\n className={['type-body-sm ds:text-[var(--muted-foreground)]', className]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n));\nDialogDescription.displayName = 'Dialog.Description';\n\ninterface DialogFooterProps extends HTMLAttributes<HTMLDivElement> {\n divider?: boolean;\n}\n\nconst DialogFooter = forwardRef<HTMLDivElement, DialogFooterProps>(\n ({ className, divider = false, ...props }, ref) => (\n <div\n ref={ref}\n className={[\n 'ds:flex ds:items-center ds:justify-end ds:gap-[var(--spacing-sm)]',\n 'ds:mt-[var(--spacing-md)]',\n divider &&\n 'ds:border-t ds:border-[color:var(--border)] ds:pt-[var(--spacing-md)]',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n ),\n);\nDialogFooter.displayName = 'Dialog.Footer';\n\nexport const Dialog = Object.assign(DialogRoot, {\n Root: DialogRoot,\n Trigger: DialogTrigger,\n Content: DialogContent,\n Header: DialogHeader,\n Title: DialogTitle,\n Description: DialogDescription,\n Footer: DialogFooter,\n Close: DialogClose,\n});\n\nexport type { DialogFooterProps };\n"],"names":["dialogAgent","handle","OVERLAY_CLASSES","CONTENT_BASE","CENTERED","contentVariants","cva","DialogIdContext","createContext","DialogRoot","children","id","openProp","defaultOpen","onOpenChange","props","openRaw","setOpen","useControllableState","open","openRef","useRef","useEffect","useMemo","useAgentRegistration","jsx","RadixDialog","DialogTrigger","forwardRef","ref","DialogClose","DialogContent","size","variant","hideCloseButton","className","t","useTranslation","instanceId","useContext","roleOverride","jsxs","IconButton","X","DialogHeader","DialogTitle","DialogDescription","DialogFooter","divider","Dialog"],"mappings":"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"}
@@ -1,14 +1,15 @@
1
- import { jsx as e, jsxs as c } from "react/jsx-runtime";
2
- import { forwardRef as r, useContext as L, useState as A, useRef as B, useEffect as E, useCallback as K, useMemo as H, createContext as V } from "react";
3
- import * as t from "@radix-ui/react-dropdown-menu";
1
+ import { jsx as e, jsxs as i } from "react/jsx-runtime";
2
+ import { forwardRef as d, useContext as O, useRef as G, useEffect as P, useMemo as L, createContext as A } from "react";
3
+ import * as n from "@radix-ui/react-dropdown-menu";
4
4
  import { c as h } from "./index-D2ZczOXr.js";
5
- import { S as q } from "./separator-CYU_bGFn.js";
6
- import { K as x } from "./kbd-Cglkd7CY.js";
7
- import { a as F } from "./use-direction-D6rvvG9G.js";
8
- import { C as J } from "./chevron-right-BrpYejk0.js";
9
- import { C as b } from "./check-DPdL_Sm7.js";
10
- import { u as Q } from "./registry-C9nwlNyL.js";
11
- const U = {
5
+ import { S as E } from "./separator-CYU_bGFn.js";
6
+ import { K as g } from "./kbd-Cglkd7CY.js";
7
+ import { u as K } from "./use-controllable-state-BiY4xTzM.js";
8
+ import { C as V } from "./chevron-right-BrpYejk0.js";
9
+ import { C as x } from "./check-DPdL_Sm7.js";
10
+ import { a as B } from "./use-direction-D6rvvG9G.js";
11
+ import { u as H } from "./registry-C9nwlNyL.js";
12
+ const q = {
12
13
  id: "dropdown-menu",
13
14
  capabilities: ["open", "close", "pick"],
14
15
  state: {
@@ -46,7 +47,7 @@ const U = {
46
47
  description: "Each menu item emits its value as data-item-id."
47
48
  }
48
49
  }
49
- }, N = h(
50
+ }, b = h(
50
51
  [
51
52
  "ds:z-[var(--z-dropdown)]",
52
53
  "ds:min-w-[8rem]",
@@ -67,7 +68,7 @@ const U = {
67
68
  "ds:motion-reduce:animate-none",
68
69
  "ds:forced-colors:border-[CanvasText]"
69
70
  ].join(" ")
70
- ), m = h(
71
+ ), p = h(
71
72
  [
72
73
  "ds:relative ds:flex ds:items-center ds:gap-[var(--spacing-sm)]",
73
74
  "ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]",
@@ -86,81 +87,78 @@ const U = {
86
87
  "ds:data-[disabled]:opacity-50 ds:data-[disabled]:cursor-not-allowed",
87
88
  "ds:data-[disabled]:pointer-events-none"
88
89
  ].join(" ")
89
- ), W = h(
90
+ ), F = h(
90
91
  [
91
92
  "ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]",
92
93
  "ds:pt-[var(--spacing-xs)] ds:pb-[var(--spacing-xs)]",
93
94
  "type-eyebrow ds:text-[color:var(--muted-foreground)]",
94
95
  "ds:select-none"
95
96
  ].join(" ")
96
- ), w = "ds:inline-flex ds:items-center ds:justify-center ds:size-4 ds:shrink-0", y = V(void 0), C = ({
97
+ ), N = "ds:inline-flex ds:items-center ds:justify-center ds:size-4 ds:shrink-0", w = A(void 0), C = ({
97
98
  dir: s,
98
99
  id: a,
99
100
  open: o,
100
- defaultOpen: n,
101
- onOpenChange: d,
102
- ...u
101
+ defaultOpen: t,
102
+ onOpenChange: r,
103
+ ...m
103
104
  }) => {
104
- const f = F(), i = o !== void 0, [G, P] = A(
105
- n ?? !1
106
- ), l = i ? !!o : G, v = B(l);
107
- E(() => {
105
+ const u = B(), [f, c] = K({
106
+ value: o,
107
+ defaultValue: t ?? !1,
108
+ onChange: r
109
+ }), l = f ?? !1, v = G(l);
110
+ P(() => {
108
111
  v.current = l;
109
112
  }, [l]);
110
- const p = K(
111
- (g) => {
112
- i || P(g), d == null || d(g);
113
- },
114
- [i, d]
115
- ), O = H(
113
+ const T = L(
116
114
  () => ({
117
115
  getIsOpen: () => v.current,
118
- open: () => p(!0),
119
- close: () => p(!1)
116
+ open: () => c(!0),
117
+ close: () => c(!1)
120
118
  }),
121
- [p]
119
+ [c]
122
120
  );
123
- return Q(U, O, a), /* @__PURE__ */ e(y.Provider, { value: a, children: /* @__PURE__ */ e(
124
- t.Root,
121
+ return H(q, T, a), /* @__PURE__ */ e(w.Provider, { value: a, children: /* @__PURE__ */ e(
122
+ n.Root,
125
123
  {
126
- dir: s ?? f,
124
+ dir: s ?? u,
127
125
  open: l,
128
- onOpenChange: p,
129
- ...u
126
+ onOpenChange: c,
127
+ ...m
130
128
  }
131
129
  ) });
132
130
  };
133
131
  C.displayName = "DropdownMenu.Root";
134
- const X = t.Trigger, Y = t.Portal, Z = t.Group, _ = t.RadioGroup, S = r(({ className: s, sideOffset: a = 8, ...o }, n) => {
135
- const d = L(y);
136
- return /* @__PURE__ */ e(t.Portal, { children: /* @__PURE__ */ e(
137
- t.Content,
132
+ const J = n.Trigger, Q = n.Portal, U = n.Group, W = n.RadioGroup, y = d(({ className: s, sideOffset: a = 8, ...o }, t) => {
133
+ const r = O(w);
134
+ return /* @__PURE__ */ e(n.Portal, { children: /* @__PURE__ */ e(
135
+ n.Content,
138
136
  {
139
- ref: n,
137
+ ref: t,
140
138
  sideOffset: a,
141
- className: N({ className: s }),
139
+ className: b({ className: s }),
142
140
  "data-component": "dropdown-menu",
143
- "data-component-id": d,
141
+ "data-component-id": r,
144
142
  ...o
145
143
  }
146
144
  ) });
147
145
  });
148
- S.displayName = "DropdownMenu.Content";
149
- const D = r(
146
+ y.displayName = "DropdownMenu.Content";
147
+ const R = d(
150
148
  ({
151
149
  className: s,
152
150
  startIcon: a,
153
151
  endIcon: o,
154
- description: n,
155
- shortcut: d,
156
- children: u,
157
- ...f
158
- }, i) => /* @__PURE__ */ c(
159
- t.Item,
152
+ description: t,
153
+ shortcut: r,
154
+ children: m,
155
+ ...u
156
+ }, f) => /* @__PURE__ */ i(
157
+ n.Item,
160
158
  {
161
- ref: i,
162
- className: m({ className: s }),
163
- ...f,
159
+ ref: f,
160
+ className: p({ className: s }),
161
+ ...u,
164
162
  children: [
165
163
  a ? /* @__PURE__ */ e(
166
164
  "span",
@@ -170,11 +168,11 @@ const D = r(
170
168
  children: a
171
169
  }
172
170
  ) : null,
173
- /* @__PURE__ */ c("span", { className: "ds:flex-1 ds:flex ds:flex-col ds:min-w-0", children: [
174
- /* @__PURE__ */ e("span", { className: "ds:truncate", children: u }),
175
- n ? /* @__PURE__ */ e("span", { className: "type-meta ds:text-[color:var(--muted-foreground)] ds:truncate", children: n }) : null
171
+ /* @__PURE__ */ i("span", { className: "ds:flex-1 ds:flex ds:flex-col ds:min-w-0", children: [
172
+ /* @__PURE__ */ e("span", { className: "ds:truncate", children: m }),
173
+ t ? /* @__PURE__ */ e("span", { className: "type-meta ds:text-[color:var(--muted-foreground)] ds:truncate", children: t }) : null
176
174
  ] }),
177
- d ? /* @__PURE__ */ e("span", { className: "ds:ms-auto", children: /* @__PURE__ */ e(x, { keys: d, size: "sm" }) }) : o ? /* @__PURE__ */ e(
175
+ r ? /* @__PURE__ */ e("span", { className: "ds:ms-auto", children: /* @__PURE__ */ e(g, { keys: r, size: "sm" }) }) : o ? /* @__PURE__ */ e(
178
176
  "span",
179
177
  {
180
178
  "aria-hidden": "true",
@@ -186,29 +184,29 @@ const D = r(
186
184
  }
187
185
  )
188
186
  );
189
- D.displayName = "DropdownMenu.Item";
190
- const R = r(({ className: s, children: a, ...o }, n) => /* @__PURE__ */ c(
191
- t.CheckboxItem,
187
+ R.displayName = "DropdownMenu.Item";
188
+ const S = d(({ className: s, children: a, ...o }, t) => /* @__PURE__ */ i(
189
+ n.CheckboxItem,
192
190
  {
193
- ref: n,
194
- className: m({ className: s }),
191
+ ref: t,
192
+ className: p({ className: s }),
195
193
  ...o,
196
194
  children: [
197
- /* @__PURE__ */ e("span", { className: w, children: /* @__PURE__ */ e(t.ItemIndicator, { children: /* @__PURE__ */ e(b, { "aria-hidden": !0, className: "ds:size-4" }) }) }),
195
+ /* @__PURE__ */ e("span", { className: N, children: /* @__PURE__ */ e(n.ItemIndicator, { children: /* @__PURE__ */ e(x, { "aria-hidden": !0, className: "ds:size-4" }) }) }),
198
196
  /* @__PURE__ */ e("span", { className: "ds:flex-1 ds:truncate", children: a })
199
197
  ]
200
198
  }
201
199
  ));
202
- R.displayName = "DropdownMenu.CheckboxItem";
203
- const $ = _, M = r(({ className: s, children: a, ...o }, n) => /* @__PURE__ */ c(
204
- t.RadioItem,
200
+ S.displayName = "DropdownMenu.CheckboxItem";
201
+ const X = W, D = d(({ className: s, children: a, ...o }, t) => /* @__PURE__ */ i(
202
+ n.RadioItem,
205
203
  {
206
- ref: n,
207
- className: m({ className: s }),
204
+ ref: t,
205
+ className: p({ className: s }),
208
206
  ...o,
209
207
  children: [
210
- /* @__PURE__ */ e("span", { className: w, children: /* @__PURE__ */ e(t.ItemIndicator, { children: /* @__PURE__ */ e(
211
- b,
208
+ /* @__PURE__ */ e("span", { className: N, children: /* @__PURE__ */ e(n.ItemIndicator, { children: /* @__PURE__ */ e(
209
+ x,
212
210
  {
213
211
  "aria-hidden": !0,
214
212
  className: "ds:size-4 ds:text-[color:var(--accent)]"
@@ -218,33 +216,33 @@ const $ = _, M = r(({ className: s, children: a, ...o }, n) => /* @__PURE__ */ c
218
216
  ]
219
217
  }
220
218
  ));
221
- M.displayName = "DropdownMenu.RadioItem";
222
- const I = r(({ className: s, ...a }, o) => /* @__PURE__ */ e(
223
- t.Label,
219
+ D.displayName = "DropdownMenu.RadioItem";
220
+ const M = d(({ className: s, ...a }, o) => /* @__PURE__ */ e(
221
+ n.Label,
224
222
  {
225
223
  ref: o,
226
- className: W({ className: s }),
224
+ className: F({ className: s }),
227
225
  ...a
228
226
  }
229
227
  ));
230
- I.displayName = "DropdownMenu.Label";
231
- const k = r(({ className: s, ...a }, o) => /* @__PURE__ */ e(t.Separator, { ref: o, asChild: !0, ...a, children: /* @__PURE__ */ e(
232
- q,
228
+ M.displayName = "DropdownMenu.Label";
229
+ const z = d(({ className: s, ...a }, o) => /* @__PURE__ */ e(n.Separator, { ref: o, asChild: !0, ...a, children: /* @__PURE__ */ e(
230
+ E,
233
231
  {
234
232
  className: ["ds:my-[calc(var(--spacing-xs)/2)]", s ?? ""].filter(Boolean).join(" ")
235
233
  }
236
234
  ) }));
237
- k.displayName = "DropdownMenu.Separator";
238
- const z = r(
239
- ({ keys: s, separator: a = "none" }, o) => /* @__PURE__ */ e("span", { ref: o, className: "ds:ms-auto ds:ps-[var(--spacing-sm)]", children: /* @__PURE__ */ e(x, { keys: s, separator: a, size: "sm" }) })
235
+ z.displayName = "DropdownMenu.Separator";
236
+ const I = d(
237
+ ({ keys: s, separator: a = "none" }, o) => /* @__PURE__ */ e("span", { ref: o, className: "ds:ms-auto ds:ps-[var(--spacing-sm)]", children: /* @__PURE__ */ e(g, { keys: s, separator: a, size: "sm" }) })
240
238
  );
241
- z.displayName = "DropdownMenu.Shortcut";
242
- const ee = t.Sub, j = r(({ className: s, startIcon: a, children: o, ...n }, d) => /* @__PURE__ */ c(
243
- t.SubTrigger,
239
+ I.displayName = "DropdownMenu.Shortcut";
240
+ const Y = n.Sub, k = d(({ className: s, startIcon: a, children: o, ...t }, r) => /* @__PURE__ */ i(
241
+ n.SubTrigger,
244
242
  {
245
- ref: d,
246
- className: m({ className: s }),
247
- ...n,
243
+ ref: r,
244
+ className: p({ className: s }),
245
+ ...t,
248
246
  children: [
249
247
  a ? /* @__PURE__ */ e(
250
248
  "span",
@@ -256,7 +254,7 @@ const ee = t.Sub, j = r(({ className: s, startIcon: a, children: o, ...n }, d) =
256
254
  ) : null,
257
255
  /* @__PURE__ */ e("span", { className: "ds:flex-1 ds:truncate", children: o }),
258
256
  /* @__PURE__ */ e(
259
- J,
257
+ V,
260
258
  {
261
259
  "aria-hidden": !0,
262
260
  className: "ds:ms-auto ds:size-4 ds:shrink-0 ds:rtl:-scale-x-100"
@@ -265,37 +263,37 @@ const ee = t.Sub, j = r(({ className: s, startIcon: a, children: o, ...n }, d) =
265
263
  ]
266
264
  }
267
265
  ));
268
- j.displayName = "DropdownMenu.SubTrigger";
269
- const T = r(({ className: s, ...a }, o) => /* @__PURE__ */ e(t.Portal, { children: /* @__PURE__ */ e(
270
- t.SubContent,
266
+ k.displayName = "DropdownMenu.SubTrigger";
267
+ const j = d(({ className: s, ...a }, o) => /* @__PURE__ */ e(n.Portal, { children: /* @__PURE__ */ e(
268
+ n.SubContent,
271
269
  {
272
270
  ref: o,
273
271
  sideOffset: 8,
274
272
  "data-component": "dropdown-menu-sub-content",
275
- className: N({ className: s }),
273
+ className: b({ className: s }),
276
274
  ...a
277
275
  }
278
276
  ) }));
279
- T.displayName = "DropdownMenu.SubContent";
280
- const le = {
277
+ j.displayName = "DropdownMenu.SubContent";
278
+ const re = {
281
279
  Root: C,
282
- Trigger: X,
283
- Portal: Y,
284
- Content: S,
285
- Group: Z,
286
- Item: D,
287
- CheckboxItem: R,
288
- RadioGroup: $,
289
- RadioItem: M,
290
- Label: I,
291
- Separator: k,
292
- Shortcut: z,
293
- Sub: ee,
294
- SubTrigger: j,
295
- SubContent: T
280
+ Trigger: J,
281
+ Portal: Q,
282
+ Content: y,
283
+ Group: U,
284
+ Item: R,
285
+ CheckboxItem: S,
286
+ RadioGroup: X,
287
+ RadioItem: D,
288
+ Label: M,
289
+ Separator: z,
290
+ Shortcut: I,
291
+ Sub: Y,
292
+ SubTrigger: k,
293
+ SubContent: j
296
294
  };
297
295
  export {
298
- le as D,
299
- U as d
296
+ re as D,
297
+ q as d
300
298
  };
301
- //# sourceMappingURL=dropdown-menu-dyV7gHh_.js.map
299
+ //# sourceMappingURL=dropdown-menu-DZxwF23X.js.map