@jmruthers/pace-core 0.5.76 → 0.5.78

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 (447) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/{RBACService-C4udt_Zp.d.ts → AuthService-Df3IozMG.d.ts} +10 -118
  3. package/dist/{DataTable-ntgmhO2W.d.ts → DataTable-BE0OXZKQ.d.ts} +9 -2
  4. package/dist/{DataTable-4GAVPIEG.js → DataTable-ETGVF4Y5.js} +50 -13
  5. package/dist/{PublicLoadingSpinner-BiNER8F5.d.ts → PublicLoadingSpinner-CnUaz0vG.d.ts} +5 -2
  6. package/dist/{UnifiedAuthProvider-Bj6YCf7c.d.ts → UnifiedAuthProvider-B391Aqum.d.ts} +42 -45
  7. package/dist/{UnifiedAuthProvider-3NKDOSOK.js → UnifiedAuthProvider-P5SOJAQ6.js} +4 -5
  8. package/dist/{api-DDMUKIUD.js → api-KG4A2X7P.js} +9 -3
  9. package/dist/{audit-6TOCAMKO.js → audit-65VNHEV2.js} +2 -2
  10. package/dist/{chunk-K34IM5CT.js → chunk-2OGV6IRV.js} +196 -626
  11. package/dist/chunk-2OGV6IRV.js.map +1 -0
  12. package/dist/{chunk-NTNILOBC.js → chunk-5BO3MI5Y.js} +4 -4
  13. package/dist/{chunk-XLZ7U46Z.js → chunk-CVMVPYAL.js} +9 -60
  14. package/dist/chunk-CVMVPYAL.js.map +1 -0
  15. package/dist/{chunk-URUTVZ7N.js → chunk-FL4ZCQLD.js} +2 -2
  16. package/dist/{chunk-LW7MMEAQ.js → chunk-FT2M4R4F.js} +2 -2
  17. package/dist/{chunk-5BSLGBYI.js → chunk-JCQZ6LA7.js} +2 -8
  18. package/dist/{chunk-5BSLGBYI.js.map → chunk-JCQZ6LA7.js.map} +1 -1
  19. package/dist/{chunk-KHJS6VIA.js → chunk-LRQ6RBJC.js} +157 -112
  20. package/dist/chunk-LRQ6RBJC.js.map +1 -0
  21. package/dist/{chunk-WN6XJWOS.js → chunk-MNJXXD6C.js} +274 -743
  22. package/dist/chunk-MNJXXD6C.js.map +1 -0
  23. package/dist/{chunk-KK73ZB4E.js → chunk-PTR5PMPE.js} +153 -132
  24. package/dist/chunk-PTR5PMPE.js.map +1 -0
  25. package/dist/{chunk-B2WTCLCV.js → chunk-Q7APDV6H.js} +18 -8
  26. package/dist/chunk-Q7APDV6H.js.map +1 -0
  27. package/dist/{chunk-A4FUBC7B.js → chunk-QGVSOUJ2.js} +2 -4
  28. package/dist/{chunk-A4FUBC7B.js.map → chunk-QGVSOUJ2.js.map} +1 -1
  29. package/dist/{chunk-FGMFQSHX.js → chunk-S63MFSY6.js} +500 -551
  30. package/dist/chunk-S63MFSY6.js.map +1 -0
  31. package/dist/{chunk-AFGTSUAD.js → chunk-VSOKOFRF.js} +4 -4
  32. package/dist/chunk-WUXCWRL6.js +20 -0
  33. package/dist/chunk-WUXCWRL6.js.map +1 -0
  34. package/dist/{chunk-Y6TXWPJO.js → chunk-YVVGHRGI.js} +105 -31
  35. package/dist/chunk-YVVGHRGI.js.map +1 -0
  36. package/dist/{chunk-M5IWZRBT.js → chunk-ZMNXIJP4.js} +2187 -981
  37. package/dist/chunk-ZMNXIJP4.js.map +1 -0
  38. package/dist/components.d.ts +6 -6
  39. package/dist/components.js +14 -18
  40. package/dist/components.js.map +1 -1
  41. package/dist/{database-C3Szpi5J.d.ts → database-BXAfr2Y_.d.ts} +18 -0
  42. package/dist/hooks.d.ts +5 -5
  43. package/dist/hooks.js +8 -9
  44. package/dist/hooks.js.map +1 -1
  45. package/dist/index.d.ts +19 -27
  46. package/dist/index.js +21 -29
  47. package/dist/index.js.map +1 -1
  48. package/dist/{organisation-BtshODVF.d.ts → organisation-D6qRDtbF.d.ts} +1 -1
  49. package/dist/providers.d.ts +7 -21
  50. package/dist/providers.js +3 -10
  51. package/dist/rbac/index.d.ts +71 -221
  52. package/dist/rbac/index.js +15 -16
  53. package/dist/{types-CGX9Vyf5.d.ts → types-BDg1mAGG.d.ts} +36 -6
  54. package/dist/types.d.ts +3 -3
  55. package/dist/types.js +61 -18
  56. package/dist/types.js.map +1 -1
  57. package/dist/{unified-CM7T0aTK.d.ts → unified-DQ4VcT7H.d.ts} +1 -1
  58. package/dist/{usePublicRouteParams-B-CumWRc.d.ts → usePublicRouteParams-BlgwXweB.d.ts} +3 -3
  59. package/dist/utils.d.ts +2 -2
  60. package/dist/utils.js +52 -9
  61. package/dist/utils.js.map +1 -1
  62. package/docs/CONTENT_AUDIT_REPORT.md +253 -0
  63. package/docs/DOCUMENTATION_AUDIT.md +172 -0
  64. package/docs/README.md +142 -147
  65. package/docs/STYLE_GUIDE.md +37 -0
  66. package/docs/api/classes/ColumnFactory.md +17 -17
  67. package/docs/api/classes/ErrorBoundary.md +1 -1
  68. package/docs/api/classes/InvalidScopeError.md +4 -4
  69. package/docs/api/classes/MissingUserContextError.md +4 -4
  70. package/docs/api/classes/OrganisationContextRequiredError.md +4 -4
  71. package/docs/api/classes/PermissionDeniedError.md +5 -5
  72. package/docs/api/classes/PublicErrorBoundary.md +1 -1
  73. package/docs/api/classes/RBACAuditManager.md +8 -8
  74. package/docs/api/classes/RBACCache.md +35 -5
  75. package/docs/api/classes/RBACEngine.md +49 -20
  76. package/docs/api/classes/RBACError.md +4 -4
  77. package/docs/api/classes/RBACNotInitializedError.md +4 -4
  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 +4 -4
  82. package/docs/api/interfaces/ButtonProps.md +1 -1
  83. package/docs/api/interfaces/CardProps.md +1 -1
  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/DataRecord.md +11 -0
  88. package/docs/api/interfaces/DataTableAction.md +65 -29
  89. package/docs/api/interfaces/DataTableColumn.md +36 -23
  90. package/docs/api/interfaces/DataTableProps.md +80 -38
  91. package/docs/api/interfaces/DataTableToolbarButton.md +7 -7
  92. package/docs/api/interfaces/EmptyStateConfig.md +5 -5
  93. package/docs/api/interfaces/EnhancedNavigationMenuProps.md +1 -1
  94. package/docs/api/interfaces/EventLogoProps.md +1 -1
  95. package/docs/api/interfaces/FileDisplayProps.md +1 -1
  96. package/docs/api/interfaces/FileMetadata.md +1 -1
  97. package/docs/api/interfaces/FileReference.md +1 -1
  98. package/docs/api/interfaces/FileSizeLimits.md +1 -1
  99. package/docs/api/interfaces/FileUploadOptions.md +1 -1
  100. package/docs/api/interfaces/FileUploadProps.md +1 -1
  101. package/docs/api/interfaces/FooterProps.md +1 -1
  102. package/docs/api/interfaces/InactivityWarningModalProps.md +1 -1
  103. package/docs/api/interfaces/InputProps.md +1 -1
  104. package/docs/api/interfaces/LabelProps.md +1 -1
  105. package/docs/api/interfaces/LoginFormProps.md +1 -1
  106. package/docs/api/interfaces/NavigationAccessRecord.md +11 -11
  107. package/docs/api/interfaces/NavigationContextType.md +9 -9
  108. package/docs/api/interfaces/NavigationGuardProps.md +1 -1
  109. package/docs/api/interfaces/NavigationItem.md +1 -1
  110. package/docs/api/interfaces/NavigationMenuProps.md +1 -1
  111. package/docs/api/interfaces/NavigationProviderProps.md +7 -7
  112. package/docs/api/interfaces/Organisation.md +1 -1
  113. package/docs/api/interfaces/OrganisationContextType.md +1 -1
  114. package/docs/api/interfaces/OrganisationMembership.md +1 -1
  115. package/docs/api/interfaces/OrganisationProviderProps.md +1 -1
  116. package/docs/api/interfaces/OrganisationSecurityError.md +1 -1
  117. package/docs/api/interfaces/PaceAppLayoutProps.md +1 -1
  118. package/docs/api/interfaces/PaceLoginPageProps.md +16 -3
  119. package/docs/api/interfaces/PageAccessRecord.md +1 -1
  120. package/docs/api/interfaces/PagePermissionContextType.md +1 -1
  121. package/docs/api/interfaces/PagePermissionGuardProps.md +2 -2
  122. package/docs/api/interfaces/PagePermissionProviderProps.md +1 -1
  123. package/docs/api/interfaces/PaletteData.md +1 -1
  124. package/docs/api/interfaces/PermissionEnforcerProps.md +4 -4
  125. package/docs/api/interfaces/PublicErrorBoundaryProps.md +1 -1
  126. package/docs/api/interfaces/PublicErrorBoundaryState.md +1 -1
  127. package/docs/api/interfaces/PublicLoadingSpinnerProps.md +1 -1
  128. package/docs/api/interfaces/PublicPageFooterProps.md +1 -1
  129. package/docs/api/interfaces/PublicPageHeaderProps.md +1 -1
  130. package/docs/api/interfaces/PublicPageLayoutProps.md +1 -1
  131. package/docs/api/interfaces/RBACConfig.md +1 -1
  132. package/docs/api/interfaces/RBACLogger.md +1 -1
  133. package/docs/api/interfaces/RoleBasedRouterContextType.md +1 -1
  134. package/docs/api/interfaces/RoleBasedRouterProps.md +1 -1
  135. package/docs/api/interfaces/RouteAccessRecord.md +2 -2
  136. package/docs/api/interfaces/RouteConfig.md +2 -2
  137. package/docs/api/interfaces/SecureDataContextType.md +1 -1
  138. package/docs/api/interfaces/SecureDataProviderProps.md +1 -1
  139. package/docs/api/interfaces/StorageConfig.md +1 -1
  140. package/docs/api/interfaces/StorageFileInfo.md +1 -1
  141. package/docs/api/interfaces/StorageFileMetadata.md +1 -1
  142. package/docs/api/interfaces/StorageListOptions.md +1 -1
  143. package/docs/api/interfaces/StorageListResult.md +1 -1
  144. package/docs/api/interfaces/StorageUploadOptions.md +1 -1
  145. package/docs/api/interfaces/StorageUploadResult.md +1 -1
  146. package/docs/api/interfaces/StorageUrlOptions.md +1 -1
  147. package/docs/api/interfaces/StyleImport.md +1 -1
  148. package/docs/api/interfaces/SwitchProps.md +1 -1
  149. package/docs/api/interfaces/ToastActionElement.md +1 -1
  150. package/docs/api/interfaces/ToastProps.md +1 -1
  151. package/docs/api/interfaces/UnifiedAuthContextType.md +94 -521
  152. package/docs/api/interfaces/UnifiedAuthProviderProps.md +16 -16
  153. package/docs/api/interfaces/UseInactivityTrackerOptions.md +1 -1
  154. package/docs/api/interfaces/UseInactivityTrackerReturn.md +1 -1
  155. package/docs/api/interfaces/UsePublicEventLogoOptions.md +1 -1
  156. package/docs/api/interfaces/UsePublicEventLogoReturn.md +1 -1
  157. package/docs/api/interfaces/UsePublicEventOptions.md +1 -1
  158. package/docs/api/interfaces/UsePublicEventReturn.md +1 -1
  159. package/docs/api/interfaces/UsePublicRouteParamsReturn.md +1 -1
  160. package/docs/api/interfaces/UseResolvedScopeOptions.md +1 -1
  161. package/docs/api/interfaces/UseResolvedScopeReturn.md +1 -1
  162. package/docs/api/interfaces/UserEventAccess.md +11 -11
  163. package/docs/api/interfaces/UserMenuProps.md +1 -1
  164. package/docs/api/interfaces/UserProfile.md +1 -1
  165. package/docs/api/modules.md +251 -269
  166. package/docs/api-reference/components.md +193 -0
  167. package/docs/api-reference/hooks.md +265 -0
  168. package/docs/api-reference/providers.md +6 -0
  169. package/docs/api-reference/types.md +6 -0
  170. package/docs/api-reference/utilities.md +207 -0
  171. package/docs/architecture/README.md +6 -0
  172. package/docs/{database-schema-requirements.md → architecture/database-schema-requirements.md} +6 -0
  173. package/docs/architecture/rbac-security-architecture.md +258 -0
  174. package/docs/architecture/services.md +9 -1
  175. package/docs/best-practices/README.md +6 -0
  176. package/docs/best-practices/accessibility.md +6 -0
  177. package/docs/{common-patterns.md → best-practices/common-patterns.md} +6 -0
  178. package/docs/best-practices/deployment.md +6 -0
  179. package/docs/best-practices/performance.md +475 -2
  180. package/docs/best-practices/security.md +6 -0
  181. package/docs/best-practices/testing.md +6 -0
  182. package/docs/core-concepts/authentication.md +6 -0
  183. package/docs/core-concepts/events.md +6 -0
  184. package/docs/core-concepts/organisations.md +6 -0
  185. package/docs/core-concepts/permissions.md +6 -0
  186. package/docs/core-concepts/rbac-system.md +8 -0
  187. package/docs/documentation-index.md +121 -182
  188. package/docs/{consuming-app-vite-config.md → getting-started/consuming-app-vite-config.md} +6 -0
  189. package/docs/getting-started/documentation-index.md +40 -0
  190. package/docs/getting-started/examples/README.md +878 -35
  191. package/docs/{faq.md → getting-started/faq.md} +7 -1
  192. package/docs/getting-started/installation-guide.md +6 -0
  193. package/docs/{quick-reference.md → getting-started/quick-reference.md} +6 -0
  194. package/docs/implementation-guides/app-layout.md +6 -0
  195. package/docs/implementation-guides/authentication.md +1021 -0
  196. package/docs/implementation-guides/component-styling.md +6 -0
  197. package/docs/implementation-guides/data-tables.md +1264 -2076
  198. package/docs/implementation-guides/dynamic-colors.md +6 -0
  199. package/docs/implementation-guides/event-theming-summary.md +6 -0
  200. package/docs/{file-reference-system.md → implementation-guides/file-reference-system.md} +6 -0
  201. package/docs/implementation-guides/file-upload-storage.md +6 -0
  202. package/docs/implementation-guides/forms.md +6 -0
  203. package/docs/implementation-guides/inactivity-tracking.md +6 -0
  204. package/docs/implementation-guides/navigation.md +6 -0
  205. package/docs/implementation-guides/organisation-security.md +6 -0
  206. package/docs/implementation-guides/permission-enforcement.md +6 -0
  207. package/docs/implementation-guides/public-pages-advanced.md +6 -0
  208. package/docs/implementation-guides/public-pages.md +6 -0
  209. package/docs/migration/MIGRATION_GUIDE.md +827 -351
  210. package/docs/migration/README.md +7 -1
  211. package/docs/migration/organisation-context-timing-fix.md +6 -0
  212. package/docs/migration/rbac-migration.md +44 -1
  213. package/docs/migration/service-architecture.md +6 -0
  214. package/docs/migration/v0.4.15-tailwind-scanning.md +6 -0
  215. package/docs/migration/v0.4.16-css-first-approach.md +6 -0
  216. package/docs/migration/v0.4.17-source-path-fix.md +6 -0
  217. package/docs/rbac/README-rbac-rls-integration.md +6 -0
  218. package/docs/rbac/README.md +6 -0
  219. package/docs/rbac/advanced-patterns.md +6 -0
  220. package/docs/rbac/api-reference.md +7 -1
  221. package/docs/rbac/breaking-changes-v3.md +222 -0
  222. package/docs/rbac/examples/rbac-rls-integration-example.md +6 -0
  223. package/docs/rbac/examples.md +6 -0
  224. package/docs/rbac/getting-started.md +6 -0
  225. package/docs/rbac/migration-guide.md +260 -0
  226. package/docs/rbac/quick-start.md +70 -13
  227. package/docs/rbac/rbac-rls-integration.md +6 -0
  228. package/docs/rbac/super-admin-guide.md +6 -0
  229. package/docs/rbac/troubleshooting.md +6 -0
  230. package/docs/security/README.md +6 -0
  231. package/docs/security/checklist.md +6 -0
  232. package/docs/styles/README.md +7 -1
  233. package/docs/{usage.md → styles/usage.md} +6 -0
  234. package/docs/testing/README.md +6 -0
  235. package/docs/{visual-testing.md → testing/visual-testing.md} +6 -0
  236. package/docs/troubleshooting/README.md +387 -5
  237. package/docs/troubleshooting/cake-page-permission-guard-issue-summary.md +6 -0
  238. package/docs/troubleshooting/common-issues.md +6 -0
  239. package/docs/troubleshooting/database-view-compatibility.md +6 -0
  240. package/docs/troubleshooting/organisation-context-setup.md +6 -0
  241. package/docs/troubleshooting/react-hooks-issue-analysis.md +6 -0
  242. package/docs/troubleshooting/styling-issues.md +6 -0
  243. package/docs/troubleshooting/tailwind-content-scanning.md +6 -0
  244. package/package.json +1 -1
  245. package/src/__tests__/helpers/__tests__/test-providers.test.tsx +2 -1
  246. package/src/__tests__/helpers/test-providers.tsx +3 -53
  247. package/src/components/DataTable/DataTable.test.tsx +319 -0
  248. package/src/components/DataTable/DataTable.tsx +32 -11
  249. package/src/components/DataTable/__tests__/{DataTable.comprehensive.test.tsx → DataTable.comprehensive.test.tsx.skip} +6 -4
  250. package/src/components/DataTable/__tests__/{DataTable.test.tsx → DataTable.test.tsx.skip} +6 -4
  251. package/src/components/DataTable/__tests__/DataTableCore.test.tsx +31 -9
  252. package/src/components/DataTable/__tests__/a11y.basic.test.tsx +601 -0
  253. package/src/components/DataTable/__tests__/keyboard.test.tsx +615 -0
  254. package/src/components/DataTable/__tests__/pagination.modes.test.tsx +639 -0
  255. package/src/components/DataTable/__tests__/ssr.strict-mode.test.tsx.skip +330 -0
  256. package/src/components/DataTable/components/AccessDeniedPage.tsx +2 -2
  257. package/src/components/DataTable/components/ActionButtons.tsx +88 -104
  258. package/src/components/DataTable/components/DataTableCore.tsx +309 -337
  259. package/src/components/DataTable/components/DataTableErrorBoundary.tsx +4 -2
  260. package/src/components/DataTable/components/DataTableModals.tsx +22 -1
  261. package/src/components/DataTable/components/EditableRow.tsx +69 -84
  262. package/src/components/DataTable/components/EmptyState.tsx +5 -1
  263. package/src/components/DataTable/components/ImportModal.tsx +65 -36
  264. package/src/components/DataTable/components/PaginationControls.tsx +40 -100
  265. package/src/components/DataTable/components/UnifiedTableBody.tsx +125 -148
  266. package/src/components/DataTable/context/DataTableContext.tsx +1 -1
  267. package/src/components/DataTable/core/ColumnFactory.ts +5 -0
  268. package/src/components/DataTable/examples/HierarchicalActionsExample.tsx +12 -10
  269. package/src/components/DataTable/examples/HierarchicalExample.tsx +1 -1
  270. package/src/components/DataTable/examples/InitialPageSizeExample.tsx +1 -0
  271. package/src/components/DataTable/examples/PerformanceExample.tsx +1 -0
  272. package/src/components/DataTable/hooks/__tests__/useColumnOrderPersistence.test.ts +1 -5
  273. package/src/components/DataTable/hooks/__tests__/useColumnVisibilityPersistence.test.ts +167 -0
  274. package/src/components/DataTable/hooks/index.ts +7 -0
  275. package/src/components/DataTable/hooks/useColumnOrderPersistence.ts +32 -15
  276. package/src/components/DataTable/hooks/useColumnVisibilityPersistence.ts +102 -0
  277. package/src/components/DataTable/hooks/useDataTableConfiguration.ts +89 -0
  278. package/src/components/DataTable/hooks/useDataTableDataPipeline.ts +117 -0
  279. package/src/components/DataTable/hooks/useDataTablePermissions.ts +71 -27
  280. package/src/components/DataTable/hooks/useDataTableState.ts +39 -11
  281. package/src/components/DataTable/hooks/useEffectiveColumnOrder.ts +33 -0
  282. package/src/components/DataTable/hooks/useHierarchicalState.ts +15 -1
  283. package/src/components/DataTable/hooks/useKeyboardNavigation.ts +447 -0
  284. package/src/components/DataTable/hooks/useServerSideDataEffect.ts +94 -0
  285. package/src/components/DataTable/hooks/useTableColumns.ts +10 -7
  286. package/src/components/DataTable/hooks/useTableHandlers.ts +174 -0
  287. package/src/components/DataTable/index.ts +12 -3
  288. package/src/components/DataTable/types.ts +129 -9
  289. package/src/components/DataTable/utils/__tests__/exportUtils.test.ts +159 -22
  290. package/src/components/DataTable/utils/__tests__/flexibleImport.test.ts +111 -0
  291. package/src/components/DataTable/utils/__tests__/rowUtils.test.ts +15 -29
  292. package/src/components/DataTable/utils/a11yUtils.ts +244 -0
  293. package/src/components/DataTable/utils/debugTools.ts +609 -0
  294. package/src/components/DataTable/utils/exportUtils.ts +114 -16
  295. package/src/components/DataTable/utils/flexibleImport.ts +202 -32
  296. package/src/components/DataTable/utils/hierarchicalUtils.ts +1 -1
  297. package/src/components/DataTable/utils/index.ts +2 -0
  298. package/src/components/DataTable/utils/paginationUtils.ts +350 -0
  299. package/src/components/DataTable/utils/rowUtils.ts +6 -5
  300. package/src/components/NavigationMenu/NavigationMenu.test.tsx +19 -24
  301. package/src/components/NavigationMenu/NavigationMenu.tsx +19 -8
  302. package/src/components/PaceAppLayout/__tests__/PaceAppLayout.security.test.tsx +1 -23
  303. package/src/components/PaceLoginPage/PaceLoginPage.test.tsx +56 -6
  304. package/src/components/PaceLoginPage/PaceLoginPage.tsx +137 -13
  305. package/src/components/PublicLayout/__tests__/PublicPageHeader.test.tsx +1 -1
  306. package/src/components/Select/Select.tsx +1 -0
  307. package/src/components/examples/PermissionExample.tsx +173 -0
  308. package/src/examples/CorrectPublicPageImplementation.tsx +301 -0
  309. package/src/examples/PublicEventPage.tsx +274 -0
  310. package/src/examples/PublicPageApp.tsx +308 -0
  311. package/src/examples/PublicPageUsageExample.tsx +216 -0
  312. package/src/hooks/__tests__/useOrganisationPermissions.unit.test.tsx +12 -1
  313. package/src/hooks/__tests__/useOrganisationSecurity.unit.test.tsx +129 -17
  314. package/src/hooks/__tests__/useRBAC.unit.test.ts +151 -846
  315. package/src/hooks/useOrganisationPermissions.test.ts +42 -18
  316. package/src/hooks/useOrganisationPermissions.ts +12 -6
  317. package/src/hooks/useOrganisationSecurity.test.ts +138 -85
  318. package/src/hooks/useOrganisationSecurity.ts +41 -10
  319. package/src/index.ts +0 -1
  320. package/src/providers/AuthProvider.simplified.tsx +880 -0
  321. package/src/providers/UnifiedAuthProvider.test.simple.tsx +8 -8
  322. package/src/providers/__tests__/UnifiedAuthProvider.test.tsx +29 -19
  323. package/src/providers/index.ts +0 -1
  324. package/src/providers/services/EventServiceProvider.tsx +19 -15
  325. package/src/providers/services/InactivityServiceProvider.tsx +19 -15
  326. package/src/providers/services/OrganisationServiceProvider.tsx +19 -15
  327. package/src/providers/services/UnifiedAuthProvider.tsx +156 -127
  328. package/src/providers/services/__tests__/AuthServiceProvider.integration.test.tsx +1 -1
  329. package/src/providers/services/__tests__/UnifiedAuthProvider.integration.test.tsx +3 -3
  330. package/src/rbac/README.md +1 -1
  331. package/src/rbac/__tests__/adapters.comprehensive.test.tsx +25 -27
  332. package/src/rbac/__tests__/auth-rbac-security.integration.test.tsx +313 -0
  333. package/src/rbac/__tests__/engine.comprehensive.test.ts +114 -348
  334. package/src/rbac/__tests__/rbac-engine-core-logic.test.ts +28 -110
  335. package/src/rbac/__tests__/rbac-engine-simplified.test.ts +33 -85
  336. package/src/rbac/__tests__/scenarios.user-role.test.tsx +2 -2
  337. package/src/rbac/adapters.tsx +26 -69
  338. package/src/rbac/api.test.ts +90 -27
  339. package/src/rbac/api.ts +61 -10
  340. package/src/rbac/audit.test.ts +33 -38
  341. package/src/rbac/audit.ts +21 -6
  342. package/src/rbac/cache.ts +33 -1
  343. package/src/rbac/components/NavigationGuard.tsx +11 -11
  344. package/src/rbac/components/NavigationProvider.test.tsx +11 -5
  345. package/src/rbac/components/NavigationProvider.tsx +37 -13
  346. package/src/rbac/components/PagePermissionGuard.tsx +111 -50
  347. package/src/rbac/components/PagePermissionProvider.tsx +5 -5
  348. package/src/rbac/components/PermissionEnforcer.tsx +11 -11
  349. package/src/rbac/components/RoleBasedRouter.tsx +5 -5
  350. package/src/rbac/components/SecureDataProvider.tsx +5 -5
  351. package/src/rbac/components/__tests__/NavigationGuard.test.tsx +8 -8
  352. package/src/rbac/components/__tests__/PagePermissionGuard.test.tsx +14 -14
  353. package/src/rbac/components/__tests__/PermissionEnforcer.test.tsx +12 -12
  354. package/src/rbac/components/__tests__/RoleBasedRouter.test.tsx +6 -6
  355. package/src/rbac/engine.test.simple.ts +19 -13
  356. package/src/rbac/engine.test.ts +1 -0
  357. package/src/rbac/engine.ts +330 -766
  358. package/src/rbac/errors.ts +156 -0
  359. package/src/rbac/hooks/usePermissions.ts +32 -10
  360. package/src/rbac/hooks/useRBAC.test.ts +126 -512
  361. package/src/rbac/hooks/useRBAC.ts +147 -193
  362. package/src/rbac/hooks/useResolvedScope.ts +12 -0
  363. package/src/rbac/index.ts +7 -4
  364. package/src/rbac/security.ts +109 -18
  365. package/src/rbac/types.ts +12 -1
  366. package/src/services/AuthService.ts +2 -15
  367. package/src/services/EventService.ts +43 -46
  368. package/src/services/OrganisationService.ts +51 -31
  369. package/src/services/__tests__/AuthService.test.ts +1 -1
  370. package/src/services/__tests__/EventService.test.ts +1 -1
  371. package/src/services/__tests__/OrganisationService.test.ts +1 -1
  372. package/src/services/base/BaseService.ts +8 -0
  373. package/src/styles/base.css +208 -0
  374. package/src/styles/semantic.css +24 -0
  375. package/src/types/database.generated.ts +7347 -0
  376. package/src/types/database.ts +20 -0
  377. package/src/utils/logger.ts +179 -0
  378. package/src/utils/organisationContext.ts +11 -4
  379. package/src/utils/storage/__tests__/helpers.unit.test.ts +6 -2
  380. package/dist/appNameResolver-UURKN7NF.js +0 -22
  381. package/dist/audit-6TOCAMKO.js.map +0 -1
  382. package/dist/chunk-B2WTCLCV.js.map +0 -1
  383. package/dist/chunk-FGMFQSHX.js.map +0 -1
  384. package/dist/chunk-K34IM5CT.js.map +0 -1
  385. package/dist/chunk-KHJS6VIA.js.map +0 -1
  386. package/dist/chunk-KK73ZB4E.js.map +0 -1
  387. package/dist/chunk-M5IWZRBT.js.map +0 -1
  388. package/dist/chunk-ULBI5JGB.js +0 -109
  389. package/dist/chunk-ULBI5JGB.js.map +0 -1
  390. package/dist/chunk-WN6XJWOS.js.map +0 -1
  391. package/dist/chunk-XLZ7U46Z.js.map +0 -1
  392. package/dist/chunk-Y6TXWPJO.js.map +0 -1
  393. package/docs/DOCUMENTATION_CHECKLIST.md +0 -281
  394. package/docs/TERMINOLOGY.md +0 -231
  395. package/docs/api/interfaces/RBACContextType.md +0 -468
  396. package/docs/api/interfaces/RBACProviderProps.md +0 -107
  397. package/docs/best-practices/performance-expansion.md +0 -473
  398. package/docs/breaking-changes.md +0 -179
  399. package/docs/consuming-app-example.md +0 -290
  400. package/docs/documentation-templates.md +0 -539
  401. package/docs/examples/navigation-menu-auth-fix.md +0 -344
  402. package/docs/getting-started/examples/basic-auth-app.md +0 -520
  403. package/docs/getting-started/examples/full-featured-app.md +0 -616
  404. package/docs/getting-started/quick-start.md +0 -376
  405. package/docs/implementation-guides/datatable-filtering.md +0 -313
  406. package/docs/implementation-guides/datatable-rbac-usage.md +0 -317
  407. package/docs/implementation-guides/hierarchical-datatable.md +0 -850
  408. package/docs/implementation-guides/large-datasets.md +0 -281
  409. package/docs/implementation-guides/performance.md +0 -403
  410. package/docs/migration/quick-migration-guide.md +0 -320
  411. package/docs/migration-guide.md +0 -193
  412. package/docs/migration-guides/unified-auth-provider-mandatory-timeouts.md +0 -226
  413. package/docs/performance/README.md +0 -551
  414. package/docs/style-guide.md +0 -964
  415. package/docs/troubleshooting/authentication-issues.md +0 -334
  416. package/docs/troubleshooting/debugging.md +0 -1117
  417. package/docs/troubleshooting/migration.md +0 -918
  418. package/src/__tests__/hooks/usePermissions.test.ts +0 -261
  419. package/src/components/PaceAppLayout/__tests__/PaceAppLayout.rbac.test.tsx +0 -574
  420. package/src/hooks/__tests__/ServiceHooks.test.tsx +0 -613
  421. package/src/hooks/services/__tests__/useServiceHooks.test.tsx +0 -137
  422. package/src/hooks/services/usePermissions.ts +0 -70
  423. package/src/hooks/services/useRBACService.ts +0 -30
  424. package/src/hooks/usePermissionCheck.ts +0 -150
  425. package/src/providers/__tests__/ServiceProviders.test.tsx +0 -477
  426. package/src/providers/services/RBACServiceProvider.tsx +0 -79
  427. package/src/rbac/__tests__/integration.authflow.test.tsx +0 -119
  428. package/src/rbac/__tests__/integration.navigation.test.tsx +0 -69
  429. package/src/rbac/__tests__/integration.securedata.test.tsx +0 -92
  430. package/src/rbac/__tests__/integration.smoke.test.tsx +0 -73
  431. package/src/rbac/providers/RBACProvider.tsx +0 -645
  432. package/src/rbac/providers/__tests__/RBACProvider.integration.test.tsx +0 -688
  433. package/src/rbac/providers/__tests__/RBACProvider.test.tsx +0 -1186
  434. package/src/rbac/providers/index.ts +0 -11
  435. package/src/services/RBACService.ts +0 -522
  436. package/src/services/__tests__/RBACService.test.ts +0 -492
  437. package/src/services/interfaces/IRBACService.ts +0 -62
  438. package/src/utils/appNameResolver.test 2.ts +0 -494
  439. /package/dist/{DataTable-4GAVPIEG.js.map → DataTable-ETGVF4Y5.js.map} +0 -0
  440. /package/dist/{UnifiedAuthProvider-3NKDOSOK.js.map → UnifiedAuthProvider-P5SOJAQ6.js.map} +0 -0
  441. /package/dist/{api-DDMUKIUD.js.map → api-KG4A2X7P.js.map} +0 -0
  442. /package/dist/{appNameResolver-UURKN7NF.js.map → audit-65VNHEV2.js.map} +0 -0
  443. /package/dist/{chunk-NTNILOBC.js.map → chunk-5BO3MI5Y.js.map} +0 -0
  444. /package/dist/{chunk-URUTVZ7N.js.map → chunk-FL4ZCQLD.js.map} +0 -0
  445. /package/dist/{chunk-LW7MMEAQ.js.map → chunk-FT2M4R4F.js.map} +0 -0
  446. /package/dist/{chunk-AFGTSUAD.js.map → chunk-VSOKOFRF.js.map} +0 -0
  447. /package/docs/{app.css.example → styles/app.css.example} +0 -0
