@jmruthers/pace-core 0.5.74 → 0.5.76

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 (369) hide show
  1. package/dist/DataTable-4GAVPIEG.js +120 -0
  2. package/dist/{PublicLoadingSpinner-DLpF5bbs.d.ts → PublicLoadingSpinner-BiNER8F5.d.ts} +30 -19
  3. package/dist/RBACService-C4udt_Zp.d.ts +528 -0
  4. package/dist/{UnifiedAuthProvider-K4NRGXL4.js → UnifiedAuthProvider-3NKDOSOK.js} +6 -4
  5. package/dist/UnifiedAuthProvider-Bj6YCf7c.d.ts +113 -0
  6. package/dist/chunk-5F3NDPJV.js +232 -0
  7. package/dist/chunk-5F3NDPJV.js.map +1 -0
  8. package/dist/chunk-A4FUBC7B.js +17 -0
  9. package/dist/chunk-A4FUBC7B.js.map +1 -0
  10. package/dist/{chunk-SMJZMKYN.js → chunk-A6HBIY5P.js} +2 -11
  11. package/dist/{chunk-SMJZMKYN.js.map → chunk-A6HBIY5P.js.map} +1 -1
  12. package/dist/{chunk-LVQ26TCN.js → chunk-AFGTSUAD.js} +43 -127
  13. package/dist/chunk-AFGTSUAD.js.map +1 -0
  14. package/dist/{chunk-BKVGJVUR.js → chunk-K34IM5CT.js} +497 -33
  15. package/dist/chunk-K34IM5CT.js.map +1 -0
  16. package/dist/{chunk-UJMCGBLS.js → chunk-KHJS6VIA.js} +203 -41
  17. package/dist/chunk-KHJS6VIA.js.map +1 -0
  18. package/dist/{chunk-ORSMVXO2.js → chunk-KK73ZB4E.js} +9 -14
  19. package/dist/chunk-KK73ZB4E.js.map +1 -0
  20. package/dist/{chunk-VKOCWWVY.js → chunk-L3RV2ALE.js} +1 -6
  21. package/dist/{chunk-VKOCWWVY.js.map → chunk-L3RV2ALE.js.map} +1 -1
  22. package/dist/chunk-LW7MMEAQ.js +59 -0
  23. package/dist/chunk-LW7MMEAQ.js.map +1 -0
  24. package/dist/{chunk-IHMMNKNA.js → chunk-M5IWZRBT.js} +5118 -1864
  25. package/dist/chunk-M5IWZRBT.js.map +1 -0
  26. package/dist/{chunk-DG5Z55HH.js → chunk-NTNILOBC.js} +7 -9
  27. package/dist/chunk-NTNILOBC.js.map +1 -0
  28. package/dist/chunk-PYUXFQJ3.js +11 -0
  29. package/dist/chunk-PYUXFQJ3.js.map +1 -0
  30. package/dist/chunk-URUTVZ7N.js +27 -0
  31. package/dist/chunk-URUTVZ7N.js.map +1 -0
  32. package/dist/chunk-WN6XJWOS.js +2468 -0
  33. package/dist/chunk-WN6XJWOS.js.map +1 -0
  34. package/dist/{chunk-3SP4P7NS.js → chunk-XLZ7U46Z.js} +59 -1
  35. package/dist/chunk-XLZ7U46Z.js.map +1 -0
  36. package/dist/{chunk-H2TNUICK.js → chunk-Y6TXWPJO.js} +50 -50
  37. package/dist/chunk-Y6TXWPJO.js.map +1 -0
  38. package/dist/{chunk-YNUBMSMV.js → chunk-YCKPEMJA.js} +186 -263
  39. package/dist/chunk-YCKPEMJA.js.map +1 -0
  40. package/dist/components.d.ts +4 -5
  41. package/dist/components.js +35 -41
  42. package/dist/components.js.map +1 -1
  43. package/dist/hooks.d.ts +20 -43
  44. package/dist/hooks.js +13 -12
  45. package/dist/hooks.js.map +1 -1
  46. package/dist/index.d.ts +156 -10
  47. package/dist/index.js +193 -96
  48. package/dist/index.js.map +1 -1
  49. package/dist/{organisation-t-vvQC3g.d.ts → organisation-BtshODVF.d.ts} +4 -3
  50. package/dist/providers.d.ts +27 -38
  51. package/dist/providers.js +33 -23
  52. package/dist/rbac/index.d.ts +114 -5
  53. package/dist/rbac/index.js +15 -15
  54. package/dist/styles/index.js +2 -2
  55. package/dist/theming/runtime.js +1 -3
  56. package/dist/types.d.ts +3 -3
  57. package/dist/types.js +1 -1
  58. package/dist/types.js.map +1 -1
  59. package/dist/{unified-CMPjE_fv.d.ts → unified-CM7T0aTK.d.ts} +1 -1
  60. package/dist/useInactivityTracker-MRUU55XI.js +10 -0
  61. package/dist/{usePublicRouteParams-Ua1Vz-HG.d.ts → usePublicRouteParams-B-CumWRc.d.ts} +3 -3
  62. package/dist/utils.js +7 -9
  63. package/dist/utils.js.map +1 -1
  64. package/dist/validation.d.ts +1 -1
  65. package/docs/TERMINOLOGY.md +231 -0
  66. package/docs/api/classes/ColumnFactory.md +1 -1
  67. package/docs/api/classes/ErrorBoundary.md +1 -1
  68. package/docs/api/classes/InvalidScopeError.md +1 -1
  69. package/docs/api/classes/MissingUserContextError.md +1 -1
  70. package/docs/api/classes/OrganisationContextRequiredError.md +1 -1
  71. package/docs/api/classes/PermissionDeniedError.md +1 -1
  72. package/docs/api/classes/PublicErrorBoundary.md +1 -1
  73. package/docs/api/classes/RBACAuditManager.md +1 -1
  74. package/docs/api/classes/RBACCache.md +1 -1
  75. package/docs/api/classes/RBACEngine.md +1 -1
  76. package/docs/api/classes/RBACError.md +1 -1
  77. package/docs/api/classes/RBACNotInitializedError.md +1 -1
  78. package/docs/api/classes/SecureSupabaseClient.md +1 -1
  79. package/docs/api/classes/StorageUtils.md +1 -1
  80. package/docs/api/enums/FileCategory.md +1 -1
  81. package/docs/api/interfaces/AggregateConfig.md +1 -1
  82. package/docs/api/interfaces/ButtonProps.md +3 -3
  83. package/docs/api/interfaces/CardProps.md +2 -2
  84. package/docs/api/interfaces/ColorPalette.md +1 -1
  85. package/docs/api/interfaces/ColorShade.md +1 -1
  86. package/docs/api/interfaces/DataAccessRecord.md +1 -1
  87. package/docs/api/interfaces/DataTableAction.md +1 -1
  88. package/docs/api/interfaces/DataTableColumn.md +1 -1
  89. package/docs/api/interfaces/DataTableProps.md +1 -1
  90. package/docs/api/interfaces/DataTableToolbarButton.md +1 -1
  91. package/docs/api/interfaces/EmptyStateConfig.md +1 -1
  92. package/docs/api/interfaces/EnhancedNavigationMenuProps.md +1 -1
  93. package/docs/api/interfaces/EventLogoProps.md +2 -2
  94. package/docs/api/interfaces/FileDisplayProps.md +1 -1
  95. package/docs/api/interfaces/FileMetadata.md +1 -1
  96. package/docs/api/interfaces/FileReference.md +1 -1
  97. package/docs/api/interfaces/FileSizeLimits.md +1 -1
  98. package/docs/api/interfaces/FileUploadOptions.md +1 -1
  99. package/docs/api/interfaces/FileUploadProps.md +1 -1
  100. package/docs/api/interfaces/FooterProps.md +1 -1
  101. package/docs/api/interfaces/InactivityWarningModalProps.md +1 -1
  102. package/docs/api/interfaces/InputProps.md +2 -2
  103. package/docs/api/interfaces/LabelProps.md +1 -1
  104. package/docs/api/interfaces/LoginFormProps.md +1 -1
  105. package/docs/api/interfaces/NavigationAccessRecord.md +1 -1
  106. package/docs/api/interfaces/NavigationContextType.md +1 -1
  107. package/docs/api/interfaces/NavigationGuardProps.md +1 -1
  108. package/docs/api/interfaces/NavigationItem.md +1 -1
  109. package/docs/api/interfaces/NavigationMenuProps.md +1 -1
  110. package/docs/api/interfaces/NavigationProviderProps.md +1 -1
  111. package/docs/api/interfaces/Organisation.md +1 -1
  112. package/docs/api/interfaces/OrganisationContextType.md +28 -17
  113. package/docs/api/interfaces/OrganisationMembership.md +1 -1
  114. package/docs/api/interfaces/OrganisationProviderProps.md +2 -2
  115. package/docs/api/interfaces/OrganisationSecurityError.md +1 -1
  116. package/docs/api/interfaces/PaceAppLayoutProps.md +1 -1
  117. package/docs/api/interfaces/PaceLoginPageProps.md +1 -1
  118. package/docs/api/interfaces/PageAccessRecord.md +1 -1
  119. package/docs/api/interfaces/PagePermissionContextType.md +1 -1
  120. package/docs/api/interfaces/PagePermissionGuardProps.md +1 -1
  121. package/docs/api/interfaces/PagePermissionProviderProps.md +1 -1
  122. package/docs/api/interfaces/PaletteData.md +1 -1
  123. package/docs/api/interfaces/PermissionEnforcerProps.md +1 -1
  124. package/docs/api/interfaces/PublicErrorBoundaryProps.md +1 -1
  125. package/docs/api/interfaces/PublicErrorBoundaryState.md +1 -1
  126. package/docs/api/interfaces/PublicLoadingSpinnerProps.md +2 -2
  127. package/docs/api/interfaces/PublicPageFooterProps.md +1 -1
  128. package/docs/api/interfaces/PublicPageHeaderProps.md +1 -1
  129. package/docs/api/interfaces/PublicPageLayoutProps.md +1 -1
  130. package/docs/api/interfaces/RBACConfig.md +1 -1
  131. package/docs/api/interfaces/RBACContextType.md +5 -11
  132. package/docs/api/interfaces/RBACLogger.md +1 -1
  133. package/docs/api/interfaces/RBACProviderProps.md +1 -1
  134. package/docs/api/interfaces/RoleBasedRouterContextType.md +1 -1
  135. package/docs/api/interfaces/RoleBasedRouterProps.md +1 -1
  136. package/docs/api/interfaces/RouteAccessRecord.md +1 -1
  137. package/docs/api/interfaces/RouteConfig.md +1 -1
  138. package/docs/api/interfaces/SecureDataContextType.md +1 -1
  139. package/docs/api/interfaces/SecureDataProviderProps.md +1 -1
  140. package/docs/api/interfaces/StorageConfig.md +1 -1
  141. package/docs/api/interfaces/StorageFileInfo.md +1 -1
  142. package/docs/api/interfaces/StorageFileMetadata.md +1 -1
  143. package/docs/api/interfaces/StorageListOptions.md +1 -1
  144. package/docs/api/interfaces/StorageListResult.md +1 -1
  145. package/docs/api/interfaces/StorageUploadOptions.md +1 -1
  146. package/docs/api/interfaces/StorageUploadResult.md +1 -1
  147. package/docs/api/interfaces/StorageUrlOptions.md +1 -1
  148. package/docs/api/interfaces/StyleImport.md +1 -1
  149. package/docs/api/interfaces/SwitchProps.md +1 -1
  150. package/docs/api/interfaces/ToastActionElement.md +1 -1
  151. package/docs/api/interfaces/ToastProps.md +1 -1
  152. package/docs/api/interfaces/UnifiedAuthContextType.md +524 -440
  153. package/docs/api/interfaces/UnifiedAuthProviderProps.md +14 -14
  154. package/docs/api/interfaces/UseInactivityTrackerOptions.md +1 -1
  155. package/docs/api/interfaces/UseInactivityTrackerReturn.md +1 -1
  156. package/docs/api/interfaces/UsePublicEventLogoOptions.md +1 -1
  157. package/docs/api/interfaces/UsePublicEventLogoReturn.md +1 -1
  158. package/docs/api/interfaces/UsePublicEventOptions.md +1 -1
  159. package/docs/api/interfaces/UsePublicEventReturn.md +1 -1
  160. package/docs/api/interfaces/UsePublicRouteParamsReturn.md +1 -1
  161. package/docs/api/interfaces/UseResolvedScopeOptions.md +47 -0
  162. package/docs/api/interfaces/UseResolvedScopeReturn.md +47 -0
  163. package/docs/api/interfaces/UserEventAccess.md +11 -11
  164. package/docs/api/interfaces/UserMenuProps.md +1 -1
  165. package/docs/api/interfaces/UserProfile.md +1 -1
  166. package/docs/api/modules.md +234 -61
  167. package/docs/api-reference/providers.md +26 -7
  168. package/docs/architecture/services.md +30 -32
  169. package/docs/best-practices/README.md +20 -0
  170. package/docs/best-practices/accessibility.md +566 -0
  171. package/docs/best-practices/performance-expansion.md +473 -0
  172. package/docs/breaking-changes.md +2 -5
  173. package/docs/core-concepts/authentication.md +15 -7
  174. package/docs/documentation-index.md +1 -1
  175. package/docs/documentation-templates.md +539 -0
  176. package/docs/getting-started/quick-start.md +16 -66
  177. package/docs/implementation-guides/component-styling.md +410 -0
  178. package/docs/implementation-guides/data-tables.md +1 -1
  179. package/docs/migration/service-architecture.md +121 -260
  180. package/docs/rbac/README-rbac-rls-integration.md +48 -38
  181. package/docs/style-guide.md +39 -0
  182. package/{src/rbac/examples → examples/RBAC}/CompleteRBACExample.tsx +3 -2
  183. package/{src/rbac/examples → examples/RBAC}/EventBasedApp.tsx +5 -4
  184. package/{src/components/examples → examples/RBAC}/PermissionExample.tsx +7 -6
  185. package/examples/RBAC/__tests__/PermissionExample.test.tsx +150 -0
  186. package/examples/RBAC/index.ts +13 -0
  187. package/examples/README.md +37 -0
  188. package/examples/index.ts +22 -0
  189. package/{src/examples → examples/public-pages}/CorrectPublicPageImplementation.tsx +1 -1
  190. package/{src/examples → examples/public-pages}/PublicEventPage.tsx +1 -1
  191. package/{src/examples → examples/public-pages}/PublicPageApp.tsx +1 -1
  192. package/{src/examples → examples/public-pages}/PublicPageUsageExample.tsx +1 -1
  193. package/examples/public-pages/__tests__/PublicPageUsageExample.test.tsx +159 -0
  194. package/examples/public-pages/index.ts +14 -0
  195. package/package.json +22 -18
  196. package/src/__tests__/TEST_GUIDE_CURSOR.md +940 -9
  197. package/src/__tests__/helpers/README.md +255 -0
  198. package/src/__tests__/helpers/index.ts +62 -0
  199. package/src/__tests__/helpers/supabaseMock.ts +75 -5
  200. package/src/__tests__/rbac/PagePermissionGuard.test.tsx +6 -8
  201. package/src/components/DataTable/__tests__/DataTable.default-state.test.tsx +17 -6
  202. package/src/components/DataTable/__tests__/DataTableCore.test.tsx +73 -9
  203. package/src/components/DataTable/components/DataTableCore.tsx +280 -475
  204. package/src/components/DataTable/components/UnifiedTableBody.tsx +120 -153
  205. package/src/components/DataTable/components/__tests__/COVERAGE_NOTE.md +55 -0
  206. package/src/components/DataTable/components/index.ts +1 -2
  207. package/src/components/DataTable/context/__tests__/DataTableContext.test.tsx +208 -275
  208. package/src/components/DataTable/core/__tests__/ColumnFactory.test.ts +254 -0
  209. package/src/components/DataTable/core/index.ts +1 -8
  210. package/src/components/DataTable/examples/__tests__/HierarchicalExample.test.tsx +45 -0
  211. package/src/components/DataTable/examples/__tests__/PerformanceExample.test.tsx +117 -0
  212. package/src/components/DataTable/hooks/__tests__/useColumnOrderPersistence.test.ts +525 -0
  213. package/src/components/DataTable/hooks/__tests__/useColumnReordering.test.ts +570 -0
  214. package/src/components/DataTable/hooks/__tests__/useHierarchicalState.test.ts +214 -0
  215. package/src/components/DataTable/hooks/__tests__/useTableColumns.test.ts +224 -0
  216. package/src/components/DataTable/hooks/index.ts +6 -0
  217. package/src/components/DataTable/hooks/useColumnReordering.ts +1 -0
  218. package/src/components/DataTable/hooks/useDataTablePermissions.ts +149 -0
  219. package/src/components/DataTable/hooks/useDataTableState.ts +12 -6
  220. package/src/components/DataTable/hooks/useHierarchicalState.ts +26 -8
  221. package/src/components/DataTable/hooks/useTableColumns.ts +153 -0
  222. package/src/components/DataTable/index.ts +1 -9
  223. package/src/components/DataTable/utils/__tests__/COVERAGE_NOTE.md +89 -0
  224. package/src/components/DataTable/utils/__tests__/exportUtils.test.ts +3 -6
  225. package/src/components/DataTable/utils/__tests__/flexibleImport.test.ts +462 -0
  226. package/src/components/DataTable/utils/__tests__/hierarchicalSorting.test.ts +247 -0
  227. package/src/components/DataTable/utils/__tests__/hierarchicalUtils.test.ts +8 -6
  228. package/src/components/DataTable/utils/__tests__/performanceUtils.test.ts +466 -0
  229. package/src/components/DataTable/utils/__tests__/rowUtils.test.ts +265 -0
  230. package/src/components/DataTable/utils/errorHandling.ts +52 -460
  231. package/src/components/DataTable/utils/exportUtils.ts +46 -15
  232. package/src/components/DataTable/utils/hierarchicalSorting.ts +50 -3
  233. package/src/components/DataTable/utils/hierarchicalUtils.ts +167 -34
  234. package/src/components/DataTable/utils/index.ts +5 -0
  235. package/src/components/DataTable/utils/rowUtils.ts +68 -0
  236. package/src/components/Dialog/examples/__tests__/HtmlDialogExample.test.tsx +71 -0
  237. package/src/components/Dialog/examples/__tests__/SimpleHtmlTest.test.tsx +122 -0
  238. package/src/components/EventSelector/EventSelector.test.tsx +672 -0
  239. package/src/components/EventSelector/EventSelector.tsx +1 -1
  240. package/src/components/Header/Header.test.tsx +35 -1
  241. package/src/components/Header/Header.tsx +3 -1
  242. package/src/components/Label/__tests__/Label.test.tsx +434 -0
  243. package/src/components/OrganisationSelector/OrganisationSelector.tsx +3 -3
  244. package/src/components/PaceAppLayout/__tests__/PaceAppLayout.rbac.test.tsx +24 -4
  245. package/src/components/PaceLoginPage/PaceLoginPage.test.tsx +3 -2
  246. package/src/components/PublicLayout/__tests__/PublicPageContextChecker.test.tsx +190 -0
  247. package/src/components/PublicLayout/__tests__/PublicPageDebugger.test.tsx +185 -0
  248. package/src/components/PublicLayout/__tests__/PublicPageProvider.test.tsx +313 -0
  249. package/src/components/Select/Select.test.tsx +143 -120
  250. package/src/components/Select/Select.tsx +47 -212
  251. package/src/components/Select/hooks.ts +36 -1
  252. package/src/components/Select/index.ts +2 -1
  253. package/src/hooks/__tests__/useFocusManagement.unit.test.ts +220 -0
  254. package/src/hooks/__tests__/useIsMobile.unit.test.ts +117 -0
  255. package/src/hooks/__tests__/useKeyboardShortcuts.unit.test.ts +295 -0
  256. package/src/hooks/__tests__/useOrganisationSecurity.unit.test.tsx +29 -19
  257. package/src/hooks/__tests__/useRBAC.unit.test.ts +7 -3
  258. package/src/hooks/__tests__/useSecureDataAccess.unit.test.tsx +115 -19
  259. package/src/hooks/services/__tests__/useServiceHooks.test.tsx +137 -0
  260. package/src/hooks/useEventTheme.test.ts +350 -0
  261. package/src/hooks/useEventTheme.ts +1 -1
  262. package/src/hooks/useEvents.ts +61 -0
  263. package/src/hooks/useOrganisationSecurity.test.ts +4 -4
  264. package/src/hooks/useOrganisationSecurity.ts +2 -2
  265. package/src/hooks/useOrganisations.ts +64 -0
  266. package/src/hooks/useSecureDataAccess.test.ts +37 -30
  267. package/src/hooks/useSecureDataAccess.ts +2 -2
  268. package/src/index.ts +18 -3
  269. package/src/providers/AuthProvider.tsx +8 -292
  270. package/src/providers/EventProvider.tsx +15 -425
  271. package/src/providers/InactivityProvider.tsx +8 -231
  272. package/src/providers/OrganisationProvider.test.simple.tsx +3 -2
  273. package/src/providers/OrganisationProvider.tsx +11 -890
  274. package/src/providers/UnifiedAuthProvider.tsx +8 -320
  275. package/src/providers/__tests__/AuthProvider.test.tsx +18 -17
  276. package/src/providers/__tests__/EventProvider.test.tsx +253 -2
  277. package/src/providers/__tests__/InactivityProvider.test-helper.tsx +65 -0
  278. package/src/providers/__tests__/InactivityProvider.test.tsx +46 -114
  279. package/src/providers/__tests__/OrganisationProvider.test.tsx +313 -3
  280. package/src/providers/__tests__/ProviderLifecycle.test.tsx +341 -0
  281. package/src/providers/__tests__/UnifiedAuthProvider.test.tsx +383 -2
  282. package/src/providers/index.ts +8 -7
  283. package/src/providers/services/EventServiceProvider.tsx +3 -0
  284. package/src/providers/services/UnifiedAuthProvider.tsx +3 -0
  285. package/src/rbac/hooks/__tests__/usePermissions.integration.test.ts +437 -0
  286. package/src/rbac/hooks/index.ts +2 -0
  287. package/src/rbac/hooks/usePermissions.test.ts +296 -0
  288. package/src/rbac/hooks/useRBAC.test.ts +9 -5
  289. package/src/rbac/hooks/useRBAC.ts +3 -3
  290. package/src/rbac/hooks/useResolvedScope.ts +232 -0
  291. package/src/rbac/providers/__tests__/RBACProvider.integration.test.tsx +688 -0
  292. package/src/rbac/providers/__tests__/RBACProvider.test.tsx +507 -0
  293. package/src/services/AuthService.ts +19 -4
  294. package/src/services/__tests__/AuthService.test.ts +288 -0
  295. package/src/services/__tests__/InactivityService.lifecycle.test.ts +411 -0
  296. package/src/services/__tests__/OrganisationService.pagination.test.ts +375 -0
  297. package/src/styles/core.css +2 -0
  298. package/src/types/__tests__/README.md +114 -0
  299. package/src/types/__tests__/guards.test.ts +246 -0
  300. package/src/types/__tests__/validation.test.ts +731 -0
  301. package/src/types/guards.ts +1 -0
  302. package/src/types/organisation.ts +3 -2
  303. package/src/utils/__tests__/file-reference.test.ts +383 -0
  304. package/src/utils/__tests__/performanceBenchmark.test.ts +175 -0
  305. package/src/utils/appNameResolver.test.ts +54 -0
  306. package/src/validation/__tests__/csrf.unit.test.ts +63 -0
  307. package/src/validation/__tests__/passwordSchema.unit.test.ts +105 -0
  308. package/src/validation/__tests__/sanitization.unit.test.ts +250 -0
  309. package/src/validation/__tests__/schemaUtils.unit.test.ts +451 -0
  310. package/src/validation/__tests__/user.unit.test.ts +440 -0
  311. package/dist/DataTable-2QR5TER5.js +0 -102
  312. package/dist/RBACProvider-BO4ilsQB.d.ts +0 -63
  313. package/dist/UnifiedAuthProvider-D02AMXgO.d.ts +0 -103
  314. package/dist/chunk-3SP4P7NS.js.map +0 -1
  315. package/dist/chunk-B5LK25HV.js +0 -953
  316. package/dist/chunk-B5LK25HV.js.map +0 -1
  317. package/dist/chunk-BKVGJVUR.js.map +0 -1
  318. package/dist/chunk-C5Q5LRU5.js +0 -5691
  319. package/dist/chunk-C5Q5LRU5.js.map +0 -1
  320. package/dist/chunk-CDDYJCYU.js +0 -79
  321. package/dist/chunk-CDDYJCYU.js.map +0 -1
  322. package/dist/chunk-DG5Z55HH.js.map +0 -1
  323. package/dist/chunk-H2TNUICK.js.map +0 -1
  324. package/dist/chunk-IHMMNKNA.js.map +0 -1
  325. package/dist/chunk-LVQ26TCN.js.map +0 -1
  326. package/dist/chunk-ORSMVXO2.js.map +0 -1
  327. package/dist/chunk-TYHR5X4W.js +0 -33
  328. package/dist/chunk-TYHR5X4W.js.map +0 -1
  329. package/dist/chunk-UJMCGBLS.js.map +0 -1
  330. package/dist/chunk-V6BHACCH.js +0 -17
  331. package/dist/chunk-V6BHACCH.js.map +0 -1
  332. package/dist/chunk-YNUBMSMV.js.map +0 -1
  333. package/dist/eventContext-BBA42P6G.js +0 -14
  334. package/dist/rbac/cli/policy-manager.js +0 -278
  335. package/dist/rbac/cli/policy-manager.js.map +0 -1
  336. package/docs/api/interfaces/EventContextType.md +0 -96
  337. package/docs/api/interfaces/EventProviderProps.md +0 -19
  338. package/docs/documentation-style-checklist.md +0 -294
  339. package/src/components/DataTable/components/DataTableBody.tsx +0 -488
  340. package/src/components/DataTable/components/DraggableColumnHeader.tsx +0 -144
  341. package/src/components/DataTable/components/VirtualizedDataTable.tsx +0 -515
  342. package/src/components/DataTable/core/ActionManager.ts +0 -235
  343. package/src/components/DataTable/core/ColumnManager.ts +0 -205
  344. package/src/components/DataTable/core/DataManager.ts +0 -188
  345. package/src/components/DataTable/core/DataTableContext.tsx +0 -181
  346. package/src/components/DataTable/core/LocalDataAdapter.ts +0 -264
  347. package/src/components/DataTable/core/PluginRegistry.ts +0 -229
  348. package/src/components/DataTable/core/StateManager.ts +0 -311
  349. package/src/components/DataTable/core/__tests__/ActionManager.test.ts +0 -634
  350. package/src/components/DataTable/core/__tests__/DataManager.test.ts +0 -519
  351. package/src/components/DataTable/core/__tests__/StateManager.test.ts +0 -714
  352. package/src/components/DataTable/core/interfaces.ts +0 -338
  353. package/src/components/DataTable/utils/debugTools.ts +0 -583
  354. package/src/components/Select/Select.bug-test.tsx +0 -69
  355. package/src/components/Select/Select.refactored.tsx +0 -497
  356. package/src/providers/OrganisationProvider.test.tsx +0 -164
  357. package/src/providers/UnifiedAuthProvider.test.tsx +0 -124
  358. package/src/providers/__tests__/AuthProvider.test.tsx.backup +0 -771
  359. package/src/providers/__tests__/EventProvider.test.tsx.backup +0 -824
  360. package/src/providers/__tests__/OrganisationProvider.test.tsx.backup +0 -820
  361. package/src/providers/__tests__/UnifiedAuthProvider.test.tsx.backup +0 -911
  362. package/src/providers/__tests__/UnifiedAuthProvider.test.tsx.backup2 +0 -166
  363. package/src/rbac/cli/__tests__/policy-manager.test.ts +0 -339
  364. package/src/rbac/cli/policy-manager.ts +0 -443
  365. package/dist/{DataTable-2QR5TER5.js.map → DataTable-4GAVPIEG.js.map} +0 -0
  366. package/dist/{UnifiedAuthProvider-K4NRGXL4.js.map → UnifiedAuthProvider-3NKDOSOK.js.map} +0 -0
  367. package/dist/{eventContext-BBA42P6G.js.map → useInactivityTracker-MRUU55XI.js.map} +0 -0
  368. package/dist/{validation-PM_iOaTI.d.ts → validation-D8VcbTzC.d.ts} +2 -2
  369. /package/src/utils/{appNameResolver.test.ts.backup → appNameResolver.test 2.ts} +0 -0
