@plumile/ui 0.1.54 → 0.1.56

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 (217) hide show
  1. package/lib/atomic/atoms/button/Button.d.ts.map +1 -1
  2. package/lib/atomic/atoms/button/Button.js +5 -2
  3. package/lib/atomic/atoms/formatted-date/FormattedDate.d.ts +14 -0
  4. package/lib/atomic/atoms/formatted-date/FormattedDate.d.ts.map +1 -0
  5. package/lib/atomic/atoms/formatted-date/FormattedDate.js +29 -0
  6. package/lib/atomic/atoms/icon-button/IconMenuButton.d.ts +8 -0
  7. package/lib/atomic/atoms/icon-button/IconMenuButton.d.ts.map +1 -0
  8. package/lib/atomic/atoms/icon-button/IconMenuButton.js +10 -0
  9. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts +14 -0
  10. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts.map +1 -0
  11. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.js +16 -0
  12. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts +13 -0
  13. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts.map +1 -0
  14. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.js +42 -0
  15. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts +13 -0
  16. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts.map +1 -0
  17. package/lib/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.js +37 -0
  18. package/lib/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts +25 -0
  19. package/lib/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts.map +1 -0
  20. package/lib/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.js +221 -0
  21. package/lib/atomic/molecules/breadcrumb_navigation/types.d.ts +15 -0
  22. package/lib/atomic/molecules/breadcrumb_navigation/types.d.ts.map +1 -0
  23. package/lib/atomic/molecules/breadcrumb_navigation/types.js +2 -0
  24. package/lib/atomic/molecules/dropdown/Dropdown.d.ts +26 -0
  25. package/lib/atomic/molecules/dropdown/Dropdown.d.ts.map +1 -0
  26. package/lib/atomic/molecules/dropdown/Dropdown.js +271 -0
  27. package/lib/atomic/molecules/dropdown/dropdown.css.d.ts +8 -0
  28. package/lib/atomic/molecules/dropdown/dropdown.css.d.ts.map +1 -0
  29. package/lib/atomic/molecules/dropdown/dropdown.css.js +30 -0
  30. package/lib/atomic/molecules/form-actions/FormActions.d.ts +16 -0
  31. package/lib/atomic/molecules/form-actions/FormActions.d.ts.map +1 -0
  32. package/lib/atomic/molecules/form-actions/FormActions.js +27 -0
  33. package/lib/atomic/molecules/toast/ToastProvider.d.ts +19 -0
  34. package/lib/atomic/molecules/toast/ToastProvider.d.ts.map +1 -0
  35. package/lib/atomic/molecules/toast/ToastProvider.js +113 -0
  36. package/lib/atomic/molecules/toast/ToastViewport.d.ts +24 -0
  37. package/lib/atomic/molecules/toast/ToastViewport.d.ts.map +1 -0
  38. package/lib/atomic/molecules/toast/ToastViewport.js +40 -0
  39. package/lib/atomic/molecules/toast/constants.d.ts +2 -0
  40. package/lib/atomic/molecules/toast/constants.d.ts.map +1 -0
  41. package/lib/atomic/molecules/toast/constants.js +2 -0
  42. package/lib/atomic/molecules/toast/toast.css.d.ts +25 -0
  43. package/lib/atomic/molecules/toast/toast.css.d.ts.map +1 -0
  44. package/lib/atomic/molecules/toast/toast.css.js +106 -0
  45. package/lib/components/data-table/DataTable.css.d.ts +61 -0
  46. package/lib/components/data-table/DataTable.css.d.ts.map +1 -0
  47. package/lib/components/data-table/DataTable.css.js +285 -0
  48. package/lib/components/data-table/DataTable.d.ts +32 -0
  49. package/lib/components/data-table/DataTable.d.ts.map +1 -0
  50. package/lib/components/data-table/DataTable.js +95 -0
  51. package/lib/components/data-table/TableCell.css.d.ts +26 -0
  52. package/lib/components/data-table/TableCell.css.d.ts.map +1 -0
  53. package/lib/components/data-table/TableCell.css.js +45 -0
  54. package/lib/components/data-table/TableCell.d.ts +46 -0
  55. package/lib/components/data-table/TableCell.d.ts.map +1 -0
  56. package/lib/components/data-table/TableCell.js +72 -0
  57. package/lib/components/data-table/TableCellBase.d.ts +13 -0
  58. package/lib/components/data-table/TableCellBase.d.ts.map +1 -0
  59. package/lib/components/data-table/TableCellBase.js +11 -0
  60. package/lib/components/data-table/VirtualizedConnectionTable.css.d.ts +5 -0
  61. package/lib/components/data-table/VirtualizedConnectionTable.css.d.ts.map +1 -0
  62. package/lib/components/data-table/VirtualizedConnectionTable.css.js +18 -0
  63. package/lib/components/data-table/VirtualizedConnectionTable.d.ts +32 -0
  64. package/lib/components/data-table/VirtualizedConnectionTable.d.ts.map +1 -0
  65. package/lib/components/data-table/VirtualizedConnectionTable.js +304 -0
  66. package/lib/components/data-table/tableBreakpoints.d.ts +9 -0
  67. package/lib/components/data-table/tableBreakpoints.d.ts.map +1 -0
  68. package/lib/components/data-table/tableBreakpoints.js +34 -0
  69. package/lib/components/select/SimpleSelect.css.d.ts +23 -0
  70. package/lib/components/select/SimpleSelect.css.d.ts.map +1 -0
  71. package/lib/components/select/SimpleSelect.css.js +175 -0
  72. package/lib/components/select/SimpleSelect.d.ts +22 -0
  73. package/lib/components/select/SimpleSelect.d.ts.map +1 -0
  74. package/lib/components/select/SimpleSelect.js +218 -0
  75. package/lib/components/subscriptions/RefetchNeededBanner.css.d.ts +5 -0
  76. package/lib/components/subscriptions/RefetchNeededBanner.css.d.ts.map +1 -0
  77. package/lib/components/subscriptions/RefetchNeededBanner.css.js +32 -0
  78. package/lib/components/subscriptions/RefetchNeededBanner.d.ts +9 -0
  79. package/lib/components/subscriptions/RefetchNeededBanner.d.ts.map +1 -0
  80. package/lib/components/subscriptions/RefetchNeededBanner.js +17 -0
  81. package/lib/esm/atomic/atoms/button/Button.js +35 -33
  82. package/lib/esm/atomic/atoms/button/Button.js.map +1 -1
  83. package/lib/esm/atomic/atoms/formatted-date/FormattedDate.js +32 -0
  84. package/lib/esm/atomic/atoms/formatted-date/FormattedDate.js.map +1 -0
  85. package/lib/esm/atomic/atoms/icon-button/IconMenuButton.js +26 -0
  86. package/lib/esm/atomic/atoms/icon-button/IconMenuButton.js.map +1 -0
  87. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.js +55 -0
  88. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.js.map +1 -0
  89. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.js +61 -0
  90. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.js.map +1 -0
  91. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.js +64 -0
  92. package/lib/esm/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.js.map +1 -0
  93. package/lib/esm/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.js +30 -0
  94. package/lib/esm/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.js.map +1 -0
  95. package/lib/esm/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.ts.vanilla-Bhz61Foa.css +1 -0
  96. package/lib/esm/atomic/molecules/breadcrumb_navigation/types.js +2 -0
  97. package/lib/esm/atomic/molecules/breadcrumb_navigation/types.js.map +1 -0
  98. package/lib/esm/atomic/molecules/dropdown/Dropdown.js +178 -0
  99. package/lib/esm/atomic/molecules/dropdown/Dropdown.js.map +1 -0
  100. package/lib/esm/atomic/molecules/dropdown/dropdown.css.js +13 -0
  101. package/lib/esm/atomic/molecules/dropdown/dropdown.css.js.map +1 -0
  102. package/lib/esm/atomic/molecules/form-actions/FormActions.js +57 -0
  103. package/lib/esm/atomic/molecules/form-actions/FormActions.js.map +1 -0
  104. package/lib/esm/atomic/molecules/toast/ToastProvider.js +78 -0
  105. package/lib/esm/atomic/molecules/toast/ToastProvider.js.map +1 -0
  106. package/lib/esm/atomic/molecules/toast/ToastViewport.js +71 -0
  107. package/lib/esm/atomic/molecules/toast/ToastViewport.js.map +1 -0
  108. package/lib/esm/atomic/molecules/toast/constants.js +5 -0
  109. package/lib/esm/atomic/molecules/toast/constants.js.map +1 -0
  110. package/lib/esm/atomic/molecules/toast/toast.css.js +17 -0
  111. package/lib/esm/atomic/molecules/toast/toast.css.js.map +1 -0
  112. package/lib/esm/atomic/molecules/toast/toast.css.ts.vanilla-2GtcGJsi.css +1 -0
  113. package/lib/esm/components/data-table/DataTable.css.js +24 -0
  114. package/lib/esm/components/data-table/DataTable.css.js.map +1 -0
  115. package/lib/esm/components/data-table/DataTable.css.ts.vanilla-BLE98fwj.css +1 -0
  116. package/lib/esm/components/data-table/DataTable.js +141 -0
  117. package/lib/esm/components/data-table/DataTable.js.map +1 -0
  118. package/lib/esm/components/data-table/TableCell.css.js +15 -0
  119. package/lib/esm/components/data-table/TableCell.css.js.map +1 -0
  120. package/lib/esm/components/data-table/TableCell.css.ts.vanilla-i5QJvdbl.css +1 -0
  121. package/lib/esm/components/data-table/TableCell.js +74 -0
  122. package/lib/esm/components/data-table/TableCell.js.map +1 -0
  123. package/lib/esm/components/data-table/TableCellBase.js +16 -0
  124. package/lib/esm/components/data-table/TableCellBase.js.map +1 -0
  125. package/lib/esm/components/data-table/VirtualizedConnectionTable.css.js +10 -0
  126. package/lib/esm/components/data-table/VirtualizedConnectionTable.css.js.map +1 -0
  127. package/lib/esm/components/data-table/VirtualizedConnectionTable.js +249 -0
  128. package/lib/esm/components/data-table/VirtualizedConnectionTable.js.map +1 -0
  129. package/lib/esm/components/data-table/tableBreakpoints.js +37 -0
  130. package/lib/esm/components/data-table/tableBreakpoints.js.map +1 -0
  131. package/lib/esm/components/select/SimpleSelect.css.js +22 -0
  132. package/lib/esm/components/select/SimpleSelect.css.js.map +1 -0
  133. package/lib/esm/components/select/SimpleSelect.css.ts.vanilla-Bil1v8q6.css +1 -0
  134. package/lib/esm/components/select/SimpleSelect.js +185 -0
  135. package/lib/esm/components/select/SimpleSelect.js.map +1 -0
  136. package/lib/esm/components/subscriptions/RefetchNeededBanner.css.js +10 -0
  137. package/lib/esm/components/subscriptions/RefetchNeededBanner.css.js.map +1 -0
  138. package/lib/esm/components/subscriptions/RefetchNeededBanner.js +24 -0
  139. package/lib/esm/components/subscriptions/RefetchNeededBanner.js.map +1 -0
  140. package/lib/esm/i18n/useUiTranslation.js +8 -0
  141. package/lib/esm/i18n/useUiTranslation.js.map +1 -0
  142. package/lib/esm/index.js +68 -47
  143. package/lib/esm/index.js.map +1 -1
  144. package/lib/esm/styles/slots.js +2 -0
  145. package/lib/esm/styles/slots.js.map +1 -0
  146. package/lib/i18n/useUiTranslation.d.ts +3 -0
  147. package/lib/i18n/useUiTranslation.d.ts.map +1 -0
  148. package/lib/i18n/useUiTranslation.js +5 -0
  149. package/lib/index.d.ts +10 -0
  150. package/lib/index.d.ts.map +1 -1
  151. package/lib/index.js +11 -1
  152. package/lib/styles/slots.d.ts +2 -0
  153. package/lib/styles/slots.d.ts.map +1 -0
  154. package/lib/styles/slots.js +2 -0
  155. package/lib/types/atomic/atoms/button/Button.d.ts.map +1 -1
  156. package/lib/types/atomic/atoms/formatted-date/FormattedDate.d.ts +14 -0
  157. package/lib/types/atomic/atoms/formatted-date/FormattedDate.d.ts.map +1 -0
  158. package/lib/types/atomic/atoms/icon-button/IconMenuButton.d.ts +8 -0
  159. package/lib/types/atomic/atoms/icon-button/IconMenuButton.d.ts.map +1 -0
  160. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts +14 -0
  161. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuDropdown.d.ts.map +1 -0
  162. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts +13 -0
  163. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbMenuPopover.d.ts.map +1 -0
  164. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts +13 -0
  165. package/lib/types/atomic/molecules/breadcrumb_navigation/BreadcrumbNavigation.d.ts.map +1 -0
  166. package/lib/types/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts +25 -0
  167. package/lib/types/atomic/molecules/breadcrumb_navigation/breadcrumbNavigation.css.d.ts.map +1 -0
  168. package/lib/types/atomic/molecules/breadcrumb_navigation/types.d.ts +15 -0
  169. package/lib/types/atomic/molecules/breadcrumb_navigation/types.d.ts.map +1 -0
  170. package/lib/types/atomic/molecules/dropdown/Dropdown.d.ts +26 -0
  171. package/lib/types/atomic/molecules/dropdown/Dropdown.d.ts.map +1 -0
  172. package/lib/types/atomic/molecules/dropdown/dropdown.css.d.ts +8 -0
  173. package/lib/types/atomic/molecules/dropdown/dropdown.css.d.ts.map +1 -0
  174. package/lib/types/atomic/molecules/form-actions/FormActions.d.ts +16 -0
  175. package/lib/types/atomic/molecules/form-actions/FormActions.d.ts.map +1 -0
  176. package/lib/types/atomic/molecules/toast/ToastProvider.d.ts +19 -0
  177. package/lib/types/atomic/molecules/toast/ToastProvider.d.ts.map +1 -0
  178. package/lib/types/atomic/molecules/toast/ToastViewport.d.ts +24 -0
  179. package/lib/types/atomic/molecules/toast/ToastViewport.d.ts.map +1 -0
  180. package/lib/types/atomic/molecules/toast/constants.d.ts +2 -0
  181. package/lib/types/atomic/molecules/toast/constants.d.ts.map +1 -0
  182. package/lib/types/atomic/molecules/toast/toast.css.d.ts +25 -0
  183. package/lib/types/atomic/molecules/toast/toast.css.d.ts.map +1 -0
  184. package/lib/types/components/data-table/DataTable.css.d.ts +61 -0
  185. package/lib/types/components/data-table/DataTable.css.d.ts.map +1 -0
  186. package/lib/types/components/data-table/DataTable.d.ts +32 -0
  187. package/lib/types/components/data-table/DataTable.d.ts.map +1 -0
  188. package/lib/types/components/data-table/TableCell.css.d.ts +26 -0
  189. package/lib/types/components/data-table/TableCell.css.d.ts.map +1 -0
  190. package/lib/types/components/data-table/TableCell.d.ts +46 -0
  191. package/lib/types/components/data-table/TableCell.d.ts.map +1 -0
  192. package/lib/types/components/data-table/TableCellBase.d.ts +13 -0
  193. package/lib/types/components/data-table/TableCellBase.d.ts.map +1 -0
  194. package/lib/types/components/data-table/VirtualizedConnectionTable.css.d.ts +5 -0
  195. package/lib/types/components/data-table/VirtualizedConnectionTable.css.d.ts.map +1 -0
  196. package/lib/types/components/data-table/VirtualizedConnectionTable.d.ts +32 -0
  197. package/lib/types/components/data-table/VirtualizedConnectionTable.d.ts.map +1 -0
  198. package/lib/types/components/data-table/tableBreakpoints.d.ts +9 -0
  199. package/lib/types/components/data-table/tableBreakpoints.d.ts.map +1 -0
  200. package/lib/types/components/select/SimpleSelect.css.d.ts +23 -0
  201. package/lib/types/components/select/SimpleSelect.css.d.ts.map +1 -0
  202. package/lib/types/components/select/SimpleSelect.d.ts +22 -0
  203. package/lib/types/components/select/SimpleSelect.d.ts.map +1 -0
  204. package/lib/types/components/subscriptions/RefetchNeededBanner.css.d.ts +5 -0
  205. package/lib/types/components/subscriptions/RefetchNeededBanner.css.d.ts.map +1 -0
  206. package/lib/types/components/subscriptions/RefetchNeededBanner.d.ts +9 -0
  207. package/lib/types/components/subscriptions/RefetchNeededBanner.d.ts.map +1 -0
  208. package/lib/types/i18n/useUiTranslation.d.ts +3 -0
  209. package/lib/types/i18n/useUiTranslation.d.ts.map +1 -0
  210. package/lib/types/index.d.ts +10 -0
  211. package/lib/types/index.d.ts.map +1 -1
  212. package/lib/types/styles/slots.d.ts +2 -0
  213. package/lib/types/styles/slots.d.ts.map +1 -0
  214. package/package.json +10 -3
  215. package/src/i18n/locales/en/ui.json +53 -0
  216. package/src/i18n/locales/fr/ui.json +53 -0
  217. package/src/i18n/useUiTranslation.ts +6 -0
