@cccsaurora/howler-ui 2.19.0-dev.842 → 2.19.0-dev.905

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 (328) hide show
  1. package/api/index.d.ts +0 -4
  2. package/api/index.js +2 -10
  3. package/api/search/facet/hit.d.ts +3 -1
  4. package/api/search/facet/index.d.ts +1 -3
  5. package/api/search/index.d.ts +1 -2
  6. package/api/search/index.js +1 -2
  7. package/commons/components/leftnav/LeftNavDrawer.js +1 -1
  8. package/components/app/App.js +8 -41
  9. package/components/app/hooks/useMatchers.d.ts +1 -1
  10. package/components/app/hooks/useMatchers.js +11 -23
  11. package/components/app/hooks/useMatchers.test.js +22 -22
  12. package/components/app/hooks/useTitle.js +5 -5
  13. package/components/app/providers/FavouritesProvider.js +2 -2
  14. package/components/app/providers/HitProvider.d.ts +22 -0
  15. package/components/app/providers/{RecordProvider.js → HitProvider.js} +41 -41
  16. package/components/app/providers/{RecordSearchProvider.d.ts → HitSearchProvider.d.ts} +6 -6
  17. package/components/app/providers/{RecordSearchProvider.js → HitSearchProvider.js} +17 -12
  18. package/components/app/providers/{RecordSearchProvider.test.js → HitSearchProvider.test.js} +71 -52
  19. package/components/app/providers/ModalProvider.d.ts +0 -1
  20. package/components/app/providers/ParameterProvider.d.ts +2 -9
  21. package/components/app/providers/ParameterProvider.js +240 -165
  22. package/components/app/providers/ParameterProvider.test.js +94 -346
  23. package/components/app/providers/SocketProvider.d.ts +2 -11
  24. package/components/app/providers/SocketProvider.js +5 -18
  25. package/components/app/providers/UserListProvider.js +8 -28
  26. package/components/elements/PluginTypography.d.ts +1 -2
  27. package/components/elements/PluginTypography.js +2 -3
  28. package/components/elements/UserList.d.ts +2 -5
  29. package/components/elements/UserList.js +8 -18
  30. package/components/elements/addons/search/phrase/Phrase.js +1 -1
  31. package/components/elements/display/ChipPopper.d.ts +1 -1
  32. package/components/elements/display/ChipPopper.js +5 -5
  33. package/components/elements/display/HowlerCard.js +1 -1
  34. package/components/elements/display/Modal.js +0 -2
  35. package/components/elements/display/icons/BundleButton.d.ts +6 -0
  36. package/components/elements/display/icons/BundleButton.js +32 -0
  37. package/components/elements/hit/HitActions.js +4 -4
  38. package/components/elements/hit/HitBanner.d.ts +0 -1
  39. package/components/elements/hit/HitBanner.js +47 -29
  40. package/components/elements/hit/HitCard.d.ts +0 -2
  41. package/components/elements/hit/HitCard.js +7 -7
  42. package/components/elements/{record/RecordComments.d.ts → hit/HitComments.d.ts} +4 -5
  43. package/components/elements/{record/RecordComments.js → hit/HitComments.js} +28 -29
  44. package/components/elements/{ObjectDetails.js → hit/HitDetails.js} +17 -17
  45. package/components/elements/hit/HitLabels.js +2 -2
  46. package/components/elements/hit/HitOutline.d.ts +0 -1
  47. package/components/elements/hit/HitOutline.js +3 -3
  48. package/components/elements/hit/{HitPreview.d.ts → HitQuickSearch.d.ts} +3 -3
  49. package/components/elements/hit/{HitPreview.js → HitQuickSearch.js} +4 -10
  50. package/components/elements/hit/HitRelated.d.ts +6 -0
  51. package/components/elements/hit/HitRelated.js +7 -0
  52. package/components/elements/hit/HitSummary.d.ts +1 -2
  53. package/components/elements/hit/HitSummary.js +5 -6
  54. package/components/elements/{record/RecordWorklog.d.ts → hit/HitWorklog.d.ts} +3 -4
  55. package/components/elements/{record/RecordWorklog.js → hit/HitWorklog.js} +13 -15
  56. package/components/elements/hit/aggregate/HitGraph.js +8 -8
  57. package/components/elements/hit/elements/Assigned.js +3 -6
  58. package/components/elements/hit/outlines/DefaultOutline.js +1 -1
  59. package/components/elements/view/ViewTitle.d.ts +0 -1
  60. package/components/elements/view/ViewTitle.js +2 -9
  61. package/components/hooks/useHitActions.d.ts +1 -1
  62. package/components/hooks/useHitActions.js +4 -4
  63. package/components/hooks/{useRecordSelection.d.ts → useHitSelection.d.ts} +2 -2
  64. package/components/hooks/{useRecordSelection.js → useHitSelection.js} +33 -12
  65. package/components/hooks/useMyPreferences.js +1 -10
  66. package/components/hooks/useMySearch.js +2 -2
  67. package/components/hooks/useMySitemap.js +1 -4
  68. package/components/hooks/useMyTheme.js +2 -9
  69. package/components/routes/action/edit/ActionEditor.js +2 -2
  70. package/components/routes/action/view/ActionSearch.js +1 -1
  71. package/components/routes/advanced/QueryBuilder.js +1 -1
  72. package/components/routes/advanced/QueryEditor.js +3 -3
  73. package/components/routes/advanced/historyCompletionProvider.js +3 -3
  74. package/components/routes/analytics/AnalyticDetails.js +2 -2
  75. package/components/routes/analytics/AnalyticSearch.js +1 -1
  76. package/components/routes/dossiers/DossierEditor.js +2 -2
  77. package/components/routes/dossiers/DossierEditor.test.js +1 -1
  78. package/components/routes/help/ApiDocumentation.js +1 -1
  79. package/components/routes/help/BundleDocumentation.d.ts +3 -0
  80. package/components/routes/help/BundleDocumentation.js +12 -0
  81. package/components/routes/help/HitBannerDocumentation.js +0 -1
  82. package/components/routes/help/HitDocumentation.js +3 -1
  83. package/components/routes/help/markdown/en/bundles.md.js +1 -0
  84. package/components/routes/help/markdown/fr/bundles.md.js +1 -0
  85. package/components/routes/hits/search/BundleParentMenu.d.ts +6 -0
  86. package/components/routes/hits/search/BundleParentMenu.js +32 -0
  87. package/components/routes/hits/search/BundleScroller.d.ts +2 -0
  88. package/components/routes/hits/search/BundleScroller.js +6 -0
  89. package/components/routes/hits/search/{RecordBrowser.js → HitBrowser.js} +9 -9
  90. package/components/{elements/record/RecordContextMenu.d.ts → routes/hits/search/HitContextMenu.d.ts} +3 -3
  91. package/components/routes/hits/search/HitContextMenu.js +239 -0
  92. package/components/{elements/record/RecordContextMenu.test.js → routes/hits/search/HitContextMenu.test.js} +43 -98
  93. package/components/routes/hits/search/{RecordQuery.d.ts → HitQuery.d.ts} +2 -2
  94. package/components/routes/hits/search/{RecordQuery.js → HitQuery.js} +6 -6
  95. package/components/routes/hits/search/InformationPane.d.ts +0 -1
  96. package/components/routes/hits/search/InformationPane.js +63 -50
  97. package/components/routes/hits/search/LayoutSettings.js +3 -3
  98. package/components/routes/hits/search/QuerySettings.js +1 -2
  99. package/components/routes/hits/search/QuerySettings.test.js +9 -14
  100. package/components/routes/hits/search/SearchPane.js +49 -26
  101. package/components/routes/hits/search/ViewLink.js +3 -3
  102. package/components/routes/hits/search/ViewLink.test.js +8 -8
  103. package/components/routes/hits/search/grid/AddColumnModal.js +4 -5
  104. package/components/routes/hits/search/grid/EnhancedCell.d.ts +1 -2
  105. package/components/routes/hits/search/grid/EnhancedCell.js +2 -2
  106. package/components/routes/hits/search/grid/HitGrid.js +18 -20
  107. package/components/routes/hits/search/grid/{RecordRow.d.ts → HitRow.d.ts} +2 -3
  108. package/components/routes/hits/search/grid/{RecordRow.js → HitRow.js} +8 -10
  109. package/components/routes/hits/view/HitViewer.js +13 -12
  110. package/components/routes/home/ViewCard.js +41 -47
  111. package/components/{elements/MarkdownEditor.js → routes/overviews/OverviewEditor.js} +3 -3
  112. package/components/routes/overviews/OverviewViewer.js +2 -2
  113. package/components/routes/views/ViewComposer.js +19 -46
  114. package/locales/en/translation.json +3 -122
  115. package/locales/fr/translation.json +3 -120
  116. package/models/WithMetadata.d.ts +1 -2
  117. package/models/entities/generated/{ThreatEnrichment.d.ts → Enrichment.d.ts} +1 -1
  118. package/models/entities/generated/Hit.d.ts +0 -1
  119. package/models/entities/generated/Howler.d.ts +5 -0
  120. package/models/entities/generated/Rule.d.ts +9 -6
  121. package/models/entities/generated/Threat.d.ts +2 -2
  122. package/models/entities/generated/View.d.ts +0 -1
  123. package/package.json +121 -141
  124. package/plugins/clue/components/ClueTypography.js +2 -2
  125. package/plugins/clue/utils.d.ts +1 -2
  126. package/tests/mocks.d.ts +1 -11
  127. package/tests/mocks.js +7 -12
  128. package/tests/server-handlers.js +1 -6
  129. package/tests/utils.d.ts +0 -4
  130. package/tests/utils.js +0 -20
  131. package/utils/constants.d.ts +3 -4
  132. package/utils/constants.js +0 -6
  133. package/utils/hitFunctions.d.ts +1 -2
  134. package/utils/hitFunctions.js +4 -4
  135. package/utils/socketUtils.d.ts +0 -14
  136. package/utils/socketUtils.js +1 -17
  137. package/utils/viewUtils.js +0 -3
  138. package/api/search/case.d.ts +0 -4
  139. package/api/search/case.js +0 -8
  140. package/api/socket/index.d.ts +0 -3
  141. package/api/socket/index.js +0 -6
  142. package/api/socket/viewers.d.ts +0 -2
  143. package/api/socket/viewers.js +0 -8
  144. package/api/socket/viewers.test.js +0 -44
  145. package/api/v2/case/index.d.ts +0 -9
  146. package/api/v2/case/index.js +0 -21
  147. package/api/v2/case/items.d.ts +0 -6
  148. package/api/v2/case/items.js +0 -18
  149. package/api/v2/case/rules.d.ts +0 -6
  150. package/api/v2/case/rules.js +0 -18
  151. package/api/v2/index.d.ts +0 -4
  152. package/api/v2/index.js +0 -6
  153. package/api/v2/search/facet.d.ts +0 -3
  154. package/api/v2/search/facet.js +0 -12
  155. package/api/v2/search/index.d.ts +0 -5
  156. package/api/v2/search/index.js +0 -24
  157. package/components/app/providers/RecordProvider.d.ts +0 -23
  158. package/components/elements/ContextMenu.d.ts +0 -56
  159. package/components/elements/ContextMenu.js +0 -109
  160. package/components/elements/ContextMenu.test.d.ts +0 -1
  161. package/components/elements/ContextMenu.test.js +0 -215
  162. package/components/elements/ObjectDetails.d.ts +0 -6
  163. package/components/elements/case/CaseCard.d.ts +0 -12
  164. package/components/elements/case/CaseCard.js +0 -42
  165. package/components/elements/case/CasePreview.d.ts +0 -6
  166. package/components/elements/case/CasePreview.js +0 -17
  167. package/components/elements/case/StatusIcon.d.ts +0 -5
  168. package/components/elements/case/StatusIcon.js +0 -13
  169. package/components/elements/hit/elements/AnalyticLink.d.ts +0 -9
  170. package/components/elements/hit/elements/AnalyticLink.js +0 -22
  171. package/components/elements/hit/elements/Assigned.test.d.ts +0 -1
  172. package/components/elements/hit/elements/Assigned.test.js +0 -65
  173. package/components/elements/hit/related/RelatedRecords.js +0 -63
  174. package/components/elements/observable/ObservableCard.d.ts +0 -6
  175. package/components/elements/observable/ObservableCard.js +0 -22
  176. package/components/elements/observable/ObservablePreview.d.ts +0 -6
  177. package/components/elements/observable/ObservablePreview.js +0 -12
  178. package/components/elements/record/RecordContextMenu.js +0 -268
  179. package/components/elements/record/RecordContextMenu.test.d.ts +0 -1
  180. package/components/elements/record/RecordRelated.d.ts +0 -7
  181. package/components/elements/record/RecordRelated.js +0 -34
  182. package/components/hooks/useRelatedRecords.d.ts +0 -13
  183. package/components/hooks/useRelatedRecords.js +0 -32
  184. package/components/routes/cases/CaseViewer.d.ts +0 -2
  185. package/components/routes/cases/CaseViewer.js +0 -44
  186. package/components/routes/cases/CaseViewer.test.d.ts +0 -1
  187. package/components/routes/cases/CaseViewer.test.js +0 -133
  188. package/components/routes/cases/Cases.d.ts +0 -2
  189. package/components/routes/cases/Cases.js +0 -148
  190. package/components/routes/cases/constants.d.ts +0 -6
  191. package/components/routes/cases/constants.js +0 -6
  192. package/components/routes/cases/detail/AlertPanel.d.ts +0 -6
  193. package/components/routes/cases/detail/AlertPanel.js +0 -33
  194. package/components/routes/cases/detail/CaseAssets.d.ts +0 -11
  195. package/components/routes/cases/detail/CaseAssets.js +0 -104
  196. package/components/routes/cases/detail/CaseAssets.test.d.ts +0 -1
  197. package/components/routes/cases/detail/CaseAssets.test.js +0 -167
  198. package/components/routes/cases/detail/CaseDashboard.d.ts +0 -7
  199. package/components/routes/cases/detail/CaseDashboard.js +0 -66
  200. package/components/routes/cases/detail/CaseDetails.d.ts +0 -6
  201. package/components/routes/cases/detail/CaseDetails.js +0 -70
  202. package/components/routes/cases/detail/CaseOverview.d.ts +0 -7
  203. package/components/routes/cases/detail/CaseOverview.js +0 -43
  204. package/components/routes/cases/detail/CaseRules.d.ts +0 -7
  205. package/components/routes/cases/detail/CaseRules.js +0 -57
  206. package/components/routes/cases/detail/CaseRules.test.d.ts +0 -1
  207. package/components/routes/cases/detail/CaseRules.test.js +0 -221
  208. package/components/routes/cases/detail/CaseSidebar.d.ts +0 -8
  209. package/components/routes/cases/detail/CaseSidebar.js +0 -107
  210. package/components/routes/cases/detail/CaseSidebar.test.d.ts +0 -1
  211. package/components/routes/cases/detail/CaseSidebar.test.js +0 -266
  212. package/components/routes/cases/detail/CaseTask.d.ts +0 -11
  213. package/components/routes/cases/detail/CaseTask.js +0 -66
  214. package/components/routes/cases/detail/CaseTimeline.d.ts +0 -12
  215. package/components/routes/cases/detail/CaseTimeline.js +0 -106
  216. package/components/routes/cases/detail/CaseTimeline.test.d.ts +0 -1
  217. package/components/routes/cases/detail/CaseTimeline.test.js +0 -320
  218. package/components/routes/cases/detail/CreateRuleDialog.d.ts +0 -9
  219. package/components/routes/cases/detail/CreateRuleDialog.js +0 -163
  220. package/components/routes/cases/detail/CreateRuleDialog.test.d.ts +0 -1
  221. package/components/routes/cases/detail/CreateRuleDialog.test.js +0 -259
  222. package/components/routes/cases/detail/ItemPage.d.ts +0 -6
  223. package/components/routes/cases/detail/ItemPage.js +0 -95
  224. package/components/routes/cases/detail/RelatedCasePanel.d.ts +0 -6
  225. package/components/routes/cases/detail/RelatedCasePanel.js +0 -34
  226. package/components/routes/cases/detail/TaskPanel.d.ts +0 -7
  227. package/components/routes/cases/detail/TaskPanel.js +0 -52
  228. package/components/routes/cases/detail/aggregates/CaseAggregate.d.ts +0 -11
  229. package/components/routes/cases/detail/aggregates/CaseAggregate.js +0 -24
  230. package/components/routes/cases/detail/aggregates/SourceAggregate.d.ts +0 -6
  231. package/components/routes/cases/detail/aggregates/SourceAggregate.js +0 -26
  232. package/components/routes/cases/detail/assets/Asset.d.ts +0 -14
  233. package/components/routes/cases/detail/assets/Asset.js +0 -12
  234. package/components/routes/cases/detail/assets/Asset.test.d.ts +0 -1
  235. package/components/routes/cases/detail/assets/Asset.test.js +0 -72
  236. package/components/routes/cases/detail/sidebar/CaseFolder.d.ts +0 -20
  237. package/components/routes/cases/detail/sidebar/CaseFolder.js +0 -83
  238. package/components/routes/cases/detail/sidebar/CaseFolder.test.d.ts +0 -1
  239. package/components/routes/cases/detail/sidebar/CaseFolder.test.js +0 -295
  240. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.d.ts +0 -34
  241. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.js +0 -103
  242. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.test.d.ts +0 -1
  243. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.test.js +0 -363
  244. package/components/routes/cases/detail/sidebar/FolderEntry.d.ts +0 -25
  245. package/components/routes/cases/detail/sidebar/FolderEntry.js +0 -88
  246. package/components/routes/cases/detail/sidebar/FolderEntry.test.d.ts +0 -1
  247. package/components/routes/cases/detail/sidebar/FolderEntry.test.js +0 -206
  248. package/components/routes/cases/detail/sidebar/RootDropZone.d.ts +0 -5
  249. package/components/routes/cases/detail/sidebar/RootDropZone.js +0 -33
  250. package/components/routes/cases/detail/sidebar/types.d.ts +0 -9
  251. package/components/routes/cases/detail/sidebar/utils.d.ts +0 -3
  252. package/components/routes/cases/detail/sidebar/utils.js +0 -29
  253. package/components/routes/cases/detail/sidebar/utils.test.d.ts +0 -1
  254. package/components/routes/cases/detail/sidebar/utils.test.js +0 -82
  255. package/components/routes/cases/hooks/useCase.d.ts +0 -13
  256. package/components/routes/cases/hooks/useCase.js +0 -69
  257. package/components/routes/cases/hooks/useCase.test.d.ts +0 -1
  258. package/components/routes/cases/hooks/useCase.test.js +0 -141
  259. package/components/routes/cases/modals/AddToCaseModal.d.ts +0 -7
  260. package/components/routes/cases/modals/AddToCaseModal.js +0 -59
  261. package/components/routes/cases/modals/AddToCaseModal.test.d.ts +0 -1
  262. package/components/routes/cases/modals/AddToCaseModal.test.js +0 -313
  263. package/components/routes/cases/modals/CaseRecordRow.d.ts +0 -9
  264. package/components/routes/cases/modals/CaseRecordRow.js +0 -15
  265. package/components/routes/cases/modals/CreateCaseModal.d.ts +0 -7
  266. package/components/routes/cases/modals/CreateCaseModal.js +0 -55
  267. package/components/routes/cases/modals/CreateCaseModal.test.d.ts +0 -1
  268. package/components/routes/cases/modals/CreateCaseModal.test.js +0 -358
  269. package/components/routes/cases/modals/RenameItemModal.d.ts +0 -9
  270. package/components/routes/cases/modals/RenameItemModal.js +0 -48
  271. package/components/routes/cases/modals/ResolveModal.d.ts +0 -7
  272. package/components/routes/cases/modals/ResolveModal.js +0 -115
  273. package/components/routes/cases/modals/ResolveModal.test.d.ts +0 -1
  274. package/components/routes/cases/modals/ResolveModal.test.js +0 -394
  275. package/components/routes/cases/modals/hooks.d.ts +0 -7
  276. package/components/routes/cases/modals/hooks.js +0 -44
  277. package/components/routes/cases/modals/types.d.ts +0 -5
  278. package/components/routes/cases/search/CaseAssigneeFilter.d.ts +0 -6
  279. package/components/routes/cases/search/CaseAssigneeFilter.js +0 -33
  280. package/components/routes/cases/search/CaseAssigneeFilter.test.d.ts +0 -1
  281. package/components/routes/cases/search/CaseAssigneeFilter.test.js +0 -127
  282. package/components/routes/cases/search/CaseDateFilter.d.ts +0 -13
  283. package/components/routes/cases/search/CaseDateFilter.js +0 -26
  284. package/components/routes/cases/search/CaseDateFilter.test.d.ts +0 -1
  285. package/components/routes/cases/search/CaseDateFilter.test.js +0 -115
  286. package/components/routes/cases/search/CaseStatusFilter.d.ts +0 -6
  287. package/components/routes/cases/search/CaseStatusFilter.js +0 -13
  288. package/components/routes/cases/search/CaseStatusFilter.test.d.ts +0 -1
  289. package/components/routes/cases/search/CaseStatusFilter.test.js +0 -86
  290. package/components/routes/hits/search/shared/IndexPicker.d.ts +0 -2
  291. package/components/routes/hits/search/shared/IndexPicker.js +0 -20
  292. package/components/routes/observables/ObservableViewer.d.ts +0 -7
  293. package/components/routes/observables/ObservableViewer.js +0 -27
  294. package/models/entities/generated/AttachmentsFile.d.ts +0 -12
  295. package/models/entities/generated/Case.d.ts +0 -28
  296. package/models/entities/generated/DestinationOriginal.d.ts +0 -19
  297. package/models/entities/generated/EmailAttachment.d.ts +0 -8
  298. package/models/entities/generated/EmailParent.d.ts +0 -19
  299. package/models/entities/generated/Enrichments.d.ts +0 -7
  300. package/models/entities/generated/EnrichmentsIndicator.d.ts +0 -21
  301. package/models/entities/generated/HttpResponse.d.ts +0 -11
  302. package/models/entities/generated/Item.d.ts +0 -9
  303. package/models/entities/generated/Observable.d.ts +0 -85
  304. package/models/entities/generated/ObservableCloud.d.ts +0 -20
  305. package/models/entities/generated/ObservableDestination.d.ts +0 -23
  306. package/models/entities/generated/ObservableEmail.d.ts +0 -30
  307. package/models/entities/generated/ObservableFile.d.ts +0 -36
  308. package/models/entities/generated/ObservableHowler.d.ts +0 -42
  309. package/models/entities/generated/ObservableHttp.d.ts +0 -11
  310. package/models/entities/generated/ObservableObserver.d.ts +0 -21
  311. package/models/entities/generated/ObservableOrganization.d.ts +0 -7
  312. package/models/entities/generated/ObservableProcess.d.ts +0 -34
  313. package/models/entities/generated/ObservableSource.d.ts +0 -23
  314. package/models/entities/generated/ObservableThreat.d.ts +0 -21
  315. package/models/entities/generated/ObservableTls.d.ts +0 -12
  316. package/models/entities/generated/ObserverIngress.d.ts +0 -9
  317. package/models/entities/generated/Task.d.ts +0 -10
  318. package/models/socket/CaseUpdate.d.ts +0 -5
  319. package/models/socket/ViewersUpdate.d.ts +0 -4
  320. package/utils/socketUtils.test.d.ts +0 -1
  321. package/utils/socketUtils.test.js +0 -59
  322. package/utils/typeUtils.d.ts +0 -7
  323. package/utils/typeUtils.js +0 -27
  324. /package/{api/socket/viewers.test.d.ts → components/app/providers/HitSearchProvider.test.d.ts} +0 -0
  325. /package/components/elements/hit/{related/RelatedRecords.d.ts → HitDetails.d.ts} +0 -0
  326. /package/components/routes/hits/search/{RecordBrowser.d.ts → HitBrowser.d.ts} +0 -0
  327. /package/components/{app/providers/RecordSearchProvider.test.d.ts → routes/hits/search/HitContextMenu.test.d.ts} +0 -0
  328. /package/components/{elements/MarkdownEditor.d.ts → routes/overviews/OverviewEditor.d.ts} +0 -0
