@payez/next-mvp 4.0.1 → 4.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (433) hide show
  1. package/dist/api/auth-handler.d.ts +66 -0
  2. package/dist/api/auth-handler.js +397 -0
  3. package/dist/api/index.d.ts +10 -0
  4. package/dist/api/index.js +19 -0
  5. package/dist/api-handlers/account/change-password.d.ts +9 -0
  6. package/dist/api-handlers/account/change-password.js +110 -0
  7. package/dist/api-handlers/account/masked-info.d.ts +2 -0
  8. package/dist/api-handlers/account/masked-info.js +41 -0
  9. package/dist/api-handlers/account/profile.d.ts +3 -0
  10. package/dist/api-handlers/account/profile.js +63 -0
  11. package/dist/api-handlers/account/recovery/initiate.d.ts +2 -0
  12. package/dist/api-handlers/account/recovery/initiate.js +26 -0
  13. package/dist/api-handlers/account/recovery/send-code.d.ts +2 -0
  14. package/dist/api-handlers/account/recovery/send-code.js +28 -0
  15. package/dist/api-handlers/account/recovery/verify-code.d.ts +2 -0
  16. package/dist/api-handlers/account/recovery/verify-code.js +28 -0
  17. package/dist/api-handlers/account/reset-password.d.ts +2 -0
  18. package/dist/api-handlers/account/reset-password.js +26 -0
  19. package/dist/api-handlers/account/send-code.d.ts +24 -0
  20. package/dist/api-handlers/account/send-code.js +60 -0
  21. package/dist/api-handlers/account/update-phone.d.ts +27 -0
  22. package/dist/api-handlers/account/update-phone.js +64 -0
  23. package/dist/api-handlers/account/validate-password.d.ts +17 -0
  24. package/dist/api-handlers/account/validate-password.js +81 -0
  25. package/dist/api-handlers/account/verify-email.d.ts +26 -0
  26. package/dist/api-handlers/account/verify-email.js +106 -0
  27. package/dist/api-handlers/account/verify-sms.d.ts +26 -0
  28. package/dist/api-handlers/account/verify-sms.js +106 -0
  29. package/dist/api-handlers/admin/analytics.d.ts +19 -0
  30. package/dist/api-handlers/admin/analytics.js +378 -0
  31. package/dist/api-handlers/admin/audit.d.ts +19 -0
  32. package/dist/api-handlers/admin/audit.js +213 -0
  33. package/dist/api-handlers/admin/index.d.ts +21 -0
  34. package/dist/api-handlers/admin/index.js +42 -0
  35. package/dist/api-handlers/admin/redis-sessions.d.ts +35 -0
  36. package/dist/api-handlers/admin/redis-sessions.js +203 -0
  37. package/dist/api-handlers/admin/sessions.d.ts +20 -0
  38. package/dist/api-handlers/admin/sessions.js +283 -0
  39. package/dist/api-handlers/admin/site-logs.d.ts +45 -0
  40. package/dist/api-handlers/admin/site-logs.js +317 -0
  41. package/dist/api-handlers/admin/stats.d.ts +20 -0
  42. package/dist/api-handlers/admin/stats.js +239 -0
  43. package/dist/api-handlers/admin/users.d.ts +19 -0
  44. package/dist/api-handlers/admin/users.js +221 -0
  45. package/dist/api-handlers/admin/vibe-data.d.ts +79 -0
  46. package/dist/api-handlers/admin/vibe-data.js +267 -0
  47. package/dist/api-handlers/anon/preferences.d.ts +37 -0
  48. package/dist/api-handlers/anon/preferences.js +96 -0
  49. package/dist/api-handlers/auth/jwks.d.ts +2 -0
  50. package/dist/api-handlers/auth/jwks.js +24 -0
  51. package/dist/api-handlers/auth/login.d.ts +42 -0
  52. package/dist/api-handlers/auth/login.js +178 -0
  53. package/dist/api-handlers/auth/refresh.d.ts +74 -0
  54. package/dist/api-handlers/auth/refresh.js +633 -0
  55. package/dist/api-handlers/auth/signout.d.ts +37 -0
  56. package/dist/api-handlers/auth/signout.js +186 -0
  57. package/dist/api-handlers/auth/status.d.ts +8 -0
  58. package/dist/api-handlers/auth/status.js +23 -0
  59. package/dist/api-handlers/auth/update-session.d.ts +37 -0
  60. package/dist/api-handlers/auth/update-session.js +93 -0
  61. package/dist/api-handlers/auth/validate.d.ts +6 -0
  62. package/dist/api-handlers/auth/validate.js +43 -0
  63. package/dist/api-handlers/auth/verify-code.d.ts +43 -0
  64. package/dist/api-handlers/auth/verify-code.js +90 -0
  65. package/dist/api-handlers/session/refresh-viability.d.ts +14 -0
  66. package/dist/api-handlers/session/refresh-viability.js +39 -0
  67. package/dist/api-handlers/session/viability.d.ts +13 -0
  68. package/dist/api-handlers/session/viability.js +114 -0
  69. package/dist/api-handlers/test/force-expire.d.ts +23 -0
  70. package/dist/api-handlers/test/force-expire.js +59 -0
  71. package/dist/auth/auth-decision.d.ts +39 -0
  72. package/dist/auth/auth-decision.js +182 -0
  73. package/dist/auth/better-auth.d.ts +79 -0
  74. package/dist/auth/better-auth.js +119 -0
  75. package/dist/auth/route-config.d.ts +66 -0
  76. package/dist/auth/route-config.js +190 -0
  77. package/dist/auth/types/auth-types.d.ts +417 -0
  78. package/dist/auth/types/auth-types.js +53 -0
  79. package/dist/auth/types/index.d.ts +6 -0
  80. package/dist/auth/types/index.js +22 -0
  81. package/dist/auth/unauthenticated-routes.d.ts +1 -0
  82. package/dist/auth/unauthenticated-routes.js +19 -0
  83. package/dist/auth/utils/idp-client.d.ts +94 -0
  84. package/dist/auth/utils/idp-client.js +384 -0
  85. package/dist/auth/utils/index.d.ts +5 -0
  86. package/dist/auth/utils/index.js +21 -0
  87. package/dist/auth/utils/token-utils.d.ts +83 -0
  88. package/dist/auth/utils/token-utils.js +218 -0
  89. package/dist/client/AuthContext.d.ts +19 -0
  90. package/dist/client/AuthContext.js +115 -0
  91. package/dist/client/better-auth-client.d.ts +1020 -0
  92. package/dist/client/better-auth-client.js +68 -0
  93. package/dist/client/fetch-with-auth.d.ts +11 -0
  94. package/dist/client/fetch-with-auth.js +44 -0
  95. package/dist/client/fetchWithSession.d.ts +3 -0
  96. package/dist/client/fetchWithSession.js +24 -0
  97. package/dist/client/index.d.ts +9 -0
  98. package/dist/client/index.js +20 -0
  99. package/dist/client/useAnonSession.d.ts +36 -0
  100. package/dist/client/useAnonSession.js +99 -0
  101. package/dist/components/SessionSync.d.ts +13 -0
  102. package/dist/components/SessionSync.js +121 -0
  103. package/dist/components/SignalRHealthCheck.d.ts +10 -0
  104. package/dist/components/SignalRHealthCheck.js +97 -0
  105. package/dist/components/account/MobileNavDrawer.d.ts +32 -0
  106. package/dist/components/account/MobileNavDrawer.js +81 -0
  107. package/dist/components/account/UserAvatarMenu.d.ts +20 -0
  108. package/dist/components/account/UserAvatarMenu.js +91 -0
  109. package/dist/components/account/index.d.ts +9 -0
  110. package/dist/components/account/index.js +13 -0
  111. package/dist/components/admin/AlertSettingsTab.d.ts +48 -0
  112. package/dist/components/admin/AlertSettingsTab.js +351 -0
  113. package/dist/components/admin/AnalyticsTab.d.ts +22 -0
  114. package/dist/components/admin/AnalyticsTab.js +167 -0
  115. package/dist/components/admin/DataBrowserTab.d.ts +19 -0
  116. package/dist/components/admin/DataBrowserTab.js +252 -0
  117. package/dist/components/admin/LoggingSettingsTab.d.ts +73 -0
  118. package/dist/components/admin/LoggingSettingsTab.js +339 -0
  119. package/dist/components/admin/SessionsTab.d.ts +37 -0
  120. package/dist/components/admin/SessionsTab.js +165 -0
  121. package/dist/components/admin/StatsTab.d.ts +53 -0
  122. package/dist/components/admin/StatsTab.js +161 -0
  123. package/dist/components/admin/VibeAdminContext.d.ts +32 -0
  124. package/dist/components/admin/VibeAdminContext.js +38 -0
  125. package/dist/components/admin/VibeAdminLayout.d.ts +11 -0
  126. package/dist/components/admin/VibeAdminLayout.js +71 -0
  127. package/dist/components/admin/index.d.ts +29 -0
  128. package/dist/components/admin/index.js +44 -0
  129. package/dist/components/auth/FederatedAuthSection.d.ts +8 -0
  130. package/dist/components/auth/FederatedAuthSection.js +45 -0
  131. package/dist/components/auth/ModeAwareLoginPage.d.ts +10 -0
  132. package/dist/components/auth/ModeAwareLoginPage.js +42 -0
  133. package/dist/components/auth/ModeAwareSignupPage.d.ts +9 -0
  134. package/dist/components/auth/ModeAwareSignupPage.js +78 -0
  135. package/dist/components/auth/TraditionalAuthSection.d.ts +14 -0
  136. package/dist/components/auth/TraditionalAuthSection.js +20 -0
  137. package/dist/components/recovery/CompleteStep.d.ts +5 -0
  138. package/dist/components/recovery/CompleteStep.js +8 -0
  139. package/dist/components/recovery/InitiateRecoveryStep.d.ts +8 -0
  140. package/dist/components/recovery/InitiateRecoveryStep.js +20 -0
  141. package/dist/components/recovery/SelectMethodStep.d.ts +8 -0
  142. package/dist/components/recovery/SelectMethodStep.js +8 -0
  143. package/dist/components/recovery/SetPasswordStep.d.ts +6 -0
  144. package/dist/components/recovery/SetPasswordStep.js +20 -0
  145. package/dist/components/recovery/VerifyCodeStep.d.ts +10 -0
  146. package/dist/components/recovery/VerifyCodeStep.js +24 -0
  147. package/dist/components/reserved/ReservedRecoveryWarning.d.ts +38 -0
  148. package/dist/components/reserved/ReservedRecoveryWarning.js +92 -0
  149. package/dist/components/reserved/ReservedStatusBox.d.ts +30 -0
  150. package/dist/components/reserved/ReservedStatusBox.js +71 -0
  151. package/dist/components/ui/BetaBadge.d.ts +29 -0
  152. package/dist/components/ui/BetaBadge.js +38 -0
  153. package/dist/components/ui/Footer.d.ts +37 -0
  154. package/dist/components/ui/Footer.js +41 -0
  155. package/dist/config/env.d.ts +66 -0
  156. package/dist/config/env.js +57 -0
  157. package/dist/config/logger.d.ts +57 -0
  158. package/dist/config/logger.js +73 -0
  159. package/dist/config/logging-config.d.ts +30 -0
  160. package/dist/config/logging-config.js +122 -0
  161. package/dist/config/unauthenticated-routes.d.ts +17 -0
  162. package/dist/config/unauthenticated-routes.js +24 -0
  163. package/dist/config/vibe-log-transport.d.ts +81 -0
  164. package/dist/config/vibe-log-transport.js +212 -0
  165. package/dist/edge/internal-api-url.d.ts +53 -0
  166. package/dist/edge/internal-api-url.js +63 -0
  167. package/dist/edge/middleware.d.ts +14 -0
  168. package/dist/edge/middleware.js +32 -0
  169. package/dist/hooks/useAuth.d.ts +23 -0
  170. package/dist/hooks/useAuth.js +83 -0
  171. package/dist/hooks/useAuthSettings.d.ts +59 -0
  172. package/dist/hooks/useAuthSettings.js +93 -0
  173. package/dist/hooks/useAvailableProviders.d.ts +43 -0
  174. package/dist/hooks/useAvailableProviders.js +112 -0
  175. package/dist/hooks/usePasswordValidation.d.ts +27 -0
  176. package/dist/hooks/usePasswordValidation.js +102 -0
  177. package/dist/hooks/useProfile.d.ts +15 -0
  178. package/dist/hooks/useProfile.js +59 -0
  179. package/dist/hooks/usePublicAuthSettings.d.ts +56 -0
  180. package/dist/hooks/usePublicAuthSettings.js +131 -0
  181. package/dist/hooks/useSessionExpiration.d.ts +56 -0
  182. package/dist/hooks/useSessionExpiration.js +72 -0
  183. package/dist/hooks/useViabilitySession.d.ts +75 -0
  184. package/dist/hooks/useViabilitySession.js +269 -0
  185. package/dist/index.d.ts +12 -0
  186. package/dist/index.js +53 -0
  187. package/dist/lib/anon-session.d.ts +74 -0
  188. package/dist/lib/anon-session.js +169 -0
  189. package/dist/lib/api-handler.d.ts +123 -0
  190. package/dist/lib/api-handler.js +478 -0
  191. package/dist/lib/app-slug.d.ts +95 -0
  192. package/dist/lib/app-slug.js +172 -0
  193. package/dist/lib/demo-mode.d.ts +6 -0
  194. package/dist/lib/demo-mode.js +16 -0
  195. package/dist/lib/geolocation.d.ts +64 -0
  196. package/dist/lib/geolocation.js +235 -0
  197. package/dist/lib/idp-client-config.d.ts +75 -0
  198. package/dist/lib/idp-client-config.js +425 -0
  199. package/dist/lib/idp-fetch.d.ts +14 -0
  200. package/dist/lib/idp-fetch.js +91 -0
  201. package/dist/lib/internal-api.d.ts +87 -0
  202. package/dist/lib/internal-api.js +122 -0
  203. package/dist/lib/jwt-decode-client.d.ts +10 -0
  204. package/dist/lib/jwt-decode-client.js +46 -0
  205. package/dist/lib/jwt-decode.d.ts +48 -0
  206. package/dist/lib/jwt-decode.js +57 -0
  207. package/dist/lib/rate-limit-service.d.ts +23 -0
  208. package/dist/lib/rate-limit-service.js +6 -0
  209. package/dist/lib/redis.d.ts +5 -0
  210. package/dist/lib/redis.js +28 -0
  211. package/dist/lib/refresh-token-validator.d.ts +13 -0
  212. package/dist/lib/refresh-token-validator.js +117 -0
  213. package/dist/lib/roles.d.ts +145 -0
  214. package/dist/lib/roles.js +168 -0
  215. package/dist/lib/secret-validation.d.ts +4 -0
  216. package/dist/lib/secret-validation.js +14 -0
  217. package/dist/lib/session-store.d.ts +170 -0
  218. package/dist/lib/session-store.js +545 -0
  219. package/dist/lib/session.d.ts +21 -0
  220. package/dist/lib/session.js +26 -0
  221. package/dist/lib/site-logger.d.ts +214 -0
  222. package/dist/lib/site-logger.js +210 -0
  223. package/dist/lib/standardized-client-api.d.ts +161 -0
  224. package/dist/lib/standardized-client-api.js +791 -0
  225. package/dist/lib/startup-init.d.ts +40 -0
  226. package/dist/lib/startup-init.js +257 -0
  227. package/dist/lib/test-aware-get-token.d.ts +2 -0
  228. package/dist/lib/test-aware-get-token.js +86 -0
  229. package/dist/lib/token-expiry.d.ts +14 -0
  230. package/dist/lib/token-expiry.js +39 -0
  231. package/dist/lib/token-lifecycle.d.ts +78 -0
  232. package/dist/lib/token-lifecycle.js +360 -0
  233. package/dist/lib/types/api-responses.d.ts +128 -0
  234. package/dist/lib/types/api-responses.js +171 -0
  235. package/dist/lib/user-agent-parser.d.ts +50 -0
  236. package/dist/lib/user-agent-parser.js +220 -0
  237. package/dist/logging/api/admin-analytics.d.ts +3 -0
  238. package/dist/logging/api/admin-analytics.js +45 -0
  239. package/dist/logging/api/audit-log.d.ts +3 -0
  240. package/dist/logging/api/audit-log.js +52 -0
  241. package/dist/logging/components/AdminAnalyticsLayout.d.ts +10 -0
  242. package/dist/logging/components/AdminAnalyticsLayout.js +11 -0
  243. package/dist/logging/components/AuditLogViewer.d.ts +7 -0
  244. package/dist/logging/components/AuditLogViewer.js +51 -0
  245. package/dist/logging/components/ErrorMetricsCard.d.ts +7 -0
  246. package/dist/logging/components/ErrorMetricsCard.js +16 -0
  247. package/dist/logging/components/HealthMetricsCard.d.ts +7 -0
  248. package/dist/logging/components/HealthMetricsCard.js +19 -0
  249. package/dist/logging/hooks/useAdminAnalytics.d.ts +24 -0
  250. package/dist/logging/hooks/useAdminAnalytics.js +22 -0
  251. package/dist/logging/hooks/useAuditLog.d.ts +6 -0
  252. package/dist/logging/hooks/useAuditLog.js +25 -0
  253. package/dist/logging/hooks/useErrorMetrics.d.ts +6 -0
  254. package/dist/logging/hooks/useErrorMetrics.js +38 -0
  255. package/dist/logging/hooks/useHealthMetrics.d.ts +6 -0
  256. package/dist/logging/hooks/useHealthMetrics.js +41 -0
  257. package/dist/logging/index.d.ts +11 -0
  258. package/dist/logging/index.js +40 -0
  259. package/dist/logging/types/analytics.d.ts +68 -0
  260. package/dist/logging/types/analytics.js +3 -0
  261. package/dist/logging/types/audit.d.ts +29 -0
  262. package/dist/logging/types/audit.js +2 -0
  263. package/dist/logging/types/index.d.ts +2 -0
  264. package/dist/logging/types/index.js +19 -0
  265. package/dist/middleware/auth-decision.d.ts +33 -0
  266. package/dist/middleware/auth-decision.js +65 -0
  267. package/dist/middleware/create-middleware.d.ts +102 -0
  268. package/dist/middleware/create-middleware.js +469 -0
  269. package/dist/middleware/rbac-check.d.ts +51 -0
  270. package/dist/middleware/rbac-check.js +219 -0
  271. package/dist/middleware/twofa-presets.d.ts +134 -0
  272. package/dist/middleware/twofa-presets.js +175 -0
  273. package/dist/models/DecodedAccessToken.d.ts +17 -0
  274. package/dist/models/DecodedAccessToken.js +2 -0
  275. package/dist/models/SessionModel.d.ts +122 -0
  276. package/dist/models/SessionModel.js +136 -0
  277. package/dist/pages/admin-login/page.d.ts +31 -0
  278. package/dist/pages/admin-login/page.js +73 -0
  279. package/dist/pages/admin-page-permissions/PagePermissionsAdminPage.d.ts +18 -0
  280. package/dist/pages/admin-page-permissions/PagePermissionsAdminPage.js +276 -0
  281. package/dist/pages/admin-page-permissions/index.d.ts +6 -0
  282. package/dist/pages/admin-page-permissions/index.js +13 -0
  283. package/dist/pages/admin-roles/RolesAdminPage.d.ts +16 -0
  284. package/dist/pages/admin-roles/RolesAdminPage.js +261 -0
  285. package/dist/pages/admin-roles/index.d.ts +8 -0
  286. package/dist/pages/admin-roles/index.js +15 -0
  287. package/dist/pages/admin-roles/modals.d.ts +72 -0
  288. package/dist/pages/admin-roles/modals.js +154 -0
  289. package/dist/pages/client-admin/ClientSiteAdminPage.d.ts +79 -0
  290. package/dist/pages/client-admin/ClientSiteAdminPage.js +179 -0
  291. package/dist/pages/client-admin/index.d.ts +32 -0
  292. package/dist/pages/client-admin/index.js +37 -0
  293. package/dist/pages/coming-soon/page.d.ts +8 -0
  294. package/dist/pages/coming-soon/page.js +28 -0
  295. package/dist/pages/login/page.d.ts +22 -0
  296. package/dist/pages/login/page.js +230 -0
  297. package/dist/pages/profile/EnhancedProfilePage.d.ts +13 -0
  298. package/dist/pages/profile/EnhancedProfilePage.js +150 -0
  299. package/dist/pages/profile/index.d.ts +8 -0
  300. package/dist/pages/profile/index.js +16 -0
  301. package/dist/pages/profile/page.d.ts +19 -0
  302. package/dist/pages/profile/page.js +47 -0
  303. package/dist/pages/recovery/page.d.ts +1 -0
  304. package/dist/pages/recovery/page.js +142 -0
  305. package/dist/pages/roles/MyRolesPage.d.ts +24 -0
  306. package/dist/pages/roles/MyRolesPage.js +71 -0
  307. package/dist/pages/roles/components.d.ts +63 -0
  308. package/dist/pages/roles/components.js +108 -0
  309. package/dist/pages/roles/index.d.ts +8 -0
  310. package/dist/pages/roles/index.js +19 -0
  311. package/dist/pages/security/EnhancedSecurityPage.d.ts +14 -0
  312. package/dist/pages/security/EnhancedSecurityPage.js +248 -0
  313. package/dist/pages/security/index.d.ts +8 -0
  314. package/dist/pages/security/index.js +16 -0
  315. package/dist/pages/security/page.d.ts +21 -0
  316. package/dist/pages/security/page.js +212 -0
  317. package/dist/pages/settings/EnhancedSettingsPage.d.ts +46 -0
  318. package/dist/pages/settings/EnhancedSettingsPage.js +231 -0
  319. package/dist/pages/settings/index.d.ts +8 -0
  320. package/dist/pages/settings/index.js +16 -0
  321. package/dist/pages/settings/page.d.ts +7 -0
  322. package/dist/pages/settings/page.js +26 -0
  323. package/dist/pages/showcase/ShowcasePage.d.ts +13 -0
  324. package/dist/pages/showcase/ShowcasePage.js +142 -0
  325. package/dist/pages/showcase/index.d.ts +12 -0
  326. package/dist/pages/showcase/index.js +17 -0
  327. package/dist/pages/test-env/EmergencyLogoutPage.d.ts +14 -0
  328. package/dist/pages/test-env/EmergencyLogoutPage.js +99 -0
  329. package/dist/pages/test-env/JwtInspectPage.d.ts +14 -0
  330. package/dist/pages/test-env/JwtInspectPage.js +116 -0
  331. package/dist/pages/test-env/RefreshTokenPage.d.ts +15 -0
  332. package/dist/pages/test-env/RefreshTokenPage.js +93 -0
  333. package/dist/pages/test-env/TestEnvPage.d.ts +13 -0
  334. package/dist/pages/test-env/TestEnvPage.js +51 -0
  335. package/dist/pages/test-env/index.d.ts +24 -0
  336. package/dist/pages/test-env/index.js +32 -0
  337. package/dist/pages/verify-code/page.d.ts +30 -0
  338. package/dist/pages/verify-code/page.js +412 -0
  339. package/dist/routes/account/index.d.ts +28 -0
  340. package/dist/routes/account/index.js +71 -0
  341. package/dist/routes/account/masked-info.d.ts +33 -0
  342. package/dist/routes/account/masked-info.js +39 -0
  343. package/dist/routes/account/send-code.d.ts +37 -0
  344. package/dist/routes/account/send-code.js +42 -0
  345. package/dist/routes/account/update-phone.d.ts +13 -0
  346. package/dist/routes/account/update-phone.js +17 -0
  347. package/dist/routes/account/verify-email.d.ts +38 -0
  348. package/dist/routes/account/verify-email.js +43 -0
  349. package/dist/routes/account/verify-sms.d.ts +38 -0
  350. package/dist/routes/account/verify-sms.js +43 -0
  351. package/dist/routes/auth/index.d.ts +19 -0
  352. package/dist/routes/auth/index.js +64 -0
  353. package/dist/routes/auth/logout.d.ts +31 -0
  354. package/dist/routes/auth/logout.js +98 -0
  355. package/dist/routes/auth/nextauth.d.ts +22 -0
  356. package/dist/routes/auth/nextauth.js +40 -0
  357. package/dist/routes/auth/refresh.d.ts +30 -0
  358. package/dist/routes/auth/refresh.js +51 -0
  359. package/dist/routes/auth/session.d.ts +43 -0
  360. package/dist/routes/auth/session.js +157 -0
  361. package/dist/routes/auth/settings.d.ts +25 -0
  362. package/dist/routes/auth/settings.js +55 -0
  363. package/dist/routes/auth/viability.d.ts +52 -0
  364. package/dist/routes/auth/viability.js +190 -0
  365. package/dist/routes/index.d.ts +12 -0
  366. package/dist/routes/index.js +54 -0
  367. package/dist/routes/session/index.d.ts +6 -0
  368. package/dist/routes/session/index.js +10 -0
  369. package/dist/routes/session/refresh-viability.d.ts +16 -0
  370. package/dist/routes/session/refresh-viability.js +20 -0
  371. package/dist/server/auth-guard.d.ts +46 -0
  372. package/dist/server/auth-guard.js +128 -0
  373. package/dist/server/auth.d.ts +50 -0
  374. package/dist/server/auth.js +62 -0
  375. package/dist/server/decode-session.d.ts +30 -0
  376. package/dist/server/decode-session.js +78 -0
  377. package/dist/server/slim-middleware.d.ts +23 -0
  378. package/dist/server/slim-middleware.js +89 -0
  379. package/dist/server/with-auth.d.ts +33 -0
  380. package/dist/server/with-auth.js +59 -0
  381. package/dist/services/signalrActivityService.d.ts +44 -0
  382. package/dist/services/signalrActivityService.js +257 -0
  383. package/dist/stores/authStore.d.ts +154 -0
  384. package/dist/stores/authStore.js +1527 -0
  385. package/dist/theme/ThemeProvider.d.ts +14 -0
  386. package/dist/theme/ThemeProvider.js +28 -0
  387. package/dist/theme/default.d.ts +8 -0
  388. package/dist/theme/default.js +33 -0
  389. package/dist/theme/index.d.ts +15 -0
  390. package/dist/theme/index.js +25 -0
  391. package/dist/theme/types.d.ts +56 -0
  392. package/dist/theme/types.js +8 -0
  393. package/dist/theme/useTheme.d.ts +60 -0
  394. package/dist/theme/useTheme.js +63 -0
  395. package/dist/theme/utils.d.ts +13 -0
  396. package/dist/theme/utils.js +39 -0
  397. package/dist/types/api.d.ts +134 -0
  398. package/dist/types/api.js +44 -0
  399. package/dist/types/auth.d.ts +19 -0
  400. package/dist/types/auth.js +2 -0
  401. package/dist/types/logging.d.ts +42 -0
  402. package/dist/types/logging.js +2 -0
  403. package/dist/types/recovery.d.ts +48 -0
  404. package/dist/types/recovery.js +2 -0
  405. package/dist/types/security.d.ts +1 -0
  406. package/dist/types/security.js +2 -0
  407. package/dist/utils/api.d.ts +85 -0
  408. package/dist/utils/api.js +287 -0
  409. package/dist/utils/circuitBreaker.d.ts +43 -0
  410. package/dist/utils/circuitBreaker.js +91 -0
  411. package/dist/utils/error-message.d.ts +1 -0
  412. package/dist/utils/error-message.js +103 -0
  413. package/dist/utils/layout/reservedSpace.d.ts +59 -0
  414. package/dist/utils/layout/reservedSpace.js +102 -0
  415. package/dist/utils/logout.d.ts +14 -0
  416. package/dist/utils/logout.js +32 -0
  417. package/dist/vibe/client.d.ts +261 -0
  418. package/dist/vibe/client.js +445 -0
  419. package/dist/vibe/enterprise-auth.d.ts +106 -0
  420. package/dist/vibe/enterprise-auth.js +173 -0
  421. package/dist/vibe/errors.d.ts +83 -0
  422. package/dist/vibe/errors.js +146 -0
  423. package/dist/vibe/generic.d.ts +234 -0
  424. package/dist/vibe/generic.js +369 -0
  425. package/dist/vibe/hooks/index.d.ts +169 -0
  426. package/dist/vibe/hooks/index.js +252 -0
  427. package/dist/vibe/index.d.ts +25 -0
  428. package/dist/vibe/index.js +72 -0
  429. package/dist/vibe/sessions.d.ts +161 -0
  430. package/dist/vibe/sessions.js +391 -0
  431. package/dist/vibe/types.d.ts +353 -0
  432. package/dist/vibe/types.js +315 -0
  433. package/package.json +1 -1