@@ -676,4 +676,511 @@ describe('RBACProvider', () => {
676
676
  expect(screen.getByTestId('can-read-users')).toBeInTheDocument();
677
677
  });
678
678
  });
679
+
680
+ describe('[integration] Provider Initialization', () => {
681
+ it('initializes without errors', () => {
682
+ mockUseRBAC.mockReturnValue({
683
+ permissions: {
684
+ permissions: ['read:users'],
685
+ isLoading: false,
686
+ error: null,
687
+ refetch: vi.fn(),
688
+ },
689
+ can: {
690
+ can: vi.fn().mockReturnValue(true),
691
+ canAny: vi.fn().mockReturnValue(true),
692
+ canAll: vi.fn().mockReturnValue(true),
693
+ isLoading: false,
694
+ error: null,
695
+ },
696
+ organisationPermissions: {
697
+ permissions: ['read:organisation'],
698
+ isLoading: false,
699
+ error: null,
700
+ refetch: vi.fn(),
701
+ },
702
+ permissionCache: {
703
+ getCachedPermission: vi.fn(),
704
+ setCachedPermission: vi.fn(),
705
+ clearCache: vi.fn(),
706
+ isCacheValid: vi.fn().mockReturnValue(true),
707
+ },
708
+ organisationSecurity: {
709
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
710
+ canAccessEvent: vi.fn().mockReturnValue(true),
711
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
712
+ isEventAdmin: vi.fn().mockReturnValue(false),
713
+ isLoading: false,
714
+ error: null,
715
+ },
716
+ });
717
+
718
+ render(
719
+ <RBACProvider>
720
+ <TestComponent />
721
+ </RBACProvider>
722
+ );
723
+
724
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
725
+ expect(screen.getByTestId('permissions')).toBeInTheDocument();
726
+ });
727
+
728
+ it('handles missing dependencies gracefully', () => {
729
+ mockUseRBAC.mockReturnValue({
730
+ permissions: {
731
+ permissions: [],
732
+ isLoading: true,
733
+ error: null,
734
+ refetch: vi.fn(),
735
+ },
736
+ can: {
737
+ can: vi.fn().mockReturnValue(false),
738
+ canAny: vi.fn().mockReturnValue(false),
739
+ canAll: vi.fn().mockReturnValue(false),
740
+ isLoading: true,
741
+ error: null,
742
+ },
743
+ organisationPermissions: {
744
+ permissions: [],
745
+ isLoading: true,
746
+ error: null,
747
+ refetch: vi.fn(),
748
+ },
749
+ permissionCache: {
750
+ getCachedPermission: vi.fn(),
751
+ setCachedPermission: vi.fn(),
752
+ clearCache: vi.fn(),
753
+ isCacheValid: vi.fn().mockReturnValue(false),
754
+ },
755
+ organisationSecurity: {
756
+ canAccessOrganisation: vi.fn().mockReturnValue(false),
757
+ canAccessEvent: vi.fn().mockReturnValue(false),
758
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
759
+ isEventAdmin: vi.fn().mockReturnValue(false),
760
+ isLoading: true,
761
+ error: null,
762
+ },
763
+ });
764
+
765
+ render(
766
+ <RBACProvider>
767
+ <TestComponent />
768
+ </RBACProvider>
769
+ );
770
+
771
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
772
+ });
773
+ });
774
+
775
+ describe('[integration] Concurrent Permission Checks', () => {
776
+ it('handles multiple permission checks simultaneously', () => {
777
+ const mockCan = vi.fn().mockReturnValue(true);
778
+ mockUseRBAC.mockReturnValue({
779
+ permissions: {
780
+ permissions: ['read:users'],
781
+ isLoading: false,
782
+ error: null,
783
+ refetch: vi.fn(),
784
+ },
785
+ can: {
786
+ can: mockCan,
787
+ canAny: vi.fn().mockReturnValue(true),
788
+ canAll: vi.fn().mockReturnValue(true),
789
+ isLoading: false,
790
+ error: null,
791
+ },
792
+ organisationPermissions: {
793
+ permissions: ['read:organisation'],
794
+ isLoading: false,
795
+ error: null,
796
+ refetch: vi.fn(),
797
+ },
798
+ permissionCache: {
799
+ getCachedPermission: vi.fn(),
800
+ setCachedPermission: vi.fn(),
801
+ clearCache: vi.fn(),
802
+ isCacheValid: vi.fn().mockReturnValue(true),
803
+ },
804
+ organisationSecurity: {
805
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
806
+ canAccessEvent: vi.fn().mockReturnValue(true),
807
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
808
+ isEventAdmin: vi.fn().mockReturnValue(false),
809
+ isLoading: false,
810
+ error: null,
811
+ },
812
+ });
813
+
814
+ render(
815
+ <RBACProvider>
816
+ <TestComponent />
817
+ </RBACProvider>
818
+ );
819
+
820
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
821
+ });
822
+
823
+ it('maintains performance under high permission check load', () => {
824
+ const mockCan = vi.fn().mockReturnValue(true);
825
+ let callCount = 0;
826
+
827
+ mockUseRBAC.mockReturnValue({
828
+ permissions: {
829
+ permissions: ['read:users'],
830
+ isLoading: false,
831
+ error: null,
832
+ refetch: vi.fn(),
833
+ },
834
+ can: {
835
+ can: () => {
836
+ callCount++;
837
+ return mockCan();
838
+ },
839
+ canAny: vi.fn().mockReturnValue(true),
840
+ canAll: vi.fn().mockReturnValue(true),
841
+ isLoading: false,
842
+ error: null,
843
+ },
844
+ organisationPermissions: {
845
+ permissions: ['read:organisation'],
846
+ isLoading: false,
847
+ error: null,
848
+ refetch: vi.fn(),
849
+ },
850
+ permissionCache: {
851
+ getCachedPermission: vi.fn(),
852
+ setCachedPermission: vi.fn(),
853
+ clearCache: vi.fn(),
854
+ isCacheValid: vi.fn().mockReturnValue(true),
855
+ },
856
+ organisationSecurity: {
857
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
858
+ canAccessEvent: vi.fn().mockReturnValue(true),
859
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
860
+ isEventAdmin: vi.fn().mockReturnValue(false),
861
+ isLoading: false,
862
+ error: null,
863
+ },
864
+ });
865
+
866
+ render(
867
+ <RBACProvider>
868
+ <TestComponent />
869
+ </RBACProvider>
870
+ );
871
+
872
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
873
+ });
874
+ });
875
+
876
+ describe('[integration] Permission Cache Management', () => {
877
+ it('provides cache invalidation functionality', () => {
878
+ const mockClearCache = vi.fn();
879
+ mockUseRBAC.mockReturnValue({
880
+ permissions: {
881
+ permissions: ['read:users'],
882
+ isLoading: false,
883
+ error: null,
884
+ refetch: vi.fn(),
885
+ },
886
+ can: {
887
+ can: vi.fn().mockReturnValue(true),
888
+ canAny: vi.fn().mockReturnValue(true),
889
+ canAll: vi.fn().mockReturnValue(true),
890
+ isLoading: false,
891
+ error: null,
892
+ },
893
+ organisationPermissions: {
894
+ permissions: ['read:organisation'],
895
+ isLoading: false,
896
+ error: null,
897
+ refetch: vi.fn(),
898
+ },
899
+ permissionCache: {
900
+ getCachedPermission: vi.fn(),
901
+ setCachedPermission: vi.fn(),
902
+ clearCache: mockClearCache,
903
+ isCacheValid: vi.fn().mockReturnValue(true),
904
+ },
905
+ organisationSecurity: {
906
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
907
+ canAccessEvent: vi.fn().mockReturnValue(true),
908
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
909
+ isEventAdmin: vi.fn().mockReturnValue(false),
910
+ isLoading: false,
911
+ error: null,
912
+ },
913
+ });
914
+
915
+ render(
916
+ <RBACProvider>
917
+ <TestComponent />
918
+ </RBACProvider>
919
+ );
920
+
921
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
922
+ expect(mockClearCache).toBeDefined();
923
+ });
924
+
925
+ it('handles cache validation states', () => {
926
+ let cacheValid = false;
927
+ mockUseRBAC.mockReturnValue({
928
+ permissions: {
929
+ permissions: ['read:users'],
930
+ isLoading: false,
931
+ error: null,
932
+ refetch: vi.fn(),
933
+ },
934
+ can: {
935
+ can: vi.fn().mockReturnValue(true),
936
+ canAny: vi.fn().mockReturnValue(true),
937
+ canAll: vi.fn().mockReturnValue(true),
938
+ isLoading: false,
939
+ error: null,
940
+ },
941
+ organisationPermissions: {
942
+ permissions: ['read:organisation'],
943
+ isLoading: false,
944
+ error: null,
945
+ refetch: vi.fn(),
946
+ },
947
+ permissionCache: {
948
+ getCachedPermission: vi.fn(),
949
+ setCachedPermission: vi.fn(),
950
+ clearCache: vi.fn(),
951
+ isCacheValid: vi.fn(() => cacheValid),
952
+ },
953
+ organisationSecurity: {
954
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
955
+ canAccessEvent: vi.fn().mockReturnValue(true),
956
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
957
+ isEventAdmin: vi.fn().mockReturnValue(false),
958
+ isLoading: false,
959
+ error: null,
960
+ },
961
+ });
962
+
963
+ const { rerender } = render(
964
+ <RBACProvider>
965
+ <TestComponent />
966
+ </RBACProvider>
967
+ );
968
+
969
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
970
+
971
+ // Toggle cache validity
972
+ cacheValid = true;
973
+ rerender(
974
+ <RBACProvider>
975
+ <TestComponent />
976
+ </RBACProvider>
977
+ );
978
+
979
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
980
+ });
981
+ });
982
+
983
+ describe('[integration] Security and Access Control', () => {
984
+ it('validates organization access', () => {
985
+ const mockCanAccessOrg = vi.fn().mockReturnValue(true);
986
+ mockUseRBAC.mockReturnValue({
987
+ permissions: {
988
+ permissions: ['read:users'],
989
+ isLoading: false,
990
+ error: null,
991
+ refetch: vi.fn(),
992
+ },
993
+ can: {
994
+ can: vi.fn().mockReturnValue(true),
995
+ canAny: vi.fn().mockReturnValue(true),
996
+ canAll: vi.fn().mockReturnValue(true),
997
+ isLoading: false,
998
+ error: null,
999
+ },
1000
+ organisationPermissions: {
1001
+ permissions: ['read:organisation'],
1002
+ isLoading: false,
1003
+ error: null,
1004
+ refetch: vi.fn(),
1005
+ },
1006
+ permissionCache: {
1007
+ getCachedPermission: vi.fn(),
1008
+ setCachedPermission: vi.fn(),
1009
+ clearCache: vi.fn(),
1010
+ isCacheValid: vi.fn().mockReturnValue(true),
1011
+ },
1012
+ organisationSecurity: {
1013
+ canAccessOrganisation: mockCanAccessOrg,
1014
+ canAccessEvent: vi.fn().mockReturnValue(true),
1015
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
1016
+ isEventAdmin: vi.fn().mockReturnValue(false),
1017
+ isLoading: false,
1018
+ error: null,
1019
+ },
1020
+ });
1021
+
1022
+ render(
1023
+ <RBACProvider>
1024
+ <TestComponent />
1025
+ </RBACProvider>
1026
+ );
1027
+
1028
+ expect(mockCanAccessOrg).toBeDefined();
1029
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
1030
+ });
1031
+
1032
+ it('validates event access', () => {
1033
+ const mockCanAccessEvent = vi.fn().mockReturnValue(true);
1034
+ mockUseRBAC.mockReturnValue({
1035
+ permissions: {
1036
+ permissions: ['read:users'],
1037
+ isLoading: false,
1038
+ error: null,
1039
+ refetch: vi.fn(),
1040
+ },
1041
+ can: {
1042
+ can: vi.fn().mockReturnValue(true),
1043
+ canAny: vi.fn().mockReturnValue(true),
1044
+ canAll: vi.fn().mockReturnValue(true),
1045
+ isLoading: false,
1046
+ error: null,
1047
+ },
1048
+ organisationPermissions: {
1049
+ permissions: ['read:organisation'],
1050
+ isLoading: false,
1051
+ error: null,
1052
+ refetch: vi.fn(),
1053
+ },
1054
+ permissionCache: {
1055
+ getCachedPermission: vi.fn(),
1056
+ setCachedPermission: vi.fn(),
1057
+ clearCache: vi.fn(),
1058
+ isCacheValid: vi.fn().mockReturnValue(true),
1059
+ },
1060
+ organisationSecurity: {
1061
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
1062
+ canAccessEvent: mockCanAccessEvent,
1063
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
1064
+ isEventAdmin: vi.fn().mockReturnValue(false),
1065
+ isLoading: false,
1066
+ error: null,
1067
+ },
1068
+ });
1069
+
1070
+ render(
1071
+ <RBACProvider>
1072
+ <TestComponent />
1073
+ </RBACProvider>
1074
+ );
1075
+
1076
+ expect(mockCanAccessEvent).toBeDefined();
1077
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
1078
+ });
1079
+
1080
+ it('checks admin roles correctly', () => {
1081
+ const mockIsOrgAdmin = vi.fn().mockReturnValue(false);
1082
+ const mockIsEventAdmin = vi.fn().mockReturnValue(false);
1083
+
1084
+ mockUseRBAC.mockReturnValue({
1085
+ permissions: {
1086
+ permissions: ['read:users'],
1087
+ isLoading: false,
1088
+ error: null,
1089
+ refetch: vi.fn(),
1090
+ },
1091
+ can: {
1092
+ can: vi.fn().mockReturnValue(true),
1093
+ canAny: vi.fn().mockReturnValue(true),
1094
+ canAll: vi.fn().mockReturnValue(true),
1095
+ isLoading: false,
1096
+ error: null,
1097
+ },
1098
+ organisationPermissions: {
1099
+ permissions: ['read:organisation'],
1100
+ isLoading: false,
1101
+ error: null,
1102
+ refetch: vi.fn(),
1103
+ },
1104
+ permissionCache: {
1105
+ getCachedPermission: vi.fn(),
1106
+ setCachedPermission: vi.fn(),
1107
+ clearCache: vi.fn(),
1108
+ isCacheValid: vi.fn().mockReturnValue(true),
1109
+ },
1110
+ organisationSecurity: {
1111
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
1112
+ canAccessEvent: vi.fn().mockReturnValue(true),
1113
+ isOrganisationAdmin: mockIsOrgAdmin,
1114
+ isEventAdmin: mockIsEventAdmin,
1115
+ isLoading: false,
1116
+ error: null,
1117
+ },
1118
+ });
1119
+
1120
+ render(
1121
+ <RBACProvider>
1122
+ <TestComponent />
1123
+ </RBACProvider>
1124
+ );
1125
+
1126
+ expect(mockIsOrgAdmin).toBeDefined();
1127
+ expect(mockIsEventAdmin).toBeDefined();
1128
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
1129
+ });
1130
+ });
1131
+
1132
+ describe('[integration] Rapid State Changes', () => {
1133
+ it('handles rapid permission updates without errors', () => {
1134
+ let permissionState = { permissions: ['read:users'], isLoading: false, error: null, refetch: vi.fn() };
1135
+
1136
+ mockUseRBAC.mockReturnValue({
1137
+ permissions: permissionState,
1138
+ can: {
1139
+ can: vi.fn().mockReturnValue(true),
1140
+ canAny: vi.fn().mockReturnValue(true),
1141
+ canAll: vi.fn().mockReturnValue(true),
1142
+ isLoading: false,
1143
+ error: null,
1144
+ },
1145
+ organisationPermissions: {
1146
+ permissions: ['read:organisation'],
1147
+ isLoading: false,
1148
+ error: null,
1149
+ refetch: vi.fn(),
1150
+ },
1151
+ permissionCache: {
1152
+ getCachedPermission: vi.fn(),
1153
+ setCachedPermission: vi.fn(),
1154
+ clearCache: vi.fn(),
1155
+ isCacheValid: vi.fn().mockReturnValue(true),
1156
+ },
1157
+ organisationSecurity: {
1158
+ canAccessOrganisation: vi.fn().mockReturnValue(true),
1159
+ canAccessEvent: vi.fn().mockReturnValue(true),
1160
+ isOrganisationAdmin: vi.fn().mockReturnValue(false),
1161
+ isEventAdmin: vi.fn().mockReturnValue(false),
1162
+ isLoading: false,
1163
+ error: null,
1164
+ },
1165
+ });
1166
+
1167
+ const { rerender } = render(
1168
+ <RBACProvider>
1169
+ <TestComponent />
1170
+ </RBACProvider>
1171
+ );
1172
+
1173
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
1174
+
1175
+ // Rapid updates
1176
+ permissionState = { permissions: ['write:users'], isLoading: false, error: null, refetch: vi.fn() };
1177
+ rerender(
1178
+ <RBACProvider>
1179
+ <TestComponent />
1180
+ </RBACProvider>
1181
+ );
1182
+
1183
+ expect(screen.getByTestId('test-component')).toBeInTheDocument();
1184
+ });
1185
+ });
679
1186
  });
