@jmruthers/pace-core 0.6.6 → 0.6.8

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 (292) hide show
  1. package/{scripts/audit/audit-dependencies.cjs → audit-tool/00-dependencies.cjs} +227 -22
  2. package/audit-tool/audits/01-pace-core-compliance.cjs +556 -0
  3. package/audit-tool/audits/02-project-structure.cjs +240 -0
  4. package/audit-tool/audits/03-architecture.cjs +224 -0
  5. package/audit-tool/audits/04-code-quality.cjs +149 -0
  6. package/audit-tool/audits/05-styling.cjs +224 -0
  7. package/audit-tool/audits/06-security-rbac.cjs +554 -0
  8. package/audit-tool/audits/07-api-tech-stack.cjs +355 -0
  9. package/audit-tool/audits/08-testing-documentation.cjs +202 -0
  10. package/audit-tool/audits/09-operations.cjs +208 -0
  11. package/audit-tool/index.cjs +295 -0
  12. package/audit-tool/utils/code-utils.cjs +218 -0
  13. package/audit-tool/utils/file-utils.cjs +230 -0
  14. package/audit-tool/utils/report-utils.cjs +380 -0
  15. package/cursor-rules/00-standards-overview.mdc +156 -0
  16. package/cursor-rules/{00-pace-core-compliance.mdc → 01-pace-core-compliance.mdc} +187 -34
  17. package/cursor-rules/02-project-structure.mdc +37 -5
  18. package/cursor-rules/{03-solid-principles.mdc → 03-architecture.mdc} +125 -11
  19. package/cursor-rules/04-code-quality.mdc +419 -0
  20. package/cursor-rules/{08-markup-quality.mdc → 05-styling.mdc} +55 -10
  21. package/cursor-rules/{09-rbac-compliance.mdc → 06-security-rbac.mdc} +62 -6
  22. package/cursor-rules/07-api-tech-stack.mdc +377 -0
  23. package/cursor-rules/08-testing-documentation.mdc +324 -0
  24. package/cursor-rules/09-operations.mdc +365 -0
  25. package/dist/DataTable-6RMSCQJ6.js +15 -0
  26. package/dist/{DataTable-2N_tqbfq.d.ts → DataTable-DRUIgtUH.d.ts} +1 -1
  27. package/dist/{PublicPageProvider-BBH6Vqg7.d.ts → PublicPageProvider-CIGSujI2.d.ts} +40 -24
  28. package/dist/{UnifiedAuthProvider-ZT6TIGM7.js → UnifiedAuthProvider-7SNDOWYD.js} +2 -2
  29. package/dist/{api-Y4MQWOFW.js → api-7P7DI652.js} +1 -1
  30. package/dist/{chunk-MAGBIDNS.js → chunk-4DDCYDQ3.js} +8 -7
  31. package/dist/{chunk-BVP2BCJF.js → chunk-5W2A3DRC.js} +10 -9
  32. package/dist/{chunk-SD6WQY43.js → chunk-7ILTDCL2.js} +9 -1
  33. package/dist/{chunk-3QC3KRHK.js → chunk-A3W6LW53.js} +16 -1
  34. package/dist/{chunk-3O3WHILE.js → chunk-EF2UGZWY.js} +239 -63
  35. package/dist/{chunk-LAZMKTTF.js → chunk-EURB7QFZ.js} +341 -337
  36. package/dist/{chunk-2HGJFNAH.js → chunk-FEJLJNWA.js} +1 -15
  37. package/dist/{chunk-7TYHROIV.js → chunk-GS5672WG.js} +55 -13
  38. package/dist/{chunk-UIYSCEV7.js → chunk-IUBRCBSY.js} +1 -1
  39. package/dist/{chunk-ZFYPMX46.js → chunk-LX6U42O3.js} +1 -1
  40. package/dist/{chunk-FENMYN2U.js → chunk-MPBLMWVR.js} +3 -3
  41. package/dist/{chunk-ZS5VO5JB.js → chunk-NKHKXPI4.js} +408 -453
  42. package/dist/{chunk-A55DK444.js → chunk-OJ4SKRSV.js} +1 -7
  43. package/dist/{chunk-4T7OBVTU.js → chunk-S6ZQKDY6.js} +1 -1
  44. package/dist/{chunk-FTCRZOG2.js → chunk-T5CVK4R3.js} +5 -5
  45. package/dist/{chunk-OHIK3MIO.js → chunk-Z2FNRKF3.js} +13 -13
  46. package/dist/components.d.ts +5 -4
  47. package/dist/components.js +29 -34
  48. package/dist/eslint-rules/index.cjs +22 -9
  49. package/{src/eslint-rules/rules/compliance.cjs → dist/eslint-rules/rules/01-pace-core-compliance.cjs} +184 -23
  50. package/dist/eslint-rules/rules/04-code-quality.cjs +346 -0
  51. package/dist/eslint-rules/rules/05-styling.cjs +61 -0
  52. package/dist/eslint-rules/rules/{rbac.cjs → 06-security-rbac.cjs} +34 -13
  53. package/dist/eslint-rules/rules/07-api-tech-stack.cjs +385 -0
  54. package/dist/eslint-rules/rules/08-testing.cjs +94 -0
  55. package/dist/{functions-DHebl8-F.d.ts → functions-lBy5L2ry.d.ts} +1 -1
  56. package/dist/hooks.d.ts +5 -5
  57. package/dist/hooks.js +8 -8
  58. package/dist/index.d.ts +7 -7
  59. package/dist/index.js +21 -20
  60. package/dist/providers.js +2 -2
  61. package/dist/rbac/index.d.ts +1 -1
  62. package/dist/rbac/index.js +8 -8
  63. package/dist/theming/runtime.d.ts +61 -1
  64. package/dist/theming/runtime.js +1 -1
  65. package/dist/{types-B-K_5VnO.d.ts → types-DXstZpNI.d.ts} +0 -17
  66. package/dist/types.d.ts +2 -2
  67. package/dist/{usePublicRouteParams-COZ28Mvq.d.ts → usePublicRouteParams-MamNgwqe.d.ts} +19 -19
  68. package/dist/utils.d.ts +2 -2
  69. package/dist/utils.js +8 -8
  70. package/docs/README.md +1 -1
  71. package/docs/api/modules.md +106 -41
  72. package/docs/api-reference/components.md +18 -20
  73. package/docs/api-reference/hooks.md +80 -80
  74. package/docs/api-reference/types.md +1 -1
  75. package/docs/api-reference/utilities.md +1 -1
  76. package/docs/architecture/README.md +1 -1
  77. package/docs/core-concepts/events.md +3 -3
  78. package/docs/core-concepts/organisations.md +6 -6
  79. package/docs/core-concepts/permissions.md +6 -6
  80. package/docs/documentation-index.md +12 -18
  81. package/docs/getting-started/dependencies.md +23 -0
  82. package/docs/getting-started/documentation-index.md +1 -1
  83. package/docs/getting-started/examples/README.md +4 -4
  84. package/docs/getting-started/examples/full-featured-app.md +1 -1
  85. package/docs/getting-started/faq.md +2 -2
  86. package/docs/getting-started/quick-reference.md +4 -4
  87. package/docs/implementation-guides/app-layout.md +1 -1
  88. package/docs/implementation-guides/authentication.md +15 -15
  89. package/docs/implementation-guides/component-styling.md +1 -1
  90. package/docs/implementation-guides/data-tables.md +127 -34
  91. package/docs/implementation-guides/datatable-rbac-usage.md +1 -1
  92. package/docs/implementation-guides/dynamic-colors.md +3 -3
  93. package/docs/implementation-guides/file-upload-storage.md +2 -2
  94. package/docs/implementation-guides/hierarchical-datatable.md +40 -60
  95. package/docs/implementation-guides/inactivity-tracking.md +3 -3
  96. package/docs/implementation-guides/large-datasets.md +3 -2
  97. package/docs/implementation-guides/organisation-security.md +2 -2
  98. package/docs/implementation-guides/performance.md +2 -2
  99. package/docs/implementation-guides/permission-enforcement.md +1 -1
  100. package/docs/migration/V0.3.44_organisation-context-timing-fix.md +1 -1
  101. package/docs/migration/V0.4.0_rbac-migration.md +6 -6
  102. package/docs/rbac/README.md +5 -5
  103. package/docs/rbac/advanced-patterns.md +6 -6
  104. package/docs/rbac/api-reference.md +20 -20
  105. package/docs/rbac/event-based-apps.md +3 -3
  106. package/docs/rbac/examples.md +41 -41
  107. package/docs/rbac/getting-started.md +37 -37
  108. package/docs/rbac/performance.md +1 -1
  109. package/docs/rbac/quick-start.md +52 -52
  110. package/docs/rbac/secure-client-protection.md +1 -1
  111. package/docs/rbac/troubleshooting.md +1 -1
  112. package/docs/security/README.md +5 -5
  113. package/docs/standards/0-standards-overview.md +220 -0
  114. package/docs/standards/{00-pace-core-compliance.md → 1-pace-core-compliance-standards.md} +241 -185
  115. package/docs/standards/{02-project-structure.md → 2-project-structure-standards.md} +11 -47
  116. package/docs/standards/3-architecture-standards.md +606 -0
  117. package/docs/standards/4-code-quality-standards.md +728 -0
  118. package/docs/standards/{08-markup-quality.md → 5-styling-standards.md} +12 -9
  119. package/docs/standards/{09-rbac-compliance.md → 6-security-rbac-standards.md} +126 -18
  120. package/docs/standards/7-api-tech-stack-standards.md +662 -0
  121. package/docs/standards/8-testing-documentation-standards.md +401 -0
  122. package/docs/standards/9-operations-standards.md +1102 -0
  123. package/docs/standards/README.md +203 -104
  124. package/docs/troubleshooting/README.md +4 -4
  125. package/docs/troubleshooting/common-issues.md +2 -2
  126. package/docs/troubleshooting/debugging.md +9 -9
  127. package/docs/troubleshooting/migration.md +4 -4
  128. package/eslint-config-pace-core.cjs +50 -20
  129. package/package.json +50 -19
  130. package/scripts/eslint-audit.cjs +123 -0
  131. package/scripts/install-cursor-rules.cjs +11 -243
  132. package/scripts/install-eslint-config.cjs +349 -0
  133. package/scripts/validate-dependencies.cjs +248 -0
  134. package/src/__tests__/helpers/__tests__/component-test-utils.test.tsx +2 -2
  135. package/src/__tests__/helpers/__tests__/test-providers.test.tsx +2 -2
  136. package/src/__tests__/helpers/__tests__/test-utils.test.tsx +30 -18
  137. package/src/__tests__/integration/UserProfile.test.tsx +14 -14
  138. package/src/__tests__/rbac/PagePermissionGuard.test.tsx +6 -6
  139. package/src/__tests__/templates/accessibility.test.template.tsx +10 -9
  140. package/src/__tests__/templates/component.test.template.tsx +18 -15
  141. package/src/components/AddressField/AddressField.tsx +26 -1
  142. package/src/components/Alert/Alert.test.tsx +86 -22
  143. package/src/components/Alert/Alert.tsx +19 -11
  144. package/src/components/Badge/Badge.tsx +1 -1
  145. package/src/components/Calendar/Calendar.tsx +201 -47
  146. package/src/components/Checkbox/Checkbox.test.tsx +2 -1
  147. package/src/components/ContextSelector/ContextSelector.tsx +108 -126
  148. package/src/components/DataTable/AUDIT_REPORT.md +293 -0
  149. package/src/components/DataTable/DataTable.tsx +1 -19
  150. package/src/components/DataTable/__tests__/DataTableCore.test.tsx +6 -2
  151. package/src/components/DataTable/__tests__/a11y.basic.test.tsx +21 -6
  152. package/src/components/DataTable/__tests__/pagination.modes.test.tsx +3 -2
  153. package/src/components/DataTable/__tests__/test-utils/sharedTestUtils.tsx +9 -9
  154. package/src/components/DataTable/components/ColumnFilter.tsx +63 -74
  155. package/src/components/DataTable/components/ColumnVisibilityDropdown.tsx +43 -41
  156. package/src/components/DataTable/components/DataTableErrorBoundary.tsx +9 -11
  157. package/src/components/DataTable/components/DataTableLayout.tsx +5 -16
  158. package/src/components/DataTable/components/EditableRow.tsx +5 -7
  159. package/src/components/DataTable/components/EmptyState.tsx +11 -10
  160. package/src/components/DataTable/components/FilterRow.tsx +2 -4
  161. package/src/components/DataTable/components/ImportModal.tsx +124 -126
  162. package/src/components/DataTable/components/LoadingState.tsx +5 -6
  163. package/src/components/DataTable/components/SortIndicator.tsx +50 -0
  164. package/src/components/DataTable/components/__tests__/COVERAGE_NOTE.md +4 -4
  165. package/src/components/DataTable/components/__tests__/ColumnFilter.test.tsx +23 -82
  166. package/src/components/DataTable/components/__tests__/DataTableErrorBoundary.test.tsx +37 -9
  167. package/src/components/DataTable/components/__tests__/EmptyState.test.tsx +7 -4
  168. package/src/components/DataTable/components/__tests__/FilterRow.test.tsx +12 -4
  169. package/src/components/DataTable/components/__tests__/LoadingState.test.tsx +45 -27
  170. package/src/components/DataTable/components/index.ts +2 -1
  171. package/src/components/DataTable/types.ts +0 -18
  172. package/src/components/DataTable/utils/a11yUtils.ts +17 -0
  173. package/src/components/DatePickerWithTimezone/DatePickerWithTimezone.test.tsx +1 -1
  174. package/src/components/DatePickerWithTimezone/DatePickerWithTimezone.tsx +11 -15
  175. package/src/components/DateTimeField/DateTimeField.tsx +7 -8
  176. package/src/components/Dialog/Dialog.test.tsx +1 -0
  177. package/src/components/Dialog/Dialog.tsx +25 -8
  178. package/src/components/ErrorBoundary/ErrorBoundary.tsx +77 -79
  179. package/src/components/FileUpload/FileUpload.test.tsx +45 -16
  180. package/src/components/FileUpload/FileUpload.tsx +141 -130
  181. package/src/components/NavigationMenu/NavigationMenu.test.tsx +48 -12
  182. package/src/components/PaceAppLayout/PaceAppLayout.performance.test.tsx +9 -9
  183. package/src/components/PaceAppLayout/PaceAppLayout.security.test.tsx +30 -30
  184. package/src/components/PaceAppLayout/PaceAppLayout.test.tsx +4 -4
  185. package/src/components/PaceLoginPage/PaceLoginPage.test.tsx +7 -1
  186. package/src/components/Progress/Progress.tsx +2 -4
  187. package/src/components/ProtectedRoute/ProtectedRoute.tsx +8 -8
  188. package/src/components/Select/Select.tsx +86 -77
  189. package/src/components/Select/types.ts +3 -0
  190. package/src/hooks/__tests__/ServiceHooks.test.tsx +16 -16
  191. package/src/hooks/__tests__/hooks.integration.test.tsx +49 -49
  192. package/src/hooks/__tests__/useDataTablePerformance.unit.test.ts +8 -5
  193. package/src/hooks/__tests__/useFileUrl.unit.test.ts +4 -0
  194. package/src/hooks/__tests__/useFocusTrap.unit.test.tsx +99 -99
  195. package/src/hooks/__tests__/useInactivityTracker.unit.test.ts +45 -8
  196. package/src/hooks/__tests__/usePerformanceMonitor.unit.test.ts +22 -2
  197. package/src/hooks/public/usePublicEvent.ts +5 -5
  198. package/src/hooks/public/usePublicEventLogo.ts +5 -5
  199. package/src/hooks/public/usePublicFileDisplay.ts +2 -2
  200. package/src/hooks/public/usePublicRouteParams.ts +13 -9
  201. package/src/hooks/useAddressAutocomplete.test.ts +18 -18
  202. package/src/hooks/useAppConfig.ts +2 -2
  203. package/src/hooks/useEventTheme.test.ts +7 -7
  204. package/src/hooks/useEventTheme.ts +2 -1
  205. package/src/hooks/useFileDisplay.ts +2 -2
  206. package/src/hooks/useFileUrl.ts +52 -8
  207. package/src/hooks/useOrganisationSecurity.test.ts +2 -1
  208. package/src/providers/UnifiedAuthProvider.smoke.test.tsx +21 -21
  209. package/src/providers/__tests__/AuthProvider.test.tsx +21 -21
  210. package/src/providers/__tests__/EventProvider.test.tsx +61 -61
  211. package/src/providers/__tests__/InactivityProvider.test.tsx +56 -56
  212. package/src/providers/__tests__/OrganisationProvider.test.tsx +75 -75
  213. package/src/providers/__tests__/ProviderLifecycle.test.tsx +38 -38
  214. package/src/providers/__tests__/UnifiedAuthProvider.test.tsx +103 -103
  215. package/src/providers/services/__tests__/AuthServiceProvider.integration.test.tsx +7 -7
  216. package/src/providers/services/__tests__/UnifiedAuthProvider.integration.test.tsx +10 -10
  217. package/src/rbac/__tests__/auth-rbac.e2e.test.tsx +15 -6
  218. package/src/rbac/__tests__/rbac-functions.test.ts +3 -3
  219. package/src/rbac/api.test.ts +104 -0
  220. package/src/rbac/engine.ts +1 -1
  221. package/src/rbac/hooks/useCan.test.ts +2 -2
  222. package/src/rbac/secureClient.ts +1 -1
  223. package/src/rbac/types/functions.ts +1 -1
  224. package/src/styles/core.css +7 -0
  225. package/src/theming/__tests__/parseEventColours.test.ts +118 -3
  226. package/src/theming/parseEventColours.ts +77 -11
  227. package/src/types/supabase.ts +2 -3
  228. package/src/utils/__tests__/bundleAnalysis.unit.test.ts +9 -9
  229. package/src/utils/__tests__/lazyLoad.unit.test.tsx +42 -39
  230. package/src/utils/file-reference/__tests__/file-reference.test.ts +4 -0
  231. package/src/utils/formatting/formatDate.test.ts +3 -2
  232. package/src/utils/formatting/formatDateTime.test.ts +2 -2
  233. package/src/utils/google-places/googlePlacesUtils.test.ts +36 -24
  234. package/src/utils/storage/README.md +1 -1
  235. package/src/utils/storage/__tests__/helpers.unit.test.ts +19 -12
  236. package/src/utils/storage/helpers.test.ts +69 -3
  237. package/cursor-rules/01-standards-compliance.mdc +0 -285
  238. package/cursor-rules/04-testing-standards.mdc +0 -270
  239. package/cursor-rules/05-bug-reports-and-features.mdc +0 -248
  240. package/cursor-rules/06-code-quality.mdc +0 -311
  241. package/cursor-rules/07-tech-stack-compliance.mdc +0 -216
  242. package/cursor-rules/10-error-handling-patterns.mdc +0 -179
  243. package/cursor-rules/11-performance-optimization.mdc +0 -169
  244. package/cursor-rules/12-ci-cd-integration.mdc +0 -150
  245. package/dist/DataTable-LRJL4IRV.js +0 -15
  246. package/dist/eslint-rules/rules/compliance.cjs +0 -348
  247. package/dist/eslint-rules/rules/components.cjs +0 -113
  248. package/dist/eslint-rules/rules/imports.cjs +0 -102
  249. package/docs/best-practices/README.md +0 -472
  250. package/docs/best-practices/accessibility.md +0 -604
  251. package/docs/best-practices/common-patterns.md +0 -516
  252. package/docs/best-practices/deployment.md +0 -1103
  253. package/docs/best-practices/performance.md +0 -1328
  254. package/docs/best-practices/security.md +0 -940
  255. package/docs/best-practices/testing.md +0 -1034
  256. package/docs/rbac/compliance/compliance-guide.md +0 -544
  257. package/docs/standards/01-standards-compliance.md +0 -188
  258. package/docs/standards/03-solid-principles.md +0 -39
  259. package/docs/standards/04-testing-standards.md +0 -36
  260. package/docs/standards/05-bug-reports-and-features.md +0 -27
  261. package/docs/standards/06-code-quality.md +0 -34
  262. package/docs/standards/07-tech-stack-compliance.md +0 -30
  263. package/docs/standards/10-error-handling-patterns.md +0 -401
  264. package/docs/standards/11-performance-optimization.md +0 -348
  265. package/docs/standards/12-ci-cd-integration.md +0 -370
  266. package/docs/standards/ALIGNMENT_REVIEW_SUMMARY.md +0 -192
  267. package/scripts/audit/audit-compliance.cjs +0 -1295
  268. package/scripts/audit/audit-components.cjs +0 -260
  269. package/scripts/audit/audit-rbac.cjs +0 -954
  270. package/scripts/audit/audit-standards.cjs +0 -1268
  271. package/scripts/audit/index.cjs +0 -1927
  272. package/src/components/DataTable/components/DataTableBody.tsx +0 -478
  273. package/src/components/DataTable/components/DraggableColumnHeader.tsx +0 -156
  274. package/src/components/DataTable/components/ExpandButton.tsx +0 -113
  275. package/src/components/DataTable/components/GroupHeader.tsx +0 -54
  276. package/src/components/DataTable/components/ViewRowModal.tsx +0 -68
  277. package/src/components/DataTable/components/VirtualizedDataTable.tsx +0 -525
  278. package/src/components/DataTable/components/__tests__/ExpandButton.test.tsx +0 -462
  279. package/src/components/DataTable/components/__tests__/GroupHeader.test.tsx +0 -393
  280. package/src/components/DataTable/components/__tests__/ViewRowModal.test.tsx +0 -476
  281. package/src/components/DataTable/components/__tests__/VirtualizedDataTable.test.tsx +0 -128
  282. package/src/components/DataTable/core/DataTableContext.tsx +0 -216
  283. package/src/components/DataTable/core/__tests__/DataTableContext.test.tsx +0 -136
  284. package/src/components/DataTable/hooks/__tests__/useColumnReordering.test.ts +0 -570
  285. package/src/components/DataTable/hooks/useColumnReordering.ts +0 -123
  286. package/src/components/DataTable/utils/debugTools.ts +0 -514
  287. package/src/eslint-rules/index.cjs +0 -22
  288. package/src/eslint-rules/rules/components.cjs +0 -113
  289. package/src/eslint-rules/rules/imports.cjs +0 -102
  290. package/src/eslint-rules/rules/rbac.cjs +0 -790
  291. package/src/eslint-rules/utils/helpers.cjs +0 -42
  292. package/src/eslint-rules/utils/manifest-loader.cjs +0 -75