@@ -0,0 +1,161 @@
1
+ "use strict";
2
+ /**
3
+ * =============================================================================
4
+ * VIBE ADMIN STATS TAB
5
+ * =============================================================================
6
+ *
7
+ * Generic dashboard stats overview tab.
8
+ * Shows high-level metrics about users, sessions, and system health.
9
+ *
10
+ * =============================================================================
11
+ */
12
+ 'use client';
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.StatsTab = StatsTab;
15
+ const jsx_runtime_1 = require("react/jsx-runtime");
16
+ const react_1 = require("react");
17
+ const lucide_react_1 = require("lucide-react");
18
+ // -----------------------------------------------------------------------------
19
+ // COMPONENT
20
+ // -----------------------------------------------------------------------------
21
+ function StatsTab({ isDark = true, apiBasePath = '/api/admin/stats', customStats, quickActions, children, }) {
22
+ const [stats, setStats] = (0, react_1.useState)([]);
23
+ const [recentActivity, setRecentActivity] = (0, react_1.useState)([]);
24
+ const [systemStatus, setSystemStatus] = (0, react_1.useState)([]);
25
+ const [loading, setLoading] = (0, react_1.useState)(true);
26
+ const [error, setError] = (0, react_1.useState)(null);
27
+ const themeClasses = {
28
+ cardBg: isDark ? 'bg-slate-800 border-slate-700' : 'bg-white border-gray-200 shadow-sm',
29
+ textPrimary: isDark ? 'text-white' : 'text-gray-900',
30
+ textSecondary: isDark ? 'text-gray-400' : 'text-gray-600',
31
+ textMuted: isDark ? 'text-gray-500' : 'text-gray-500',
32
+ };
33
+ const colorClasses = {
34
+ blue: { bg: 'bg-blue-500/10', text: 'text-blue-400', icon: 'text-blue-400' },
35
+ green: { bg: 'bg-emerald-500/10', text: 'text-emerald-400', icon: 'text-emerald-400' },
36
+ purple: { bg: 'bg-purple-500/10', text: 'text-purple-400', icon: 'text-purple-400' },
37
+ orange: { bg: 'bg-orange-500/10', text: 'text-orange-400', icon: 'text-orange-400' },
38
+ red: { bg: 'bg-red-500/10', text: 'text-red-400', icon: 'text-red-400' },
39
+ cyan: { bg: 'bg-cyan-500/10', text: 'text-cyan-400', icon: 'text-cyan-400' },
40
+ };
41
+ const defaultIcons = {
42
+ users: lucide_react_1.Users,
43
+ sessions: lucide_react_1.Activity,
44
+ uptime: lucide_react_1.Clock,
45
+ growth: lucide_react_1.TrendingUp,
46
+ security: lucide_react_1.Shield,
47
+ system: lucide_react_1.Server,
48
+ };
49
+ const fetchStats = (0, react_1.useCallback)(async () => {
50
+ setLoading(true);
51
+ setError(null);
52
+ try {
53
+ const res = await fetch(apiBasePath);
54
+ if (!res.ok)
55
+ throw new Error('Failed to fetch stats');
56
+ const data = await res.json();
57
+ // Map API response to stat cards
58
+ const apiStats = [];
59
+ if (data.totalUsers !== undefined) {
60
+ apiStats.push({
61
+ id: 'users',
62
+ label: 'Total Users',
63
+ value: data.totalUsers,
64
+ change: data.userGrowth ? `+${data.userGrowth}%` : undefined,
65
+ changeType: 'positive',
66
+ icon: lucide_react_1.Users,
67
+ color: 'blue',
68
+ });
69
+ }
70
+ if (data.activeSessions !== undefined) {
71
+ apiStats.push({
72
+ id: 'sessions',
73
+ label: 'Active Sessions',
74
+ value: data.activeSessions,
75
+ icon: lucide_react_1.Activity,
76
+ color: 'green',
77
+ });
78
+ }
79
+ if (data.todayLogins !== undefined) {
80
+ apiStats.push({
81
+ id: 'logins',
82
+ label: 'Today Logins',
83
+ value: data.todayLogins,
84
+ icon: lucide_react_1.Clock,
85
+ color: 'purple',
86
+ });
87
+ }
88
+ if (data.newUsersToday !== undefined) {
89
+ apiStats.push({
90
+ id: 'new_users',
91
+ label: 'New Users Today',
92
+ value: data.newUsersToday,
93
+ icon: lucide_react_1.TrendingUp,
94
+ color: 'orange',
95
+ });
96
+ }
97
+ // Merge custom stats with API stats
98
+ setStats(customStats ? [...apiStats, ...customStats] : apiStats);
99
+ // Set recent activity if available
100
+ if (data.recentActivity) {
101
+ setRecentActivity(data.recentActivity);
102
+ }
103
+ // Set system status if available
104
+ if (data.systemStatus) {
105
+ setSystemStatus(data.systemStatus);
106
+ }
107
+ }
108
+ catch (err) {
109
+ setError(err.message);
110
+ // Use custom stats as fallback
111
+ if (customStats) {
112
+ setStats(customStats);
113
+ }
114
+ }
115
+ finally {
116
+ setLoading(false);
117
+ }
118
+ }, [apiBasePath, customStats]);
119
+ (0, react_1.useEffect)(() => {
120
+ fetchStats();
121
+ // Refresh stats every 60 seconds
122
+ const interval = setInterval(fetchStats, 60000);
123
+ return () => clearInterval(interval);
124
+ }, [fetchStats]);
125
+ const getTimeAgo = (dateStr) => {
126
+ const now = new Date();
127
+ const date = new Date(dateStr);
128
+ const diffMs = now.getTime() - date.getTime();
129
+ const diffSec = Math.floor(diffMs / 1000);
130
+ const diffMin = Math.floor(diffSec / 60);
131
+ const diffHour = Math.floor(diffMin / 60);
132
+ if (diffSec < 60)
133
+ return 'Just now';
134
+ if (diffMin < 60)
135
+ return `${diffMin}m ago`;
136
+ if (diffHour < 24)
137
+ return `${diffHour}h ago`;
138
+ return date.toLocaleDateString();
139
+ };
140
+ if (loading && stats.length === 0) {
141
+ return ((0, jsx_runtime_1.jsx)("div", { className: "flex items-center justify-center py-12", children: (0, jsx_runtime_1.jsxs)("svg", { className: "animate-spin h-8 w-8 text-blue-400", viewBox: "0 0 24 24", fill: "none", children: [(0, jsx_runtime_1.jsx)("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }), (0, jsx_runtime_1.jsx)("path", { className: "opacity-75", fill: "currentColor", d: "M4 12a8 8 0 018-8v4a4 4 0 00-4 4H4z" })] }) }));
142
+ }
143
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "space-y-6", children: [error && ((0, jsx_runtime_1.jsxs)("div", { className: `p-4 rounded-lg ${isDark ? 'bg-red-900/30 border-red-700' : 'bg-red-50 border-red-300'} border ${isDark ? 'text-red-300' : 'text-red-700'}`, children: [error, (0, jsx_runtime_1.jsx)("button", { onClick: fetchStats, className: "ml-4 underline", children: "Retry" })] })), (0, jsx_runtime_1.jsx)("div", { className: "grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-4 gap-4", children: stats.map((stat) => {
144
+ const Icon = stat.icon || defaultIcons[stat.id] || lucide_react_1.Activity;
145
+ const colors = colorClasses[stat.color || 'blue'];
146
+ return ((0, jsx_runtime_1.jsx)("div", { className: `${themeClasses.cardBg} border rounded-xl p-5`, children: (0, jsx_runtime_1.jsxs)("div", { className: "flex items-start justify-between", children: [(0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("p", { className: `text-sm ${themeClasses.textSecondary}`, children: stat.label }), (0, jsx_runtime_1.jsx)("p", { className: `text-3xl font-bold ${themeClasses.textPrimary} mt-1`, children: typeof stat.value === 'number' ? stat.value.toLocaleString() : stat.value }), stat.change && ((0, jsx_runtime_1.jsx)("p", { className: `text-sm mt-1 ${stat.changeType === 'positive' ? 'text-emerald-400' :
147
+ stat.changeType === 'negative' ? 'text-red-400' :
148
+ themeClasses.textMuted}`, children: stat.change }))] }), (0, jsx_runtime_1.jsx)("div", { className: `p-3 rounded-lg ${colors.bg}`, children: (0, jsx_runtime_1.jsx)(Icon, { className: `w-6 h-6 ${colors.icon}` }) })] }) }, stat.id));
149
+ }) }), (0, jsx_runtime_1.jsxs)("div", { className: "grid grid-cols-1 lg:grid-cols-3 gap-6", children: [(0, jsx_runtime_1.jsxs)("div", { className: `lg:col-span-2 ${themeClasses.cardBg} border rounded-xl`, children: [(0, jsx_runtime_1.jsx)("div", { className: `px-5 py-4 border-b ${isDark ? 'border-slate-700' : 'border-gray-200'}`, children: (0, jsx_runtime_1.jsx)("h3", { className: `font-semibold ${themeClasses.textPrimary}`, children: "Recent Activity" }) }), (0, jsx_runtime_1.jsx)("div", { className: "p-5", children: recentActivity.length > 0 ? ((0, jsx_runtime_1.jsx)("div", { className: "space-y-4", children: recentActivity.map((activity) => ((0, jsx_runtime_1.jsxs)("div", { className: "flex items-start gap-3", children: [(0, jsx_runtime_1.jsx)("div", { className: `w-2 h-2 rounded-full mt-2 ${activity.type === 'login' ? 'bg-green-400' :
150
+ activity.type === 'signup' ? 'bg-blue-400' :
151
+ activity.type === 'error' ? 'bg-red-400' :
152
+ 'bg-gray-400'}` }), (0, jsx_runtime_1.jsxs)("div", { className: "flex-1 min-w-0", children: [(0, jsx_runtime_1.jsx)("p", { className: `text-sm ${themeClasses.textPrimary}`, children: activity.message }), (0, jsx_runtime_1.jsxs)("div", { className: `flex items-center gap-2 text-xs ${themeClasses.textMuted} mt-1`, children: [activity.user && (0, jsx_runtime_1.jsx)("span", { children: activity.user }), (0, jsx_runtime_1.jsx)("span", { children: getTimeAgo(activity.timestamp) })] })] })] }, activity.id))) })) : ((0, jsx_runtime_1.jsx)("p", { className: `text-center py-8 ${themeClasses.textMuted}`, children: "No recent activity" })) })] }), (0, jsx_runtime_1.jsxs)("div", { className: "space-y-6", children: [quickActions && quickActions.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: `${themeClasses.cardBg} border rounded-xl`, children: [(0, jsx_runtime_1.jsx)("div", { className: `px-5 py-4 border-b ${isDark ? 'border-slate-700' : 'border-gray-200'}`, children: (0, jsx_runtime_1.jsx)("h3", { className: `font-semibold ${themeClasses.textPrimary}`, children: "Quick Actions" }) }), (0, jsx_runtime_1.jsx)("div", { className: "p-3", children: quickActions.map((action) => {
153
+ const Icon = action.icon || lucide_react_1.Activity;
154
+ return ((0, jsx_runtime_1.jsx)("button", { onClick: action.onClick, className: `w-full text-left p-3 rounded-lg transition-colors ${isDark ? 'hover:bg-slate-700' : 'hover:bg-gray-100'}`, children: (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-3", children: [(0, jsx_runtime_1.jsx)(Icon, { className: `w-5 h-5 ${themeClasses.textSecondary}` }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("p", { className: `font-medium ${themeClasses.textPrimary}`, children: action.label }), (0, jsx_runtime_1.jsx)("p", { className: `text-xs ${themeClasses.textMuted}`, children: action.description })] })] }) }, action.id));
155
+ }) })] })), systemStatus.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: `${themeClasses.cardBg} border rounded-xl`, children: [(0, jsx_runtime_1.jsx)("div", { className: `px-5 py-4 border-b ${isDark ? 'border-slate-700' : 'border-gray-200'}`, children: (0, jsx_runtime_1.jsx)("h3", { className: `font-semibold ${themeClasses.textPrimary}`, children: "System Status" }) }), (0, jsx_runtime_1.jsx)("div", { className: "p-5 space-y-3", children: systemStatus.map((service) => ((0, jsx_runtime_1.jsxs)("div", { className: "flex items-center justify-between", children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-2", children: [(0, jsx_runtime_1.jsx)("div", { className: `w-2 h-2 rounded-full ${service.status === 'healthy' ? 'bg-emerald-400' :
156
+ service.status === 'degraded' ? 'bg-amber-400' :
157
+ 'bg-red-400'}` }), (0, jsx_runtime_1.jsx)("span", { className: themeClasses.textPrimary, children: service.service })] }), (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-2", children: [service.latency !== undefined && ((0, jsx_runtime_1.jsxs)("span", { className: `text-xs ${themeClasses.textMuted}`, children: [service.latency, "ms"] })), (0, jsx_runtime_1.jsx)("span", { className: `text-xs px-2 py-0.5 rounded ${service.status === 'healthy' ? 'bg-emerald-500/20 text-emerald-400' :
158
+ service.status === 'degraded' ? 'bg-amber-500/20 text-amber-400' :
159
+ 'bg-red-500/20 text-red-400'}`, children: service.status })] })] }, service.service))) })] }))] })] }), children] }));
160
+ }
161
+ exports.default = StatsTab;
@@ -0,0 +1,32 @@
1
+ import React, { ReactNode } from 'react';
2
+ export interface VibeAdminConfig {
3
+ /** Collection name for this tenant (e.g., "ideal_resume", "idealvibe_app") */
4
+ collectionName: string;
5
+ /** Display name for the app (e.g., "IdealResume", "IdealVibe") */
6
+ appName: string;
7
+ /** Optional logo URL */
8
+ logoUrl?: string;
9
+ /** Base path for admin routes (default: /vibe-admin) */
10
+ basePath?: string;
11
+ /** Custom tabs to add to the admin panel */
12
+ customTabs?: AdminTab[];
13
+ /** Theme mode override */
14
+ isDarkMode?: boolean;
15
+ }
16
+ export interface AdminTab {
17
+ id: string;
18
+ label: string;
19
+ icon?: React.ElementType;
20
+ component: React.ComponentType;
21
+ }
22
+ export interface VibeAdminContextValue extends VibeAdminConfig {
23
+ /** All tabs including defaults and custom */
24
+ allTabs: AdminTab[];
25
+ }
26
+ export declare function useVibeAdmin(): VibeAdminContextValue;
27
+ interface VibeAdminProviderProps {
28
+ config: VibeAdminConfig;
29
+ children: ReactNode;
30
+ }
31
+ export declare function VibeAdminProvider({ config, children }: VibeAdminProviderProps): import("react/jsx-runtime").JSX.Element;
32
+ export default VibeAdminProvider;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.useVibeAdmin = useVibeAdmin;
5
+ exports.VibeAdminProvider = VibeAdminProvider;
6
+ const jsx_runtime_1 = require("react/jsx-runtime");
7
+ const react_1 = require("react");
8
+ // -----------------------------------------------------------------------------
9
+ // CONTEXT
10
+ // -----------------------------------------------------------------------------
11
+ const VibeAdminContext = (0, react_1.createContext)(null);
12
+ // -----------------------------------------------------------------------------
13
+ // HOOK
14
+ // -----------------------------------------------------------------------------
15
+ function useVibeAdmin() {
16
+ const context = (0, react_1.useContext)(VibeAdminContext);
17
+ if (!context) {
18
+ throw new Error('useVibeAdmin must be used within a VibeAdminProvider');
19
+ }
20
+ return context;
21
+ }
22
+ function VibeAdminProvider({ config, children }) {
23
+ // Default tabs - will be populated with actual components
24
+ const defaultTabs = [
25
+ { id: 'stats', label: 'Stats', component: () => null },
26
+ { id: 'users', label: 'Users', component: () => null },
27
+ { id: 'sessions', label: 'Sessions', component: () => null },
28
+ { id: 'analytics', label: 'Analytics', component: () => null },
29
+ ];
30
+ const allTabs = [...defaultTabs, ...(config.customTabs || [])];
31
+ const value = {
32
+ ...config,
33
+ basePath: config.basePath || '/vibe-admin',
34
+ allTabs,
35
+ };
36
+ return ((0, jsx_runtime_1.jsx)(VibeAdminContext.Provider, { value: value, children: children }));
37
+ }
38
+ exports.default = VibeAdminProvider;
@@ -0,0 +1,11 @@
1
+ import { ReactNode } from 'react';
2
+ interface VibeAdminLayoutProps {
3
+ children?: ReactNode;
4
+ activeTabId?: string;
5
+ onTabChange?: (tabId: string) => void;
6
+ headerContent?: ReactNode;
7
+ isDarkMode?: boolean;
8
+ adminRole?: string;
9
+ }
10
+ export declare function VibeAdminLayout({ children, activeTabId, onTabChange, headerContent, isDarkMode: isDarkModeProp, adminRole, }: VibeAdminLayoutProps): import("react/jsx-runtime").JSX.Element | null;
11
+ export default VibeAdminLayout;
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ 'use client';
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.VibeAdminLayout = VibeAdminLayout;
8
+ const jsx_runtime_1 = require("react/jsx-runtime");
9
+ const better_auth_client_1 = require("../../client/better-auth-client");
10
+ const navigation_1 = require("next/navigation");
11
+ const react_1 = require("react");
12
+ const link_1 = __importDefault(require("next/link"));
13
+ const VibeAdminContext_1 = require("./VibeAdminContext");
14
+ const lucide_react_1 = require("lucide-react");
15
+ const defaultNavItems = [
16
+ { id: 'stats', label: 'Dashboard', icon: lucide_react_1.LayoutDashboard },
17
+ { id: 'users', label: 'Users', icon: lucide_react_1.Users },
18
+ { id: 'sessions', label: 'Sessions', icon: lucide_react_1.Activity },
19
+ { id: 'analytics', label: 'Analytics', icon: lucide_react_1.BarChart3 },
20
+ { id: 'data', label: 'Data Browser', icon: lucide_react_1.Database },
21
+ { id: 'settings', label: 'Settings', icon: lucide_react_1.Settings },
22
+ ];
23
+ function VibeAdminLayout({ children, activeTabId = 'stats', onTabChange, headerContent, isDarkMode: isDarkModeProp, adminRole = 'vibe_app_admin', }) {
24
+ const { data: sessionData, isPending } = better_auth_client_1.authClient.useSession();
25
+ const session = sessionData;
26
+ const status = isPending ? 'loading' : session ? 'authenticated' : 'unauthenticated';
27
+ const router = (0, navigation_1.useRouter)();
28
+ const adminConfig = (0, VibeAdminContext_1.useVibeAdmin)();
29
+ const isDark = isDarkModeProp ?? adminConfig.isDarkMode ?? false;
30
+ const basePath = adminConfig.basePath || '/vibe-admin';
31
+ const navItems = [...defaultNavItems];
32
+ adminConfig.customTabs?.forEach((tab) => {
33
+ navItems.push({
34
+ id: tab.id,
35
+ label: tab.label,
36
+ icon: tab.icon || lucide_react_1.LayoutDashboard,
37
+ });
38
+ });
39
+ const userRoles = session?.user?.roles || [];
40
+ const hasAdminRole = userRoles.includes(adminRole) || userRoles.includes('payez_admin');
41
+ (0, react_1.useEffect)(() => {
42
+ if (status === 'unauthenticated') {
43
+ router.push('/account-auth/login?callbackUrl=' + basePath);
44
+ return;
45
+ }
46
+ if (status === 'authenticated' && !hasAdminRole) {
47
+ router.push('/?error=unauthorized');
48
+ }
49
+ }, [status, hasAdminRole, router, basePath]);
50
+ if (status === 'loading') {
51
+ return ((0, jsx_runtime_1.jsx)("div", { className: 'min-h-screen flex items-center justify-center ' + (isDark ? 'bg-slate-950' : 'bg-gray-50'), children: (0, jsx_runtime_1.jsxs)("div", { className: "flex flex-col items-center gap-4", children: [(0, jsx_runtime_1.jsx)("div", { className: "animate-spin rounded-full h-12 w-12 border-b-2 border-indigo-500" }), (0, jsx_runtime_1.jsx)("p", { className: isDark ? 'text-slate-400' : 'text-slate-600', children: "Loading..." })] }) }));
52
+ }
53
+ if (status === 'authenticated' && !hasAdminRole) {
54
+ return ((0, jsx_runtime_1.jsx)("div", { className: 'min-h-screen flex items-center justify-center ' + (isDark ? 'bg-slate-950' : 'bg-gray-50'), children: (0, jsx_runtime_1.jsxs)("div", { className: "text-center", children: [(0, jsx_runtime_1.jsx)(lucide_react_1.Shield, { className: 'w-16 h-16 mx-auto mb-4 ' + (isDark ? 'text-red-400' : 'text-red-500') }), (0, jsx_runtime_1.jsx)("h1", { className: 'text-2xl font-bold mb-2 ' + (isDark ? 'text-white' : 'text-gray-900'), children: "Access Denied" }), (0, jsx_runtime_1.jsx)("p", { className: 'mb-6 ' + (isDark ? 'text-slate-400' : 'text-slate-600'), children: "You do not have permission to access the admin panel." }), (0, jsx_runtime_1.jsxs)(link_1.default, { href: "/", className: "inline-flex items-center gap-2 px-4 py-2 bg-indigo-600 text-white rounded-lg hover:bg-indigo-700 transition-colors", children: [(0, jsx_runtime_1.jsx)(lucide_react_1.ArrowLeft, { className: "w-4 h-4" }), "Return to Home"] })] }) }));
55
+ }
56
+ if (status === 'unauthenticated') {
57
+ return null;
58
+ }
59
+ return ((0, jsx_runtime_1.jsxs)("div", { className: 'min-h-screen ' + (isDark ? 'bg-slate-950 text-white' : 'bg-gray-50 text-gray-900'), children: [(0, jsx_runtime_1.jsx)("header", { className: 'sticky top-0 z-40 border-b ' + (isDark ? 'bg-slate-900 border-slate-800' : 'bg-white border-gray-200'), children: (0, jsx_runtime_1.jsx)("div", { className: "container mx-auto px-4 py-4", children: (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center justify-between", children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-3", children: [adminConfig.logoUrl && ((0, jsx_runtime_1.jsx)("div", { className: 'p-2 rounded-lg ' + (isDark ? 'bg-indigo-900/30' : 'bg-indigo-100'), children: (0, jsx_runtime_1.jsx)("img", { src: adminConfig.logoUrl, alt: adminConfig.appName, className: "w-6 h-6" }) })), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("h1", { className: "text-xl font-bold", children: "Platform Admin" }), (0, jsx_runtime_1.jsxs)("p", { className: 'text-sm ' + (isDark ? 'text-slate-400' : 'text-slate-600'), children: [adminConfig.appName, " - ", adminConfig.collectionName] })] })] }), (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-4", children: [headerContent, (0, jsx_runtime_1.jsxs)(link_1.default, { href: "/", className: 'flex items-center gap-2 px-3 py-2 rounded-lg transition-colors ' + (isDark ? 'hover:bg-slate-800 text-slate-400' : 'hover:bg-gray-100 text-slate-600'), children: [(0, jsx_runtime_1.jsx)(lucide_react_1.ArrowLeft, { className: "w-4 h-4" }), "Back to App"] })] })] }) }) }), (0, jsx_runtime_1.jsxs)("div", { className: "container mx-auto px-4 py-4", children: [(0, jsx_runtime_1.jsx)("nav", { className: 'flex items-center gap-1 mb-6 border-b ' + (isDark ? 'border-slate-800' : 'border-gray-200'), children: navItems.map((item) => {
60
+ const isActive = activeTabId === item.id;
61
+ const Icon = item.icon;
62
+ const activeClass = isDark
63
+ ? 'border-indigo-500 text-indigo-400'
64
+ : 'border-indigo-600 text-indigo-700';
65
+ const inactiveClass = isDark
66
+ ? 'border-transparent text-slate-400 hover:text-white hover:border-slate-600'
67
+ : 'border-transparent text-slate-600 hover:text-gray-900 hover:border-gray-300';
68
+ return ((0, jsx_runtime_1.jsxs)("button", { onClick: () => onTabChange?.(item.id), className: 'flex items-center gap-2 px-4 py-2.5 text-sm font-medium transition-colors border-b-2 -mb-px ' + (isActive ? activeClass : inactiveClass), children: [(0, jsx_runtime_1.jsx)(Icon, { className: "w-4 h-4" }), item.label] }, item.id));
69
+ }) }), (0, jsx_runtime_1.jsx)("main", { className: "min-w-0", children: children })] })] }));
70
+ }
71
+ exports.default = VibeAdminLayout;
@@ -0,0 +1,29 @@
1
+ /**
2
+ * =============================================================================
3
+ * VIBE ADMIN COMPONENTS
4
+ * =============================================================================
5
+ *
6
+ * Generic admin panel components for Vibe-powered applications.
7
+ * These components are designed to be multi-tenant and can be configured
8
+ * per-collection via the VibeAdminProvider.
9
+ *
10
+ * Usage:
11
+ * ------
12
+ * import {
13
+ * VibeAdminProvider,
14
+ * VibeAdminLayout,
15
+ * SessionsTab,
16
+ * AnalyticsTab,
17
+ * StatsTab,
18
+ * } from '@payez/next-mvp/components/admin';
19
+ *
20
+ * =============================================================================
21
+ */
22
+ export { VibeAdminProvider, useVibeAdmin, type VibeAdminConfig, type AdminTab, type VibeAdminContextValue, } from './VibeAdminContext';
23
+ export { VibeAdminLayout } from './VibeAdminLayout';
24
+ export { SessionsTab, type SessionsTabProps, type LoginSession, type SessionStats } from './SessionsTab';
25
+ export { AnalyticsTab, type AnalyticsTabProps } from './AnalyticsTab';
26
+ export { StatsTab, type StatsTabProps, type StatCard, type QuickAction, type RecentActivity, type SystemStatus } from './StatsTab';
27
+ export { DataBrowserTab, type DataBrowserTabProps, type CollectionInfo, type TableInfo } from './DataBrowserTab';
28
+ export { LoggingSettingsTab, type LoggingSettingsTabProps, type LogLevel, type LogLevels, type RetentionSettings, type StorageLimits, type UsageStats, type LoggingSettings, } from './LoggingSettingsTab';
29
+ export { AlertSettingsTab, type AlertSettingsTabProps, type DeliveryMode, type AlertConfig, type AlertsConfig, type RateLimit, type AlertSettings, type AlertHistoryItem, } from './AlertSettingsTab';
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ /**
3
+ * =============================================================================
4
+ * VIBE ADMIN COMPONENTS
5
+ * =============================================================================
6
+ *
7
+ * Generic admin panel components for Vibe-powered applications.
8
+ * These components are designed to be multi-tenant and can be configured
9
+ * per-collection via the VibeAdminProvider.
10
+ *
11
+ * Usage:
12
+ * ------
13
+ * import {
14
+ * VibeAdminProvider,
15
+ * VibeAdminLayout,
16
+ * SessionsTab,
17
+ * AnalyticsTab,
18
+ * StatsTab,
19
+ * } from '@payez/next-mvp/components/admin';
20
+ *
21
+ * =============================================================================
22
+ */
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.AlertSettingsTab = exports.LoggingSettingsTab = exports.DataBrowserTab = exports.StatsTab = exports.AnalyticsTab = exports.SessionsTab = exports.VibeAdminLayout = exports.useVibeAdmin = exports.VibeAdminProvider = void 0;
25
+ // Context & Provider
26
+ var VibeAdminContext_1 = require("./VibeAdminContext");
27
+ Object.defineProperty(exports, "VibeAdminProvider", { enumerable: true, get: function () { return VibeAdminContext_1.VibeAdminProvider; } });
28
+ Object.defineProperty(exports, "useVibeAdmin", { enumerable: true, get: function () { return VibeAdminContext_1.useVibeAdmin; } });
29
+ // Layout
30
+ var VibeAdminLayout_1 = require("./VibeAdminLayout");
31
+ Object.defineProperty(exports, "VibeAdminLayout", { enumerable: true, get: function () { return VibeAdminLayout_1.VibeAdminLayout; } });
32
+ // Tab Components
33
+ var SessionsTab_1 = require("./SessionsTab");
34
+ Object.defineProperty(exports, "SessionsTab", { enumerable: true, get: function () { return SessionsTab_1.SessionsTab; } });
35
+ var AnalyticsTab_1 = require("./AnalyticsTab");
36
+ Object.defineProperty(exports, "AnalyticsTab", { enumerable: true, get: function () { return AnalyticsTab_1.AnalyticsTab; } });
37
+ var StatsTab_1 = require("./StatsTab");
38
+ Object.defineProperty(exports, "StatsTab", { enumerable: true, get: function () { return StatsTab_1.StatsTab; } });
39
+ var DataBrowserTab_1 = require("./DataBrowserTab");
40
+ Object.defineProperty(exports, "DataBrowserTab", { enumerable: true, get: function () { return DataBrowserTab_1.DataBrowserTab; } });
41
+ var LoggingSettingsTab_1 = require("./LoggingSettingsTab");
42
+ Object.defineProperty(exports, "LoggingSettingsTab", { enumerable: true, get: function () { return LoggingSettingsTab_1.LoggingSettingsTab; } });
43
+ var AlertSettingsTab_1 = require("./AlertSettingsTab");
44
+ Object.defineProperty(exports, "AlertSettingsTab", { enumerable: true, get: function () { return AlertSettingsTab_1.AlertSettingsTab; } });
@@ -0,0 +1,8 @@
1
+ import { FederatedProvider } from '@/types/auth';
2
+ interface Props {
3
+ providers: FederatedProvider[];
4
+ onProviderClick: (provider: FederatedProvider) => void;
5
+ isLoading?: boolean;
6
+ }
7
+ export declare function FederatedAuthSection({ providers, onProviderClick, isLoading }: Props): import("react/jsx-runtime").JSX.Element | null;
8
+ export {};
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.FederatedAuthSection = FederatedAuthSection;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const providerIcons = {
7
+ google: {
8
+ label: 'Google',
9
+ color: '#4285F4',
10
+ svg: ((0, jsx_runtime_1.jsxs)("svg", { className: "w-5 h-5", viewBox: "0 0 24 24", fill: "currentColor", children: [(0, jsx_runtime_1.jsx)("path", { d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z", fill: "#4285F4" }), (0, jsx_runtime_1.jsx)("path", { d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z", fill: "#34A853" }), (0, jsx_runtime_1.jsx)("path", { d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z", fill: "#FBBC05" }), (0, jsx_runtime_1.jsx)("path", { d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z", fill: "#EA4335" })] })),
11
+ },
12
+ microsoft: {
13
+ label: 'Microsoft',
14
+ color: '#0078D4',
15
+ svg: ((0, jsx_runtime_1.jsxs)("svg", { className: "w-5 h-5", viewBox: "0 0 24 24", fill: "currentColor", children: [(0, jsx_runtime_1.jsx)("rect", { x: "1", y: "1", width: "9", height: "9", fill: "#F25022" }), (0, jsx_runtime_1.jsx)("rect", { x: "12", y: "1", width: "9", height: "9", fill: "#7FBA00" }), (0, jsx_runtime_1.jsx)("rect", { x: "1", y: "12", width: "9", height: "9", fill: "#00A4EF" }), (0, jsx_runtime_1.jsx)("rect", { x: "12", y: "12", width: "9", height: "9", fill: "#FFB900" })] })),
16
+ },
17
+ facebook: {
18
+ label: 'Facebook',
19
+ color: '#1877F2',
20
+ svg: ((0, jsx_runtime_1.jsx)("svg", { className: "w-5 h-5", viewBox: "0 0 24 24", fill: "#1877F2", children: (0, jsx_runtime_1.jsx)("path", { d: "M24 12.073c0-6.627-5.373-12-12-12s-12 5.373-12 12c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z" }) })),
21
+ },
22
+ github: {
23
+ label: 'GitHub',
24
+ color: '#000000',
25
+ svg: ((0, jsx_runtime_1.jsx)("svg", { className: "w-5 h-5", viewBox: "0 0 24 24", fill: "currentColor", children: (0, jsx_runtime_1.jsx)("path", { d: "M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z" }) })),
26
+ },
27
+ apple: {
28
+ label: 'Apple',
29
+ color: '#000000',
30
+ svg: ((0, jsx_runtime_1.jsx)("svg", { className: "w-5 h-5", viewBox: "0 0 24 24", fill: "currentColor", children: (0, jsx_runtime_1.jsx)("path", { d: "M17.05 20.28c-.98.95-2.05.8-3.08.35-1.09-.46-2.09-.48-3.24 0-1.44.62-2.2.44-3.06-.35C2.79 15.25 3.51 7.59 9.05 7.31c1.35.07 2.29.74 3.08.8 1.18-.24 2.31-.93 3.57-.84 1.51.12 2.65.72 3.4 1.8-3.12 1.87-2.38 5.98.48 7.13-.57 1.5-1.31 2.99-2.54 4.09l.01-.01zM12.03 7.25c-.15-2.23 1.66-4.07 3.74-4.25.29 2.58-2.34 4.5-3.74 4.25z" }) })),
31
+ },
32
+ };
33
+ function FederatedAuthSection({ providers, onProviderClick, isLoading }) {
34
+ if (!providers.length) {
35
+ return null;
36
+ }
37
+ return ((0, jsx_runtime_1.jsx)("div", { className: "space-y-3", children: providers.map((provider) => {
38
+ const config = providerIcons[provider];
39
+ return ((0, jsx_runtime_1.jsxs)("button", { type: "button", onClick: () => onProviderClick(provider), disabled: isLoading, className: `w-full px-4 py-3 rounded-lg border-2 font-semibold transition-colors flex items-center justify-center gap-2 disabled:opacity-50 disabled:cursor-not-allowed`, style: {
40
+ border: '1px solid var(--border-default)',
41
+ color: 'var(--text-primary)',
42
+ background: 'var(--bg-default)',
43
+ }, children: [config.svg, "Continue with ", config.label] }, provider));
44
+ }) }));
45
+ }
@@ -0,0 +1,10 @@
1
+ import { FederatedProvider } from '@/types/auth';
2
+ interface Props {
3
+ onFederatedSignIn?: (provider: FederatedProvider) => void;
4
+ onTraditionalSignIn?: (email: string, password: string) => Promise<void>;
5
+ onForgotPassword?: () => void;
6
+ isLoading?: boolean;
7
+ error?: string | null;
8
+ }
9
+ export declare function ModeAwareLoginPage({ onFederatedSignIn, onTraditionalSignIn, onForgotPassword, isLoading, error, }: Props): import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ModeAwareLoginPage = ModeAwareLoginPage;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const AuthContext_1 = require("../../client/AuthContext");
8
+ const FederatedAuthSection_1 = require("./FederatedAuthSection");
9
+ const TraditionalAuthSection_1 = require("./TraditionalAuthSection");
10
+ function ModeAwareLoginPage({ onFederatedSignIn, onTraditionalSignIn, onForgotPassword, isLoading = false, error = null, }) {
11
+ const config = (0, AuthContext_1.useAuthConfig)();
12
+ const [email, setEmail] = (0, react_1.useState)('');
13
+ const [password, setPassword] = (0, react_1.useState)('');
14
+ const [localLoading, setLocalLoading] = (0, react_1.useState)(false);
15
+ const handleFederatedClick = (provider) => {
16
+ onFederatedSignIn?.(provider);
17
+ };
18
+ const handleTraditionalSubmit = async (e) => {
19
+ e.preventDefault();
20
+ if (!onTraditionalSignIn)
21
+ return;
22
+ setLocalLoading(true);
23
+ try {
24
+ await onTraditionalSignIn(email, password);
25
+ }
26
+ finally {
27
+ setLocalLoading(false);
28
+ }
29
+ };
30
+ const isFederated = config.mode === 'federated';
31
+ const isTraditional = config.mode === 'traditional';
32
+ const totalLoading = isLoading || localLoading;
33
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [error && ((0, jsx_runtime_1.jsx)("div", { className: "mb-6 px-4 py-3 rounded-lg", style: {
34
+ background: 'var(--color-error, #ef4444)',
35
+ color: 'white',
36
+ }, children: error })), isFederated && ((0, jsx_runtime_1.jsx)(FederatedAuthSection_1.FederatedAuthSection, { providers: config.providers, onProviderClick: handleFederatedClick, isLoading: totalLoading })), isTraditional && ((0, jsx_runtime_1.jsx)(TraditionalAuthSection_1.TraditionalAuthSection, { email: email, password: password, onEmailChange: setEmail, onPasswordChange: setPassword, onSubmit: handleTraditionalSubmit, isLoading: totalLoading, buttonText: "Sign In", showForgotPassword: config.enableRecovery, onForgotPassword: onForgotPassword })), isFederated === false && isTraditional === false && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(FederatedAuthSection_1.FederatedAuthSection, { providers: config.providers, onProviderClick: handleFederatedClick, isLoading: totalLoading }), config.providers.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { className: "relative my-6", children: [(0, jsx_runtime_1.jsx)("div", { className: "absolute inset-0 flex items-center", children: (0, jsx_runtime_1.jsx)("div", { className: "w-full", style: {
37
+ borderTop: '1px solid var(--border-default)',
38
+ } }) }), (0, jsx_runtime_1.jsx)("div", { className: "relative flex justify-center text-sm", children: (0, jsx_runtime_1.jsx)("span", { className: "px-2", style: {
39
+ background: 'var(--bg-card)',
40
+ color: 'var(--text-secondary)',
41
+ }, children: "Or sign in with email" }) })] })), (0, jsx_runtime_1.jsx)(TraditionalAuthSection_1.TraditionalAuthSection, { email: email, password: password, onEmailChange: setEmail, onPasswordChange: setPassword, onSubmit: handleTraditionalSubmit, isLoading: totalLoading, buttonText: "Sign In", showForgotPassword: config.enableRecovery, onForgotPassword: onForgotPassword })] }))] }));
42
+ }
@@ -0,0 +1,9 @@
1
+ import { FederatedProvider } from '@/types/auth';
2
+ interface Props {
3
+ onFederatedSignUp?: (provider: FederatedProvider) => void;
4
+ onTraditionalSignUp?: (email: string, password: string, confirmPassword: string) => Promise<void>;
5
+ isLoading?: boolean;
6
+ error?: string | null;
7
+ }
8
+ export declare function ModeAwareSignupPage({ onFederatedSignUp, onTraditionalSignUp, isLoading, error, }: Props): import("react/jsx-runtime").JSX.Element;
9
+ export {};
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ 'use client';
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ModeAwareSignupPage = ModeAwareSignupPage;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const AuthContext_1 = require("../../client/AuthContext");
8
+ const FederatedAuthSection_1 = require("./FederatedAuthSection");
9
+ function ModeAwareSignupPage({ onFederatedSignUp, onTraditionalSignUp, isLoading = false, error = null, }) {
10
+ const config = (0, AuthContext_1.useAuthConfig)();
11
+ const [email, setEmail] = (0, react_1.useState)('');
12
+ const [password, setPassword] = (0, react_1.useState)('');
13
+ const [confirmPassword, setConfirmPassword] = (0, react_1.useState)('');
14
+ const [localLoading, setLocalLoading] = (0, react_1.useState)(false);
15
+ const handleFederatedClick = (provider) => {
16
+ onFederatedSignUp?.(provider);
17
+ };
18
+ const handleTraditionalSubmit = async (e) => {
19
+ e.preventDefault();
20
+ if (!onTraditionalSignUp)
21
+ return;
22
+ if (password !== confirmPassword) {
23
+ alert('Passwords do not match');
24
+ return;
25
+ }
26
+ setLocalLoading(true);
27
+ try {
28
+ await onTraditionalSignUp(email, password, confirmPassword);
29
+ }
30
+ finally {
31
+ setLocalLoading(false);
32
+ }
33
+ };
34
+ const isFederated = config.mode === 'federated';
35
+ const isTraditional = config.mode === 'traditional';
36
+ const totalLoading = isLoading || localLoading;
37
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [error && ((0, jsx_runtime_1.jsx)("div", { className: "mb-6 px-4 py-3 rounded-lg", style: {
38
+ background: 'var(--color-error, #ef4444)',
39
+ color: 'white',
40
+ }, children: error })), isFederated && ((0, jsx_runtime_1.jsx)(FederatedAuthSection_1.FederatedAuthSection, { providers: config.providers, onProviderClick: handleFederatedClick, isLoading: totalLoading })), isTraditional && config.enableEmailSignup && ((0, jsx_runtime_1.jsxs)("form", { onSubmit: handleTraditionalSubmit, className: "space-y-4", children: [(0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("label", { className: "block text-sm font-medium mb-2", style: { color: 'var(--text-primary)' }, children: "Email Address" }), (0, jsx_runtime_1.jsx)("input", { type: "email", value: email, onChange: (e) => setEmail(e.target.value), placeholder: "you@example.com", disabled: totalLoading, required: true, className: "w-full px-4 py-3 rounded-lg border transition-colors focus:outline-none focus:ring-2 disabled:opacity-50", style: {
41
+ border: '1px solid var(--border-default)',
42
+ color: 'var(--text-primary)',
43
+ background: 'var(--bg-default)',
44
+ } })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("label", { className: "block text-sm font-medium mb-2", style: { color: 'var(--text-primary)' }, children: "Password" }), (0, jsx_runtime_1.jsx)("input", { type: "password", value: password, onChange: (e) => setPassword(e.target.value), placeholder: "\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022", disabled: totalLoading, required: true, className: "w-full px-4 py-3 rounded-lg border transition-colors focus:outline-none focus:ring-2 disabled:opacity-50", style: {
45
+ border: '1px solid var(--border-default)',
46
+ color: 'var(--text-primary)',
47
+ background: 'var(--bg-default)',
48
+ } })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("label", { className: "block text-sm font-medium mb-2", style: { color: 'var(--text-primary)' }, children: "Confirm Password" }), (0, jsx_runtime_1.jsx)("input", { type: "password", value: confirmPassword, onChange: (e) => setConfirmPassword(e.target.value), placeholder: "\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022", disabled: totalLoading, required: true, className: "w-full px-4 py-3 rounded-lg border transition-colors focus:outline-none focus:ring-2 disabled:opacity-50", style: {
49
+ border: '1px solid var(--border-default)',
50
+ color: 'var(--text-primary)',
51
+ background: 'var(--bg-default)',
52
+ } })] }), (0, jsx_runtime_1.jsx)("button", { type: "submit", disabled: totalLoading, className: "w-full py-3 px-4 rounded-lg font-semibold focus:outline-none focus:ring-2 disabled:opacity-50 disabled:cursor-not-allowed transition-colors mt-6", style: {
53
+ border: '1px solid var(--border-default)',
54
+ color: 'white',
55
+ background: 'var(--color-primary, #10b981)',
56
+ }, children: totalLoading ? 'Creating Account...' : 'Create Account' })] })), isFederated === false && isTraditional === false && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(FederatedAuthSection_1.FederatedAuthSection, { providers: config.providers, onProviderClick: handleFederatedClick, isLoading: totalLoading }), config.providers.length > 0 && config.enableEmailSignup && ((0, jsx_runtime_1.jsxs)("div", { className: "relative my-6", children: [(0, jsx_runtime_1.jsx)("div", { className: "absolute inset-0 flex items-center", children: (0, jsx_runtime_1.jsx)("div", { className: "w-full", style: {
57
+ borderTop: '1px solid var(--border-default)',
58
+ } }) }), (0, jsx_runtime_1.jsx)("div", { className: "relative flex justify-center text-sm", children: (0, jsx_runtime_1.jsx)("span", { className: "px-2", style: {
59
+ background: 'var(--bg-card)',
60
+ color: 'var(--text-secondary)',
61
+ }, children: "Or sign up with email" }) })] })), config.enableEmailSignup && ((0, jsx_runtime_1.jsxs)("form", { onSubmit: handleTraditionalSubmit, className: "space-y-4", children: [(0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("label", { className: "block text-sm font-medium mb-2", style: { color: 'var(--text-primary)' }, children: "Email Address" }), (0, jsx_runtime_1.jsx)("input", { type: "email", value: email, onChange: (e) => setEmail(e.target.value), placeholder: "you@example.com", disabled: totalLoading, required: true, className: "w-full px-4 py-3 rounded-lg border transition-colors focus:outline-none focus:ring-2 disabled:opacity-50", style: {
62
+ border: '1px solid var(--border-default)',
63
+ color: 'var(--text-primary)',
64
+ background: 'var(--bg-default)',
65
+ } })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("label", { className: "block text-sm font-medium mb-2", style: { color: 'var(--text-primary)' }, children: "Password" }), (0, jsx_runtime_1.jsx)("input", { type: "password", value: password, onChange: (e) => setPassword(e.target.value), placeholder: "\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022", disabled: totalLoading, required: true, className: "w-full px-4 py-3 rounded-lg border transition-colors focus:outline-none focus:ring-2 disabled:opacity-50", style: {
66
+ border: '1px solid var(--border-default)',
67
+ color: 'var(--text-primary)',
68
+ background: 'var(--bg-default)',
69
+ } })] }), (0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("label", { className: "block text-sm font-medium mb-2", style: { color: 'var(--text-primary)' }, children: "Confirm Password" }), (0, jsx_runtime_1.jsx)("input", { type: "password", value: confirmPassword, onChange: (e) => setConfirmPassword(e.target.value), placeholder: "\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022", disabled: totalLoading, required: true, className: "w-full px-4 py-3 rounded-lg border transition-colors focus:outline-none focus:ring-2 disabled:opacity-50", style: {
70
+ border: '1px solid var(--border-default)',
71
+ color: 'var(--text-primary)',
72
+ background: 'var(--bg-default)',
73
+ } })] }), (0, jsx_runtime_1.jsx)("button", { type: "submit", disabled: totalLoading, className: "w-full py-3 px-4 rounded-lg font-semibold focus:outline-none focus:ring-2 disabled:opacity-50 disabled:cursor-not-allowed transition-colors mt-6", style: {
74
+ border: '1px solid var(--border-default)',
75
+ color: 'white',
76
+ background: 'var(--color-primary, #10b981)',
77
+ }, children: totalLoading ? 'Creating Account...' : 'Create Account' })] }))] }))] }));
78
+ }