@@ -0,0 +1,609 @@
1
+ /**
2
+ * @file Advanced Debugging Tools for DataTable Performance
3
+ * @package @jmruthers/pace-core
4
+ * @module Components/DataTable/Utils/DebugTools
5
+ * @since 0.3.0
6
+ */
7
+
8
+ import React from 'react';
9
+ import type {
10
+ DataRecord,
11
+ PaginationMode,
12
+ ServerSideParams
13
+ } from '../types';
14
+ import { createLogger } from '../../../utils/logger';
15
+
16
+ /**
17
+ * Debug levels for controlling verbosity
18
+ */
19
+ export enum DebugLevel {
20
+ NONE = 0,
21
+ ERROR = 1,
22
+ WARN = 2,
23
+ INFO = 3,
24
+ DEBUG = 4,
25
+ TRACE = 5,
26
+ }
27
+
28
+ /**
29
+ * Performance debug configuration
30
+ */
31
+ export interface DebugConfig {
32
+ enabled: boolean;
33
+ level: DebugLevel;
34
+ logToConsole: boolean;
35
+ logToStorage: boolean;
36
+ maxLogEntries: number;
37
+ enablePerformanceMarks: boolean;
38
+ enableMemoryTracking: boolean;
39
+ enableRenderTracking: boolean;
40
+ enableNetworkTracking: boolean;
41
+ }
42
+
43
+ /**
44
+ * Default debug configuration
45
+ */
46
+ export const DEFAULT_DEBUG_CONFIG: DebugConfig = {
47
+ enabled: import.meta.env.MODE === 'development',
48
+ level: DebugLevel.INFO,
49
+ logToConsole: true,
50
+ logToStorage: false,
51
+ maxLogEntries: 1000,
52
+ enablePerformanceMarks: true,
53
+ enableMemoryTracking: true,
54
+ enableRenderTracking: true,
55
+ enableNetworkTracking: true,
56
+ };
57
+
58
+ /**
59
+ * Debug log entry interface
60
+ */
61
+ export interface DebugLogEntry {
62
+ timestamp: number;
63
+ level: DebugLevel;
64
+ category: string;
65
+ message: string;
66
+ data?: unknown;
67
+ stackTrace?: string;
68
+ performanceMarks?: string[];
69
+ memoryUsage?: number;
70
+ }
71
+
72
+ /**
73
+ * Performance timeline entry
74
+ */
75
+ export interface PerformanceTimelineEntry {
76
+ id: string;
77
+ operation: string;
78
+ startTime: number;
79
+ endTime?: number;
80
+ duration?: number;
81
+ metadata?: Record<string, unknown>;
82
+ children?: PerformanceTimelineEntry[];
83
+ }
84
+
85
+ /**
86
+ * Memory snapshot
87
+ */
88
+ export interface MemorySnapshot {
89
+ timestamp: number;
90
+ heapUsed: number;
91
+ heapTotal: number;
92
+ external: number;
93
+ arrayBuffers?: number;
94
+ }
95
+
96
+ /**
97
+ * Render performance data
98
+ */
99
+ export interface RenderPerformanceData {
100
+ componentName: string;
101
+ renderCount: number;
102
+ totalRenderTime: number;
103
+ averageRenderTime: number;
104
+ lastRenderTime: number;
105
+ propsChanges: number;
106
+ }
107
+
108
+ /**
109
+ * Advanced DataTable debugger
110
+ */
111
+ export class DataTableDebugger {
112
+ private config: DebugConfig
113
+ private logger = createLogger('DataTableDebugger');
114
+ private logEntries: DebugLogEntry[] = [];
115
+ private performanceTimeline: Map<string, PerformanceTimelineEntry> = new Map();
116
+ private memorySnapshots: MemorySnapshot[] = [];
117
+ private renderPerformance: Map<string, RenderPerformanceData> = new Map();
118
+ private activeOperations: Set<string> = new Set();
119
+
120
+ constructor(config: Partial<DebugConfig> = {}) {
121
+ this.config = { ...DEFAULT_DEBUG_CONFIG, ...config };
122
+ }
123
+
124
+ /**
125
+ * Log a debug message
126
+ */
127
+ log(
128
+ level: DebugLevel,
129
+ category: string,
130
+ message: string,
131
+ data?: unknown,
132
+ includeStackTrace: boolean = false
133
+ ): void {
134
+ if (!this.config.enabled || level > this.config.level) {
135
+ return;
136
+ }
137
+
138
+ const entry: DebugLogEntry = {
139
+ timestamp: Date.now(),
140
+ level,
141
+ category,
142
+ message,
143
+ data,
144
+ stackTrace: includeStackTrace ? new Error().stack : undefined,
145
+ memoryUsage: this.config.enableMemoryTracking ? this.getCurrentMemoryUsage() : undefined,
146
+ };
147
+
148
+ this.logEntries.push(entry);
149
+
150
+ // Maintain log size
151
+ if (this.logEntries.length > this.config.maxLogEntries) {
152
+ this.logEntries.shift();
153
+ }
154
+
155
+ // Console logging
156
+ if (this.config.logToConsole) {
157
+ this.logToConsole(entry);
158
+ }
159
+
160
+ // Storage logging
161
+ if (this.config.logToStorage) {
162
+ this.logToStorage(entry);
163
+ }
164
+ }
165
+
166
+ /**
167
+ * Start performance tracking for an operation
168
+ */
169
+ startOperation(operationId: string, operation: string, metadata?: Record<string, unknown>): void {
170
+ if (!this.config.enabled || !this.config.enableRenderTracking) return;
171
+
172
+ const entry: PerformanceTimelineEntry = {
173
+ id: operationId,
174
+ operation,
175
+ startTime: performance.now(),
176
+ metadata,
177
+ children: [],
178
+ };
179
+
180
+ this.performanceTimeline.set(operationId, entry);
181
+ this.activeOperations.add(operationId);
182
+
183
+ // Performance marks
184
+ if (this.config.enablePerformanceMarks) {
185
+ performance.mark(`${operationId}_start`);
186
+ }
187
+
188
+ this.log(DebugLevel.DEBUG, 'Performance', `Started operation: ${operation}`, { operationId, metadata });
189
+ }
190
+
191
+ /**
192
+ * End performance tracking for an operation
193
+ */
194
+ endOperation(operationId: string, metadata?: Record<string, unknown>): void {
195
+ if (!this.config.enabled || !this.config.enableRenderTracking) return;
196
+
197
+ const entry = this.performanceTimeline.get(operationId);
198
+ if (!entry) {
199
+ this.log(DebugLevel.WARN, 'Performance', `Operation not found: ${operationId}`);
200
+ return;
201
+ }
202
+
203
+ entry.endTime = performance.now();
204
+ entry.duration = entry.endTime - entry.startTime;
205
+ if (metadata) {
206
+ entry.metadata = { ...entry.metadata, ...metadata };
207
+ }
208
+
209
+ this.activeOperations.delete(operationId);
210
+
211
+ // Performance marks and measures
212
+ if (this.config.enablePerformanceMarks) {
213
+ performance.mark(`${operationId}_end`);
214
+ performance.measure(operationId, `${operationId}_start`, `${operationId}_end`);
215
+ }
216
+
217
+ this.log(DebugLevel.DEBUG, 'Performance', `Completed operation: ${entry.operation}`, {
218
+ operationId,
219
+ duration: entry.duration,
220
+ metadata: entry.metadata,
221
+ });
222
+ }
223
+
224
+ /**
225
+ * Track render performance
226
+ */
227
+ trackRender(componentName: string, renderTime: number, propsChanged: boolean = false): void {
228
+ if (!this.config.enabled || !this.config.enableRenderTracking) return;
229
+
230
+ const existing = this.renderPerformance.get(componentName) || {
231
+ componentName,
232
+ renderCount: 0,
233
+ totalRenderTime: 0,
234
+ averageRenderTime: 0,
235
+ lastRenderTime: 0,
236
+ propsChanges: 0,
237
+ };
238
+
239
+ existing.renderCount++;
240
+ existing.totalRenderTime += renderTime;
241
+ existing.averageRenderTime = existing.totalRenderTime / existing.renderCount;
242
+ existing.lastRenderTime = renderTime;
243
+
244
+ if (propsChanged) {
245
+ existing.propsChanges++;
246
+ }
247
+
248
+ this.renderPerformance.set(componentName, existing);
249
+
250
+ this.log(DebugLevel.TRACE, 'Render', `Component rendered: ${componentName}`, {
251
+ renderTime,
252
+ propsChanged,
253
+ averageRenderTime: existing.averageRenderTime,
254
+ });
255
+ }
256
+
257
+ /**
258
+ * Take a memory snapshot
259
+ */
260
+ takeMemorySnapshot(label?: string): MemorySnapshot {
261
+ const snapshot: MemorySnapshot = {
262
+ timestamp: Date.now(),
263
+ heapUsed: 0,
264
+ heapTotal: 0,
265
+ external: 0,
266
+ };
267
+
268
+ if ('memory' in performance) {
269
+ interface PerformanceMemory {
270
+ usedJSHeapSize: number;
271
+ totalJSHeapSize: number;
272
+ jsHeapSizeLimit: number;
273
+ }
274
+ const memory = (performance as unknown as { memory: PerformanceMemory }).memory;
275
+ snapshot.heapUsed = memory.usedJSHeapSize;
276
+ snapshot.heapTotal = memory.totalJSHeapSize;
277
+ snapshot.external = memory.usedJSHeapSize;
278
+ }
279
+
280
+ this.memorySnapshots.push(snapshot);
281
+
282
+ // Keep last 100 snapshots
283
+ if (this.memorySnapshots.length > 100) {
284
+ this.memorySnapshots.shift();
285
+ }
286
+
287
+ this.log(DebugLevel.DEBUG, 'Memory', `Memory snapshot${label ? ` (${label})` : ''}`, snapshot);
288
+
289
+ return snapshot;
290
+ }
291
+
292
+ /**
293
+ * Analyze performance bottlenecks
294
+ */
295
+ analyzePerformance(): {
296
+ slowestOperations: PerformanceTimelineEntry[];
297
+ memoryTrends: { increasing: boolean; trend: number };
298
+ renderHotspots: RenderPerformanceData[];
299
+ recommendations: string[];
300
+ } {
301
+ const timeline = Array.from(this.performanceTimeline.values())
302
+ .filter(entry => entry.duration !== undefined)
303
+ .sort((a, b) => (b.duration || 0) - (a.duration || 0));
304
+
305
+ const slowestOperations = timeline.slice(0, 10);
306
+
307
+ // Memory trend analysis
308
+ const recentSnapshots = this.memorySnapshots.slice(-10);
309
+ const memoryTrend = recentSnapshots.length > 1
310
+ ? (recentSnapshots[recentSnapshots.length - 1].heapUsed - recentSnapshots[0].heapUsed) / recentSnapshots.length
311
+ : 0;
312
+
313
+ // Render hotspots
314
+ const renderHotspots = Array.from(this.renderPerformance.values())
315
+ .sort((a, b) => b.averageRenderTime - a.averageRenderTime)
316
+ .slice(0, 5);
317
+
318
+ // Generate recommendations
319
+ const recommendations: string[] = [];
320
+
321
+ if (slowestOperations.length > 0 && slowestOperations[0].duration! > 100) {
322
+ recommendations.push(`Consider optimizing ${slowestOperations[0].operation} (${slowestOperations[0].duration!.toFixed(2)}ms)`);
323
+ }
324
+
325
+ if (memoryTrend > 1024 * 1024) { // 1MB increase per snapshot
326
+ recommendations.push('Memory usage is increasing rapidly - check for memory leaks');
327
+ }
328
+
329
+ if (renderHotspots.length > 0 && renderHotspots[0].averageRenderTime > 16.67) { // 60fps threshold
330
+ recommendations.push(`${renderHotspots[0].componentName} is rendering slowly - consider memoization`);
331
+ }
332
+
333
+ return {
334
+ slowestOperations,
335
+ memoryTrends: {
336
+ increasing: memoryTrend > 0,
337
+ trend: memoryTrend,
338
+ },
339
+ renderHotspots,
340
+ recommendations,
341
+ };
342
+ }
343
+
344
+ /**
345
+ * Generate performance report
346
+ */
347
+ generateReport(): {
348
+ summary: {
349
+ totalOperations: number;
350
+ averageOperationTime: number;
351
+ totalRenders: number;
352
+ memorySnapshots: number;
353
+ logEntries: number;
354
+ };
355
+ performance: {
356
+ slowestOperations: PerformanceTimelineEntry[];
357
+ memoryTrends: { increasing: boolean; trend: number };
358
+ renderHotspots: RenderPerformanceData[];
359
+ recommendations: string[];
360
+ };
361
+ logs: DebugLogEntry[];
362
+ timeline: PerformanceTimelineEntry[];
363
+ } {
364
+ const completedOperations = Array.from(this.performanceTimeline.values())
365
+ .filter(op => op.duration !== undefined);
366
+
367
+ const averageOperationTime = completedOperations.length > 0
368
+ ? completedOperations.reduce((sum, op) => sum + (op.duration || 0), 0) / completedOperations.length
369
+ : 0;
370
+
371
+ const totalRenders = Array.from(this.renderPerformance.values())
372
+ .reduce((sum, data) => sum + data.renderCount, 0);
373
+
374
+ return {
375
+ summary: {
376
+ totalOperations: completedOperations.length,
377
+ averageOperationTime,
378
+ totalRenders,
379
+ memorySnapshots: this.memorySnapshots.length,
380
+ logEntries: this.logEntries.length,
381
+ },
382
+ performance: this.analyzePerformance(),
383
+ logs: this.logEntries.slice(-50), // Last 50 logs
384
+ timeline: Array.from(this.performanceTimeline.values()),
385
+ };
386
+ }
387
+
388
+ /**
389
+ * Export debug data
390
+ */
391
+ exportDebugData(): string {
392
+ const report = this.generateReport();
393
+ return JSON.stringify(report, null, 2);
394
+ }
395
+
396
+ /**
397
+ * Clear all debug data
398
+ */
399
+ clear(): void {
400
+ this.logEntries = [];
401
+ this.performanceTimeline.clear();
402
+ this.memorySnapshots = [];
403
+ this.renderPerformance.clear();
404
+ this.activeOperations.clear();
405
+ }
406
+
407
+ /**
408
+ * Get current memory usage
409
+ */
410
+ private getCurrentMemoryUsage(): number {
411
+ if ('memory' in performance) {
412
+ interface PerformanceMemory {
413
+ usedJSHeapSize: number;
414
+ totalJSHeapSize: number;
415
+ jsHeapSizeLimit: number;
416
+ }
417
+ const memory = (performance as unknown as { memory: PerformanceMemory }).memory;
418
+ return memory.usedJSHeapSize / (1024 * 1024); // MB
419
+ }
420
+ return 0;
421
+ }
422
+
423
+ /**
424
+ * Log to console with appropriate styling
425
+ */
426
+ private logToConsole(entry: DebugLogEntry): void {
427
+ const timestamp = new Date(entry.timestamp).toISOString();
428
+ const levelName = DebugLevel[entry.level];
429
+ const message = `[${timestamp}] [${levelName}] [${entry.category}] ${entry.message}`;
430
+
431
+ switch (entry.level) {
432
+ case DebugLevel.ERROR:
433
+ this.logger.error(message, entry.data);
434
+ break;
435
+ case DebugLevel.WARN:
436
+ this.logger.warn(message, entry.data);
437
+ break;
438
+ case DebugLevel.INFO:
439
+ this.logger.info(message, entry.data);
440
+ break;
441
+ case DebugLevel.DEBUG:
442
+ case DebugLevel.TRACE:
443
+ this.logger.debug(message, entry.data);
444
+ break;
445
+ }
446
+ }
447
+
448
+ /**
449
+ * Log to local storage
450
+ */
451
+ private logToStorage(entry: DebugLogEntry): void {
452
+ if (typeof window === 'undefined') return;
453
+
454
+ try {
455
+ const stored = localStorage.getItem('datatable-debug-logs');
456
+ const logs = stored ? JSON.parse(stored) : [];
457
+ logs.push(entry);
458
+
459
+ // Keep last 500 entries
460
+ if (logs.length > 500) {
461
+ logs.splice(0, logs.length - 500);
462
+ }
463
+
464
+ localStorage.setItem('datatable-debug-logs', JSON.stringify(logs));
465
+ } catch (error) {
466
+ this.logger.warn('Failed to store debug log:', error);
467
+ }
468
+ }
469
+ }
470
+
471
+ /**
472
+ * Global debugger instance
473
+ */
474
+ export const dataTableDebugger = new DataTableDebugger();
475
+
476
+ /**
477
+ * Performance profiler decorator
478
+ */
479
+ export function profile(operation: string) {
480
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
481
+ return function (target: any, propertyKey: string, descriptor: PropertyDescriptor) {
482
+ const originalMethod = descriptor.value;
483
+
484
+ descriptor.value = async function (this: unknown, ...args: unknown[]) {
485
+ const operationId = `${target.constructor.name}.${propertyKey}_${Date.now()}`;
486
+
487
+ dataTableDebugger.startOperation(operationId, operation, {
488
+ className: target.constructor.name,
489
+ methodName: propertyKey,
490
+ args: args.length,
491
+ });
492
+
493
+ try {
494
+ const result = await originalMethod.apply(this, args);
495
+ dataTableDebugger.endOperation(operationId, { success: true });
496
+ return result;
497
+ } catch (error) {
498
+ dataTableDebugger.endOperation(operationId, { success: false, error: error instanceof Error ? error.message : String(error) });
499
+ dataTableDebugger.log(DebugLevel.ERROR, 'Performance', `Operation failed: ${operation}`, error);
500
+ throw error;
501
+ }
502
+ };
503
+
504
+ return descriptor;
505
+ };
506
+ }
507
+
508
+ /**
509
+ * Memory monitoring utility
510
+ */
511
+ export class MemoryMonitor {
512
+ private debuggerInstance: DataTableDebugger;
513
+ private intervalId: NodeJS.Timeout | null = null;
514
+
515
+ constructor(debuggerInstance: DataTableDebugger = dataTableDebugger) {
516
+ this.debuggerInstance = debuggerInstance;
517
+ }
518
+
519
+ start(interval: number = 5000): void {
520
+ this.stop(); // Stop any existing monitoring
521
+
522
+ this.intervalId = setInterval(() => {
523
+ this.debuggerInstance.takeMemorySnapshot('periodic');
524
+ }, interval);
525
+ }
526
+
527
+ stop(): void {
528
+ if (this.intervalId) {
529
+ clearInterval(this.intervalId);
530
+ this.intervalId = null;
531
+ }
532
+ }
533
+ }
534
+
535
+ /**
536
+ * Performance monitoring React hook
537
+ */
538
+ export function usePerformanceDebugger(componentName: string) {
539
+ const startTime = React.useRef<number>(0);
540
+
541
+ React.useEffect(() => {
542
+ startTime.current = performance.now();
543
+
544
+ return () => {
545
+ const renderTime = performance.now() - startTime.current;
546
+ dataTableDebugger.trackRender(componentName, renderTime);
547
+ };
548
+ });
549
+
550
+ const trackOperation = React.useCallback((operation: string, fn: () => unknown) => {
551
+ const operationId = `${componentName}_${operation}_${Date.now()}`;
552
+ dataTableDebugger.startOperation(operationId, operation);
553
+
554
+ try {
555
+ const result = fn();
556
+ dataTableDebugger.endOperation(operationId);
557
+ return result;
558
+ } catch (error) {
559
+ dataTableDebugger.endOperation(operationId, { error: error instanceof Error ? error.message : String(error) });
560
+ throw error;
561
+ }
562
+ }, [componentName]);
563
+
564
+ return {
565
+ trackOperation,
566
+ log: (level: DebugLevel, message: string, data?: unknown) =>
567
+ dataTableDebugger.log(level, componentName, message, data),
568
+ };
569
+ }
570
+
571
+ /**
572
+ * Development tools integration
573
+ */
574
+ export function setupDevTools(): void {
575
+ if (typeof window === 'undefined' || import.meta.env.MODE !== 'development') {
576
+ return;
577
+ }
578
+
579
+ // Expose debugger to global scope for browser dev tools
580
+ interface WindowWithDataTableDebugger extends Window {
581
+ __DATATABLE_DEBUGGER__: typeof dataTableDebugger;
582
+ dataTableDebug: {
583
+ getReport: () => ReturnType<typeof dataTableDebugger.generateReport>;
584
+ exportData: () => ReturnType<typeof dataTableDebugger.exportDebugData>;
585
+ clearLogs: () => void;
586
+ takeSnapshot: (label?: string) => ReturnType<typeof dataTableDebugger.takeMemorySnapshot>;
587
+ analyze: () => ReturnType<typeof dataTableDebugger.analyzePerformance>;
588
+ };
589
+ }
590
+
591
+ const windowWithDebugger = window as unknown as WindowWithDataTableDebugger;
592
+ windowWithDebugger.__DATATABLE_DEBUGGER__ = dataTableDebugger;
593
+
594
+ // Add console commands
595
+ windowWithDebugger.dataTableDebug = {
596
+ getReport: () => dataTableDebugger.generateReport(),
597
+ exportData: () => dataTableDebugger.exportDebugData(),
598
+ clearLogs: () => dataTableDebugger.clear(),
599
+ takeSnapshot: (label?: string) => dataTableDebugger.takeMemorySnapshot(label),
600
+ analyze: () => dataTableDebugger.analyzePerformance(),
601
+ };
602
+
603
+ createLogger('DataTableDebugTools').info('Debug Tools loaded. Use window.dataTableDebug for debugging.');
604
+ }
605
+
606
+ /**
607
+ * Initialize debugging tools
608
+ */
609
+ setupDevTools();