@@ -58,15 +58,15 @@ const TestComponent = () => {
58
58
  const auth = useUnifiedAuth();
59
59
 
60
60
  return (
61
- <div data-testid="test-component">
62
- <div data-testid="hasUser">{auth.user !== null ? 'true' : 'false'}</div>
63
- <div data-testid="hasSession">{auth.session !== null ? 'true' : 'false'}</div>
64
- <div data-testid="hasSignIn">{typeof auth.signIn === 'function' ? 'true' : 'false'}</div>
65
- <div data-testid="hasSignOut">{typeof auth.signOut === 'function' ? 'true' : 'false'}</div>
66
- <div data-testid="hasOrganisation">{typeof auth.selectedOrganisation === 'object' && auth.selectedOrganisation !== null ? 'true' : 'false'}</div>
67
- <div data-testid="hasEvents">{Array.isArray(auth.events) ? 'true' : 'false'}</div>
68
- <div data-testid="hasAppName">{typeof auth.appName === 'string' ? 'true' : 'false'}</div>
69
- </div>
61
+ <section data-testid="test-component">
62
+ <p data-testid="hasUser">{auth.user !== null ? 'true' : 'false'}</p>
63
+ <p data-testid="hasSession">{auth.session !== null ? 'true' : 'false'}</p>
64
+ <p data-testid="hasSignIn">{typeof auth.signIn === 'function' ? 'true' : 'false'}</p>
65
+ <p data-testid="hasSignOut">{typeof auth.signOut === 'function' ? 'true' : 'false'}</p>
66
+ <p data-testid="hasOrganisation">{typeof auth.selectedOrganisation === 'object' && auth.selectedOrganisation !== null ? 'true' : 'false'}</p>
67
+ <p data-testid="hasEvents">{Array.isArray(auth.events) ? 'true' : 'false'}</p>
68
+ <p data-testid="hasAppName">{typeof auth.appName === 'string' ? 'true' : 'false'}</p>
69
+ </section>
70
70
  );
71
71
  };