package/api/index.d.ts CHANGED
@@ -8,10 +8,8 @@ import * as hit from '@cccsaurora/howler-ui/api/hit';
8
8
  import * as notebook from '@cccsaurora/howler-ui/api/notebook';
9
9
  import * as overview from '@cccsaurora/howler-ui/api/overview';
10
10
  import * as search from '@cccsaurora/howler-ui/api/search';
11
- import * as socket from '@cccsaurora/howler-ui/api/socket';
12
11
  import * as template from '@cccsaurora/howler-ui/api/template';
13
12
  import * as user from '@cccsaurora/howler-ui/api/user';
14
- import * as v2 from '@cccsaurora/howler-ui/api/v2';
15
13
  import * as view from '@cccsaurora/howler-ui/api/view';
16
14
  /**
17
15
  * Defining the default export exposing all children routes of '/api/v1/'.
@@ -26,12 +24,10 @@ declare const api: {
26
24
  hit: typeof hit;
27
25
  overview: typeof overview;
28
26
  search: typeof search;
29
- socket: typeof socket;
30
27
  template: typeof template;
31
28
  user: typeof user;
32
29
  view: typeof view;
33
30
  notebook: typeof notebook;
34
- v2: typeof v2;
35
31
  };
36
32
  /**
37
33
  * The specification interface of an Howler HTTP response.
package/api/index.js CHANGED
@@ -8,10 +8,8 @@ import * as hit from '@cccsaurora/howler-ui/api/hit';
8
8
  import * as notebook from '@cccsaurora/howler-ui/api/notebook';
9
9
  import * as overview from '@cccsaurora/howler-ui/api/overview';
10
10
  import * as search from '@cccsaurora/howler-ui/api/search';
11
- import * as socket from '@cccsaurora/howler-ui/api/socket';
12
11
  import * as template from '@cccsaurora/howler-ui/api/template';
13
12
  import * as user from '@cccsaurora/howler-ui/api/user';
14
- import * as v2 from '@cccsaurora/howler-ui/api/v2';
15
13
  import * as view from '@cccsaurora/howler-ui/api/view';
16
14
  import AxiosClient from '@cccsaurora/howler-ui/rest/AxiosClient';
17
15
  import urlJoin from 'url-join';
@@ -37,12 +35,10 @@ const api = {
37
35
  hit,
38
36
  overview,
39
37
  search,
40
- socket,
41
38
  template,
42
39
  user,
43
40
  view,
44
- notebook,
45
- v2
41
+ notebook
46
42
  };
47
43
  /**
48
44
  * The base section of the Howler API uri.
@@ -61,11 +57,7 @@ export const uri = () => {
61
57
  * @returns `string` - properly formatted howler uri.
62
58
  */