@@ -184,7 +184,10 @@ export class AuthService extends BaseService implements IAuthService {
184
184
  this.notify();
185
185
  return { user: null, session: null, error };
186
186
  } catch (error) {
187
- const authError = error as AuthError;
187
+ // Convert regular Error to AuthError if needed
188
+ const authError = error instanceof AuthError
189
+ ? error
190
+ : new AuthError(error instanceof Error ? error.message : 'Authentication failed');
188
191
  this.authError = authError;
189
192
  this.notify();
190
193
  return { user: null, session: null, error: authError };
@@ -237,12 +240,24 @@ export class AuthService extends BaseService implements IAuthService {
237
240
  this.session = null;
238
241
  } else {
239
242
  this.authError = null;
240
- this.user = data?.user ?? null;
241
- this.session = data?.session ?? null;
243
+ // Only update user and session if both are present (valid session)
244
+ if (data?.user && data?.session) {
245
+ this.user = data.user;
246
+ this.session = data.session;
247
+ } else {
248
+ // If no valid session, clear everything
249
+ this.user = null;
250
+ this.session = null;
251
+ }
242
252
  }
243
253
 
244
254
  this.notify();
245
- return { user: data?.user ?? null, session: data?.session ?? null, error };
255
+ // Only return user if we have a valid session
256
+ return {
257
+ user: (data?.user && data?.session) ? data.user : null,
258
+ session: data?.session ?? null,
259
+ error
260
+ };
246
261
  } catch (error) {
247
262
  // Convert regular Error to AuthError if needed
248
263
  const authError = error instanceof AuthError