72
72
 
@@ -91,7 +91,7 @@ describe('UnifiedAuthProvider', () => {
91
91
  </UnifiedAuthProvider>
92
92
  );
93
93
 
94
- expect(screen.getByTestId('test-component')).toBeInTheDocument();
94
+ expect(screen.getByTestId('test-component')).toBeDefined();
95
95
  });
96
96
 
97
97
  it('renders with custom app name', () => {
@@ -101,7 +101,7 @@ describe('UnifiedAuthProvider', () => {
101
101
  </UnifiedAuthProvider>
102
102
  );
103
103
 
104
- expect(screen.getByTestId('test-component')).toBeInTheDocument();
104
+ expect(screen.getByTestId('test-component')).toBeDefined();
105
105
  });
106
106
 
107
107
  it('renders without supabase client', () => {
@@ -111,7 +111,7 @@ describe('UnifiedAuthProvider', () => {
111
111
  </UnifiedAuthProvider>
112
112
  );
113
113
 
114
- expect(screen.getByTestId('test-component')).toBeInTheDocument();
114
+ expect(screen.getByTestId('test-component')).toBeDefined();
115
115
  });
116
116
  });
117
117
 
@@ -148,9 +148,9 @@ describe('UnifiedAuthProvider', () => {
148
148
  const TestHookComponent = () => {
149
149
  try {
150
150
  const auth = useUnifiedAuth();
151
- return <div data-testid="hook-success">Hook works</div>;
151
+ return <p data-testid="hook-success">Hook works</p>;
152
152
  } catch (error) {
153
- return <div data-testid="hook-error">Hook failed</div>;
153
+ return <p data-testid="hook-error">Hook failed</p>;
154
154
  }
155
155
  };
156
156
 
@@ -160,7 +160,7 @@ describe('UnifiedAuthProvider', () => {
160
160
  </UnifiedAuthProvider>
161
161
  );
162
162
 
163
- expect(screen.getByTestId('hook-success')).toBeInTheDocument();
163
+ expect(screen.getByTestId('hook-success')).toBeDefined();
164
164
  });
165
165
  });
