@alepha/ui 0.18.1 → 0.18.3

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 (280) hide show
  1. package/dist/admin/{AdminApiKeys-C-6_Q-lH.js → AdminApiKeys-Dy_k-4Vd.js} +17 -38
  2. package/dist/admin/AdminApiKeys-Dy_k-4Vd.js.map +1 -0
  3. package/dist/admin/{AdminAudits-Bgbf04hO.js → AdminAudits-CKiFMSSU.js} +23 -19
  4. package/dist/admin/AdminAudits-CKiFMSSU.js.map +1 -0
  5. package/dist/admin/AdminDashboard-PhC_dZqo.js +67 -0
  6. package/dist/admin/AdminDashboard-PhC_dZqo.js.map +1 -0
  7. package/dist/admin/{AdminFiles-B9a7G3cY.js → AdminFiles-DFTjijGp.js} +3 -7
  8. package/dist/admin/AdminFiles-DFTjijGp.js.map +1 -0
  9. package/dist/admin/{AdminJobDashboard-DaTwf5OY.js → AdminJobDashboard-BL8gGPDp.js} +2 -2
  10. package/dist/admin/{AdminJobDashboard-DaTwf5OY.js.map → AdminJobDashboard-BL8gGPDp.js.map} +1 -1
  11. package/dist/admin/{AdminJobExecutions-B9cek5dl.js → AdminJobExecutions-D9E-CS-U.js} +24 -36
  12. package/dist/admin/AdminJobExecutions-D9E-CS-U.js.map +1 -0
  13. package/dist/admin/{AdminJobRegistry-DFgV3oqx.js → AdminJobRegistry-Ci9ue1zC.js} +10 -18
  14. package/dist/admin/AdminJobRegistry-Ci9ue1zC.js.map +1 -0
  15. package/dist/admin/AdminLayout-I6TlUMPc.js +61 -0
  16. package/dist/admin/AdminLayout-I6TlUMPc.js.map +1 -0
  17. package/dist/admin/AdminNotifications-ZPHCYrv7.js +542 -0
  18. package/dist/admin/AdminNotifications-ZPHCYrv7.js.map +1 -0
  19. package/dist/admin/{AdminParameters-DHw9ATgl.js → AdminParameters-CqgvhRsb.js} +120 -105
  20. package/dist/admin/AdminParameters-CqgvhRsb.js.map +1 -0
  21. package/dist/admin/{AdminSessions-BhGJPI3z.js → AdminSessions-Bz5NRuoW.js} +48 -53
  22. package/dist/admin/AdminSessions-Bz5NRuoW.js.map +1 -0
  23. package/dist/admin/{AdminUserLayout-BdC4Te8m.js → AdminUserLayout-lXT6I0Qq.js} +14 -8
  24. package/dist/admin/AdminUserLayout-lXT6I0Qq.js.map +1 -0
  25. package/dist/admin/{AdminUserProfile-DAt23fqY.js → AdminUserProfile-vFBLoJ3h.js} +3 -3
  26. package/dist/admin/{AdminUserProfile-DAt23fqY.js.map → AdminUserProfile-vFBLoJ3h.js.map} +1 -1
  27. package/dist/admin/{AdminUserSessions-1uzcx02z.js → AdminUserSessions-CT_YDim0.js} +33 -35
  28. package/dist/admin/AdminUserSessions-CT_YDim0.js.map +1 -0
  29. package/dist/admin/AdminUsers-D1UfGya9.js +206 -0
  30. package/dist/admin/AdminUsers-D1UfGya9.js.map +1 -0
  31. package/dist/admin/{AuthLayout-DFJvCvzw.js → AuthLayout-_frhdgOO.js} +2 -2
  32. package/dist/admin/{AuthLayout-DFJvCvzw.js.map → AuthLayout-_frhdgOO.js.map} +1 -1
  33. package/dist/admin/{IconGoogle-CSQLPYwX.js → IconGoogle-Ch1m3Uzl.js} +1 -1
  34. package/dist/admin/{IconGoogle-CSQLPYwX.js.map → IconGoogle-Ch1m3Uzl.js.map} +1 -1
  35. package/dist/admin/Login-xtNmQtGh.js +275 -0
  36. package/dist/admin/Login-xtNmQtGh.js.map +1 -0
  37. package/dist/{auth/Profile-BMX_Ar_s.js → admin/Profile-_AtPUwAP.js} +31 -27
  38. package/dist/admin/Profile-_AtPUwAP.js.map +1 -0
  39. package/dist/admin/{Register-Cs10l8vX.js → Register-JcCjHUUn.js} +199 -143
  40. package/dist/admin/Register-JcCjHUUn.js.map +1 -0
  41. package/dist/admin/{ResetPassword-BwDdfkGH.js → ResetPassword-CwGBPLJO.js} +7 -7
  42. package/dist/admin/ResetPassword-CwGBPLJO.js.map +1 -0
  43. package/dist/admin/{VerifyEmail-DfXHAiQl.js → VerifyEmail-hNxWejWf.js} +23 -8
  44. package/dist/admin/VerifyEmail-hNxWejWf.js.map +1 -0
  45. package/dist/admin/{core-2xoLiT0o.js → core-CYaRQ8O-.js} +2082 -688
  46. package/dist/admin/core-CYaRQ8O-.js.map +1 -0
  47. package/dist/admin/index.d.ts +112 -48
  48. package/dist/admin/index.d.ts.map +1 -1
  49. package/dist/admin/index.js +467 -69
  50. package/dist/admin/index.js.map +1 -1
  51. package/dist/auth/{AuthLayout-CAE1pX9s.js → AuthLayout-AvLlcLjS.js} +2 -2
  52. package/dist/auth/{AuthLayout-CAE1pX9s.js.map → AuthLayout-AvLlcLjS.js.map} +1 -1
  53. package/dist/auth/Login-BA1E8IZl.js +275 -0
  54. package/dist/auth/Login-BA1E8IZl.js.map +1 -0
  55. package/dist/{admin/Profile-B-c9pCPf.js → auth/Profile-YcWdeuFz.js} +31 -27
  56. package/dist/auth/Profile-YcWdeuFz.js.map +1 -0
  57. package/dist/auth/{Register-6hi_cpfF.js → Register-CPhEO5MG.js} +198 -142
  58. package/dist/auth/Register-CPhEO5MG.js.map +1 -0
  59. package/dist/{demo/ResetPassword-DWN0lzr5.js → auth/ResetPassword-DCtGcneA.js} +7 -7
  60. package/dist/auth/ResetPassword-DCtGcneA.js.map +1 -0
  61. package/dist/{demo/VerifyEmail-DZWL72K4.js → auth/VerifyEmail-DkH7NBfn.js} +23 -8
  62. package/dist/auth/VerifyEmail-DkH7NBfn.js.map +1 -0
  63. package/dist/auth/{core-niW0sFLv.js → core-D5jIAVF2.js} +1385 -329
  64. package/dist/auth/core-D5jIAVF2.js.map +1 -0
  65. package/dist/auth/index.d.ts +105 -49
  66. package/dist/auth/index.d.ts.map +1 -1
  67. package/dist/auth/index.js +29 -26
  68. package/dist/auth/index.js.map +1 -1
  69. package/dist/core/index.d.ts +210 -74
  70. package/dist/core/index.d.ts.map +1 -1
  71. package/dist/core/index.js +2247 -834
  72. package/dist/core/index.js.map +1 -1
  73. package/dist/demo/{AuthLayout-jLa0aKsI.js → AuthLayout-Brri4A-L.js} +2 -2
  74. package/dist/demo/{AuthLayout-jLa0aKsI.js.map → AuthLayout-Brri4A-L.js.map} +1 -1
  75. package/dist/demo/DemoButton-wiCxZZ_L.js +182 -0
  76. package/dist/demo/DemoButton-wiCxZZ_L.js.map +1 -0
  77. package/dist/demo/DemoControlSelect-D7ILObVg.js +305 -0
  78. package/dist/demo/DemoControlSelect-D7ILObVg.js.map +1 -0
  79. package/dist/demo/DemoDataTable-DZ5Y8pFX.js +362 -0
  80. package/dist/demo/DemoDataTable-DZ5Y8pFX.js.map +1 -0
  81. package/dist/demo/{DemoDialog-4ItHLf9t.js → DemoDialog-CUWdLHim.js} +2 -2
  82. package/dist/demo/{DemoDialog-4ItHLf9t.js.map → DemoDialog-CUWdLHim.js.map} +1 -1
  83. package/dist/demo/{DemoFlex-EtVq8QfX.js → DemoFlex-a8OhMMvq.js} +3 -3
  84. package/dist/demo/{DemoFlex-EtVq8QfX.js.map → DemoFlex-a8OhMMvq.js.map} +1 -1
  85. package/dist/demo/{DemoHeading-BS-vGfkI.js → DemoHeading-C13OVDfS.js} +3 -3
  86. package/dist/demo/{DemoHeading-BS-vGfkI.js.map → DemoHeading-C13OVDfS.js.map} +1 -1
  87. package/dist/demo/{DemoHome-Clbn8AmS.js → DemoHome-D_De3UiT.js} +2 -2
  88. package/dist/demo/{DemoHome-Clbn8AmS.js.map → DemoHome-D_De3UiT.js.map} +1 -1
  89. package/dist/demo/{DemoJsonViewer-DkIX_ky2.js → DemoJsonViewer-B50s9aGM.js} +3 -3
  90. package/dist/demo/{DemoJsonViewer-DkIX_ky2.js.map → DemoJsonViewer-B50s9aGM.js.map} +1 -1
  91. package/dist/demo/{DemoLayout-C56xb5EE.js → DemoLayout-CHU8WTwO.js} +14 -5
  92. package/dist/demo/DemoLayout-CHU8WTwO.js.map +1 -0
  93. package/dist/demo/{DemoLogin-BZwpicOS.js → DemoLogin-BBlrWpml.js} +49 -32
  94. package/dist/demo/DemoLogin-BBlrWpml.js.map +1 -0
  95. package/dist/demo/{DemoRegister-C7_qc4MJ.js → DemoRegister-BuNE3_-f.js} +49 -50
  96. package/dist/demo/DemoRegister-BuNE3_-f.js.map +1 -0
  97. package/dist/demo/{DemoResetPassword-BI1Ct4Dw.js → DemoResetPassword-D_IjjjOJ.js} +12 -16
  98. package/dist/demo/DemoResetPassword-D_IjjjOJ.js.map +1 -0
  99. package/dist/demo/{DemoSidebar-CcBo4ltC.js → DemoSidebar-Giy2HRBD.js} +3 -3
  100. package/dist/demo/{DemoSidebar-CcBo4ltC.js.map → DemoSidebar-Giy2HRBD.js.map} +1 -1
  101. package/dist/demo/{DemoText-CzXuUn3g.js → DemoText-ubcw-vog.js} +3 -3
  102. package/dist/demo/{DemoText-CzXuUn3g.js.map → DemoText-ubcw-vog.js.map} +1 -1
  103. package/dist/demo/{DemoToast-BgHDhWrX.js → DemoToast-9die_dYT.js} +2 -2
  104. package/dist/demo/{DemoToast-BgHDhWrX.js.map → DemoToast-9die_dYT.js.map} +1 -1
  105. package/dist/demo/{DemoTypeForm-DDzWoMSV.js → DemoTypeForm-D_d6OVKL.js} +8 -4
  106. package/dist/demo/DemoTypeForm-D_d6OVKL.js.map +1 -0
  107. package/dist/demo/DemoVerifyEmail-B43KlF4F.js +34 -0
  108. package/dist/demo/DemoVerifyEmail-B43KlF4F.js.map +1 -0
  109. package/dist/demo/Login-C12N4oGs.js +275 -0
  110. package/dist/demo/Login-C12N4oGs.js.map +1 -0
  111. package/dist/demo/{Profile-CWqti7FB.js → Profile-DS5q4vOh.js} +31 -27
  112. package/dist/demo/Profile-DS5q4vOh.js.map +1 -0
  113. package/dist/demo/{Register-a70LPgs2.js → Register-B4hLBeEv.js} +198 -142
  114. package/dist/demo/Register-B4hLBeEv.js.map +1 -0
  115. package/dist/{auth/ResetPassword-CqfTk1FI.js → demo/ResetPassword-D8g9ha1N.js} +7 -7
  116. package/dist/demo/ResetPassword-D8g9ha1N.js.map +1 -0
  117. package/dist/demo/{Showcase-Dq3MISpd.js → Showcase-D6Fxt4X4.js} +64 -65
  118. package/dist/demo/Showcase-D6Fxt4X4.js.map +1 -0
  119. package/dist/{auth/VerifyEmail-nWiSTMjF.js → demo/VerifyEmail-BjDo0cZA.js} +23 -8
  120. package/dist/demo/VerifyEmail-BjDo0cZA.js.map +1 -0
  121. package/dist/demo/{auth-d6n3xbug.js → auth-ByVTreDl.js} +8 -8
  122. package/dist/demo/{auth-d6n3xbug.js.map → auth-ByVTreDl.js.map} +1 -1
  123. package/dist/demo/{core-RCUw1Q-a.js → core-DFgB3yU4.js} +2182 -756
  124. package/dist/demo/core-DFgB3yU4.js.map +1 -0
  125. package/dist/demo/index.d.ts +1 -0
  126. package/dist/demo/index.d.ts.map +1 -1
  127. package/dist/demo/index.js +24 -18
  128. package/dist/demo/index.js.map +1 -1
  129. package/package.json +7 -7
  130. package/src/admin/{AdminRouter.ts → AdminRouter.tsx} +150 -18
  131. package/src/admin/components/AdminDashboard.tsx +52 -0
  132. package/src/admin/components/AdminLayout.tsx +32 -40
  133. package/src/admin/components/audits/AdminAudits.tsx +22 -16
  134. package/src/admin/components/files/AdminFiles.tsx +1 -6
  135. package/src/admin/components/jobs/AdminJobExecutions.tsx +33 -39
  136. package/src/admin/components/jobs/AdminJobRegistry.tsx +9 -18
  137. package/src/admin/components/keys/AdminApiKeys.tsx +23 -41
  138. package/src/admin/components/notifications/AdminNotifications.tsx +519 -0
  139. package/src/admin/components/parameters/ParameterDetails.tsx +12 -270
  140. package/src/admin/components/parameters/ParameterDetailsConfigForm.tsx +238 -0
  141. package/src/admin/components/parameters/ParameterDetailsLoading.tsx +24 -0
  142. package/src/admin/components/parameters/ParameterHistory.tsx +10 -11
  143. package/src/admin/components/parameters/ParameterTree.tsx +28 -184
  144. package/src/admin/components/parameters/ParameterTreeNode.tsx +151 -0
  145. package/src/admin/components/sessions/AdminSessions.tsx +71 -71
  146. package/src/admin/components/shared/AdminResourceHeader.tsx +2 -25
  147. package/src/admin/components/shared/AdminResourceHeaderMenuItem.tsx +37 -0
  148. package/src/admin/components/shared/AdminResourceTabs.tsx +2 -26
  149. package/src/admin/components/shared/AdminResourceTabsItem.tsx +36 -0
  150. package/src/admin/components/users/AdminUserSessions.tsx +33 -31
  151. package/src/admin/components/users/AdminUsers.tsx +184 -72
  152. package/src/admin/index.ts +2 -2
  153. package/src/admin/primitives/$uiAdmin.ts +1 -1
  154. package/src/auth/components/Login.tsx +188 -121
  155. package/src/auth/components/Profile.tsx +1 -22
  156. package/src/auth/components/ProfileField.tsx +39 -0
  157. package/src/auth/components/Register.tsx +215 -158
  158. package/src/auth/components/ResetPassword.tsx +7 -11
  159. package/src/auth/components/VerifyEmail.tsx +35 -10
  160. package/src/auth/components/buttons/UserButton.tsx +20 -24
  161. package/src/auth/index.ts +1 -0
  162. package/src/core/atoms/alephaSidebarAtom.ts +1 -1
  163. package/src/core/atoms/alephaThemeListAtom.ts +14 -1
  164. package/src/core/atoms/alephaThemeOverridesAtom.ts +17 -0
  165. package/src/core/atoms/themes/editorial.ts +184 -0
  166. package/src/core/atoms/themes/monochrome.ts +197 -0
  167. package/src/core/atoms/themes/rosePine.ts +208 -0
  168. package/src/core/atoms/themes/softBrutalism.ts +221 -0
  169. package/src/core/atoms/themes/terminal.ts +186 -0
  170. package/src/core/components/Flex.tsx +101 -1
  171. package/src/core/components/Text.tsx +1 -1
  172. package/src/core/components/buttons/ActionButton.tsx +109 -87
  173. package/src/core/components/buttons/DarkModeButton.tsx +3 -3
  174. package/src/core/components/buttons/LanguageButton.tsx +1 -1
  175. package/src/core/components/buttons/OmnibarButton.tsx +1 -2
  176. package/src/core/components/buttons/ThemeButton.tsx +40 -11
  177. package/src/core/components/buttons/ThemeExpertModal.tsx +184 -0
  178. package/src/core/components/buttons/ToggleSidebarButton.tsx +1 -2
  179. package/src/core/components/data/DetailDrawer.tsx +102 -96
  180. package/src/core/components/data/DetailList.tsx +2 -1
  181. package/src/core/components/layout/AppBar.tsx +10 -0
  182. package/src/core/components/layout/Breadcrumb.tsx +3 -6
  183. package/src/core/components/layout/DashboardShell.tsx +28 -11
  184. package/src/core/components/layout/Sidebar.tsx +18 -235
  185. package/src/core/components/layout/SidebarCollapsedItem.tsx +91 -0
  186. package/src/core/components/layout/SidebarItem.tsx +146 -0
  187. package/src/core/components/layout/index.ts +3 -1
  188. package/src/core/constants/ui.ts +5 -5
  189. package/src/core/form/components/Control.tsx +31 -29
  190. package/src/core/form/components/ControlArray.tsx +13 -39
  191. package/src/core/form/components/ControlDate.tsx +10 -21
  192. package/src/core/form/components/ControlNumber.tsx +4 -33
  193. package/src/core/form/components/ControlQueryBuilder.tsx +12 -175
  194. package/src/core/form/components/ControlQueryBuilderHelp.tsx +165 -0
  195. package/src/core/form/components/ControlSelect.browser.spec.tsx +343 -0
  196. package/src/core/form/components/ControlSelect.tsx +294 -92
  197. package/src/core/form/components/TypeForm.browser.spec.tsx +3 -3
  198. package/src/core/form/components/TypeForm.tsx +5 -2
  199. package/src/core/form/index.ts +8 -1
  200. package/src/core/form/utils/parseInput.ts +7 -3
  201. package/src/core/hooks/useTheme.ts +26 -3
  202. package/src/core/index.ts +9 -2
  203. package/src/core/interfaces/AlephaTheme.ts +2 -0
  204. package/src/core/json/components/JsonViewer.tsx +103 -319
  205. package/src/core/json/components/JsonViewerCopyButton.tsx +46 -0
  206. package/src/core/json/components/JsonViewerRowNode.tsx +120 -0
  207. package/src/core/json/components/JsonViewerShared.ts +76 -0
  208. package/src/core/providers/ThemeProvider.ts +108 -8
  209. package/src/core/services/DialogService.tsx +24 -3
  210. package/src/core/styles.css +33 -20
  211. package/src/core/table/components/ColumnPicker.tsx +3 -3
  212. package/src/core/table/components/DataTable.tsx +233 -143
  213. package/src/core/table/components/DataTableFilters.tsx +6 -16
  214. package/src/core/table/components/DataTablePagination.tsx +58 -29
  215. package/src/core/table/components/DataTableToolbar.tsx +16 -7
  216. package/src/core/table/components/FilterPicker.tsx +3 -3
  217. package/src/core/table/index.ts +1 -0
  218. package/src/core/table/interfaces/types.ts +42 -9
  219. package/src/core/utils/icons.tsx +2 -2
  220. package/src/demo/DemoRouter.ts +8 -1
  221. package/src/demo/components/DemoLayout.tsx +12 -2
  222. package/src/demo/components/auth/DemoLogin.tsx +35 -28
  223. package/src/demo/components/auth/DemoRegister.tsx +35 -49
  224. package/src/demo/components/auth/DemoResetPassword.tsx +5 -9
  225. package/src/demo/components/auth/DemoVerifyEmail.tsx +7 -6
  226. package/src/demo/components/core/DemoButton.tsx +123 -103
  227. package/src/demo/components/core/DemoControlSelect.tsx +325 -0
  228. package/src/demo/components/core/DemoDataTable.tsx +255 -241
  229. package/src/demo/components/core/DemoTypeForm.tsx +7 -2
  230. package/src/demo/components/shared/MacWindow.tsx +5 -11
  231. package/src/demo/components/shared/Showcase.tsx +28 -42
  232. package/dist/admin/AdminApiKeys-C-6_Q-lH.js.map +0 -1
  233. package/dist/admin/AdminAudits-Bgbf04hO.js.map +0 -1
  234. package/dist/admin/AdminFiles-B9a7G3cY.js.map +0 -1
  235. package/dist/admin/AdminJobExecutions-B9cek5dl.js.map +0 -1
  236. package/dist/admin/AdminJobRegistry-DFgV3oqx.js.map +0 -1
  237. package/dist/admin/AdminLayout-DHsvWxVB.js +0 -70
  238. package/dist/admin/AdminLayout-DHsvWxVB.js.map +0 -1
  239. package/dist/admin/AdminParameters-DHw9ATgl.js.map +0 -1
  240. package/dist/admin/AdminSessions-BhGJPI3z.js.map +0 -1
  241. package/dist/admin/AdminUserLayout-BdC4Te8m.js.map +0 -1
  242. package/dist/admin/AdminUserSessions-1uzcx02z.js.map +0 -1
  243. package/dist/admin/AdminUsers-C85c3eiQ.js +0 -121
  244. package/dist/admin/AdminUsers-C85c3eiQ.js.map +0 -1
  245. package/dist/admin/Login-BGheURrg.js +0 -219
  246. package/dist/admin/Login-BGheURrg.js.map +0 -1
  247. package/dist/admin/Profile-B-c9pCPf.js.map +0 -1
  248. package/dist/admin/Register-Cs10l8vX.js.map +0 -1
  249. package/dist/admin/ResetPassword-BwDdfkGH.js.map +0 -1
  250. package/dist/admin/VerifyEmail-DfXHAiQl.js.map +0 -1
  251. package/dist/admin/auth-Dr0Cf8I7.js +0 -319
  252. package/dist/admin/auth-Dr0Cf8I7.js.map +0 -1
  253. package/dist/admin/core-2xoLiT0o.js.map +0 -1
  254. package/dist/auth/Login-Denw_UGy.js +0 -219
  255. package/dist/auth/Login-Denw_UGy.js.map +0 -1
  256. package/dist/auth/Profile-BMX_Ar_s.js.map +0 -1
  257. package/dist/auth/Register-6hi_cpfF.js.map +0 -1
  258. package/dist/auth/ResetPassword-CqfTk1FI.js.map +0 -1
  259. package/dist/auth/VerifyEmail-nWiSTMjF.js.map +0 -1
  260. package/dist/auth/core-niW0sFLv.js.map +0 -1
  261. package/dist/demo/DemoButton-BmaWZVwf.js +0 -178
  262. package/dist/demo/DemoButton-BmaWZVwf.js.map +0 -1
  263. package/dist/demo/DemoDataTable-Z9xyV221.js +0 -362
  264. package/dist/demo/DemoDataTable-Z9xyV221.js.map +0 -1
  265. package/dist/demo/DemoLayout-C56xb5EE.js.map +0 -1
  266. package/dist/demo/DemoLogin-BZwpicOS.js.map +0 -1
  267. package/dist/demo/DemoRegister-C7_qc4MJ.js.map +0 -1
  268. package/dist/demo/DemoResetPassword-BI1Ct4Dw.js.map +0 -1
  269. package/dist/demo/DemoTypeForm-DDzWoMSV.js.map +0 -1
  270. package/dist/demo/DemoVerifyEmail-C_Irdnov.js +0 -30
  271. package/dist/demo/DemoVerifyEmail-C_Irdnov.js.map +0 -1
  272. package/dist/demo/Login-hSOU3jZc.js +0 -219
  273. package/dist/demo/Login-hSOU3jZc.js.map +0 -1
  274. package/dist/demo/Profile-CWqti7FB.js.map +0 -1
  275. package/dist/demo/Register-a70LPgs2.js.map +0 -1
  276. package/dist/demo/ResetPassword-DWN0lzr5.js.map +0 -1
  277. package/dist/demo/Showcase-Dq3MISpd.js.map +0 -1
  278. package/dist/demo/VerifyEmail-DZWL72K4.js.map +0 -1
  279. package/dist/demo/core-RCUw1Q-a.js.map +0 -1
  280. package/src/demo/styles.css +0 -0