@@ -0,0 +1,15 @@
1
+ export type BreadcrumbNode = {
2
+ name: string;
3
+ to: string;
4
+ };
5
+ export type BreadcrumbMenuItem = {
6
+ id: string;
7
+ name: string;
8
+ to: string;
9
+ description?: string | null;
10
+ };
11
+ export type BreadcrumbMenuConfig = {
12
+ items: readonly BreadcrumbMenuItem[];
13
+ selectedId?: string | null;
14
+ };
15
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/atomic/molecules/breadcrumb_navigation/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,KAAK,EAAE,SAAS,kBAAkB,EAAE,CAAC;IACrC,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC5B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXRvbWljL21vbGVjdWxlcy9icmVhZGNydW1iX25hdmlnYXRpb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEJyZWFkY3J1bWJOb2RlID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIHRvOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBCcmVhZGNydW1iTWVudUl0ZW0gPSB7XG4gIGlkOiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgdG86IHN0cmluZztcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmcgfCBudWxsO1xufTtcblxuZXhwb3J0IHR5cGUgQnJlYWRjcnVtYk1lbnVDb25maWcgPSB7XG4gIGl0ZW1zOiByZWFkb25seSBCcmVhZGNydW1iTWVudUl0ZW1bXTtcbiAgc2VsZWN0ZWRJZD86IHN0cmluZyB8IG51bGw7XG59O1xuIl19
@@ -0,0 +1,26 @@
1
+ import { type ReactNode, type ReactElement, type JSX } from 'react';
2
+ export type DropdownPlacement = 'bottom-start' | 'bottom-end' | 'top-start' | 'top-end';
3
+ interface DropdownContextValue {
4
+ close: () => void;
5
+ open: () => void;
6
+ isOpen: boolean;
7
+ }
8
+ export declare const useDropdown: () => DropdownContextValue;
9
+ export interface DropdownProps {
10
+ trigger: ReactElement | ((isOpen: boolean) => ReactElement);
11
+ children: ReactNode;
12
+ className?: string;
13
+ contentClassName?: string;
14
+ placement?: DropdownPlacement;
15
+ offset?: number;
16
+ matchTriggerWidth?: boolean;
17
+ open?: boolean;
18
+ defaultOpen?: boolean;
19
+ onOpenChange?: (open: boolean) => void;
20
+ closeOnItemClick?: boolean;
21
+ portalContainer?: HTMLElement | null;
22
+ ariaLabel?: string;
23
+ }
24
+ export declare const Dropdown: ({ trigger, children, className, contentClassName, placement, offset, matchTriggerWidth, open, defaultOpen, onOpenChange, closeOnItemClick, portalContainer, ariaLabel, }: DropdownProps) => JSX.Element;
25
+ export {};
26
+ //# sourceMappingURL=Dropdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.d.ts","sourceRoot":"","sources":["../../../../src/atomic/molecules/dropdown/Dropdown.tsx"],"names":[],"mappings":"AAAA,OAAO,EAML,KAAK,SAAS,EACd,KAAK,YAAY,EACjB,KAAK,GAAG,EAUT,MAAM,OAAO,CAAC;AAOf,MAAM,MAAM,iBAAiB,GACzB,cAAc,GACd,YAAY,GACZ,WAAW,GACX,SAAS,CAAC;AAEd,UAAU,oBAAoB;IAC5B,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,MAAM,EAAE,OAAO,CAAC;CACjB;AAMD,eAAO,MAAM,WAAW,QAAO,oBAM9B,CAAC;AAEF,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,YAAY,GAAG,CAAC,CAAC,MAAM,EAAE,OAAO,KAAK,YAAY,CAAC,CAAC;IAC5D,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,EAAE,iBAAiB,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,eAAe,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;IAErC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAsBD,eAAO,MAAM,QAAQ,GAAI,0KActB,aAAa,KAAG,GAAG,CAAC,OA0TtB,CAAC"}
@@ -0,0 +1,271 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState, useRef, useEffect, useLayoutEffect, useCallback, createContext, useContext, isValidElement, cloneElement, } from 'react';
3
+ import { createPortal } from 'react-dom';
4
+ import * as classes from './dropdown.css.js';
5
+ import { cx } from '../../../theme/tools.js';
6
+ const DropdownContext = createContext(null);
7
+ export const useDropdown = () => {
8
+ const ctx = useContext(DropdownContext);
9
+ if (ctx == null) {
10
+ throw new Error('useDropdown must be used within a <Dropdown />');
11
+ }
12
+ return ctx;
13
+ };
14
+ const isForwardRefComponent = (type) => {
15
+ if (type == null || typeof type !== 'object') {
16
+ return false;
17
+ }
18
+ return (type.$$typeof === Symbol.for('react.forward_ref'));
19
+ };
20
+ export const Dropdown = ({ trigger, children, className, contentClassName, placement = 'bottom-start', offset = 4, matchTriggerWidth = true, open, defaultOpen = false, onOpenChange, closeOnItemClick = false, portalContainer, ariaLabel, }) => {
21
+ const isControlled = open != null;
22
+ const [uncontrolledOpen, setUncontrolledOpen] = useState(defaultOpen);
23
+ let isOpen = uncontrolledOpen;
24
+ if (isControlled) {
25
+ isOpen = Boolean(open);
26
+ }
27
+ const containerRef = useRef(null);
28
+ const triggerRef = useRef(null);
29
+ const contentRef = useRef(null);
30
+ const [position, setPosition] = useState(null);
31
+ const cleanupRef = useRef([]);
32
+ const setOpen = useCallback((next) => {
33
+ if (!isControlled) {
34
+ setUncontrolledOpen(next);
35
+ }
36
+ onOpenChange?.(next);
37
+ }, [isControlled, onOpenChange]);
38
+ const toggle = useCallback(() => {
39
+ setOpen(!isOpen);
40
+ }, [isOpen, setOpen]);
41
+ const close = useCallback(() => {
42
+ setOpen(false);
43
+ }, [setOpen]);
44
+ const openFn = useCallback(() => {
45
+ setOpen(true);
46
+ }, [setOpen]);
47
+ const computePosition = useCallback(() => {
48
+ const triggerEl = triggerRef.current;
49
+ const contentEl = contentRef.current;
50
+ if (triggerEl == null) {
51
+ return;
52
+ }
53
+ if (contentEl == null) {
54
+ return;
55
+ }
56
+ const rect = triggerEl.getBoundingClientRect();
57
+ let top = 0;
58
+ let left = 0;
59
+ switch (placement) {
60
+ case 'bottom-start':
61
+ top = rect.bottom + offset;
62
+ left = rect.left;
63
+ break;
64
+ case 'bottom-end':
65
+ top = rect.bottom + offset;
66
+ left = rect.right - contentEl.offsetWidth;
67
+ break;
68
+ case 'top-start':
69
+ top = rect.top - contentEl.offsetHeight - offset;
70
+ left = rect.left;
71
+ break;
72
+ case 'top-end':
73
+ top = rect.top - contentEl.offsetHeight - offset;
74
+ left = rect.right - contentEl.offsetWidth;
75
+ break;
76
+ default:
77
+ top = rect.bottom + offset;
78
+ left = rect.left;
79
+ }
80
+ const vw = window.innerWidth;
81
+ const vh = window.innerHeight;
82
+ let width;
83
+ if (matchTriggerWidth) {
84
+ width = rect.width;
85
+ }
86
+ const contentWidth = width ?? contentEl.offsetWidth;
87
+ if (left + contentWidth > vw - 4) {
88
+ left = Math.max(4, vw - contentWidth - 4);
89
+ }
90
+ if (left < 4)
91
+ left = 4;
92
+ const contentHeight = contentEl.offsetHeight;
93
+ if (top + contentHeight > vh - 4) {
94
+ if (placement.startsWith('bottom')) {
95
+ const flippedTop = rect.top - contentHeight - offset;
96
+ if (flippedTop >= 4) {
97
+ top = flippedTop;
98
+ }
99
+ else {
100
+ top = Math.max(4, vh - contentHeight - 4);
101
+ }
102
+ }
103
+ else {
104
+ top = Math.max(4, vh - contentHeight - 4);
105
+ }
106
+ }
107
+ if (top < 4)
108
+ top = 4;
109
+ setPosition({ top, left, width });
110
+ }, [placement, offset, matchTriggerWidth]);
111
+ useLayoutEffect(() => {
112
+ if (isOpen)
113
+ computePosition();
114
+ }, [isOpen, computePosition, children]);
115
+ useEffect(() => {
116
+ if (!isOpen)
117
+ return;
118
+ const handle = () => {
119
+ computePosition();
120
+ };
121
+ window.addEventListener('resize', handle);
122
+ window.addEventListener('scroll', handle, true);
123
+ const cleanup = () => {
124
+ window.removeEventListener('resize', handle);
125
+ window.removeEventListener('scroll', handle, true);
126
+ };
127
+ cleanupRef.current.push(cleanup);
128
+ }, [isOpen, computePosition]);
129
+ useEffect(() => {
130
+ if (!isOpen)
131
+ return;
132
+ const onDocMouseDown = (e) => {
133
+ const target = e.target;
134
+ if (containerRef.current != null &&
135
+ contentRef.current != null &&
136
+ !containerRef.current.contains(target) &&
137
+ !contentRef.current.contains(target)) {
138
+ close();
139
+ }
140
+ };
141
+ const onKey = (e) => {
142
+ if (e.key === 'Escape') {
143
+ close();
144
+ triggerRef.current?.focus();
145
+ }
146
+ };
147
+ document.addEventListener('mousedown', onDocMouseDown);
148
+ document.addEventListener('keydown', onKey);
149
+ const cleanup = () => {
150
+ document.removeEventListener('mousedown', onDocMouseDown);
151
+ document.removeEventListener('keydown', onKey);
152
+ };
153
+ cleanupRef.current.push(cleanup);
154
+ }, [isOpen, close]);
155
+ useEffect(() => {
156
+ if (!isOpen)
157
+ return;
158
+ const firstFocusable = contentRef.current?.querySelector('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
159
+ firstFocusable?.focus();
160
+ }, [isOpen]);
161
+ useEffect(() => {
162
+ if (!isOpen || !closeOnItemClick)
163
+ return;
164
+ const handler = (e) => {
165
+ if (contentRef.current?.contains(e.target)) {
166
+ close();
167
+ }
168
+ };
169
+ document.addEventListener('click', handler, { capture: true });
170
+ const cleanup = () => {
171
+ document.removeEventListener('click', handler, { capture: true });
172
+ };
173
+ cleanupRef.current.push(cleanup);
174
+ }, [isOpen, closeOnItemClick, close]);
175
+ useEffect(() => {
176
+ return () => {
177
+ cleanupRef.current.forEach((fn) => {
178
+ fn();
179
+ });
180
+ cleanupRef.current = [];
181
+ };
182
+ }, []);
183
+ let triggerElement = trigger;
184
+ if (typeof trigger === 'function') {
185
+ triggerElement = trigger(isOpen);
186
+ }
187
+ if (!isValidElement(triggerElement)) {
188
+ throw new Error('Dropdown trigger must be a React element.');
189
+ }
190
+ const isHostElement = typeof triggerElement.type === 'string';
191
+ const isButtonElement = isHostElement && triggerElement.type === 'button';
192
+ const canAttachRef = isHostElement ||
193
+ typeof triggerElement.type === 'function' ||
194
+ isForwardRefComponent(triggerElement.type);
195
+ if (!canAttachRef) {
196
+ throw new Error('Dropdown trigger must be a DOM element or component that accepts a ref.');
197
+ }
198
+ const triggerElementRef = triggerElement.props.ref ??
199
+ triggerElement.ref;
200
+ const setTriggerRef = (node) => {
201
+ triggerRef.current = node;
202
+ if (typeof triggerElementRef === 'function') {
203
+ triggerElementRef(node);
204
+ }
205
+ else if (triggerElementRef != null) {
206
+ triggerElementRef.current =
207
+ node;
208
+ }
209
+ };
210
+ const triggerProps = triggerElement.props;
211
+ const handleTriggerClick = (event) => {
212
+ triggerProps.onClick?.(event);
213
+ if (event.defaultPrevented) {
214
+ return;
215
+ }
216
+ toggle();
217
+ };
218
+ const handleTriggerKeyDown = (event) => {
219
+ triggerProps.onKeyDown?.(event);
220
+ if (event.defaultPrevented) {
221
+ return;
222
+ }
223
+ if (event.key === 'Enter' || event.key === ' ') {
224
+ event.preventDefault();
225
+ toggle();
226
+ }
227
+ };
228
+ const mergedTriggerProps = {
229
+ onClick: handleTriggerClick,
230
+ 'aria-haspopup': 'menu',
231
+ 'aria-expanded': isOpen,
232
+ };
233
+ if (ariaLabel != null && ariaLabel !== '') {
234
+ mergedTriggerProps['aria-label'] = ariaLabel;
235
+ }
236
+ if (isButtonElement) {
237
+ if (triggerProps.type == null) {
238
+ mergedTriggerProps.type = 'button';
239
+ }
240
+ }
241
+ else {
242
+ mergedTriggerProps.onKeyDown = handleTriggerKeyDown;
243
+ if (triggerProps.role == null) {
244
+ mergedTriggerProps.role = 'button';
245
+ }
246
+ if (triggerProps.tabIndex == null) {
247
+ mergedTriggerProps.tabIndex = 0;
248
+ }
249
+ }
250
+ mergedTriggerProps.ref = setTriggerRef;
251
+ let contentStyles = {};
252
+ if (position != null) {
253
+ contentStyles = {
254
+ top: position.top,
255
+ left: position.left,
256
+ width: position.width,
257
+ };
258
+ }
259
+ const portalTarget = portalContainer ?? document.body;
260
+ const contextValue = {
261
+ close,
262
+ open: openFn,
263
+ isOpen,
264
+ };
265
+ let dropdownContent = null;
266
+ if (isOpen) {
267
+ dropdownContent = createPortal(_jsx("div", { ref: contentRef, role: "menu", className: cx(classes.content, classes.contentPositioned, contentClassName), style: contentStyles, children: children }), portalTarget);
268
+ }
269
+ return (_jsxs(DropdownContext.Provider, { value: contextValue, children: [_jsx("div", { className: cx(classes.container, className), ref: containerRef, children: cloneElement(triggerElement, mergedTriggerProps) }), dropdownContent] }));
270
+ };
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../../../../src/atomic/molecules/dropdown/Dropdown.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n  useState,\n  useRef,\n  useEffect,\n  useLayoutEffect,\n  useCallback,\n  type ReactNode,\n  type ReactElement,\n  type JSX,\n  type Ref,\n  type MutableRefObject,\n  type HTMLAttributes,\n  type MouseEvent as ReactMouseEvent,\n  type KeyboardEvent as ReactKeyboardEvent,\n  createContext,\n  useContext,\n  isValidElement,\n  cloneElement,\n} from 'react';\nimport { createPortal } from 'react-dom';\n\nimport * as classes from './dropdown.css.js';\nimport { cx } from '../../../theme/tools.js';\n\n// Types\nexport type DropdownPlacement =\n  | 'bottom-start'\n  | 'bottom-end'\n  | 'top-start'\n  | 'top-end';\n\ninterface DropdownContextValue {\n  close: () => void;\n  open: () => void;\n  isOpen: boolean;\n}\n\nconst DropdownContext = createContext<DropdownContextValue | null>(null);\n/**\n * Access the nearest Dropdown context. Throws if used outside a <Dropdown />.\n */\nexport const useDropdown = (): DropdownContextValue => {\n  const ctx = useContext(DropdownContext);\n  if (ctx == null) {\n    throw new Error('useDropdown must be used within a <Dropdown />');\n  }\n  return ctx;\n};\n\nexport interface DropdownProps {\n  trigger: ReactElement | ((isOpen: boolean) => ReactElement);\n  children: ReactNode;\n  className?: string;\n  contentClassName?: string;\n  placement?: DropdownPlacement;\n  offset?: number;\n  matchTriggerWidth?: boolean;\n  open?: boolean; // controlled\n  defaultOpen?: boolean; // uncontrolled\n  onOpenChange?: (open: boolean) => void;\n  closeOnItemClick?: boolean;\n  portalContainer?: HTMLElement | null;\n  // Accessible label if trigger is an icon only\n  ariaLabel?: string;\n}\n\ninterface PositionState {\n  top: number;\n  left: number;\n  width?: number;\n}\n\nconst isForwardRefComponent = (type: unknown): boolean => {\n  if (type == null || typeof type !== 'object') {\n    return false;\n  }\n  return (\n    (type as { $$typeof?: symbol }).$$typeof === Symbol.for('react.forward_ref')\n  );\n};\n\n/**\n * A scalable, portal-based dropdown component with basic collision handling,\n * controlled/uncontrolled modes, accessibility attributes, and optional\n * trigger width matching. Content is rendered in a React portal (default: document.body).\n */\nexport const Dropdown = ({\n  trigger,\n  children,\n  className,\n  contentClassName,\n  placement = 'bottom-start',\n  offset = 4,\n  matchTriggerWidth = true,\n  open,\n  defaultOpen = false,\n  onOpenChange,\n  closeOnItemClick = false,\n  portalContainer,\n  ariaLabel,\n}: DropdownProps): JSX.Element => {\n  const isControlled = open != null;\n  const [uncontrolledOpen, setUncontrolledOpen] = useState(defaultOpen);\n  let isOpen = uncontrolledOpen;\n  if (isControlled) {\n    isOpen = Boolean(open);\n  }\n\n  const containerRef = useRef<HTMLDivElement>(null);\n  const triggerRef = useRef<HTMLElement>(null);\n  const contentRef = useRef<HTMLDivElement>(null);\n  const [position, setPosition] = useState<PositionState | null>(null);\n  // Accumulate manual cleanups for effects where returning a function violates lint rules.\n  const cleanupRef = useRef<(() => void)[]>([]);\n\n  const setOpen = useCallback(\n    (next: boolean) => {\n      if (!isControlled) {\n        setUncontrolledOpen(next);\n      }\n      onOpenChange?.(next);\n    },\n    [isControlled, onOpenChange],\n  );\n\n  const toggle = useCallback(() => {\n    setOpen(!isOpen);\n  }, [isOpen, setOpen]);\n  const close = useCallback(() => {\n    setOpen(false);\n  }, [setOpen]);\n  const openFn = useCallback(() => {\n    setOpen(true);\n  }, [setOpen]);\n\n  // Positioning logic\n  const computePosition = useCallback(() => {\n    const triggerEl = triggerRef.current;\n    const contentEl = contentRef.current;\n    if (triggerEl == null) {\n      return;\n    }\n    if (contentEl == null) {\n      return;\n    }\n\n    const rect = triggerEl.getBoundingClientRect();\n    let top = 0;\n    let left = 0;\n\n    switch (placement) {\n      case 'bottom-start':\n        top = rect.bottom + offset;\n        left = rect.left;\n        break;\n      case 'bottom-end':\n        top = rect.bottom + offset;\n        left = rect.right - contentEl.offsetWidth;\n        break;\n      case 'top-start':\n        top = rect.top - contentEl.offsetHeight - offset;\n        left = rect.left;\n        break;\n      case 'top-end':\n        top = rect.top - contentEl.offsetHeight - offset;\n        left = rect.right - contentEl.offsetWidth;\n        break;\n      default:\n        top = rect.bottom + offset;\n        left = rect.left;\n    }\n\n    // Keep within viewport (basic collision handling)\n    const vw = window.innerWidth;\n    const vh = window.innerHeight;\n    let width: number | undefined;\n    if (matchTriggerWidth) {\n      width = rect.width;\n    }\n    const contentWidth = width ?? contentEl.offsetWidth;\n\n    if (left + contentWidth > vw - 4) {\n      left = Math.max(4, vw - contentWidth - 4);\n    }\n    if (left < 4) left = 4;\n    const contentHeight = contentEl.offsetHeight;\n    if (top + contentHeight > vh - 4) {\n      // Try flip to top if bottom overflows and initial was bottom\n      if (placement.startsWith('bottom')) {\n        const flippedTop = rect.top - contentHeight - offset;\n        if (flippedTop >= 4) {\n          top = flippedTop;\n        } else {\n          top = Math.max(4, vh - contentHeight - 4);\n        }\n      } else {\n        top = Math.max(4, vh - contentHeight - 4);\n      }\n    }\n    if (top < 4) top = 4;\n\n    setPosition({ top, left, width });\n  }, [placement, offset, matchTriggerWidth]);\n\n  useLayoutEffect(() => {\n    if (isOpen) computePosition();\n  }, [isOpen, computePosition, children]);\n\n  useEffect(() => {\n    if (!isOpen) return;\n    const handle = () => {\n      computePosition();\n    };\n    window.addEventListener('resize', handle);\n    window.addEventListener('scroll', handle, true);\n    const cleanup = () => {\n      window.removeEventListener('resize', handle);\n      window.removeEventListener('scroll', handle, true);\n    };\n    cleanupRef.current.push(cleanup);\n  }, [isOpen, computePosition]);\n\n  // Outside click & Escape\n  useEffect(() => {\n    if (!isOpen) return;\n    const onDocMouseDown = (e: globalThis.MouseEvent) => {\n      const target = e.target as Node;\n      if (\n        containerRef.current != null &&\n        contentRef.current != null &&\n        !containerRef.current.contains(target) &&\n        !contentRef.current.contains(target)\n      ) {\n        close();\n      }\n    };\n    const onKey = (e: globalThis.KeyboardEvent) => {\n      if (e.key === 'Escape') {\n        close();\n        triggerRef.current?.focus();\n      }\n    };\n    document.addEventListener('mousedown', onDocMouseDown);\n    document.addEventListener('keydown', onKey);\n    const cleanup = () => {\n      document.removeEventListener('mousedown', onDocMouseDown);\n      document.removeEventListener('keydown', onKey);\n    };\n    cleanupRef.current.push(cleanup);\n  }, [isOpen, close]);\n\n  // Keyboard navigation basic (ArrowDown focuses first focusable)\n  useEffect(() => {\n    if (!isOpen) return;\n    const firstFocusable = contentRef.current?.querySelector<HTMLElement>(\n      'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\n    );\n    firstFocusable?.focus();\n  }, [isOpen]);\n\n  // Close on item click if enabled\n  useEffect(() => {\n    if (!isOpen || !closeOnItemClick) return;\n    const handler = (e: globalThis.MouseEvent) => {\n      if (contentRef.current?.contains(e.target as Node)) {\n        close();\n      }\n    };\n    document.addEventListener('click', handler, { capture: true });\n    // Explicit cleanup without returning (lint rule forbids returning arrow fn)\n    const cleanup = () => {\n      document.removeEventListener('click', handler, { capture: true });\n    };\n    // Store in ref to run on unmount / dependency change\n    cleanupRef.current.push(cleanup);\n  }, [isOpen, closeOnItemClick, close]);\n  // Run accumulated cleanups on unmount\n  useEffect(() => {\n    return () => {\n      cleanupRef.current.forEach((fn) => {\n        fn();\n      });\n      cleanupRef.current = [];\n    };\n  }, []);\n\n  let triggerElement = trigger;\n  if (typeof trigger === 'function') {\n    triggerElement = trigger(isOpen);\n  }\n\n  if (!isValidElement(triggerElement)) {\n    throw new Error('Dropdown trigger must be a React element.');\n  }\n\n  const isHostElement = typeof triggerElement.type === 'string';\n  const isButtonElement = isHostElement && triggerElement.type === 'button';\n  const canAttachRef =\n    isHostElement ||\n    typeof triggerElement.type === 'function' ||\n    isForwardRefComponent(triggerElement.type);\n\n  if (!canAttachRef) {\n    throw new Error(\n      'Dropdown trigger must be a DOM element or component that accepts a ref.',\n    );\n  }\n\n  const triggerElementRef =\n    (triggerElement.props as { ref?: Ref<HTMLElement> }).ref ??\n    (triggerElement as ReactElement & { ref?: Ref<HTMLElement> }).ref;\n  const setTriggerRef = (node: HTMLElement | null) => {\n    triggerRef.current = node;\n    if (typeof triggerElementRef === 'function') {\n      triggerElementRef(node);\n    } else if (triggerElementRef != null) {\n      (triggerElementRef as MutableRefObject<HTMLElement | null>).current =\n        node;\n    }\n  };\n\n  const triggerProps = triggerElement.props as HTMLAttributes<HTMLElement> & {\n    type?: string;\n  };\n\n  const handleTriggerClick = (event: ReactMouseEvent<HTMLElement>) => {\n    triggerProps.onClick?.(event);\n    if (event.defaultPrevented) {\n      return;\n    }\n    toggle();\n  };\n\n  const handleTriggerKeyDown = (event: ReactKeyboardEvent<HTMLElement>) => {\n    triggerProps.onKeyDown?.(event);\n    if (event.defaultPrevented) {\n      return;\n    }\n    if (event.key === 'Enter' || event.key === ' ') {\n      event.preventDefault();\n      toggle();\n    }\n  };\n\n  const mergedTriggerProps: Record<string, unknown> = {\n    onClick: handleTriggerClick,\n    'aria-haspopup': 'menu',\n    'aria-expanded': isOpen,\n  };\n\n  if (ariaLabel != null && ariaLabel !== '') {\n    mergedTriggerProps['aria-label'] = ariaLabel;\n  }\n\n  if (isButtonElement) {\n    if (triggerProps.type == null) {\n      mergedTriggerProps.type = 'button';\n    }\n  } else {\n    mergedTriggerProps.onKeyDown = handleTriggerKeyDown;\n    if (triggerProps.role == null) {\n      mergedTriggerProps.role = 'button';\n    }\n    if (triggerProps.tabIndex == null) {\n      mergedTriggerProps.tabIndex = 0;\n    }\n  }\n\n  mergedTriggerProps.ref = setTriggerRef;\n\n  let contentStyles: React.CSSProperties = {};\n  if (position != null) {\n    contentStyles = {\n      top: position.top,\n      left: position.left,\n      width: position.width,\n    };\n  }\n\n  const portalTarget = portalContainer ?? document.body;\n\n  const contextValue: DropdownContextValue = {\n    close,\n    open: openFn,\n    isOpen,\n  };\n\n  let dropdownContent: JSX.Element | null = null;\n  if (isOpen) {\n    dropdownContent = createPortal(\n      <div\n        ref={contentRef}\n        role=\"menu\"\n        className={cx(\n          classes.content,\n          classes.contentPositioned,\n          contentClassName,\n        )}\n        style={contentStyles}\n      >\n        {children}\n      </div>,\n      portalTarget,\n    );\n  }\n\n  return (\n    <DropdownContext.Provider value={contextValue}>\n      <div className={cx(classes.container, className)} ref={containerRef}>\n        {cloneElement(triggerElement, mergedTriggerProps)}\n      </div>\n      {dropdownContent}\n    </DropdownContext.Provider>\n  );\n};\n"]}
@@ -0,0 +1,8 @@
1
+ export declare const container: string;
2
+ export declare const content: string;
3
+ export declare const contentPositioned: string;
4
+ export declare const hidden: string;
5
+ export declare const focusOutlineReset: string;
6
+ export declare const menu: string;
7
+ export declare const menuItem: string;
8
+ //# sourceMappingURL=dropdown.css.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdown.css.d.ts","sourceRoot":"","sources":["../../../../src/atomic/molecules/dropdown/dropdown.css.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,SAAS,QAEpB,CAAC;AAGH,eAAO,MAAM,OAAO,QAKlB,CAAC;AAEH,eAAO,MAAM,iBAAiB,QAI5B,CAAC;AAEH,eAAO,MAAM,MAAM,QAEjB,CAAC;AAEH,eAAO,MAAM,iBAAiB,QAE5B,CAAC;AAEH,eAAO,MAAM,IAAI,QAIf,CAAC;AAEH,eAAO,MAAM,QAAQ,QAEnB,CAAC"}
@@ -0,0 +1,30 @@
1
+ import { sprinkles } from '../../../theme/sprinkles.css.js';
2
+ export const container = sprinkles({
3
+ position: 'relative',
4
+ });
5
+ export const content = sprinkles({
6
+ backgroundColor: 'white',
7
+ borderRadius: 'xl',
8
+ zIndex: 'modal',
9
+ overflow: 'hidden',
10
+ });
11
+ export const contentPositioned = sprinkles({
12
+ position: 'fixed',
13
+ top: 0,
14
+ left: 0,
15
+ });
16
+ export const hidden = sprinkles({
17
+ display: 'none',
18
+ });
19
+ export const focusOutlineReset = sprinkles({
20
+ outline: 'none',
21
+ });
22
+ export const menu = sprinkles({
23
+ listStyleType: 'none',
24
+ margin: 0,
25
+ padding: 0,
26
+ });
27
+ export const menuItem = sprinkles({
28
+ cursor: 'pointer',
29
+ });
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY3NzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2F0b21pYy9tb2xlY3VsZXMvZHJvcGRvd24vZHJvcGRvd24uY3NzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUc1RCxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQ2pDLFFBQVEsRUFBRSxVQUFVO0NBQ3JCLENBQUMsQ0FBQztBQUdILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxTQUFTLENBQUM7SUFDL0IsZUFBZSxFQUFFLE9BQU87SUFDeEIsWUFBWSxFQUFFLElBQUk7SUFDbEIsTUFBTSxFQUFFLE9BQU87SUFDZixRQUFRLEVBQUUsUUFBUTtDQUNuQixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxTQUFTLENBQUM7SUFDekMsUUFBUSxFQUFFLE9BQU87SUFDakIsR0FBRyxFQUFFLENBQUM7SUFDTixJQUFJLEVBQUUsQ0FBQztDQUNSLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxTQUFTLENBQUM7SUFDOUIsT0FBTyxFQUFFLE1BQU07Q0FDaEIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsU0FBUyxDQUFDO0lBQ3pDLE9BQU8sRUFBRSxNQUFNO0NBQ2hCLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBRyxTQUFTLENBQUM7SUFDNUIsYUFBYSxFQUFFLE1BQU07SUFDckIsTUFBTSxFQUFFLENBQUM7SUFDVCxPQUFPLEVBQUUsQ0FBQztDQUNYLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxTQUFTLENBQUM7SUFDaEMsTUFBTSxFQUFFLFNBQVM7Q0FDbEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc3ByaW5rbGVzIH0gZnJvbSAnLi4vLi4vLi4vdGhlbWUvc3ByaW5rbGVzLmNzcy5qcyc7XG5cbi8vIENvbnRhaW5lciBvbmx5IHdyYXBzIHRoZSB0cmlnZ2VyIG5vdzsgbWVudSBjb250ZW50IGlzIHBvcnRhbGVkIHRvIGJvZHkuXG5leHBvcnQgY29uc3QgY29udGFpbmVyID0gc3ByaW5rbGVzKHtcbiAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG59KTtcblxuLy8gQmFzZSB2aXN1YWwgc3R5bGluZyBmb3IgdGhlIGRyb3Bkb3duIGNvbnRlbnQuIFBvc2l0aW9uICh0b3AvbGVmdCkgaXMgYXBwbGllZCBpbmxpbmUuXG5leHBvcnQgY29uc3QgY29udGVudCA9IHNwcmlua2xlcyh7XG4gIGJhY2tncm91bmRDb2xvcjogJ3doaXRlJyxcbiAgYm9yZGVyUmFkaXVzOiAneGwnLFxuICB6SW5kZXg6ICdtb2RhbCcsXG4gIG92ZXJmbG93OiAnaGlkZGVuJyxcbn0pO1xuXG5leHBvcnQgY29uc3QgY29udGVudFBvc2l0aW9uZWQgPSBzcHJpbmtsZXMoe1xuICBwb3NpdGlvbjogJ2ZpeGVkJyxcbiAgdG9wOiAwLFxuICBsZWZ0OiAwLFxufSk7XG5cbmV4cG9ydCBjb25zdCBoaWRkZW4gPSBzcHJpbmtsZXMoe1xuICBkaXNwbGF5OiAnbm9uZScsXG59KTtcblxuZXhwb3J0IGNvbnN0IGZvY3VzT3V0bGluZVJlc2V0ID0gc3ByaW5rbGVzKHtcbiAgb3V0bGluZTogJ25vbmUnLFxufSk7XG5cbmV4cG9ydCBjb25zdCBtZW51ID0gc3ByaW5rbGVzKHtcbiAgbGlzdFN0eWxlVHlwZTogJ25vbmUnLFxuICBtYXJnaW46IDAsXG4gIHBhZGRpbmc6IDAsXG59KTtcblxuZXhwb3J0IGNvbnN0IG1lbnVJdGVtID0gc3ByaW5rbGVzKHtcbiAgY3Vyc29yOiAncG9pbnRlcicsXG59KTtcbiJdfQ==
@@ -0,0 +1,16 @@
1
+ import { type ComponentProps, type JSX, type ReactNode } from 'react';
2
+ import { Button } from '../../atoms/button/Button.js';
3
+ export type FormActionsProps = {
4
+ onCancel: () => void;
5
+ cancelLabel?: string;
6
+ submitLabel?: string;
7
+ submitLoadingLabel?: string;
8
+ isSubmitting?: boolean;
9
+ submitDisabled?: boolean;
10
+ className?: string;
11
+ renderSubmitContent?: (isSubmitting: boolean) => ReactNode;
12
+ submitButtonProps?: Omit<ComponentProps<typeof Button>, 'children' | 'type'>;
13
+ cancelButtonProps?: Omit<ComponentProps<typeof Button>, 'children' | 'type' | 'variant'>;
14
+ };
15
+ export declare const FormActions: ({ onCancel, cancelLabel, submitLabel, submitLoadingLabel, isSubmitting, submitDisabled, className, renderSubmitContent, submitButtonProps, cancelButtonProps, }: FormActionsProps) => JSX.Element;
16
+ //# sourceMappingURL=FormActions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormActions.d.ts","sourceRoot":"","sources":["../../../../src/atomic/molecules/form-actions/FormActions.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,GAAG,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAEtE,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAC;AAGtD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,mBAAmB,CAAC,EAAE,CAAC,YAAY,EAAE,OAAO,KAAK,SAAS,CAAC;IAC3D,iBAAiB,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,OAAO,MAAM,CAAC,EAAE,UAAU,GAAG,MAAM,CAAC,CAAC;IAC7E,iBAAiB,CAAC,EAAE,IAAI,CACtB,cAAc,CAAC,OAAO,MAAM,CAAC,EAC7B,UAAU,GAAG,MAAM,GAAG,SAAS,CAChC,CAAC;CACH,CAAC;AAEF,eAAO,MAAM,WAAW,GAAI,iKAWzB,gBAAgB,KAAG,GAAG,CAAC,OAyDzB,CAAC"}
@@ -0,0 +1,27 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button } from '../../atoms/button/Button.js';
3
+ import { useUiTranslation } from '../../../i18n/useUiTranslation.js';
4
+ export const FormActions = ({ onCancel, cancelLabel, submitLabel, submitLoadingLabel, isSubmitting = false, submitDisabled = false, className, renderSubmitContent, submitButtonProps, cancelButtonProps, }) => {
5
+ const { t } = useUiTranslation();
6
+ const resolvedCancelLabel = cancelLabel ?? t('common.actions.cancel');
7
+ const resolvedSubmitLabel = submitLabel ?? t('common.actions.save');
8
+ const resolvedSubmitLoadingLabel = submitLoadingLabel ?? t('common.actions.saving');
9
+ const cancelProps = cancelButtonProps ?? {};
10
+ const { className: cancelClassName, disabled: cancelDisabled, ...restCancelButtonProps } = cancelProps;
11
+ const submitProps = submitButtonProps ?? {};
12
+ const { className: submitClassName, disabled: submitDisabledOverride, ...restSubmitButtonProps } = submitProps;
13
+ let submitContent;
14
+ if (renderSubmitContent != null) {
15
+ submitContent = renderSubmitContent(isSubmitting);
16
+ }
17
+ else if (isSubmitting) {
18
+ submitContent = resolvedSubmitLoadingLabel;
19
+ }
20
+ else {
21
+ submitContent = resolvedSubmitLabel;
22
+ }
23
+ const isCancelDisabled = Boolean(cancelDisabled);
24
+ const isSubmitDisabled = Boolean(submitDisabled) || isSubmitting || submitDisabledOverride === true;
25
+ return (_jsxs("div", { className: className, children: [_jsx(Button, { type: "button", variant: "text", onClick: onCancel, disabled: isCancelDisabled, className: cancelClassName, ...restCancelButtonProps, children: resolvedCancelLabel }), _jsx(Button, { type: "submit", variant: "primary", disabled: isSubmitDisabled, className: submitClassName, ...restSubmitButtonProps, children: submitContent })] }));
26
+ };
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRm9ybUFjdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXRvbWljL21vbGVjdWxlcy9mb3JtLWFjdGlvbnMvRm9ybUFjdGlvbnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFFQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFrQnJFLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLEVBQzFCLFFBQVEsRUFDUixXQUFXLEVBQ1gsV0FBVyxFQUNYLGtCQUFrQixFQUNsQixZQUFZLEdBQUcsS0FBSyxFQUNwQixjQUFjLEdBQUcsS0FBSyxFQUN0QixTQUFTLEVBQ1QsbUJBQW1CLEVBQ25CLGlCQUFpQixFQUNqQixpQkFBaUIsR0FDQSxFQUFlLEVBQUU7SUFDbEMsTUFBTSxFQUFFLENBQUMsRUFBRSxHQUFHLGdCQUFnQixFQUFFLENBQUM7SUFDakMsTUFBTSxtQkFBbUIsR0FBRyxXQUFXLElBQUksQ0FBQyxDQUFDLHVCQUF1QixDQUFDLENBQUM7SUFDdEUsTUFBTSxtQkFBbUIsR0FBRyxXQUFXLElBQUksQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDcEUsTUFBTSwwQkFBMEIsR0FDOUIsa0JBQWtCLElBQUksQ0FBQyxDQUFDLHVCQUF1QixDQUFDLENBQUM7SUFDbkQsTUFBTSxXQUFXLEdBQUcsaUJBQWlCLElBQUksRUFBRSxDQUFDO0lBQzVDLE1BQU0sRUFDSixTQUFTLEVBQUUsZUFBZSxFQUMxQixRQUFRLEVBQUUsY0FBYyxFQUN4QixHQUFHLHFCQUFxQixFQUN6QixHQUFHLFdBQVcsQ0FBQztJQUVoQixNQUFNLFdBQVcsR0FBRyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDNUMsTUFBTSxFQUNKLFNBQVMsRUFBRSxlQUFlLEVBQzFCLFFBQVEsRUFBRSxzQkFBc0IsRUFDaEMsR0FBRyxxQkFBcUIsRUFDekIsR0FBRyxXQUFXLENBQUM7SUFFaEIsSUFBSSxhQUF3QixDQUFDO0lBRTdCLElBQUksbUJBQW1CLElBQUksSUFBSSxFQUFFLENBQUM7UUFDaEMsYUFBYSxHQUFHLG1CQUFtQixDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ3BELENBQUM7U0FBTSxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQ3hCLGFBQWEsR0FBRywwQkFBMEIsQ0FBQztJQUM3QyxDQUFDO1NBQU0sQ0FBQztRQUNOLGFBQWEsR0FBRyxtQkFBbUIsQ0FBQztJQUN0QyxDQUFDO0lBRUQsTUFBTSxnQkFBZ0IsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDakQsTUFBTSxnQkFBZ0IsR0FDcEIsT0FBTyxDQUFDLGNBQWMsQ0FBQyxJQUFJLFlBQVksSUFBSSxzQkFBc0IsS0FBSyxJQUFJLENBQUM7SUFFN0UsT0FBTyxDQUNMLGVBQUssU0FBUyxFQUFFLFNBQVMsYUFDdkIsS0FBQyxNQUFNLElBQ0wsSUFBSSxFQUFDLFFBQVEsRUFDYixPQUFPLEVBQUMsTUFBTSxFQUNkLE9BQU8sRUFBRSxRQUFRLEVBQ2pCLFFBQVEsRUFBRSxnQkFBZ0IsRUFDMUIsU0FBUyxFQUFFLGVBQWUsS0FDdEIscUJBQXFCLFlBRXhCLG1CQUFtQixHQUNiLEVBQ1QsS0FBQyxNQUFNLElBQ0wsSUFBSSxFQUFDLFFBQVEsRUFDYixPQUFPLEVBQUMsU0FBUyxFQUNqQixRQUFRLEVBQUUsZ0JBQWdCLEVBQzFCLFNBQVMsRUFBRSxlQUFlLEtBQ3RCLHFCQUFxQixZQUV4QixhQUFhLEdBQ1AsSUFDTCxDQUNQLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIENvbXBvbmVudFByb3BzLCB0eXBlIEpTWCwgdHlwZSBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL2F0b21zL2J1dHRvbi9CdXR0b24uanMnO1xuaW1wb3J0IHsgdXNlVWlUcmFuc2xhdGlvbiB9IGZyb20gJy4uLy4uLy4uL2kxOG4vdXNlVWlUcmFuc2xhdGlvbi5qcyc7XG5cbmV4cG9ydCB0eXBlIEZvcm1BY3Rpb25zUHJvcHMgPSB7XG4gIG9uQ2FuY2VsOiAoKSA9PiB2b2lkO1xuICBjYW5jZWxMYWJlbD86IHN0cmluZztcbiAgc3VibWl0TGFiZWw/OiBzdHJpbmc7XG4gIHN1Ym1pdExvYWRpbmdMYWJlbD86IHN0cmluZztcbiAgaXNTdWJtaXR0aW5nPzogYm9vbGVhbjtcbiAgc3VibWl0RGlzYWJsZWQ/OiBib29sZWFuO1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIHJlbmRlclN1Ym1pdENvbnRlbnQ/OiAoaXNTdWJtaXR0aW5nOiBib29sZWFuKSA9PiBSZWFjdE5vZGU7XG4gIHN1Ym1pdEJ1dHRvblByb3BzPzogT21pdDxDb21wb25lbnRQcm9wczx0eXBlb2YgQnV0dG9uPiwgJ2NoaWxkcmVuJyB8ICd0eXBlJz47XG4gIGNhbmNlbEJ1dHRvblByb3BzPzogT21pdDxcbiAgICBDb21wb25lbnRQcm9wczx0eXBlb2YgQnV0dG9uPixcbiAgICAnY2hpbGRyZW4nIHwgJ3R5cGUnIHwgJ3ZhcmlhbnQnXG4gID47XG59O1xuXG5leHBvcnQgY29uc3QgRm9ybUFjdGlvbnMgPSAoe1xuICBvbkNhbmNlbCxcbiAgY2FuY2VsTGFiZWwsXG4gIHN1Ym1pdExhYmVsLFxuICBzdWJtaXRMb2FkaW5nTGFiZWwsXG4gIGlzU3VibWl0dGluZyA9IGZhbHNlLFxuICBzdWJtaXREaXNhYmxlZCA9IGZhbHNlLFxuICBjbGFzc05hbWUsXG4gIHJlbmRlclN1Ym1pdENvbnRlbnQsXG4gIHN1Ym1pdEJ1dHRvblByb3BzLFxuICBjYW5jZWxCdXR0b25Qcm9wcyxcbn06IEZvcm1BY3Rpb25zUHJvcHMpOiBKU1guRWxlbWVudCA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVWlUcmFuc2xhdGlvbigpO1xuICBjb25zdCByZXNvbHZlZENhbmNlbExhYmVsID0gY2FuY2VsTGFiZWwgPz8gdCgnY29tbW9uLmFjdGlvbnMuY2FuY2VsJyk7XG4gIGNvbnN0IHJlc29sdmVkU3VibWl0TGFiZWwgPSBzdWJtaXRMYWJlbCA/PyB0KCdjb21tb24uYWN0aW9ucy5zYXZlJyk7XG4gIGNvbnN0IHJlc29sdmVkU3VibWl0TG9hZGluZ0xhYmVsID1cbiAgICBzdWJtaXRMb2FkaW5nTGFiZWwgPz8gdCgnY29tbW9uLmFjdGlvbnMuc2F2aW5nJyk7XG4gIGNvbnN0IGNhbmNlbFByb3BzID0gY2FuY2VsQnV0dG9uUHJvcHMgPz8ge307XG4gIGNvbnN0IHtcbiAgICBjbGFzc05hbWU6IGNhbmNlbENsYXNzTmFtZSxcbiAgICBkaXNhYmxlZDogY2FuY2VsRGlzYWJsZWQsXG4gICAgLi4ucmVzdENhbmNlbEJ1dHRvblByb3BzXG4gIH0gPSBjYW5jZWxQcm9wcztcblxuICBjb25zdCBzdWJtaXRQcm9wcyA9IHN1Ym1pdEJ1dHRvblByb3BzID8/IHt9O1xuICBjb25zdCB7XG4gICAgY2xhc3NOYW1lOiBzdWJtaXRDbGFzc05hbWUsXG4gICAgZGlzYWJsZWQ6IHN1Ym1pdERpc2FibGVkT3ZlcnJpZGUsXG4gICAgLi4ucmVzdFN1Ym1pdEJ1dHRvblByb3BzXG4gIH0gPSBzdWJtaXRQcm9wcztcblxuICBsZXQgc3VibWl0Q29udGVudDogUmVhY3ROb2RlO1xuXG4gIGlmIChyZW5kZXJTdWJtaXRDb250ZW50ICE9IG51bGwpIHtcbiAgICBzdWJtaXRDb250ZW50ID0gcmVuZGVyU3VibWl0Q29udGVudChpc1N1Ym1pdHRpbmcpO1xuICB9IGVsc2UgaWYgKGlzU3VibWl0dGluZykge1xuICAgIHN1Ym1pdENvbnRlbnQgPSByZXNvbHZlZFN1Ym1pdExvYWRpbmdMYWJlbDtcbiAgfSBlbHNlIHtcbiAgICBzdWJtaXRDb250ZW50ID0gcmVzb2x2ZWRTdWJtaXRMYWJlbDtcbiAgfVxuXG4gIGNvbnN0IGlzQ2FuY2VsRGlzYWJsZWQgPSBCb29sZWFuKGNhbmNlbERpc2FibGVkKTtcbiAgY29uc3QgaXNTdWJtaXREaXNhYmxlZCA9XG4gICAgQm9vbGVhbihzdWJtaXREaXNhYmxlZCkgfHwgaXNTdWJtaXR0aW5nIHx8IHN1Ym1pdERpc2FibGVkT3ZlcnJpZGUgPT09IHRydWU7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgIDxCdXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIHZhcmlhbnQ9XCJ0ZXh0XCJcbiAgICAgICAgb25DbGljaz17b25DYW5jZWx9XG4gICAgICAgIGRpc2FibGVkPXtpc0NhbmNlbERpc2FibGVkfVxuICAgICAgICBjbGFzc05hbWU9e2NhbmNlbENsYXNzTmFtZX1cbiAgICAgICAgey4uLnJlc3RDYW5jZWxCdXR0b25Qcm9wc31cbiAgICAgID5cbiAgICAgICAge3Jlc29sdmVkQ2FuY2VsTGFiZWx9XG4gICAgICA8L0J1dHRvbj5cbiAgICAgIDxCdXR0b25cbiAgICAgICAgdHlwZT1cInN1Ym1pdFwiXG4gICAgICAgIHZhcmlhbnQ9XCJwcmltYXJ5XCJcbiAgICAgICAgZGlzYWJsZWQ9e2lzU3VibWl0RGlzYWJsZWR9XG4gICAgICAgIGNsYXNzTmFtZT17c3VibWl0Q2xhc3NOYW1lfVxuICAgICAgICB7Li4ucmVzdFN1Ym1pdEJ1dHRvblByb3BzfVxuICAgICAgPlxuICAgICAgICB7c3VibWl0Q29udGVudH1cbiAgICAgIDwvQnV0dG9uPlxuICAgIDwvZGl2PlxuICApO1xufTtcbiJdfQ==
@@ -0,0 +1,19 @@
1
+ import { type JSX, type ReactNode } from 'react';
2
+ import { type ToastItem } from './ToastViewport.js';
3
+ export type ToastApi = {
4
+ push: (toast: Omit<ToastItem, 'id'> & {
5
+ id?: string;
6
+ }) => string;
7
+ dismiss: (toastId: string) => void;
8
+ clear: () => void;
9
+ info: (title: ReactNode, message?: ReactNode) => string;
10
+ warning: (title: ReactNode, message?: ReactNode) => string;
11
+ error: (title: ReactNode, message?: ReactNode) => string;
12
+ };
13
+ export type ToastProviderProps = {
14
+ children: ReactNode;
15
+ maxToasts?: number;
16
+ };
17
+ export declare const ToastProvider: ({ children, maxToasts, }: ToastProviderProps) => JSX.Element;
18
+ export declare const useToast: () => ToastApi;
19
+ //# sourceMappingURL=ToastProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToastProvider.d.ts","sourceRoot":"","sources":["../../../../src/atomic/molecules/toast/ToastProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAQL,KAAK,GAAG,EACR,KAAK,SAAS,EACf,MAAM,OAAO,CAAC;AAEf,OAAO,EAEL,KAAK,SAAS,EAEf,MAAM,oBAAoB,CAAC;AAG5B,MAAM,MAAM,QAAQ,GAAG;IACrB,IAAI,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,GAAG;QAAE,EAAE,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,MAAM,CAAC;IACjE,OAAO,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,IAAI,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,SAAS,KAAK,MAAM,CAAC;IACxD,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,SAAS,KAAK,MAAM,CAAC;IAC3D,KAAK,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,SAAS,KAAK,MAAM,CAAC;CAC1D,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAUF,eAAO,MAAM,aAAa,GAAI,0BAG3B,kBAAkB,KAAG,GAAG,CAAC,OAgH3B,CAAC;AAEF,eAAO,MAAM,QAAQ,QAAO,QAM3B,CAAC"}