166
166
 
@@ -177,7 +177,7 @@ describe('UnifiedAuthProvider', () => {
177
177
  </UnifiedAuthProvider>
178
178
  );
179
179
 
180
- expect(screen.getByTestId('test-component')).toBeInTheDocument();
180
+ expect(screen.getByTestId('test-component')).toBeDefined();
181
181
  });
182
182
 
183
183
  it('uses default configuration', () => {
@@ -187,7 +187,7 @@ describe('UnifiedAuthProvider', () => {
187
187
  </UnifiedAuthProvider>
188
188
  );
189
189
 
190
- expect(screen.getByTestId('test-component')).toBeInTheDocument();
190
+ expect(screen.getByTestId('test-component')).toBeDefined();
191
191
  });
192
192
  });
193
193
 
@@ -197,12 +197,12 @@ describe('UnifiedAuthProvider', () => {
197
197
  const auth = useUnifiedAuth();
198
198
 
199
199
  return (
200
- <div>
201
- <div data-testid="composition-success">composed</div>
202
- <div data-testid="has-all-contexts">
200
+ <section>
201
+ <p data-testid="composition-success">composed</p>
202
+ <p data-testid="has-all-contexts">
203
203
  {auth.user && auth.session && auth.isAuthenticated ? 'yes' : 'no'}
204
- </div>
205
- </div>
204
+ </p>
205
+ </section>
206
206
  );
207
207
  };
208
208
 
@@ -225,13 +225,13 @@ describe('UnifiedAuthProvider', () => {
225
225
  const auth = useUnifiedAuth();
226
226
 
227
227
  return (
228
- <div>
229
- <div data-testid="user-context">{auth.user ? 'present' : 'missing'}</div>
230
- <div data-testid="session-context">{auth.session ? 'present' : 'missing'}</div>
231
- <div data-testid="organisation-context">{auth.selectedOrganisation ? 'present' : 'missing'}</div>
232
- <div data-testid="event-context">{auth.selectedEvent ? 'missing' : 'present'}</div>
233
- <div data-testid="app-context">{auth.appName ? 'present' : 'missing'}</div>
234
- </div>
228
+ <section>
229
+ <p data-testid="user-context">{auth.user ? 'present' : 'missing'}</p>
230
+ <p data-testid="session-context">{auth.session ? 'present' : 'missing'}</p>
231
+ <p data-testid="organisation-context">{auth.selectedOrganisation ? 'present' : 'missing'}</p>
232
+ <p data-testid="event-context">{auth.selectedEvent ? 'missing' : 'present'}</p>
233
+ <p data-testid="app-context">{auth.appName ? 'present' : 'missing'}</p>
234
+ </section>
235
235
  );
236
236
  };
237
237
 
@@ -258,10 +258,10 @@ describe('UnifiedAuthProvider', () => {
258
258
  const auth = useUnifiedAuth();
259
259
 
260
260
  return (
261
- <div>
262
- <div data-testid="provider-hierarchy">valid</div>
263
- <div data-testid="auth-available">{auth ? 'yes' : 'no'}</div>
264
- </div>
261
+ <section>
262
+ <p data-testid="provider-hierarchy">valid</p>
263
+ <p data-testid="auth-available">{auth ? 'yes' : 'no'}</p>
264
+ </section>
265
265
  );
266
266
  };
267
267
 
@@ -282,14 +282,14 @@ describe('UnifiedAuthProvider', () => {
282
282
  const auth = useUnifiedAuth();
283
283
 
284
284
  return (
285
- <div>
286
- <div data-testid="loading-orchestration">
285
+ <section>
286
+ <p data-testid="loading-orchestration">
287
287
  {auth.isLoading ? 'loading' : 'ready'}
288
- </div>
289
- <div data-testid="context-ready">
288
+ </p>
289
+ <p data-testid="context-ready">
290
290
  {auth.user && auth.session ? 'ready' : 'initializing'}
291
- </div>
292
- </div>
291
+ </p>
292
+ </section>
293
293
  );
294
294
  };
295
295
 
@@ -299,8 +299,8 @@ describe('UnifiedAuthProvider', () => {
299
299
  </UnifiedAuthProvider>
300
300
  );
301
301
 
302
- expect(screen.getByTestId('loading-orchestration')).toBeInTheDocument();
303
- expect(screen.getByTestId('context-ready')).toBeInTheDocument();
302
+ expect(screen.getByTestId('loading-orchestration')).toBeDefined();
303
+ expect(screen.getByTestId('context-ready')).toBeDefined();
304
304
  });
305
305
 
306
306
  it('coordinates loading across multiple context sources', () => {
@@ -308,12 +308,12 @@ describe('UnifiedAuthProvider', () => {
308
308
  const auth = useUnifiedAuth();
309
309
 
310
310
  return (
311
- <div>
312
- <div data-testid="coordination">{auth.isLoading ? 'coordinating' : 'coordinated'}</div>
313
- <div data-testid="all-contexts-loaded">
311
+ <section>
312
+ <p data-testid="coordination">{auth.isLoading ? 'coordinating' : 'coordinated'}</p>
313
+ <p data-testid="all-contexts-loaded">
314
314
  {auth.user && auth.session && !auth.isLoading ? 'loaded' : 'loading'}
315
- </div>
316
- </div>
315
+ </p>
316
+ </section>
317
317
  );
318
318
  };
319
319
 
@@ -323,8 +323,8 @@ describe('UnifiedAuthProvider', () => {
323
323
  </UnifiedAuthProvider>
324
324
  );
325
325
 
326
- expect(screen.getByTestId('coordination')).toBeInTheDocument();
327
- expect(screen.getByTestId('all-contexts-loaded')).toBeInTheDocument();
326
+ expect(screen.getByTestId('coordination')).toBeDefined();
327
+ expect(screen.getByTestId('all-contexts-loaded')).toBeDefined();
328
328
  });
329
329
  });
330
330
 
@@ -334,12 +334,12 @@ describe('UnifiedAuthProvider', () => {
334
334
  const auth = useUnifiedAuth();
335
335
 
336
336
  return (
337
- <div>
338
- <div data-testid="error-state">{auth.error ? 'has-error' : 'no-error'}</div>
339
- <div data-testid="still-functional">
337
+ <section>
338
+ <p data-testid="error-state">{auth.error ? 'has-error' : 'no-error'}</p>
339
+ <p data-testid="still-functional">
340
340
  {auth.user || auth.session ? 'functional' : 'broken'}
341
- </div>
342
- </div>
341
+ </p>
342
+ </section>
343
343
  );
344
344
  };
345
345
 
@@ -349,8 +349,8 @@ describe('UnifiedAuthProvider', () => {
349
349
  </UnifiedAuthProvider>
350
350
  );
351
351
 
352
- expect(screen.getByTestId('error-state')).toBeInTheDocument();
353
- expect(screen.getByTestId('still-functional')).toBeInTheDocument();
352
+ expect(screen.getByTestId('error-state')).toBeDefined();
353
+ expect(screen.getByTestId('still-functional')).toBeDefined();
354
354
  });
355
355
 
356
356
  it('provides error recovery mechanisms', () => {
@@ -358,12 +358,12 @@ describe('UnifiedAuthProvider', () => {
358
358
  const auth = useUnifiedAuth();
359
359
 
360
360
  return (
361
- <div>
362
- <div data-testid="recovery-available">
361
+ <section>
362
+ <p data-testid="recovery-available">
363
363
  {auth.refreshSession ? 'available' : 'unavailable'}
364
- </div>
365
- <div data-testid="error-handled">{auth.error ? 'handled' : 'no-error'}</div>
366
- </div>
364
+ </p>
365
+ <p data-testid="error-handled">{auth.error ? 'handled' : 'no-error'}</p>
366
+ </section>
367
367
  );
368
368
  };
369
369
 
@@ -373,8 +373,8 @@ describe('UnifiedAuthProvider', () => {
373
373
  </UnifiedAuthProvider>
374
374
  );
375
375
 
376
- expect(screen.getByTestId('recovery-available')).toBeInTheDocument();
377
- expect(screen.getByTestId('error-handled')).toBeInTheDocument();
376
+ expect(screen.getByTestId('recovery-available')).toBeDefined();
377
+ expect(screen.getByTestId('error-handled')).toBeDefined();
378
378
  });
379
379
 
380
380
  it('maintains stability during error states', () => {
@@ -382,12 +382,12 @@ describe('UnifiedAuthProvider', () => {
382
382
  const auth = useUnifiedAuth();
383
383
 
384
384
  return (
385
- <div>
386
- <div data-testid="stable-during-error">
385
+ <section>
386
+ <p data-testid="stable-during-error">
387
387
  {auth ? 'stable' : 'unstable'}
388
- </div>
389
- <div data-testid="re-render-safe">safe</div>
390
- </div>
388
+ </p>
389
+ <p data-testid="re-render-safe">safe</p>
390
+ </section>
391
391
  );
392
392
  };
393
393
 
@@ -397,7 +397,7 @@ describe('UnifiedAuthProvider', () => {
397
397
  </UnifiedAuthProvider>
398
398
  );
399
399
 
400
- expect(screen.getByTestId('stable-during-error')).toBeInTheDocument();
400
+ expect(screen.getByTestId('stable-during-error')).toBeDefined();
401
401
 
402
402
  // Re-render during error state
403
403
  rerender(
@@ -416,14 +416,14 @@ describe('UnifiedAuthProvider', () => {
416
416
  const auth = useUnifiedAuth();
417
417
 
418
418
  return (
419
- <div>
420
- <div data-testid="hook-access">
419
+ <section>
420
+ <p data-testid="hook-access">
421
421
  {auth.user && auth.session && auth.isAuthenticated ? 'full' : 'partial'}
422
- </div>
423
- <div data-testid="hook-methods">
422
+ </p>
423
+ <p data-testid="hook-methods">
424
424
  {auth.signIn && auth.signOut && auth.refreshSession ? 'complete' : 'incomplete'}
425
- </div>
426
- </div>
425
+ </p>
426
+ </section>
427
427
  );
428
428
  };
429
429
 
@@ -447,12 +447,12 @@ describe('UnifiedAuthProvider', () => {
447
447
  const auth = useUnifiedAuth();
448
448
 
449
449
  return (
450
- <div>
451
- <div data-testid="user-stable">{auth.user ? 'stable' : 'unstable'}</div>
452
- <div data-testid="methods-stable">
450
+ <section>
451
+ <p data-testid="user-stable">{auth.user ? 'stable' : 'unstable'}</p>
452
+ <p data-testid="methods-stable">
453
453
  {auth.signIn && auth.signOut ? 'stable' : 'unstable'}
454
- </div>
455
- </div>
454
+ </p>
455
+ </section>
456
456
  );
457
457
  };
458
458
 
@@ -486,10 +486,10 @@ describe('UnifiedAuthProvider', () => {
486
486
  const isAuthenticated = auth.isAuthenticated;
487
487
 
488
488
  return (
489
- <div>
490
- <div data-testid="concurrent-safe">safe</div>
491
- <div data-testid="all-reads">{user && session && isAuthenticated ? 'success' : 'fail'}</div>
492
- </div>
489
+ <section>
490
+ <p data-testid="concurrent-safe">safe</p>
491
+ <p data-testid="all-reads">{user && session && isAuthenticated ? 'success' : 'fail'}</p>
492
+ </section>
493
493
  );
494
494
  };
495
495
 
@@ -514,13 +514,13 @@ describe('UnifiedAuthProvider', () => {
514
514
  const auth = useUnifiedAuth();
515
515
 
516
516
  return (
517
- <div>
518
- <div data-testid="custom-app-name">{auth.appName}</div>
519
- <div data-testid="app-name-present">{auth.appName ? 'present' : 'missing'}</div>
520
- <div data-testid="app-name-consistent">
517
+ <section>
518
+ <p data-testid="custom-app-name">{auth.appName}</p>
519
+ <p data-testid="app-name-present">{auth.appName ? 'present' : 'missing'}</p>
520
+ <p data-testid="app-name-consistent">
521
521
  {auth.appName && auth.appName.length > 0 ? 'consistent' : 'inconsistent'}
522
- </div>
523
- </div>
522
+ </p>
523
+ </section>
524
524
  );
525
525
  };
526
526
 
@@ -542,14 +542,14 @@ describe('UnifiedAuthProvider', () => {
542
542
  const auth = useUnifiedAuth();
543
543
 
544
544
  return (
545
- <div>
546
- <div data-testid="rbac-enabled">
545
+ <section>
546
+ <p data-testid="rbac-enabled">
547
547
  {auth.isAuthenticated ? 'enabled' : 'disabled'}
548
- </div>
549
- <div data-testid="session-available">
548
+ </p>
549
+ <p data-testid="session-available">
550
550
  {auth.session ? 'available' : 'unavailable'}
551
- </div>
552
- </div>
551
+ </p>
552
+ </section>
553
553
  );
554
554
  };
555
555
 
@@ -564,7 +564,7 @@ describe('UnifiedAuthProvider', () => {
564
564
  expect(screen.getByTestId('rbac-enabled')).toHaveTextContent('enabled');
565
565
  }, { timeout: 3000 });
566
566
 
567
- expect(screen.getByTestId('session-available')).toBeInTheDocument();
567
+ expect(screen.getByTestId('session-available')).toBeDefined();
568
568
  });
569
569
 
570
570
  it('configures inactivity tracking when enabled', () => {
@@ -572,14 +572,14 @@ describe('UnifiedAuthProvider', () => {
572
572
  const auth = useUnifiedAuth();
573
573
 
574
574
  return (
575
- <div>
576
- <div data-testid="inactivity-config">
575
+ <section>
576
+ <p data-testid="inactivity-config">
577
577
  {auth.isLoading ? 'configuring' : 'configured'}
578
- </div>
579
- <div data-testid="context-complete">
578
+ </p>
579
+ <p data-testid="context-complete">
580
580
  {auth.user && auth.session ? 'complete' : 'incomplete'}
581
- </div>
582
- </div>
581
+ </p>
582
+ </section>
583
583
  );
584
584
  };
585
585
 
@@ -589,7 +589,7 @@ describe('UnifiedAuthProvider', () => {
589
589
  </UnifiedAuthProvider>
590
590
  );
591
591
 
592
- expect(screen.getByTestId('inactivity-config')).toBeInTheDocument();
592
+ expect(screen.getByTestId('inactivity-config')).toBeDefined();
593
593
  expect(screen.getByTestId('context-complete')).toHaveTextContent('complete');
594
594
  });
595
595
  });
@@ -67,12 +67,12 @@ function TestComponent() {
67
67
  }, [authService]);
68
68
 
69
69
  return (
70
- <div>
71
- <div data-testid="user-id">{authService.getUser()?.id || 'no-user'}</div>
72
- <div data-testid="is-authenticated">{authService.isAuthenticated().toString()}</div>
73
- <div data-testid="is-loading">{authService.isLoading().toString()}</div>
74
- <div data-testid="error">{authService.getError()?.message || 'no-error'}</div>
75
- </div>
70
+ <section>
71
+ <p data-testid="user-id">{authService.getUser()?.id || 'no-user'}</p>
72
+ <p data-testid="is-authenticated">{authService.isAuthenticated().toString()}</p>
73
+ <p data-testid="is-loading">{authService.isLoading().toString()}</p>
74
+ <p data-testid="error">{authService.getError()?.message || 'no-error'}</p>
75
+ </section>
76
76
  );
77
77
  }
78
78
 
@@ -198,7 +198,7 @@ describe('AuthServiceProvider Integration', () => {
198
198
  // The subscription is set up in useEffect, so we need to wait for that
199
199
  await waitFor(() => {
200
200
  // Check if subscription is set up by verifying the component has rendered
201
- expect(screen.getByTestId('user-id')).toBeInTheDocument();
201
+ expect(screen.getByTestId('user-id')).toBeDefined();
202
202
  }, { interval: 10, timeout: 1000 });
203
203
 
204
204
  // Wait a bit more to ensure subscription is fully set up
@@ -61,16 +61,16 @@ function TestComponent() {
61
61
  const auth = useUnifiedAuth();
62
62
 
63
63
  return (
64
- <div>
65
- <div data-testid="user-id">{auth.user?.id || 'no-user'}</div>
66
- <div data-testid="is-authenticated">{auth.isAuthenticated.toString()}</div>
67
- <div data-testid="is-loading">{auth.isLoading.toString()}</div>
68
- <div data-testid="app-name">{auth.appName}</div>
69
- <div data-testid="permissions-count">{0}</div>
70
- <div data-testid="roles-count">{0}</div>
71
- <div data-testid="organisations-count">{auth.organisations.length}</div>
72
- <div data-testid="events-count">{auth.events.length}</div>
73
- </div>
64
+ <section>
65
+ <p data-testid="user-id">{auth.user?.id || 'no-user'}</p>
66
+ <p data-testid="is-authenticated">{auth.isAuthenticated.toString()}</p>
67
+ <p data-testid="is-loading">{auth.isLoading.toString()}</p>
68
+ <p data-testid="app-name">{auth.appName}</p>
69
+ <p data-testid="permissions-count">{0}</p>
70
+ <p data-testid="roles-count">{0}</p>
71
+ <p data-testid="organisations-count">{auth.organisations.length}</p>
72
+ <p data-testid="events-count">{auth.events.length}</p>
73
+ </section>
74
74
  );
75
75
  }
76
76
 
@@ -109,9 +109,12 @@ describe('Auth/RBAC E2E Flows', () => {
109
109
  }
110
110
  return Promise.resolve({ data: false, error: null });
111
111
  },
112
- util_app_resolve: (params?: any) => {
112
+ data_app_resolve: (params?: any) => {
113
113
  // Return app ID for TEST_APP
114
- return Promise.resolve({ data: { id: 'app-123', name: 'TEST_APP' }, error: null });
114
+ return Promise.resolve({
115
+ data: [{ app_id: 'app-123', app_name: 'TEST_APP', is_active: true, has_access: true }],
116
+ error: null
117
+ });
115
118
  },
116
119
  data_user_organisation_roles_get: (params?: any) => {
117
120
  // Return organisation roles/memberships
@@ -241,8 +244,11 @@ describe('Auth/RBAC E2E Flows', () => {
241
244
  return Promise.resolve({ data: true, error: null });
242
245
  }
243
246
  // Handle other RPCs
244
- if (functionName === 'util_app_resolve') {
245
- return Promise.resolve({ data: { id: 'app-123', name: 'TEST_APP' }, error: null });
247
+ if (functionName === 'data_app_resolve') {
248
+ return Promise.resolve({
249
+ data: [{ app_id: 'app-123', app_name: 'TEST_APP', is_active: true, has_access: true }],
250
+ error: null
251
+ });
246
252
  }
247
253
  if (functionName === 'data_user_organisation_roles_get') {
248
254
  return Promise.resolve({ data: [], error: null });
@@ -419,8 +425,11 @@ describe('Auth/RBAC E2E Flows', () => {
419
425
  return Promise.resolve({ data: false, error: null });
420
426
  }
421
427
  // Handle other RPCs
422
- if (functionName === 'util_app_resolve') {
423
- return Promise.resolve({ data: { id: 'app-123', name: 'TEST_APP' }, error: null });
428
+ if (functionName === 'data_app_resolve') {
429
+ return Promise.resolve({
430
+ data: [{ app_id: 'app-123', app_name: 'TEST_APP', is_active: true, has_access: true }],
431
+ error: null
432
+ });
424
433
  }
425
434
  if (functionName === 'data_user_organisation_roles_get') {
426
435
  return Promise.resolve({
@@ -430,7 +430,7 @@ describe('RBAC Functions', () => {
430
430
  });
431
431
  });
432
432
 
433
- describe('rbac_roles_list', () => {
433
+ describe('data_rbac_roles_list', () => {
434
434
  it('should list all user roles', async () => {
435
435
  mockSupabase.rpc.mockResolvedValue({
436
436
  data: [
@@ -454,7 +454,7 @@ describe('RBAC Functions', () => {
454
454
  error: null
455
455
  });
456
456
 
457
- const result = await mockSupabase.rpc('rbac_roles_list', {
457
+ const result = await mockSupabase.rpc('data_rbac_roles_list', {
458
458
  p_user_id: mockUser.id
459
459
  });
460
460
 
@@ -476,7 +476,7 @@ describe('RBAC Functions', () => {
476
476
  error: null
477
477
  });
478
478
 
479
- const result = await mockSupabase.rpc('rbac_roles_list', {
479
+ const result = await mockSupabase.rpc('data_rbac_roles_list', {
480
480
  p_user_id: mockUser.id,
481
481
  p_organisation_id: mockOrganisation.id
482
482
  });