@@ -0,0 +1,542 @@
1
+ import { _ as ActionButton, b as useToast, d as DetailList, l as Flex$1, r as DataTable, s as Text$1 } from "./core-CYaRQ8O-.js";
2
+ import { t } from "alepha";
3
+ import { useI18n } from "alepha/react/i18n";
4
+ import { Badge, Code, Paper } from "@mantine/core";
5
+ import { jsx, jsxs } from "react/jsx-runtime";
6
+ import { useCallback, useEffect, useState } from "react";
7
+ import { IconRefresh } from "@tabler/icons-react";
8
+ import { useClient } from "alepha/react";
9
+
10
+ //#region ../../src/admin/components/notifications/AdminNotifications.tsx
11
+ const formatDuration = (start, end) => {
12
+ const startTime = new Date(start).getTime();
13
+ const duration = (end ? new Date(end).getTime() : Date.now()) - startTime;
14
+ if (duration < 1e3) return `${duration}ms`;
15
+ if (duration < 6e4) return `${(duration / 1e3).toFixed(1)}s`;
16
+ if (duration < 36e5) return `${Math.floor(duration / 6e4)}m ${Math.floor(duration % 6e4 / 1e3)}s`;
17
+ return `${Math.floor(duration / 36e5)}h ${Math.floor(duration % 36e5 / 6e4)}m`;
18
+ };
19
+ const notificationFilters = t.object({ status: t.optional(t.enum([
20
+ "pending",
21
+ "scheduled",
22
+ "retrying",
23
+ "running",
24
+ "completed",
25
+ "failed",
26
+ "dead",
27
+ "cancelled"
28
+ ])) });
29
+ const AdminNotifications = () => {
30
+ const client = useClient();
31
+ const { l } = useI18n();
32
+ return /* @__PURE__ */ jsx(Flex$1, {
33
+ p: "md",
34
+ flex: 1,
35
+ direction: "column",
36
+ gap: "md",
37
+ children: /* @__PURE__ */ jsx(DataTable, {
38
+ submitOnInit: true,
39
+ defaultSize: 20,
40
+ typeFormProps: {
41
+ skipSubmitButton: true,
42
+ columns: 3
43
+ },
44
+ tableProps: {
45
+ horizontalSpacing: "sm",
46
+ verticalSpacing: "sm"
47
+ },
48
+ onFilterChange: (_key, _value, form) => form.submit(),
49
+ filters: notificationFilters,
50
+ defaultFilters: ["status"],
51
+ items: async (filters) => {
52
+ return await client.findNotifications({ query: { ...filters } });
53
+ },
54
+ columns: {
55
+ status: {
56
+ label: "Status",
57
+ value: (item) => {
58
+ return /* @__PURE__ */ jsx(Badge, {
59
+ size: "sm",
60
+ variant: "light",
61
+ color: item.status === "completed" ? "green" : item.status === "running" ? "blue" : item.status === "failed" || item.status === "dead" ? "red" : item.status === "cancelled" ? "yellow" : "gray",
62
+ children: item.status
63
+ });
64
+ }
65
+ },
66
+ template: {
67
+ label: "Template",
68
+ value: (item) => /* @__PURE__ */ jsx(Text$1, {
69
+ size: "sm",
70
+ fw: 500,
71
+ ff: "monospace",
72
+ children: item.template ?? "—"
73
+ })
74
+ },
75
+ type: {
76
+ label: "Type",
77
+ value: (item) => /* @__PURE__ */ jsx(Badge, {
78
+ size: "sm",
79
+ variant: "light",
80
+ color: item.type === "email" ? "blue" : "teal",
81
+ children: item.type ?? "—"
82
+ })
83
+ },
84
+ contact: {
85
+ label: "Contact",
86
+ value: (item) => /* @__PURE__ */ jsx(Text$1, {
87
+ size: "xs",
88
+ c: "dimmed",
89
+ lineClamp: 1,
90
+ children: item.contact ?? "—"
91
+ })
92
+ },
93
+ category: {
94
+ label: "Category",
95
+ defaultHidden: true,
96
+ value: (item) => /* @__PURE__ */ jsx(Text$1, {
97
+ size: "xs",
98
+ c: "dimmed",
99
+ children: item.category ?? "—"
100
+ })
101
+ },
102
+ flags: {
103
+ label: "Flags",
104
+ defaultHidden: true,
105
+ value: (item) => /* @__PURE__ */ jsxs(Flex$1, {
106
+ gap: 4,
107
+ children: [
108
+ item.critical && /* @__PURE__ */ jsx(Badge, {
109
+ size: "xs",
110
+ variant: "light",
111
+ color: "red",
112
+ children: "critical"
113
+ }),
114
+ item.sensitive && /* @__PURE__ */ jsx(Badge, {
115
+ size: "xs",
116
+ variant: "light",
117
+ color: "orange",
118
+ children: "sensitive"
119
+ }),
120
+ !item.critical && !item.sensitive && /* @__PURE__ */ jsx(Text$1, {
121
+ size: "xs",
122
+ c: "dimmed",
123
+ children: "—"
124
+ })
125
+ ]
126
+ })
127
+ },
128
+ createdAt: {
129
+ label: "Created",
130
+ value: (item) => /* @__PURE__ */ jsx(Text$1, {
131
+ size: "xs",
132
+ c: "dimmed",
133
+ children: l(item.createdAt, { date: "fromNow" })
134
+ })
135
+ },
136
+ duration: {
137
+ label: "Duration",
138
+ defaultHidden: true,
139
+ value: (item) => /* @__PURE__ */ jsx(Text$1, {
140
+ size: "xs",
141
+ c: "dimmed",
142
+ ff: "monospace",
143
+ children: item.startedAt && (item.completedAt || item.status === "running") ? formatDuration(item.startedAt, item.completedAt) : "—"
144
+ })
145
+ },
146
+ error: {
147
+ label: "Error",
148
+ defaultHidden: true,
149
+ value: (item) => /* @__PURE__ */ jsx(Text$1, {
150
+ size: "xs",
151
+ c: "dimmed",
152
+ lineClamp: 1,
153
+ children: item.error ?? "—"
154
+ })
155
+ }
156
+ },
157
+ panel: {
158
+ can: (item) => Boolean(item.error),
159
+ render: (item) => /* @__PURE__ */ jsx(Flex$1, {
160
+ direction: "column",
161
+ gap: "sm",
162
+ p: "sm",
163
+ children: item.error && /* @__PURE__ */ jsxs(Flex$1, {
164
+ direction: "column",
165
+ gap: 2,
166
+ children: [/* @__PURE__ */ jsx(Text$1, {
167
+ size: "xs",
168
+ c: "dimmed",
169
+ tt: "uppercase",
170
+ fw: 600,
171
+ children: "Error"
172
+ }), /* @__PURE__ */ jsx(Paper, {
173
+ p: "xs",
174
+ radius: "sm",
175
+ withBorder: true,
176
+ children: /* @__PURE__ */ jsx(Text$1, {
177
+ size: "sm",
178
+ style: {
179
+ whiteSpace: "pre-wrap",
180
+ wordBreak: "break-word"
181
+ },
182
+ children: item.error
183
+ })
184
+ })]
185
+ })
186
+ })
187
+ },
188
+ drawer: (item) => /* @__PURE__ */ jsx(NotificationDetailContent, { item })
189
+ })
190
+ });
191
+ };
192
+ const NotificationDetailContent = ({ item }) => {
193
+ const client = useClient();
194
+ const { l } = useI18n();
195
+ const toast = useToast();
196
+ const [detail, setDetail] = useState(null);
197
+ const [loading, setLoading] = useState(false);
198
+ const loadDetail = useCallback(async (id) => {
199
+ setDetail(null);
200
+ setLoading(true);
201
+ try {
202
+ setDetail(await client.getNotification({ params: { id } }));
203
+ } catch {
204
+ toast.danger("Failed to load notification details");
205
+ } finally {
206
+ setLoading(false);
207
+ }
208
+ }, [client, toast]);
209
+ useEffect(() => {
210
+ loadDetail(item.id);
211
+ }, [item.id, loadDetail]);
212
+ if (loading) return /* @__PURE__ */ jsx(Flex$1, {
213
+ align: "center",
214
+ justify: "center",
215
+ py: "xl",
216
+ children: /* @__PURE__ */ jsx(Text$1, {
217
+ c: "dimmed",
218
+ children: "Loading..."
219
+ })
220
+ });
221
+ if (!detail) return null;
222
+ const rendered = detail.rendered;
223
+ const detailItems = [
224
+ {
225
+ label: "ID",
226
+ value: /* @__PURE__ */ jsx(Text$1, {
227
+ size: "sm",
228
+ ff: "monospace",
229
+ children: detail.id
230
+ }),
231
+ copyable: detail.id
232
+ },
233
+ {
234
+ label: "Status",
235
+ value: /* @__PURE__ */ jsx(Text$1, {
236
+ size: "sm",
237
+ tt: "capitalize",
238
+ children: detail.status
239
+ })
240
+ },
241
+ {
242
+ label: "Template",
243
+ value: /* @__PURE__ */ jsx(Text$1, {
244
+ size: "sm",
245
+ ff: "monospace",
246
+ children: detail.template
247
+ })
248
+ },
249
+ {
250
+ label: "Type",
251
+ value: /* @__PURE__ */ jsx(Badge, {
252
+ size: "sm",
253
+ variant: "light",
254
+ color: detail.type === "email" ? "blue" : "teal",
255
+ children: detail.type
256
+ })
257
+ },
258
+ {
259
+ label: "Contact",
260
+ value: detail.contact
261
+ },
262
+ {
263
+ label: "Category",
264
+ value: detail.category,
265
+ hidden: !detail.category
266
+ },
267
+ {
268
+ label: "Critical",
269
+ value: detail.critical ? "Yes" : "No",
270
+ hidden: !detail.critical
271
+ },
272
+ {
273
+ label: "Sensitive",
274
+ value: detail.sensitive ? "Yes" : "No",
275
+ hidden: !detail.sensitive
276
+ },
277
+ {
278
+ label: "Created",
279
+ value: String(l(detail.createdAt, { date: "lll" }))
280
+ },
281
+ {
282
+ label: "Started",
283
+ value: detail.startedAt ? String(l(detail.startedAt, { date: "lll" })) : void 0,
284
+ hidden: !detail.startedAt
285
+ },
286
+ {
287
+ label: "Duration",
288
+ value: detail.startedAt && (detail.completedAt || detail.status === "running") ? /* @__PURE__ */ jsx(Text$1, {
289
+ size: "sm",
290
+ ff: "monospace",
291
+ children: formatDuration(detail.startedAt, detail.completedAt)
292
+ }) : void 0,
293
+ hidden: !(detail.startedAt && (detail.completedAt || detail.status === "running"))
294
+ }
295
+ ];
296
+ return /* @__PURE__ */ jsxs(Flex$1, {
297
+ direction: "column",
298
+ gap: "md",
299
+ children: [
300
+ /* @__PURE__ */ jsxs(Flex$1, {
301
+ align: "center",
302
+ gap: "sm",
303
+ children: [
304
+ /* @__PURE__ */ jsx(Text$1, {
305
+ fw: 600,
306
+ ff: "monospace",
307
+ children: detail.template
308
+ }),
309
+ /* @__PURE__ */ jsx(Badge, {
310
+ size: "sm",
311
+ variant: "light",
312
+ color: detail.type === "email" ? "blue" : "teal",
313
+ children: detail.type
314
+ }),
315
+ /* @__PURE__ */ jsx(Text$1, {
316
+ size: "sm",
317
+ tt: "capitalize",
318
+ c: "dimmed",
319
+ children: detail.status
320
+ })
321
+ ]
322
+ }),
323
+ /* @__PURE__ */ jsx(Flex$1, {
324
+ gap: "xs",
325
+ children: /* @__PURE__ */ jsx(ActionButton, {
326
+ tooltip: "Refresh",
327
+ variant: "light",
328
+ size: "xs",
329
+ icon: IconRefresh,
330
+ onClick: () => loadDetail(item.id)
331
+ })
332
+ }),
333
+ /* @__PURE__ */ jsxs(Paper, {
334
+ p: "sm",
335
+ radius: "md",
336
+ withBorder: true,
337
+ children: [/* @__PURE__ */ jsx(Text$1, {
338
+ size: "sm",
339
+ fw: 600,
340
+ mb: "xs",
341
+ children: "Details"
342
+ }), /* @__PURE__ */ jsx(DetailList, {
343
+ items: detailItems,
344
+ columns: 2
345
+ })]
346
+ }),
347
+ rendered && /* @__PURE__ */ jsxs(Paper, {
348
+ p: "sm",
349
+ radius: "md",
350
+ withBorder: true,
351
+ children: [
352
+ /* @__PURE__ */ jsx(Text$1, {
353
+ size: "sm",
354
+ fw: 600,
355
+ mb: "xs",
356
+ children: "Content"
357
+ }),
358
+ rendered.type === "email" && /* @__PURE__ */ jsxs(Flex$1, {
359
+ direction: "column",
360
+ gap: "xs",
361
+ children: [
362
+ /* @__PURE__ */ jsxs(Flex$1, {
363
+ direction: "column",
364
+ gap: 2,
365
+ children: [/* @__PURE__ */ jsx(Text$1, {
366
+ size: "xs",
367
+ c: "dimmed",
368
+ tt: "uppercase",
369
+ fw: 600,
370
+ children: "To"
371
+ }), /* @__PURE__ */ jsx(Text$1, {
372
+ size: "sm",
373
+ children: String(rendered.to ?? "")
374
+ })]
375
+ }),
376
+ /* @__PURE__ */ jsxs(Flex$1, {
377
+ direction: "column",
378
+ gap: 2,
379
+ children: [/* @__PURE__ */ jsx(Text$1, {
380
+ size: "xs",
381
+ c: "dimmed",
382
+ tt: "uppercase",
383
+ fw: 600,
384
+ children: "Subject"
385
+ }), /* @__PURE__ */ jsx(Text$1, {
386
+ size: "sm",
387
+ children: String(rendered.subject ?? "")
388
+ })]
389
+ }),
390
+ /* @__PURE__ */ jsxs(Flex$1, {
391
+ direction: "column",
392
+ gap: 2,
393
+ children: [/* @__PURE__ */ jsx(Text$1, {
394
+ size: "xs",
395
+ c: "dimmed",
396
+ tt: "uppercase",
397
+ fw: 600,
398
+ children: "Body"
399
+ }), /* @__PURE__ */ jsx(Paper, {
400
+ p: "xs",
401
+ radius: "sm",
402
+ withBorder: true,
403
+ children: /* @__PURE__ */ jsx(Text$1, {
404
+ size: "sm",
405
+ style: {
406
+ whiteSpace: "pre-wrap",
407
+ wordBreak: "break-word"
408
+ },
409
+ children: String(rendered.body ?? "")
410
+ })
411
+ })]
412
+ })
413
+ ]
414
+ }),
415
+ rendered.type === "sms" && /* @__PURE__ */ jsxs(Flex$1, {
416
+ direction: "column",
417
+ gap: "xs",
418
+ children: [/* @__PURE__ */ jsxs(Flex$1, {
419
+ direction: "column",
420
+ gap: 2,
421
+ children: [/* @__PURE__ */ jsx(Text$1, {
422
+ size: "xs",
423
+ c: "dimmed",
424
+ tt: "uppercase",
425
+ fw: 600,
426
+ children: "To"
427
+ }), /* @__PURE__ */ jsx(Text$1, {
428
+ size: "sm",
429
+ children: String(rendered.to ?? "")
430
+ })]
431
+ }), /* @__PURE__ */ jsxs(Flex$1, {
432
+ direction: "column",
433
+ gap: 2,
434
+ children: [/* @__PURE__ */ jsx(Text$1, {
435
+ size: "xs",
436
+ c: "dimmed",
437
+ tt: "uppercase",
438
+ fw: 600,
439
+ children: "Message"
440
+ }), /* @__PURE__ */ jsx(Paper, {
441
+ p: "xs",
442
+ radius: "sm",
443
+ withBorder: true,
444
+ children: /* @__PURE__ */ jsx(Text$1, {
445
+ size: "sm",
446
+ style: {
447
+ whiteSpace: "pre-wrap",
448
+ wordBreak: "break-word"
449
+ },
450
+ children: String(rendered.message ?? "")
451
+ })
452
+ })]
453
+ })]
454
+ })
455
+ ]
456
+ }),
457
+ detail.variables && Object.keys(detail.variables).length > 0 && /* @__PURE__ */ jsxs(Paper, {
458
+ p: "sm",
459
+ radius: "md",
460
+ withBorder: true,
461
+ children: [/* @__PURE__ */ jsx(Text$1, {
462
+ size: "sm",
463
+ fw: 600,
464
+ mb: "xs",
465
+ children: "Variables"
466
+ }), /* @__PURE__ */ jsx(Code, {
467
+ block: true,
468
+ children: JSON.stringify(detail.variables, null, 2)
469
+ })]
470
+ }),
471
+ detail.error && /* @__PURE__ */ jsxs(Paper, {
472
+ p: "sm",
473
+ radius: "md",
474
+ withBorder: true,
475
+ children: [/* @__PURE__ */ jsx(Text$1, {
476
+ size: "sm",
477
+ fw: 600,
478
+ mb: "xs",
479
+ children: "Error"
480
+ }), /* @__PURE__ */ jsx(Paper, {
481
+ p: "xs",
482
+ radius: "sm",
483
+ withBorder: true,
484
+ children: /* @__PURE__ */ jsx(Text$1, {
485
+ size: "sm",
486
+ style: {
487
+ whiteSpace: "pre-wrap",
488
+ wordBreak: "break-word"
489
+ },
490
+ children: detail.error
491
+ })
492
+ })]
493
+ }),
494
+ detail.logs && detail.logs.length > 0 && /* @__PURE__ */ jsxs(Paper, {
495
+ p: "sm",
496
+ radius: "md",
497
+ withBorder: true,
498
+ children: [/* @__PURE__ */ jsxs(Text$1, {
499
+ size: "sm",
500
+ fw: 600,
501
+ mb: "xs",
502
+ children: [
503
+ "Logs (",
504
+ detail.logs.length,
505
+ ")"
506
+ ]
507
+ }), /* @__PURE__ */ jsx(Flex$1, {
508
+ direction: "column",
509
+ style: {
510
+ maxHeight: 300,
511
+ overflowY: "auto"
512
+ },
513
+ children: detail.logs.map((log, i) => /* @__PURE__ */ jsxs(Flex$1, {
514
+ gap: "sm",
515
+ py: 2,
516
+ children: [
517
+ /* @__PURE__ */ jsx(Badge, {
518
+ size: "xs",
519
+ variant: "default",
520
+ children: log.level
521
+ }),
522
+ /* @__PURE__ */ jsx(Text$1, {
523
+ size: "xs",
524
+ c: "dimmed",
525
+ ff: "monospace",
526
+ children: new Date(log.timestamp).toLocaleTimeString()
527
+ }),
528
+ /* @__PURE__ */ jsx(Text$1, {
529
+ size: "xs",
530
+ children: log.message
531
+ })
532
+ ]
533
+ }, i))
534
+ })]
535
+ })
536
+ ]
537
+ });
538
+ };
539
+
540
+ //#endregion
541
+ export { AdminNotifications as default };
542
+ //# sourceMappingURL=AdminNotifications-ZPHCYrv7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AdminNotifications-ZPHCYrv7.js","names":["Flex","Text"],"sources":["../../src/admin/components/notifications/AdminNotifications.tsx"],"sourcesContent":["import type { DetailListItem } from \"@alepha/ui\";\nimport {\n ActionButton,\n DataTable,\n DetailList,\n Flex,\n Text,\n useToast,\n} from \"@alepha/ui\";\nimport { Badge, Code, Paper } from \"@mantine/core\";\nimport { IconRefresh } from \"@tabler/icons-react\";\nimport { type Page, t } from \"alepha\";\nimport type {\n AdminNotificationController,\n NotificationDetailResource,\n NotificationResource,\n} from \"alepha/api/notifications\";\nimport type { LogEntry } from \"alepha/logger\";\nimport { useClient } from \"alepha/react\";\nimport { useI18n } from \"alepha/react/i18n\";\nimport { useCallback, useEffect, useState } from \"react\";\n\n// ─────────────────────────────────────────────────────────────────────────────\n\nconst formatDuration = (\n start: Date | string,\n end?: Date | string | null,\n): string => {\n const startTime = new Date(start).getTime();\n const endTime = end ? new Date(end).getTime() : Date.now();\n const duration = endTime - startTime;\n\n if (duration < 1000) return `${duration}ms`;\n if (duration < 60000) return `${(duration / 1000).toFixed(1)}s`;\n if (duration < 3600000)\n return `${Math.floor(duration / 60000)}m ${Math.floor((duration % 60000) / 1000)}s`;\n return `${Math.floor(duration / 3600000)}h ${Math.floor((duration % 3600000) / 60000)}m`;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n\nconst notificationFilters = t.object({\n status: t.optional(\n t.enum([\n \"pending\",\n \"scheduled\",\n \"retrying\",\n \"running\",\n \"completed\",\n \"failed\",\n \"dead\",\n \"cancelled\",\n ]),\n ),\n});\n\n// ─────────────────────────────────────────────────────────────────────────────\n\nconst AdminNotifications = () => {\n const client = useClient<AdminNotificationController>();\n const { l } = useI18n();\n\n return (\n <Flex p=\"md\" flex={1} direction=\"column\" gap=\"md\">\n <DataTable<NotificationResource, typeof notificationFilters>\n submitOnInit\n defaultSize={20}\n typeFormProps={{\n skipSubmitButton: true,\n columns: 3,\n }}\n tableProps={{\n horizontalSpacing: \"sm\",\n verticalSpacing: \"sm\",\n }}\n onFilterChange={(_key, _value, form) => form.submit()}\n filters={notificationFilters}\n defaultFilters={[\"status\"]}\n items={async (filters) => {\n const response = await client.findNotifications({\n query: { ...filters },\n });\n return response as Page<NotificationResource>;\n }}\n columns={{\n status: {\n label: \"Status\",\n value: (item) => {\n const color =\n item.status === \"completed\"\n ? \"green\"\n : item.status === \"running\"\n ? \"blue\"\n : item.status === \"failed\" || item.status === \"dead\"\n ? \"red\"\n : item.status === \"cancelled\"\n ? \"yellow\"\n : \"gray\";\n return (\n <Badge size=\"sm\" variant=\"light\" color={color}>\n {item.status}\n </Badge>\n );\n },\n },\n template: {\n label: \"Template\",\n value: (item) => (\n <Text size=\"sm\" fw={500} ff=\"monospace\">\n {item.template ?? \"\\u2014\"}\n </Text>\n ),\n },\n type: {\n label: \"Type\",\n value: (item) => (\n <Badge\n size=\"sm\"\n variant=\"light\"\n color={item.type === \"email\" ? \"blue\" : \"teal\"}\n >\n {item.type ?? \"\\u2014\"}\n </Badge>\n ),\n },\n contact: {\n label: \"Contact\",\n value: (item) => (\n <Text size=\"xs\" c=\"dimmed\" lineClamp={1}>\n {item.contact ?? \"\\u2014\"}\n </Text>\n ),\n },\n category: {\n label: \"Category\",\n defaultHidden: true,\n value: (item) => (\n <Text size=\"xs\" c=\"dimmed\">\n {item.category ?? \"\\u2014\"}\n </Text>\n ),\n },\n flags: {\n label: \"Flags\",\n defaultHidden: true,\n value: (item) => (\n <Flex gap={4}>\n {item.critical && (\n <Badge size=\"xs\" variant=\"light\" color=\"red\">\n critical\n </Badge>\n )}\n {item.sensitive && (\n <Badge size=\"xs\" variant=\"light\" color=\"orange\">\n sensitive\n </Badge>\n )}\n {!item.critical && !item.sensitive && (\n <Text size=\"xs\" c=\"dimmed\">\n {\"\\u2014\"}\n </Text>\n )}\n </Flex>\n ),\n },\n createdAt: {\n label: \"Created\",\n value: (item) => (\n <Text size=\"xs\" c=\"dimmed\">\n {l(item.createdAt, { date: \"fromNow\" })}\n </Text>\n ),\n },\n duration: {\n label: \"Duration\",\n defaultHidden: true,\n value: (item) => (\n <Text size=\"xs\" c=\"dimmed\" ff=\"monospace\">\n {item.startedAt &&\n (item.completedAt || item.status === \"running\")\n ? formatDuration(item.startedAt, item.completedAt)\n : \"\\u2014\"}\n </Text>\n ),\n },\n error: {\n label: \"Error\",\n defaultHidden: true,\n value: (item) => (\n <Text size=\"xs\" c=\"dimmed\" lineClamp={1}>\n {item.error ?? \"\\u2014\"}\n </Text>\n ),\n },\n }}\n panel={{\n can: (item) => Boolean(item.error),\n render: (item) => (\n <Flex direction=\"column\" gap=\"sm\" p=\"sm\">\n {item.error && (\n <Flex direction=\"column\" gap={2}>\n <Text size=\"xs\" c=\"dimmed\" tt=\"uppercase\" fw={600}>\n Error\n </Text>\n <Paper p=\"xs\" radius=\"sm\" withBorder>\n <Text\n size=\"sm\"\n style={{\n whiteSpace: \"pre-wrap\",\n wordBreak: \"break-word\",\n }}\n >\n {item.error}\n </Text>\n </Paper>\n </Flex>\n )}\n </Flex>\n ),\n }}\n drawer={(item) => <NotificationDetailContent item={item} />}\n />\n </Flex>\n );\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n\nconst NotificationDetailContent = ({\n item,\n}: {\n item: NotificationResource;\n}) => {\n const client = useClient<AdminNotificationController>();\n const { l } = useI18n();\n const toast = useToast();\n const [detail, setDetail] = useState<NotificationDetailResource | null>(null);\n const [loading, setLoading] = useState(false);\n\n const loadDetail = useCallback(\n async (id: string) => {\n setDetail(null);\n setLoading(true);\n try {\n const data = await client.getNotification({ params: { id } });\n setDetail(data);\n } catch {\n toast.danger(\"Failed to load notification details\");\n } finally {\n setLoading(false);\n }\n },\n [client, toast],\n );\n\n useEffect(() => {\n loadDetail(item.id);\n }, [item.id, loadDetail]);\n\n if (loading) {\n return (\n <Flex align=\"center\" justify=\"center\" py=\"xl\">\n <Text c=\"dimmed\">Loading...</Text>\n </Flex>\n );\n }\n\n if (!detail) return null;\n\n const rendered = detail.rendered as Record<string, unknown> | undefined;\n\n const detailItems: DetailListItem[] = [\n {\n label: \"ID\",\n value: (\n <Text size=\"sm\" ff=\"monospace\">\n {detail.id}\n </Text>\n ),\n copyable: detail.id,\n },\n {\n label: \"Status\",\n value: (\n <Text size=\"sm\" tt=\"capitalize\">\n {detail.status}\n </Text>\n ),\n },\n {\n label: \"Template\",\n value: (\n <Text size=\"sm\" ff=\"monospace\">\n {detail.template}\n </Text>\n ),\n },\n {\n label: \"Type\",\n value: (\n <Badge\n size=\"sm\"\n variant=\"light\"\n color={detail.type === \"email\" ? \"blue\" : \"teal\"}\n >\n {detail.type}\n </Badge>\n ),\n },\n {\n label: \"Contact\",\n value: detail.contact,\n },\n {\n label: \"Category\",\n value: detail.category,\n hidden: !detail.category,\n },\n {\n label: \"Critical\",\n value: detail.critical ? \"Yes\" : \"No\",\n hidden: !detail.critical,\n },\n {\n label: \"Sensitive\",\n value: detail.sensitive ? \"Yes\" : \"No\",\n hidden: !detail.sensitive,\n },\n {\n label: \"Created\",\n value: String(l(detail.createdAt, { date: \"lll\" })),\n },\n {\n label: \"Started\",\n value: detail.startedAt\n ? String(l(detail.startedAt, { date: \"lll\" }))\n : undefined,\n hidden: !detail.startedAt,\n },\n {\n label: \"Duration\",\n value:\n detail.startedAt &&\n (detail.completedAt || detail.status === \"running\") ? (\n <Text size=\"sm\" ff=\"monospace\">\n {formatDuration(detail.startedAt, detail.completedAt)}\n </Text>\n ) : undefined,\n hidden: !(\n detail.startedAt &&\n (detail.completedAt || detail.status === \"running\")\n ),\n },\n ];\n\n return (\n <Flex direction=\"column\" gap=\"md\">\n {/* Header */}\n <Flex align=\"center\" gap=\"sm\">\n <Text fw={600} ff=\"monospace\">\n {detail.template}\n </Text>\n <Badge\n size=\"sm\"\n variant=\"light\"\n color={detail.type === \"email\" ? \"blue\" : \"teal\"}\n >\n {detail.type}\n </Badge>\n <Text size=\"sm\" tt=\"capitalize\" c=\"dimmed\">\n {detail.status}\n </Text>\n </Flex>\n\n {/* Actions */}\n <Flex gap=\"xs\">\n <ActionButton\n tooltip=\"Refresh\"\n variant=\"light\"\n size=\"xs\"\n icon={IconRefresh}\n onClick={() => loadDetail(item.id)}\n />\n </Flex>\n\n {/* Details */}\n <Paper p=\"sm\" radius=\"md\" withBorder>\n <Text size=\"sm\" fw={600} mb=\"xs\">\n Details\n </Text>\n <DetailList items={detailItems} columns={2} />\n </Paper>\n\n {/* Rendered Content */}\n {rendered && (\n <Paper p=\"sm\" radius=\"md\" withBorder>\n <Text size=\"sm\" fw={600} mb=\"xs\">\n Content\n </Text>\n {rendered.type === \"email\" && (\n <Flex direction=\"column\" gap=\"xs\">\n <Flex direction=\"column\" gap={2}>\n <Text size=\"xs\" c=\"dimmed\" tt=\"uppercase\" fw={600}>\n To\n </Text>\n <Text size=\"sm\">{String(rendered.to ?? \"\")}</Text>\n </Flex>\n <Flex direction=\"column\" gap={2}>\n <Text size=\"xs\" c=\"dimmed\" tt=\"uppercase\" fw={600}>\n Subject\n </Text>\n <Text size=\"sm\">{String(rendered.subject ?? \"\")}</Text>\n </Flex>\n <Flex direction=\"column\" gap={2}>\n <Text size=\"xs\" c=\"dimmed\" tt=\"uppercase\" fw={600}>\n Body\n </Text>\n <Paper p=\"xs\" radius=\"sm\" withBorder>\n <Text\n size=\"sm\"\n style={{\n whiteSpace: \"pre-wrap\",\n wordBreak: \"break-word\",\n }}\n >\n {String(rendered.body ?? \"\")}\n </Text>\n </Paper>\n </Flex>\n </Flex>\n )}\n {rendered.type === \"sms\" && (\n <Flex direction=\"column\" gap=\"xs\">\n <Flex direction=\"column\" gap={2}>\n <Text size=\"xs\" c=\"dimmed\" tt=\"uppercase\" fw={600}>\n To\n </Text>\n <Text size=\"sm\">{String(rendered.to ?? \"\")}</Text>\n </Flex>\n <Flex direction=\"column\" gap={2}>\n <Text size=\"xs\" c=\"dimmed\" tt=\"uppercase\" fw={600}>\n Message\n </Text>\n <Paper p=\"xs\" radius=\"sm\" withBorder>\n <Text\n size=\"sm\"\n style={{\n whiteSpace: \"pre-wrap\",\n wordBreak: \"break-word\",\n }}\n >\n {String(rendered.message ?? \"\")}\n </Text>\n </Paper>\n </Flex>\n </Flex>\n )}\n </Paper>\n )}\n\n {/* Variables */}\n {detail.variables && Object.keys(detail.variables).length > 0 && (\n <Paper p=\"sm\" radius=\"md\" withBorder>\n <Text size=\"sm\" fw={600} mb=\"xs\">\n Variables\n </Text>\n <Code block>{JSON.stringify(detail.variables, null, 2)}</Code>\n </Paper>\n )}\n\n {/* Error */}\n {detail.error && (\n <Paper p=\"sm\" radius=\"md\" withBorder>\n <Text size=\"sm\" fw={600} mb=\"xs\">\n Error\n </Text>\n <Paper p=\"xs\" radius=\"sm\" withBorder>\n <Text\n size=\"sm\"\n style={{\n whiteSpace: \"pre-wrap\",\n wordBreak: \"break-word\",\n }}\n >\n {detail.error}\n </Text>\n </Paper>\n </Paper>\n )}\n\n {/* Logs */}\n {detail.logs && detail.logs.length > 0 && (\n <Paper p=\"sm\" radius=\"md\" withBorder>\n <Text size=\"sm\" fw={600} mb=\"xs\">\n Logs ({detail.logs.length})\n </Text>\n <Flex\n direction=\"column\"\n style={{ maxHeight: 300, overflowY: \"auto\" }}\n >\n {detail.logs.map((log: LogEntry, i: number) => (\n <Flex key={i} gap=\"sm\" py={2}>\n <Badge size=\"xs\" variant=\"default\">\n {log.level}\n </Badge>\n <Text size=\"xs\" c=\"dimmed\" ff=\"monospace\">\n {new Date(log.timestamp).toLocaleTimeString()}\n </Text>\n <Text size=\"xs\">{log.message}</Text>\n </Flex>\n ))}\n </Flex>\n </Paper>\n )}\n </Flex>\n );\n};\n\nexport default AdminNotifications;\n"],"mappings":"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"}