63
59
  const format = (_uri) => {
64
- // skip validation if we're hitting the socket endpoints
65
- if (_uri.startsWith('/socket')) {
66
- return _uri;
67
- }
68
- return _uri.startsWith('/api') ? _uri : `${uri()}/${_uri.replace(/\/$/, '')}`;
60
+ return _uri.startsWith(uri()) ? _uri : `${uri()}/${_uri.replace(/\/$/, '')}`;
69
61
  };
70
62
  /**
71
63
  * Append series of search parameters to the specified uri.
@@ -1,3 +1,5 @@
1
1
  import type { HowlerFacetSearchRequest, HowlerFacetSearchResponse } from '@cccsaurora/howler-ui/api/search/facet';
2
2
  export declare const uri: () => string;
3
- export declare const post: (request?: HowlerFacetSearchRequest) => Promise<HowlerFacetSearchResponse>;
3
+ export declare const post: (request?: HowlerFacetSearchRequest) => Promise<{
4
+ [index: string]: HowlerFacetSearchResponse;
5
+ }>;
@@ -8,8 +8,6 @@ export type HowlerFacetSearchRequest = {
8
8
  filters?: string[];
9
9
  };
10
10
  export type HowlerFacetSearchResponse = {
11
- [field: string]: {
12
- [value: string]: number;
13
- };
11
+ [value: string]: number;
14
12
  };
15
13
  export { hit };
@@ -1,6 +1,5 @@
1
1
  import * as action from '@cccsaurora/howler-ui/api/search/action';
2
2
  import * as analytic from '@cccsaurora/howler-ui/api/search/analytic';
3
- import * as case_ from '@cccsaurora/howler-ui/api/search/case';
4
3
  import * as count from '@cccsaurora/howler-ui/api/search/count';
5
4
  import * as dossier from '@cccsaurora/howler-ui/api/search/dossier';
6
5
  import * as facet from '@cccsaurora/howler-ui/api/search/facet';
@@ -61,4 +60,4 @@ export type HowlerExplainSearchResponse = {
61
60
  explanation: string;
62
61
  }[];
63
62
  };
64
- export { action, analytic, case_ as case, count, dossier, facet, fields, grouped, histogram, hit, overview, template, user, view };
63
+ export { action, analytic, count, dossier, facet, fields, grouped, histogram, hit, overview, template, user, view };
@@ -1,7 +1,6 @@
1
1
  import { joinUri, uri as parentUri } from '@cccsaurora/howler-ui/api';
2
2
  import * as action from '@cccsaurora/howler-ui/api/search/action';
3
3
  import * as analytic from '@cccsaurora/howler-ui/api/search/analytic';
4
- import * as case_ from '@cccsaurora/howler-ui/api/search/case';
5
4
  import * as count from '@cccsaurora/howler-ui/api/search/count';
6
5
  import * as dossier from '@cccsaurora/howler-ui/api/search/dossier';
7
6
  import * as facet from '@cccsaurora/howler-ui/api/search/facet';
@@ -16,4 +15,4 @@ import * as view from '@cccsaurora/howler-ui/api/search/view';
16
15
  export const uri = () => {
17
16
  return joinUri(parentUri(), 'search');
18
17
  };
19
- export { action, analytic, case_ as case, count, dossier, facet, fields, grouped, histogram, hit, overview, template, user, view };
18
+ export { action, analytic, count, dossier, facet, fields, grouped, histogram, hit, overview, template, user, view };
@@ -75,7 +75,7 @@ const LeftNavDrawer = () => {
75
75
  }
76
76
  }, children: _jsx(AppName, {}) }), !isTopLayout && _jsx(Divider, {})] }));
77
77
  const hide = (_jsx(List, { disablePadding: true, children: _jsxs(ListItemButton, { onClick: leftnav.toggle, children: [_jsx(ListItemIcon, { children: leftnav.open ? _jsx(ChevronLeftIcon, {}) : _jsx(ChevronRightIcon, {}) }), _jsx(ListItemText, { primary: t('drawer.collapse') })] }, "chevron") }));
78
- return (_jsx(ClickAwayListener, { mouseEvent: "onMouseDown", touchEvent: "onTouchStart", onClickAway: onCloseDrawerIfOpen, children: _jsxs(StyledDrawer, { variant: "permanent", style: { height: '100%' }, width: preferences.leftnav.width, open: leftnav.open, children: [leftnav.open ? (header) : (_jsx(Tooltip, { title: preferences.appName, "aria-label": preferences.appName, placement: "right", children: header })), _jsx(List, { disablePadding: true, children: leftnav.elements.map((e, i) => {
78
+ return (_jsx(ClickAwayListener, { mouseEvent: "onMouseDown", touchEvent: "onTouchStart", onClickAway: onCloseDrawerIfOpen, children: _jsxs(StyledDrawer, { PaperProps: { elevation: 1 }, variant: "permanent", style: { height: '100%' }, width: preferences.leftnav.width, open: leftnav.open, children: [leftnav.open ? (header) : (_jsx(Tooltip, { title: preferences.appName, "aria-label": preferences.appName, placement: "right", children: header })), _jsx(List, { disablePadding: true, children: leftnav.elements.map((e, i) => {
79
79
  if (e.type === 'item') {
80
80
  const item = e.element;
81
81
  return _jsx(LeftNavItem, { item: item, onClick: isSmDown && onCloseDrawerIfOpen }, item.id);
@@ -26,13 +26,6 @@ import UserSearchProvider from '@cccsaurora/howler-ui/components/routes/admin/us
26
26
  import QueryBuilder from '@cccsaurora/howler-ui/components/routes/advanced/QueryBuilder';
27
27
  import AnalyticDetails from '@cccsaurora/howler-ui/components/routes/analytics/AnalyticDetails';
28
28
  import AnalyticSearch from '@cccsaurora/howler-ui/components/routes/analytics/AnalyticSearch';
29
- import CaseViewer from '@cccsaurora/howler-ui/components/routes/cases/CaseViewer';
30
- import Cases from '@cccsaurora/howler-ui/components/routes/cases/Cases';
31
- import CaseAssets from '@cccsaurora/howler-ui/components/routes/cases/detail/CaseAssets';
32
- import CaseDashboard from '@cccsaurora/howler-ui/components/routes/cases/detail/CaseDashboard';
33
- import CaseRules from '@cccsaurora/howler-ui/components/routes/cases/detail/CaseRules';
34
- import CaseTimeline from '@cccsaurora/howler-ui/components/routes/cases/detail/CaseTimeline';
35
- import ItemPage from '@cccsaurora/howler-ui/components/routes/cases/detail/ItemPage';
36
29
  import DossierEditor from '@cccsaurora/howler-ui/components/routes/dossiers/DossierEditor';
37
30
  import Dossiers from '@cccsaurora/howler-ui/components/routes/dossiers/Dossiers';
38
31
  import ActionDocumentation from '@cccsaurora/howler-ui/components/routes/help/ActionDocumentation';
@@ -47,7 +40,7 @@ import RetentionDocumentation from '@cccsaurora/howler-ui/components/routes/help
47
40
  import SearchDocumentation from '@cccsaurora/howler-ui/components/routes/help/SearchDocumentation';
48
41
  import TemplateDocumentation from '@cccsaurora/howler-ui/components/routes/help/TemplateDocumentation';
49
42
  import ViewDocumentation from '@cccsaurora/howler-ui/components/routes/help/ViewDocumentation';
50
- import RecordBrowser from '@cccsaurora/howler-ui/components/routes/hits/search/RecordBrowser';
43
+ import HitBrowser from '@cccsaurora/howler-ui/components/routes/hits/search/HitBrowser';
51
44
  import HitViewer from '@cccsaurora/howler-ui/components/routes/hits/view/HitViewer';
52
45
  import Home from '@cccsaurora/howler-ui/components/routes/home';
53
46
  import OverviewViewer from '@cccsaurora/howler-ui/components/routes/overviews/OverviewViewer';
@@ -79,11 +72,11 @@ import AvatarProvider from './providers/AvatarProvider';
79
72
  import CustomPluginProvider from './providers/CustomPluginProvider';
80
73
  import FavouriteProvider from './providers/FavouritesProvider';
81
74
  import FieldProvider from './providers/FieldProvider';
75
+ import HitProvider from './providers/HitProvider';
82
76
  import LocalStorageProvider from './providers/LocalStorageProvider';
83
77
  import ModalProvider from './providers/ModalProvider';
84
78
  import OverviewProvider from './providers/OverviewProvider';
85
79
  import ParameterProvider from './providers/ParameterProvider';
86
- import RecordProvider from './providers/RecordProvider';
87
80
  import SocketProvider from './providers/SocketProvider';
88
81
  import UserListProvider from './providers/UserListProvider';
89
82
  import ViewProvider from './providers/ViewProvider';
@@ -156,7 +149,7 @@ const MyAppProvider = ({ children }) => {
156
149
  const mySitemap = useMySitemap();
157
150
  const myUser = useMyUser();
158
151
  const mySearch = useMySearch();
159
- return (_jsx(ErrorBoundary, { children: _jsx(AppProvider, { preferences: myPreferences, theme: myTheme, sitemap: mySitemap, user: myUser, search: mySearch, children: _jsx(CustomPluginProvider, { children: _jsx(ErrorBoundary, { children: _jsx(ErrorBoundary, { children: _jsx(ViewProvider, { children: _jsx(AvatarProvider, { children: _jsx(ModalProvider, { children: _jsx(FieldProvider, { children: _jsx(LocalStorageProvider, { children: _jsx(SocketProvider, { children: _jsx(RecordProvider, { children: _jsx(OverviewProvider, { children: _jsx(AnalyticProvider, { children: _jsx(FavouriteProvider, { children: _jsx(UserListProvider, { children: children }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }));
152
+ return (_jsx(ErrorBoundary, { children: _jsx(AppProvider, { preferences: myPreferences, theme: myTheme, sitemap: mySitemap, user: myUser, search: mySearch, children: _jsx(CustomPluginProvider, { children: _jsx(ErrorBoundary, { children: _jsx(ErrorBoundary, { children: _jsx(ViewProvider, { children: _jsx(AvatarProvider, { children: _jsx(ModalProvider, { children: _jsx(FieldProvider, { children: _jsx(LocalStorageProvider, { children: _jsx(SocketProvider, { children: _jsx(HitProvider, { children: _jsx(OverviewProvider, { children: _jsx(AnalyticProvider, { children: _jsx(FavouriteProvider, { children: _jsx(UserListProvider, { children: children }) }) }) }) }) }) }) }) }) }) }) }) }) }) }) }));
160
153
  };
161
154
  const AppProviderWrapper = () => {
162
155
  return (_jsx(I18nextProvider, { i18n: i18n, defaultNS: "translation", children: _jsx(ApiConfigProvider, { children: _jsx(PluginProvider, { pluginStore: howlerPluginStore.pluginStore, children: _jsx(AppBarProvider, { children: _jsxs(MyAppProvider, { children: [_jsx(MyApp, {}), _jsx(Modal, {})] }) }) }) }) }));
@@ -180,45 +173,19 @@ const createRouter = () => createBrowserRouter([
180
173
  },
181
174
  {
182
175
  path: 'hits',
183
- element: _jsx(RecordBrowser, {})
176
+ element: _jsx(HitBrowser, {})
184
177
  },
185
178
  {
186
179
  path: 'search',
187
- element: _jsx(RecordBrowser, {})
180
+ element: _jsx(HitBrowser, {})
188
181
  },
189
182
  {
190
183
  path: 'hits/:id',
191
184
  element: _jsx(HitViewer, {})
192
185
  },
193
186
  {
194
- path: 'cases',
195
- element: _jsx(Cases, {})
196
- },
197
- {
198
- path: 'cases/:id',
199
- element: _jsx(CaseViewer, {}),
200
- children: [
201
- {
202
- index: true,
203
- element: _jsx(CaseDashboard, {})
204
- },
205
- {
206
- path: 'assets',
207
- element: _jsx(CaseAssets, {})
208
- },
209
- {
210
- path: 'timeline',
211
- element: _jsx(CaseTimeline, {})
212
- },
213
- {
214
- path: 'rules',
215
- element: _jsx(CaseRules, {})
216
- },
217
- {
218
- path: '*',
219
- element: _jsx(ItemPage, {})
220
- }
221
- ]
187
+ path: 'bundles/:id',
188
+ element: _jsx(HitBrowser, {})
222
189
  },
223
190
  {
224
191
  path: 'templates',
@@ -258,7 +225,7 @@ const createRouter = () => createBrowserRouter([
258
225
  },
259
226
  {
260
227
  path: 'views/:id',
261
- element: _jsx(RecordBrowser, {})
228
+ element: _jsx(HitBrowser, {})
262
229
  },
263
230
  {
264
231
  path: 'views/:id/edit',
@@ -1,6 +1,6 @@
1
1
  import type { Hit } from '@cccsaurora/howler-ui/models/entities/generated/Hit';
2
2
  import type { WithMetadata } from '@cccsaurora/howler-ui/models/WithMetadata';
3
- declare const useMatchers: (lazy?: boolean) => {
3
+ declare const useMatchers: () => {
4
4
  getMatchingDossiers: (hit: WithMetadata<Hit>) => Promise<import("../../../models/entities/generated/Dossier").Dossier[]>;
5
5
  getMatchingOverview: (hit: WithMetadata<Hit>) => Promise<import("../../../models/entities/generated/Overview").Overview>;
6
6
  getMatchingTemplate: (hit: WithMetadata<Hit>) => Promise<import("../../../models/entities/generated/Template").Template>;
@@ -2,9 +2,9 @@
2
2
  import { has } from 'lodash-es';
3
3
  import { useCallback } from 'react';
4
4
  import { useContextSelector } from 'use-context-selector';
5
- import { RecordContext } from '../providers/RecordProvider';
6
- const useMatchers = (lazy = false) => {
7
- const getRecord = useContextSelector(RecordContext, ctx => ctx.getRecord);
5
+ import { HitContext } from '../providers/HitProvider';
6
+ const useMatchers = () => {
7
+ const getHit = useContextSelector(HitContext, ctx => ctx.getHit);
8
8
  const getMatchingTemplate = useCallback(async (hit) => {
9
9
  if (!hit) {
10
10
  return null;
@@ -12,18 +12,15 @@ const useMatchers = (lazy = false) => {
12
12
  if (has(hit, '__template')) {
13
13
  return hit.__template;
14
14
  }
15
- if (lazy) {
16
- return null;
17
- }
18
15
  // This is a fallback in case metadata is not included. In most cases templates are shown, the template metadata
19
16
  // should also exist
20
17
  try {
21
- return (await getRecord(hit.howler.id, true)).__template;
18
+ return (await getHit(hit.howler.id, true)).__template;
22
19
  }
23
20
  catch (e) {
24
21
  return null;
25
22
  }
26
- }, [getRecord, lazy]);
23
+ }, [getHit]);
27
24
  const getMatchingOverview = useCallback(async (hit) => {
28
25
  if (!hit) {
29
26
  return null;
@@ -31,18 +28,15 @@ const useMatchers = (lazy = false) => {
31
28
  if (has(hit, '__overview')) {
32
29
  return hit.__overview;
33
30
  }
34
- if (lazy) {
35
- return null;
36
- }
37
31
  // This is a fallback in case metadata is not included. In most cases templates are shown, the template metadata
38
32
  // should also exist
39
33
  try {
40
- return (await getRecord(hit.howler.id, true)).__overview;
34
+ return (await getHit(hit.howler.id, true)).__overview;
41
35
  }
42
36
  catch (e) {
43
37
  return null;
44
38
  }
45
- }, [getRecord, lazy]);
39
+ }, [getHit]);
46
40
  const getMatchingDossiers = useCallback(async (hit) => {
47
41
  if (!hit) {
48
42
  return null;
@@ -50,18 +44,15 @@ const useMatchers = (lazy = false) => {
50
44
  if (has(hit, '__dossiers')) {
51
45
  return hit.__dossiers;
52
46
  }
53
- if (lazy) {
54
- return null;
55
- }
56
47
  // This is a fallback in case metadata is not included. In most cases templates are shown, the template metadata
57
48
  // should also exist
58
49
  try {
59
- return (await getRecord(hit.howler.id, true)).__dossiers ?? [];
50
+ return (await getHit(hit.howler.id, true)).__dossiers ?? [];
60
51
  }
61
52
  catch (e) {
62
53
  return [];
63
54
  }
64
- }, [getRecord, lazy]);
55
+ }, [getHit]);
65
56
  const getMatchingAnalytic = useCallback(async (hit) => {
66
57
  if (!hit) {
67
58
  return null;
@@ -69,17 +60,14 @@ const useMatchers = (lazy = false) => {
69
60
  if (has(hit, '__analytic')) {
70
61
  return hit.__analytic;
71
62
  }
72
- if (lazy) {
73
- return null;
74
- }
75
63
  // This is a fallback in case metadata is not included.
76
64
  try {
77
- return (await getRecord(hit.howler.id, true)).__analytic;
65
+ return (await getHit(hit.howler.id, true)).__analytic;
78
66
  }
79
67
  catch (e) {
80
68
  return null;
81
69
  }
82
- }, [getRecord, lazy]);
70
+ }, [getHit]);
83
71
  return {
84
72
  getMatchingDossiers,
85
73
  getMatchingOverview,
@@ -1,7 +1,7 @@
1
1
  import { renderHook } from '@testing-library/react';
2
2
  import { useContextSelector } from 'use-context-selector';
3
3
  import { beforeEach, describe, expect, it, vi } from 'vitest';
4
- import { RecordContext } from '../providers/RecordProvider';
4
+ import { HitContext } from '../providers/HitProvider';
5
5
  import useMatchers from './useMatchers';
6
6
  // Mock the useContextSelector hook
7
7
  vi.mock('use-context-selector', () => ({
@@ -40,14 +40,14 @@ const mockHitWithMetadata = {
40
40
  __overview: mockOverview,
41
41
  __dossiers: mockDossiers
42
42
  };
43
- const mockGetRecord = vi.fn();
43
+ const mockGetHit = vi.fn();
44
44
  describe('useMatchers', () => {
45
45
  beforeEach(() => {
46
46
  vi.clearAllMocks();
47
47
  // Mock useContextSelector to return our mock getHit function
48
48
  useContextSelector.mockImplementation((context, selector) => {
49
- if (context === RecordContext) {
50
- return selector({ getRecord: mockGetRecord });
49
+ if (context === HitContext) {
50
+ return selector({ getHit: mockGetHit });
51
51
  }
52
52
  return null;
53
53
  });
@@ -69,25 +69,25 @@ describe('useMatchers', () => {
69
69
  const { result } = renderHook(() => useMatchers());
70
70
  const template = await result.current.getMatchingTemplate(mockHitWithMetadata);
71
71
  expect(template).toBe(mockTemplate);
72
- expect(mockGetRecord).not.toHaveBeenCalled();
72
+ expect(mockGetHit).not.toHaveBeenCalled();
73
73
  });
74
74
  it('should fetch hit with metadata when template is not present', async () => {
75
75
  const { has } = await import('lodash-es');
76
76
  has.mockReturnValue(false);
77
77
  const hitWithFetchedMetadata = { ...mockHit, __template: mockTemplate };
78
- mockGetRecord.mockResolvedValue(hitWithFetchedMetadata);
78
+ mockGetHit.mockResolvedValue(hitWithFetchedMetadata);
79
79
  const { result } = renderHook(() => useMatchers());
80
80
  const template = await result.current.getMatchingTemplate(mockHit);
81
81
  expect(template).toBe(mockTemplate);
82
- expect(mockGetRecord).toHaveBeenCalledWith('test-hit-id', true);
82
+ expect(mockGetHit).toHaveBeenCalledWith('test-hit-id', true);
83
83
  });
84
84
  it('should handle getHit rejection gracefully', async () => {
85
85
  const { has } = await import('lodash-es');
86
86
  has.mockReturnValue(false);
87
- mockGetRecord.mockRejectedValue(new Error('Failed to fetch hit'));
87
+ mockGetHit.mockRejectedValue(new Error('Failed to fetch hit'));
88
88
  const { result } = renderHook(() => useMatchers());
89
89
  await expect(result.current.getMatchingTemplate(mockHit)).resolves.toBeNull();
90
- expect(mockGetRecord).toHaveBeenCalledWith('test-hit-id', true);
90
+ expect(mockGetHit).toHaveBeenCalledWith('test-hit-id', true);
91
91
  });
92
92
  });
93
93
  describe('getMatchingOverview', () => {
@@ -107,25 +107,25 @@ describe('useMatchers', () => {
107
107
  const { result } = renderHook(() => useMatchers());
108
108
  const overview = await result.current.getMatchingOverview(mockHitWithMetadata);
109
109
  expect(overview).toBe(mockOverview);
110
- expect(mockGetRecord).not.toHaveBeenCalled();
110
+ expect(mockGetHit).not.toHaveBeenCalled();
111
111
  });
112
112
  it('should fetch hit with metadata when overview is not present', async () => {
113
113
  const { has } = await import('lodash-es');
114
114
  has.mockReturnValue(false);
115
115
  const hitWithFetchedMetadata = { ...mockHit, __overview: mockOverview };
116
- mockGetRecord.mockResolvedValue(hitWithFetchedMetadata);
116
+ mockGetHit.mockResolvedValue(hitWithFetchedMetadata);
117
117
  const { result } = renderHook(() => useMatchers());
118
118
  const overview = await result.current.getMatchingOverview(mockHit);
119
119
  expect(overview).toBe(mockOverview);
120
- expect(mockGetRecord).toHaveBeenCalledWith('test-hit-id', true);
120
+ expect(mockGetHit).toHaveBeenCalledWith('test-hit-id', true);
121
121
  });
122
122
  it('should handle getHit rejection gracefully', async () => {
123
123
  const { has } = await import('lodash-es');
124
124
  has.mockReturnValue(false);
125
- mockGetRecord.mockRejectedValue(new Error('Failed to fetch hit'));
125
+ mockGetHit.mockRejectedValue(new Error('Failed to fetch hit'));
126
126
  const { result } = renderHook(() => useMatchers());
127
127
  await expect(result.current.getMatchingOverview(mockHit)).resolves.toBeNull();
128
- expect(mockGetRecord).toHaveBeenCalledWith('test-hit-id', true);
128
+ expect(mockGetHit).toHaveBeenCalledWith('test-hit-id', true);
129
129
  });
130
130
  });
131
131
  describe('getMatchingDossiers', () => {
@@ -145,25 +145,25 @@ describe('useMatchers', () => {
145
145
  const { result } = renderHook(() => useMatchers());
146
146
  const dossiers = await result.current.getMatchingDossiers(mockHitWithMetadata);
147
147
  expect(dossiers).toBe(mockDossiers);
148
- expect(mockGetRecord).not.toHaveBeenCalled();
148
+ expect(mockGetHit).not.toHaveBeenCalled();
149
149
  });
150
150
  it('should fetch hit with metadata when dossiers are not present', async () => {
151
151
  const { has } = await import('lodash-es');
152
152
  has.mockReturnValue(false);
153
153
  const hitWithFetchedMetadata = { ...mockHit, __dossiers: mockDossiers };
154
- mockGetRecord.mockResolvedValue(hitWithFetchedMetadata);
154
+ mockGetHit.mockResolvedValue(hitWithFetchedMetadata);
155
155
  const { result } = renderHook(() => useMatchers());
156
156
  const dossiers = await result.current.getMatchingDossiers(mockHit);
157
157
  expect(dossiers).toBe(mockDossiers);
158
- expect(mockGetRecord).toHaveBeenCalledWith('test-hit-id', true);
158
+ expect(mockGetHit).toHaveBeenCalledWith('test-hit-id', true);
159
159
  });
160
160
  it('should handle getHit rejection gracefully', async () => {
161
161
  const { has } = await import('lodash-es');
162
162
  has.mockReturnValue(false);
163
- mockGetRecord.mockRejectedValue(new Error('Failed to fetch hit'));
163
+ mockGetHit.mockRejectedValue(new Error('Failed to fetch hit'));
164
164
  const { result } = renderHook(() => useMatchers());
165
165
  await expect(result.current.getMatchingDossiers(mockHit)).resolves.toEqual([]);
166
- expect(mockGetRecord).toHaveBeenCalledWith('test-hit-id', true);
166
+ expect(mockGetHit).toHaveBeenCalledWith('test-hit-id', true);
167
167
  });
168
168
  });
169
169
  describe('integration tests', () => {
@@ -177,7 +177,7 @@ describe('useMatchers', () => {
177
177
  ...mockHit,
178
178
  __template: mockTemplate
179
179
  };
180
- mockGetRecord.mockResolvedValue({
180
+ mockGetHit.mockResolvedValue({
181
181
  ...mockHit,
182
182
  __overview: mockOverview,
183
183
  __dossiers: mockDossiers
@@ -200,7 +200,7 @@ describe('useMatchers', () => {
200
200
  it('should handle empty or undefined metadata gracefully', async () => {
201
201
  const { has } = await import('lodash-es');
202
202
  has.mockReturnValue(false);
203
- mockGetRecord.mockResolvedValue({
203
+ mockGetHit.mockResolvedValue({
204
204
  ...mockHit,
205
205
  __template: undefined,
206
206
  __overview: null,
@@ -213,7 +213,7 @@ describe('useMatchers', () => {
213
213
  expect(template).toBeUndefined();
214
214
  expect(overview).toBeNull();
215
215
  expect(dossiers).toEqual([]);
216
- expect(mockGetRecord).toHaveBeenCalledTimes(3);
216
+ expect(mockGetHit).toHaveBeenCalledTimes(3);
217
217
  });
218
218
  it('should maintain referential equality of returned functions', () => {
219
219
  const { result, rerender } = renderHook(() => useMatchers());
@@ -5,23 +5,23 @@ import { useTranslation } from 'react-i18next';
5
5
  import { useLocation, useParams, useSearchParams } from 'react-router-dom';
6
6
  import { useContextSelector } from 'use-context-selector';
7
7
  import { AnalyticContext } from '../providers/AnalyticProvider';
8
- import { RecordContext } from '../providers/RecordProvider';
8
+ import { HitContext } from '../providers/HitProvider';
9
9
  const useTitle = () => {
10
10
  const { t } = useTranslation();
11
11
  const location = useLocation();
12
12
  const params = useParams();
13
13
  const searchParams = useSearchParams()[0];
14
14
  const sitemap = useMySitemap();
15
- const { getAnalyticFromId } = useContext(AnalyticContext) ?? {};
16
- const hits = useContextSelector(RecordContext, ctx => ctx.records);
17
- const getHit = useContextSelector(RecordContext, ctx => ctx.getRecord);
15
+ const { getAnalyticFromId } = useContext(AnalyticContext);
16
+ const hits = useContextSelector(HitContext, ctx => ctx.hits);
17
+ const getHit = useContextSelector(HitContext, ctx => ctx.getHit);
18
18
  const setTitle = useCallback((title) => {
19
19
  document.querySelector('title').innerHTML = title;
20
20
  }, []);
21
21
  const runChecks = useCallback(async () => {
22
22
  const searchType = location.pathname.replace(/^\/(\w+)(\/.+)?$/, '$1').replace(/s$/, '');
23
23
  if (searchType === 'analytic') {
24
- if (params.id && getAnalyticFromId) {
24
+ if (params.id) {
25
25
  const analytic = await getAnalyticFromId(params.id);
26
26
  if (analytic) {
27
27
  setTitle(`${t('route.analytics.view')} - ${analytic.name}`);
@@ -120,11 +120,11 @@ const FavouriteProvider = ({ children }) => {
120
120
  (async () => {
121
121
  const analyticElement = processAnalyticElement();
122
122
  if (analyticElement) {
123
- newElements.splice(2, 0, analyticElement);
123
+ newElements.splice(1, 0, analyticElement);
124
124
  }
125
125
  const viewElement = await processViewElement();
126
126
  if (viewElement) {
127
- newElements.splice(2, 0, viewElement);
127
+ newElements.splice(1, 0, viewElement);
128
128
  }
129
129
  leftNav.setElements(newElements);
130
130
  })();
@@ -0,0 +1,22 @@
1
+ import type { Hit } from '@cccsaurora/howler-ui/models/entities/generated/Hit';
2
+ import type { WithMetadata } from '@cccsaurora/howler-ui/models/WithMetadata';
3
+ import type { FC, PropsWithChildren } from 'react';
4
+ export interface HitContextType {
5
+ hits: {
6
+ [index: string]: Hit;
7
+ };
8
+ selectedHits: Hit[];
9
+ addHitToSelection: (id: string) => void;
10
+ removeHitFromSelection: (id: string) => void;
11
+ clearSelectedHits: (except?: string) => void;
12
+ loadHits: (hits: Hit[]) => void;
13
+ updateHit: (newHit: Hit) => void;
14
+ getHit: (id: string, force?: boolean) => Promise<WithMetadata<Hit>>;
15
+ }
16
+ export declare const HitContext: import("use-context-selector").Context<HitContextType>;
17
+ /**
18
+ * Central repository for storing individual hit data across the application. Allows efficient retrieval of hits across componenents.
19
+ */
20
+ declare const HitProvider: FC<PropsWithChildren>;
21
+ export declare const useHitContextSelector: <Selected>(selector: (value: HitContextType) => Selected) => Selected;
22
+ export default HitProvider;