@sinequa/atomic-angular 0.0.140 → 0.1.3

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 (207) hide show
  1. package/README.md +145 -0
  2. package/components/no-result/i18n/en.json +5 -0
  3. package/components/no-result/i18n/fr.json +5 -0
  4. package/components/sort-selector/i18n/en.json +3 -0
  5. package/components/sort-selector/i18n/fr.json +3 -0
  6. package/components/source/i18n/en.json +3 -0
  7. package/components/source/i18n/fr.json +3 -0
  8. package/features/alerts/i18n/en.json +33 -0
  9. package/features/alerts/i18n/fr.json +33 -0
  10. package/features/bookmarks/i18n/en.json +11 -0
  11. package/features/bookmarks/i18n/fr.json +11 -0
  12. package/features/collections/i18n/en.json +17 -0
  13. package/features/collections/i18n/fr.json +16 -0
  14. package/features/dialogs/i18n/en.json +15 -0
  15. package/features/dialogs/i18n/fr.json +15 -0
  16. package/features/did-you-mean/i18n/en.json +5 -0
  17. package/features/did-you-mean/i18n/fr.json +5 -0
  18. package/features/drawer/i18n/en.json +22 -0
  19. package/features/drawer/i18n/fr.json +22 -0
  20. package/features/export/i18n/en.json +7 -0
  21. package/features/export/i18n/fr.json +7 -0
  22. package/features/feedback/i18n/en.json +26 -0
  23. package/features/feedback/i18n/fr.json +26 -0
  24. package/features/filters/i18n/en.json +14 -0
  25. package/features/filters/i18n/fr.json +14 -0
  26. package/features/labels/i18n/en.json +8 -0
  27. package/features/labels/i18n/fr.json +8 -0
  28. package/features/recent-searches/i18n/en.json +6 -0
  29. package/features/recent-searches/i18n/fr.json +6 -0
  30. package/features/saved-searches/i18n/en.json +8 -0
  31. package/features/saved-searches/i18n/fr.json +8 -0
  32. package/features/sign-in/i18n/en.json +12 -0
  33. package/features/sign-in/i18n/fr.json +14 -0
  34. package/fesm2022/sinequa-atomic-angular.mjs +7948 -2383
  35. package/fesm2022/sinequa-atomic-angular.mjs.map +1 -1
  36. package/index.d.ts +6036 -3
  37. package/package.json +68 -10
  38. package/assets/tailwind.css +0 -248
  39. package/esm2022/lib/assistant/index.mjs +0 -2
  40. package/esm2022/lib/assistant/signalR.web.service.mjs +0 -81
  41. package/esm2022/lib/components/dropdown.mjs +0 -127
  42. package/esm2022/lib/components/index.mjs +0 -5
  43. package/esm2022/lib/components/menu/index.mjs +0 -3
  44. package/esm2022/lib/components/menu/menu-item.mjs +0 -22
  45. package/esm2022/lib/components/menu/menu.mjs +0 -99
  46. package/esm2022/lib/components/metadata/index.mjs +0 -2
  47. package/esm2022/lib/components/metadata/metadata.component.mjs +0 -65
  48. package/esm2022/lib/components/theme/index.mjs +0 -3
  49. package/esm2022/lib/components/theme/theme-selector.component.mjs +0 -67
  50. package/esm2022/lib/components/theme/theme-toggle.component.mjs +0 -67
  51. package/esm2022/lib/directives/index.mjs +0 -5
  52. package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -47
  53. package/esm2022/lib/directives/select-article-on-click.directive.mjs +0 -39
  54. package/esm2022/lib/directives/show-bookmark.directive.mjs +0 -55
  55. package/esm2022/lib/directives/theme-provider.directive.mjs +0 -31
  56. package/esm2022/lib/guards/auth.guard.mjs +0 -27
  57. package/esm2022/lib/guards/index.mjs +0 -3
  58. package/esm2022/lib/guards/initialization.guard.mjs +0 -41
  59. package/esm2022/lib/interceptors/audit.interceptor.mjs +0 -23
  60. package/esm2022/lib/interceptors/auth.interceptor.mjs +0 -49
  61. package/esm2022/lib/interceptors/body.interceptor.mjs +0 -24
  62. package/esm2022/lib/interceptors/error.interceptor.mjs +0 -35
  63. package/esm2022/lib/interceptors/index.mjs +0 -7
  64. package/esm2022/lib/interceptors/toast.interceptor.mjs +0 -27
  65. package/esm2022/lib/models/aggregation.mjs +0 -2
  66. package/esm2022/lib/models/article-metadata.mjs +0 -2
  67. package/esm2022/lib/models/autocomplete.mjs +0 -2
  68. package/esm2022/lib/models/custom-json.mjs +0 -2
  69. package/esm2022/lib/models/filter-dropdown.mjs +0 -2
  70. package/esm2022/lib/models/index.mjs +0 -7
  71. package/esm2022/lib/models/user-settings.mjs +0 -2
  72. package/esm2022/lib/pipes/highlight-word.pipe.mjs +0 -33
  73. package/esm2022/lib/pipes/index.mjs +0 -3
  74. package/esm2022/lib/pipes/source-icon.pipe.mjs +0 -43
  75. package/esm2022/lib/providers/eager-provider.mjs +0 -24
  76. package/esm2022/lib/providers/index.mjs +0 -2
  77. package/esm2022/lib/public-api.mjs +0 -19
  78. package/esm2022/lib/resolvers/index.mjs +0 -2
  79. package/esm2022/lib/resolvers/query-name-resolver.mjs +0 -14
  80. package/esm2022/lib/resources/index.mjs +0 -2
  81. package/esm2022/lib/resources/themes.mjs +0 -53
  82. package/esm2022/lib/services/application.service.mjs +0 -245
  83. package/esm2022/lib/services/autocomplete.service.mjs +0 -85
  84. package/esm2022/lib/services/drawer/backdrop.service.mjs +0 -23
  85. package/esm2022/lib/services/drawer/drawer-stack.service.mjs +0 -152
  86. package/esm2022/lib/services/drawer/drawer.service.mjs +0 -38
  87. package/esm2022/lib/services/index.mjs +0 -12
  88. package/esm2022/lib/services/label.service.mjs +0 -161
  89. package/esm2022/lib/services/navigation.service.mjs +0 -59
  90. package/esm2022/lib/services/saved-searches.service.mjs +0 -75
  91. package/esm2022/lib/services/search.service.mjs +0 -89
  92. package/esm2022/lib/services/selection-history.service.mjs +0 -92
  93. package/esm2022/lib/services/selection.service.mjs +0 -87
  94. package/esm2022/lib/stores/aggregations.store.mjs +0 -62
  95. package/esm2022/lib/stores/app.store.mjs +0 -265
  96. package/esm2022/lib/stores/application.store.mjs +0 -93
  97. package/esm2022/lib/stores/index.mjs +0 -9
  98. package/esm2022/lib/stores/principal.store.mjs +0 -47
  99. package/esm2022/lib/stores/query-params.store.mjs +0 -208
  100. package/esm2022/lib/stores/selection.store.mjs +0 -46
  101. package/esm2022/lib/stores/theme.store.mjs +0 -116
  102. package/esm2022/lib/stores/user-settings.store.mjs +0 -272
  103. package/esm2022/lib/tokens/highlights.mjs +0 -32
  104. package/esm2022/lib/tokens/index.mjs +0 -2
  105. package/esm2022/lib/utils/debounced-signal.mjs +0 -38
  106. package/esm2022/lib/utils/index.mjs +0 -8
  107. package/esm2022/lib/utils/inline-worker.mjs +0 -40
  108. package/esm2022/lib/utils/query.mjs +0 -58
  109. package/esm2022/lib/utils/routes.mjs +0 -28
  110. package/esm2022/lib/utils/tailwind-utils.mjs +0 -6
  111. package/esm2022/lib/utils/theme-body-hook.mjs +0 -18
  112. package/esm2022/lib/utils/theme-registry.mjs +0 -6
  113. package/esm2022/lib/web-services/aggregations.service.mjs +0 -104
  114. package/esm2022/lib/web-services/app.service.mjs +0 -48
  115. package/esm2022/lib/web-services/audit.service.mjs +0 -122
  116. package/esm2022/lib/web-services/index.mjs +0 -10
  117. package/esm2022/lib/web-services/json-method-plugin.service.mjs +0 -54
  118. package/esm2022/lib/web-services/preview.service.mjs +0 -327
  119. package/esm2022/lib/web-services/principal.service.mjs +0 -46
  120. package/esm2022/lib/web-services/query.service.mjs +0 -123
  121. package/esm2022/lib/web-services/text-chunck.service.mjs +0 -46
  122. package/esm2022/public-api.mjs +0 -5
  123. package/esm2022/sinequa-atomic-angular.mjs +0 -5
  124. package/lib/assistant/index.d.ts +0 -1
  125. package/lib/assistant/signalR.web.service.d.ts +0 -46
  126. package/lib/components/dropdown.d.ts +0 -50
  127. package/lib/components/index.d.ts +0 -4
  128. package/lib/components/menu/index.d.ts +0 -2
  129. package/lib/components/menu/menu-item.d.ts +0 -8
  130. package/lib/components/menu/menu.d.ts +0 -24
  131. package/lib/components/metadata/index.d.ts +0 -1
  132. package/lib/components/metadata/metadata.component.d.ts +0 -24
  133. package/lib/components/theme/index.d.ts +0 -2
  134. package/lib/components/theme/theme-selector.component.d.ts +0 -70
  135. package/lib/components/theme/theme-toggle.component.d.ts +0 -10
  136. package/lib/directives/index.d.ts +0 -4
  137. package/lib/directives/infinite-scroll.directive.d.ts +0 -30
  138. package/lib/directives/select-article-on-click.directive.d.ts +0 -14
  139. package/lib/directives/show-bookmark.directive.d.ts +0 -52
  140. package/lib/directives/theme-provider.directive.d.ts +0 -20
  141. package/lib/guards/auth.guard.d.ts +0 -7
  142. package/lib/guards/index.d.ts +0 -2
  143. package/lib/guards/initialization.guard.d.ts +0 -20
  144. package/lib/interceptors/audit.interceptor.d.ts +0 -13
  145. package/lib/interceptors/auth.interceptor.d.ts +0 -14
  146. package/lib/interceptors/body.interceptor.d.ts +0 -11
  147. package/lib/interceptors/error.interceptor.d.ts +0 -9
  148. package/lib/interceptors/index.d.ts +0 -5
  149. package/lib/interceptors/toast.interceptor.d.ts +0 -13
  150. package/lib/models/aggregation.d.ts +0 -12
  151. package/lib/models/article-metadata.d.ts +0 -5
  152. package/lib/models/autocomplete.d.ts +0 -5
  153. package/lib/models/custom-json.d.ts +0 -58
  154. package/lib/models/filter-dropdown.d.ts +0 -10
  155. package/lib/models/index.d.ts +0 -6
  156. package/lib/models/user-settings.d.ts +0 -32
  157. package/lib/pipes/highlight-word.pipe.d.ts +0 -22
  158. package/lib/pipes/index.d.ts +0 -2
  159. package/lib/pipes/source-icon.pipe.d.ts +0 -54
  160. package/lib/providers/eager-provider.d.ts +0 -11
  161. package/lib/providers/index.d.ts +0 -1
  162. package/lib/public-api.d.ts +0 -15
  163. package/lib/resolvers/index.d.ts +0 -1
  164. package/lib/resolvers/query-name-resolver.d.ts +0 -9
  165. package/lib/resources/index.d.ts +0 -1
  166. package/lib/resources/themes.d.ts +0 -51
  167. package/lib/services/application.service.d.ts +0 -178
  168. package/lib/services/autocomplete.service.d.ts +0 -91
  169. package/lib/services/drawer/backdrop.service.d.ts +0 -9
  170. package/lib/services/drawer/drawer-stack.service.d.ts +0 -70
  171. package/lib/services/drawer/drawer.service.d.ts +0 -15
  172. package/lib/services/index.d.ts +0 -11
  173. package/lib/services/label.service.d.ts +0 -117
  174. package/lib/services/navigation.service.d.ts +0 -33
  175. package/lib/services/saved-searches.service.d.ts +0 -145
  176. package/lib/services/search.service.d.ts +0 -155
  177. package/lib/services/selection-history.service.d.ts +0 -50
  178. package/lib/services/selection.service.d.ts +0 -127
  179. package/lib/stores/aggregations.store.d.ts +0 -50
  180. package/lib/stores/app.store.d.ts +0 -208
  181. package/lib/stores/application.store.d.ts +0 -106
  182. package/lib/stores/index.d.ts +0 -8
  183. package/lib/stores/principal.store.d.ts +0 -53
  184. package/lib/stores/query-params.store.d.ts +0 -187
  185. package/lib/stores/selection.store.d.ts +0 -62
  186. package/lib/stores/theme.store.d.ts +0 -55
  187. package/lib/stores/user-settings.store.d.ts +0 -161
  188. package/lib/tokens/highlights.d.ts +0 -8
  189. package/lib/tokens/index.d.ts +0 -1
  190. package/lib/utils/debounced-signal.d.ts +0 -25
  191. package/lib/utils/index.d.ts +0 -7
  192. package/lib/utils/inline-worker.d.ts +0 -11
  193. package/lib/utils/query.d.ts +0 -26
  194. package/lib/utils/routes.d.ts +0 -16
  195. package/lib/utils/tailwind-utils.d.ts +0 -2
  196. package/lib/utils/theme-body-hook.d.ts +0 -6
  197. package/lib/utils/theme-registry.d.ts +0 -3
  198. package/lib/web-services/aggregations.service.d.ts +0 -60
  199. package/lib/web-services/app.service.d.ts +0 -30
  200. package/lib/web-services/audit.service.d.ts +0 -75
  201. package/lib/web-services/index.d.ts +0 -9
  202. package/lib/web-services/json-method-plugin.service.d.ts +0 -41
  203. package/lib/web-services/preview.service.d.ts +0 -295
  204. package/lib/web-services/principal.service.d.ts +0 -28
  205. package/lib/web-services/query.service.d.ts +0 -29
  206. package/lib/web-services/text-chunck.service.d.ts +0 -22
  207. package/public-api.d.ts +0 -1
@@ -1,47 +0,0 @@
1
- import { withDevtools } from "@angular-architects/ngrx-toolkit";
2
- import { computed, inject } from "@angular/core";
3
- import { patchState, signalStore, signalStoreFeature, withComputed, withMethods, withState } from "@ngrx/signals";
4
- import { firstValueFrom, map } from "rxjs";
5
- import { globalConfig } from "@sinequa/atomic";
6
- import { PrincipalService } from "../web-services/principal.service";
7
- export const PrincipalStore = signalStore({ providedIn: 'root' }, withDevtools("Principal"), withState({ principal: {}, userOverrideActive: false }), withPrincipalFeatures());
8
- /**
9
- * Enhances the store with principal-related features.
10
- *
11
- * This function integrates state, methods, and computed properties related to the principal.
12
- *
13
- * @returns A feature that can be added to a signal store.
14
- *
15
- * @feature
16
- * - State:
17
- * - `principal`: An object representing the principal.
18
- * - `userOverrideActive`: A boolean indicating if user override is active.
19
- *
20
- * - Methods:
21
- * - `initialize()`: Initializes the principal state by fetching the principal data from the `PrincipalService`.
22
- *
23
- * - Computed Properties:
24
- * - `allowUserOverride`: A computed boolean indicating if user override is allowed based on the principal's administrator status and the `userOverrideActive` state.
25
- * - `isOverridingUser`: A computed boolean indicating if the user override is currently active.
26
- */
27
- export function withPrincipalFeatures() {
28
- return signalStoreFeature(withState({ principal: {}, userOverrideActive: false }), withMethods((store, principalService = inject(PrincipalService)) => ({
29
- /**
30
- * Initializes the principal store by fetching the principal data from the principal service.
31
- * It patches the store with the fetched principal data and a user override active flag from the global configuration.
32
- *
33
- * @returns A promise that resolves when the principal data has been fetched and the store has been patched.
34
- */
35
- initialize() {
36
- return firstValueFrom(principalService.getPrincipal()
37
- .pipe(map(principal => {
38
- const { userOverrideActive = false } = globalConfig;
39
- patchState(store, { principal, userOverrideActive });
40
- })));
41
- }
42
- })), withComputed(({ principal, userOverrideActive }) => ({
43
- allowUserOverride: computed(() => principal().isAdministrator && userOverrideActive() === false),
44
- isOverridingUser: computed(() => userOverrideActive() === true)
45
- })));
46
- }
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpbmNpcGFsLnN0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXRvbWljLWFuZ3VsYXIvc3JjL2xpYi9zdG9yZXMvcHJpbmNpcGFsLnN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNoRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxrQkFBa0IsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsSCxPQUFPLEVBQUUsY0FBYyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUUzQyxPQUFPLEVBQWEsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFPckUsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLFdBQVcsQ0FDdkMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLEVBQ3RCLFlBQVksQ0FBQyxXQUFXLENBQUMsRUFDekIsU0FBUyxDQUFDLEVBQUUsU0FBUyxFQUFFLEVBQUUsRUFBRSxrQkFBa0IsRUFBRSxLQUFLLEVBQW9CLENBQUMsRUFDekUscUJBQXFCLEVBQUUsQ0FDeEIsQ0FBQztBQUVGOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQkc7QUFDSCxNQUFNLFVBQVUscUJBQXFCO0lBQ25DLE9BQU8sa0JBQWtCLENBQ3ZCLFNBQVMsQ0FBQyxFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFvQixDQUFDLEVBQ3pFLFdBQVcsQ0FBQyxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNuRTs7Ozs7V0FLRztRQUNILFVBQVU7WUFDUixPQUFPLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUU7aUJBQ2xELElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLEVBQUU7Z0JBQ3BCLE1BQU0sRUFBRSxrQkFBa0IsR0FBRyxLQUFLLEVBQUUsR0FBRyxZQUFZLENBQUM7Z0JBQ3BELFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFBO1lBQ3RELENBQUMsQ0FBQyxDQUNILENBQUMsQ0FBQztRQUNMLENBQUM7S0FDRixDQUFDLENBQUMsRUFDSCxZQUFZLENBQUMsQ0FBQyxFQUFDLFNBQVMsRUFBRSxrQkFBa0IsRUFBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pELGlCQUFpQixFQUFFLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxlQUFlLElBQUksa0JBQWtCLEVBQUUsS0FBSyxLQUFLLENBQUU7UUFDakcsZ0JBQWdCLEVBQUUsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLGtCQUFrQixFQUFFLEtBQUssSUFBSSxDQUFDO0tBQ2hFLENBQUMsQ0FBQyxDQUNKLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgd2l0aERldnRvb2xzIH0gZnJvbSBcIkBhbmd1bGFyLWFyY2hpdGVjdHMvbmdyeC10b29sa2l0XCI7XHJcbmltcG9ydCB7IGNvbXB1dGVkLCBpbmplY3QgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBwYXRjaFN0YXRlLCBzaWduYWxTdG9yZSwgc2lnbmFsU3RvcmVGZWF0dXJlLCB3aXRoQ29tcHV0ZWQsIHdpdGhNZXRob2RzLCB3aXRoU3RhdGUgfSBmcm9tIFwiQG5ncngvc2lnbmFsc1wiO1xyXG5pbXBvcnQgeyBmaXJzdFZhbHVlRnJvbSwgbWFwIH0gZnJvbSBcInJ4anNcIjtcclxuXHJcbmltcG9ydCB7IFByaW5jaXBhbCwgZ2xvYmFsQ29uZmlnIH0gZnJvbSBcIkBzaW5lcXVhL2F0b21pY1wiO1xyXG5pbXBvcnQgeyBQcmluY2lwYWxTZXJ2aWNlIH0gZnJvbSBcIi4uL3dlYi1zZXJ2aWNlcy9wcmluY2lwYWwuc2VydmljZVwiO1xyXG5cclxudHlwZSBQcmluY2lwYWxTdGF0ZSA9IHtcclxuICBwcmluY2lwYWw6IFByaW5jaXBhbDtcclxuICB1c2VyT3ZlcnJpZGVBY3RpdmU6IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBQcmluY2lwYWxTdG9yZSA9IHNpZ25hbFN0b3JlKFxyXG4gIHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0sXHJcbiAgd2l0aERldnRvb2xzKFwiUHJpbmNpcGFsXCIpLFxyXG4gIHdpdGhTdGF0ZSh7IHByaW5jaXBhbDoge30sIHVzZXJPdmVycmlkZUFjdGl2ZTogZmFsc2UgfSBhcyBQcmluY2lwYWxTdGF0ZSksXHJcbiAgd2l0aFByaW5jaXBhbEZlYXR1cmVzKClcclxuKTtcclxuXHJcbi8qKlxyXG4gKiBFbmhhbmNlcyB0aGUgc3RvcmUgd2l0aCBwcmluY2lwYWwtcmVsYXRlZCBmZWF0dXJlcy5cclxuICpcclxuICogVGhpcyBmdW5jdGlvbiBpbnRlZ3JhdGVzIHN0YXRlLCBtZXRob2RzLCBhbmQgY29tcHV0ZWQgcHJvcGVydGllcyByZWxhdGVkIHRvIHRoZSBwcmluY2lwYWwuXHJcbiAqXHJcbiAqIEByZXR1cm5zIEEgZmVhdHVyZSB0aGF0IGNhbiBiZSBhZGRlZCB0byBhIHNpZ25hbCBzdG9yZS5cclxuICpcclxuICogQGZlYXR1cmVcclxuICogLSBTdGF0ZTpcclxuICogICAtIGBwcmluY2lwYWxgOiBBbiBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBwcmluY2lwYWwuXHJcbiAqICAgLSBgdXNlck92ZXJyaWRlQWN0aXZlYDogQSBib29sZWFuIGluZGljYXRpbmcgaWYgdXNlciBvdmVycmlkZSBpcyBhY3RpdmUuXHJcbiAqXHJcbiAqIC0gTWV0aG9kczpcclxuICogICAtIGBpbml0aWFsaXplKClgOiBJbml0aWFsaXplcyB0aGUgcHJpbmNpcGFsIHN0YXRlIGJ5IGZldGNoaW5nIHRoZSBwcmluY2lwYWwgZGF0YSBmcm9tIHRoZSBgUHJpbmNpcGFsU2VydmljZWAuXHJcbiAqXHJcbiAqIC0gQ29tcHV0ZWQgUHJvcGVydGllczpcclxuICogICAtIGBhbGxvd1VzZXJPdmVycmlkZWA6IEEgY29tcHV0ZWQgYm9vbGVhbiBpbmRpY2F0aW5nIGlmIHVzZXIgb3ZlcnJpZGUgaXMgYWxsb3dlZCBiYXNlZCBvbiB0aGUgcHJpbmNpcGFsJ3MgYWRtaW5pc3RyYXRvciBzdGF0dXMgYW5kIHRoZSBgdXNlck92ZXJyaWRlQWN0aXZlYCBzdGF0ZS5cclxuICogICAtIGBpc092ZXJyaWRpbmdVc2VyYDogQSBjb21wdXRlZCBib29sZWFuIGluZGljYXRpbmcgaWYgdGhlIHVzZXIgb3ZlcnJpZGUgaXMgY3VycmVudGx5IGFjdGl2ZS5cclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiB3aXRoUHJpbmNpcGFsRmVhdHVyZXMoKSB7XHJcbiAgcmV0dXJuIHNpZ25hbFN0b3JlRmVhdHVyZShcclxuICAgIHdpdGhTdGF0ZSh7IHByaW5jaXBhbDoge30sIHVzZXJPdmVycmlkZUFjdGl2ZTogZmFsc2UgfSBhcyBQcmluY2lwYWxTdGF0ZSksXHJcbiAgICB3aXRoTWV0aG9kcygoc3RvcmUsIHByaW5jaXBhbFNlcnZpY2UgPSBpbmplY3QoUHJpbmNpcGFsU2VydmljZSkpID0+ICh7XHJcbiAgICAgIC8qKlxyXG4gICAgICAgKiBJbml0aWFsaXplcyB0aGUgcHJpbmNpcGFsIHN0b3JlIGJ5IGZldGNoaW5nIHRoZSBwcmluY2lwYWwgZGF0YSBmcm9tIHRoZSBwcmluY2lwYWwgc2VydmljZS5cclxuICAgICAgICogSXQgcGF0Y2hlcyB0aGUgc3RvcmUgd2l0aCB0aGUgZmV0Y2hlZCBwcmluY2lwYWwgZGF0YSBhbmQgYSB1c2VyIG92ZXJyaWRlIGFjdGl2ZSBmbGFnIGZyb20gdGhlIGdsb2JhbCBjb25maWd1cmF0aW9uLlxyXG4gICAgICAgKlxyXG4gICAgICAgKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBwcmluY2lwYWwgZGF0YSBoYXMgYmVlbiBmZXRjaGVkIGFuZCB0aGUgc3RvcmUgaGFzIGJlZW4gcGF0Y2hlZC5cclxuICAgICAgICovXHJcbiAgICAgIGluaXRpYWxpemUoKSB7XHJcbiAgICAgICAgcmV0dXJuIGZpcnN0VmFsdWVGcm9tKHByaW5jaXBhbFNlcnZpY2UuZ2V0UHJpbmNpcGFsKClcclxuICAgICAgICAgIC5waXBlKG1hcChwcmluY2lwYWwgPT4ge1xyXG4gICAgICAgICAgICBjb25zdCB7IHVzZXJPdmVycmlkZUFjdGl2ZSA9IGZhbHNlIH0gPSBnbG9iYWxDb25maWc7XHJcbiAgICAgICAgICAgIHBhdGNoU3RhdGUoc3RvcmUsIHsgcHJpbmNpcGFsLCB1c2VyT3ZlcnJpZGVBY3RpdmUgfSlcclxuICAgICAgICAgIH0pXHJcbiAgICAgICAgKSk7XHJcbiAgICAgIH1cclxuICAgIH0pKSxcclxuICAgIHdpdGhDb21wdXRlZCgoe3ByaW5jaXBhbCwgdXNlck92ZXJyaWRlQWN0aXZlfSkgPT4gKHtcclxuICAgICAgYWxsb3dVc2VyT3ZlcnJpZGU6IGNvbXB1dGVkKCgpID0+IHByaW5jaXBhbCgpLmlzQWRtaW5pc3RyYXRvciAmJiB1c2VyT3ZlcnJpZGVBY3RpdmUoKSA9PT0gZmFsc2UgKSxcclxuICAgICAgaXNPdmVycmlkaW5nVXNlcjogY29tcHV0ZWQoKCkgPT4gdXNlck92ZXJyaWRlQWN0aXZlKCkgPT09IHRydWUpXHJcbiAgICB9KSlcclxuICApO1xyXG59Il19
@@ -1,208 +0,0 @@
1
- import { withDevtools } from '@angular-architects/ngrx-toolkit';
2
- import { getState, patchState, signalStore, signalStoreFeature, withMethods, withState } from '@ngrx/signals';
3
- import { addConcepts, queryParamsFromUrl } from '@sinequa/atomic';
4
- import { inject, Injector, runInInjectionContext } from '@angular/core';
5
- import { buildQuery } from '../utils';
6
- const initialState = {};
7
- export const QueryParamsStore = signalStore({ providedIn: 'root' }, withDevtools("QueryParams"), withState(initialState), withQueryParamsFeatures());
8
- export function withQueryParamsFeatures() {
9
- return signalStoreFeature(withState(initialState), withMethods((store, injector = inject(Injector)) => ({
10
- /**
11
- * Sets the state from the given URL by extracting query parameters and updating the store.
12
- *
13
- * @param url - The URL containing query parameters to set the state from.
14
- *
15
- * The function performs the following steps:
16
- * 1. Extracts the path from the URL.
17
- * 2. Parses the query parameters from the URL.
18
- * 3. Decodes and parses the filters from the query parameters.
19
- * 4. Converts the page parameter to a number if it exists.
20
- * 5. Updates the store state with the extracted and parsed values.
21
- */
22
- setFromUrl(url) {
23
- const path = url.split('?')[0];
24
- const { q: text, f, id, p, s: sort, c, t: tab } = queryParamsFromUrl(url);
25
- const filters = f ? JSON.parse(decodeURIComponent(f)) : [];
26
- const spellingCorrectionMode = c;
27
- let page;
28
- if (p) {
29
- page = parseInt(p, 10);
30
- }
31
- patchState(store, (state) => {
32
- return { ...state, path, text, filters, id, page, sort, spellingCorrectionMode, tab };
33
- });
34
- },
35
- /**
36
- * Adds a filter to the store's state.
37
- *
38
- * @param filter - The filter to be added to the state.
39
- *
40
- * The function calls the `updateFilter` method to add the filter to the state.
41
- */
42
- addFilter(filter) {
43
- this.updateFilter(filter);
44
- },
45
- /**
46
- * Updates the filter in the store's state.
47
- *
48
- * @param filter - The filter to be updated. If the filter is `undefined`, the state remains unchanged.
49
- *
50
- * The function performs the following operations:
51
- * - Adds the filter to the state if it doesn't already exist and has values.
52
- * - Removes the filter if the 'between' operator is selected but no values are provided.
53
- * - Removes the filter if no values are selected and the operator is not 'between'.
54
- * - Updates the filter values if the filter already exists.
55
- *
56
- * @remarks
57
- * - If the filter is `undefined`, the state remains unchanged.
58
- * - If the filter's operator is 'between' and both `start` and `end` are `undefined`, the filter is removed.
59
- * - If the filter's operator is not 'between' and `filters`, `value`, and `values` are all `undefined`, the filter is removed.
60
- * - If the filter already exists, its values are updated.
61
- */
62
- updateFilter(filter) {
63
- patchState(store, (state) => {
64
- if (filter === undefined)
65
- return state;
66
- const allFilters = state.filters || [];
67
- const existing = allFilters.findIndex((f) => f.field === filter.field);
68
- // Add filter if it doesn't exist and has values
69
- if (existing === -1) {
70
- return ({ ...state, filters: [...allFilters || [], filter] });
71
- }
72
- if (existing >= 0) {
73
- // remove filter if between operator is selected but no values are selected
74
- if (filter.operator === 'between' && filter.start === undefined && filter.end === undefined) {
75
- return ({ ...state, filters: allFilters.filter(f => f.field !== filter.field) });
76
- }
77
- // Remove filter if no values are selected
78
- if (filter.operator !== 'between' && filter.filters === undefined && filter.value === undefined && filter.values === undefined) {
79
- return ({ ...state, filters: (allFilters || []).filter(f => f?.field !== filter.field) });
80
- }
81
- // Update filter values
82
- if (existing >= 0) {
83
- const filters = allFilters.toSpliced(existing, 1, filter);
84
- return ({ ...state, filters });
85
- }
86
- }
87
- return state;
88
- });
89
- },
90
- /**
91
- * Removes a filter from the store based on the specified field.
92
- *
93
- * @param field - The field of the filter to be removed.
94
- */
95
- removeFilter(field) {
96
- if (!field)
97
- return;
98
- patchState(store, (state) => {
99
- const filters = state.filters?.filter(f => f.field !== field);
100
- return { ...state, filters };
101
- });
102
- },
103
- /**
104
- * Removes a filter from the state by its name.
105
- *
106
- * @param name - The name of the filter to be removed.
107
- */
108
- removeFilterByName(name) {
109
- if (!name)
110
- return;
111
- patchState(store, (state) => {
112
- const filters = state.filters?.filter(f => f.name !== name);
113
- return { ...state, filters };
114
- });
115
- },
116
- /**
117
- * Clears all filters from the state.
118
- *
119
- * This method updates the state by setting the `filters` property to an empty array.
120
- * It uses the `patchState` function to apply the state change.
121
- */
122
- clearFilters() {
123
- patchState(store, (state) => {
124
- return { ...state, filters: [] };
125
- });
126
- },
127
- /**
128
- * Updates the current state with the provided query parameters.
129
- *
130
- * @param params - A partial object containing the query parameters to be updated.
131
- */
132
- patch(params) {
133
- patchState(store, (state) => {
134
- return { ...state, ...params };
135
- });
136
- },
137
- /**
138
- * Retrieves a filter object based on the provided field or name.
139
- *
140
- * @param {string} fieldOrName - The field or name to search for in the filters.
141
- * @returns {Partial<LegacyFilter & {count: number}> | null} - The filter object with an additional count property, or null if not found.
142
- *
143
- * The method performs the following steps:
144
- * 1. Checks if the `fieldOrName` parameter is provided. If not, returns null.
145
- * 2. Searches for a filter with a matching field in the store's filters.
146
- * 3. If no filter is found by field, searches for a filter with a matching name.
147
- * 4. If a filter is found and has a `value` property, returns the filter with a count of 1.
148
- * 5. If a filter is found and does not have an array of filters, returns the filter with a count of 1.
149
- * 6. If a filter is found and has a `values` property, returns the filter with the count set to the length of the `values` array.
150
- * 7. If a filter is found and has an array of filters, returns the filter with the count set to the length of the `filters` array.
151
- * 8. If none of the above conditions are met, returns the filter with a count of 0.
152
- */
153
- getFilter(fieldOrName) {
154
- if (!fieldOrName)
155
- return null;
156
- let filter = getState(store).filters?.find(f => f?.field === fieldOrName);
157
- // if not found, return checks for the filter name
158
- if (!filter)
159
- filter = getState(store).filters?.find(f => f?.name === fieldOrName);
160
- // if filter is found, return null
161
- if (!filter)
162
- return null;
163
- if (filter.operator && filter.operator === 'or') {
164
- const count = Array.isArray(filter.filters) ? filter.filters.length : 1;
165
- return ({ ...filter, count });
166
- }
167
- if (filter.operator && filter.operator === 'and') {
168
- return ({ ...filter, count: 1 });
169
- }
170
- if (filter && filter.value)
171
- return ({ ...filter, count: 1 });
172
- if (filter && filter.values)
173
- return ({ ...filter, count: filter.values.length });
174
- if (filter && Array.isArray(filter.filters) === false)
175
- return ({ ...filter, count: 1 });
176
- if (filter && Array.isArray(filter.filters))
177
- return ({ ...filter, count: filter.filters.length });
178
- return ({ ...filter, count: 0 });
179
- },
180
- /**
181
- * Constructs and returns a query object based on the current state of the store.
182
- *
183
- * This method retrieves various parameters from the store's state, such as filters, sort order, tab, query text, query name, and spelling correction mode.
184
- * It processes the filters to separate out "concepts" filters and incorporates them into the query text.
185
- * The remaining filters are combined appropriately.
186
- * Finally, it builds and returns the query object using the processed parameters.
187
- *
188
- * @returns Query The constructed query object.
189
- */
190
- getQuery() {
191
- const { filters: allFilters = [], sort, tab, text: queryText = '', name, spellingCorrectionMode } = getState(store);
192
- let text = queryText;
193
- // remove concepts filters from the query to add them in the query expression
194
- const [conceptsFilters] = allFilters.filter(f => f.field === "concepts");
195
- if (conceptsFilters) {
196
- const concepts = conceptsFilters.filters ? conceptsFilters.filters.map(f => f.value) : [conceptsFilters.value];
197
- text = addConcepts(queryText, concepts);
198
- }
199
- const filters = allFilters.filter(f => f.field !== "concepts");
200
- const f = filters.length > 1
201
- ? { operator: "and", filters }
202
- : filters[0];
203
- const query = runInInjectionContext(injector, () => buildQuery({ filters: f, name, sort, spellingCorrectionMode, tab, text }));
204
- return query;
205
- }
206
- })));
207
- }
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-params.store.js","sourceRoot":"","sources":["../../../../../projects/atomic-angular/src/lib/stores/query-params.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,kBAAkB,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE9G,OAAO,EAAE,WAAW,EAAuB,kBAAkB,EAA0B,MAAM,iBAAiB,CAAC;AAE/G,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAQtC,MAAM,YAAY,GAAqB,EAAE,CAAC;AAE1C,MAAM,CAAC,MAAM,gBAAgB,GAAG,WAAW,CACzC,EAAE,UAAU,EAAE,MAAM,EAAE,EACtB,YAAY,CAAC,aAAa,CAAC,EAC3B,SAAS,CAAC,YAAY,CAAC,EACvB,uBAAuB,EAAE,CAC1B,CAAA;AAED,MAAM,UAAU,uBAAuB;IACrC,OAAO,kBAAkB,CACvB,SAAS,CAAC,YAAY,CAAC,EACvB,WAAW,CAAC,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;QACnD;;;;;;;;;;;WAWG;QACH,UAAU,CAAC,GAAW;YACpB,MAAM,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAE/B,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAC;YAC1E,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3D,MAAM,sBAAsB,GAAG,CAA2B,CAAC;YAE3D,IAAI,IAAwB,CAAC;YAC7B,IAAI,CAAC,EAAE,CAAC;gBACN,IAAI,GAAG,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACzB,CAAC;YAED,UAAU,CAAC,KAAK,EAAE,CAAC,KAAuB,EAAE,EAAE;gBAC5C,OAAO,EAAE,GAAG,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,sBAAsB,EAAE,GAAG,EAAE,CAAC;YACxF,CAAC,CAAC,CAAA;QACJ,CAAC;QACD;;;;;;WAMG;QACH,SAAS,CAAC,MAAoB;YAC5B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC5B,CAAC;QACD;;;;;;;;;;;;;;;;WAgBG;QACH,YAAY,CAAC,MAAoB;YAC/B,UAAU,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC1B,IAAG,MAAM,KAAK,SAAS;oBAAE,OAAO,KAAK,CAAC;gBAEtC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;gBAEvC,MAAM,QAAQ,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,CAAC;gBAEvE,gDAAgD;gBAChD,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE,CAAC;oBACpB,OAAO,CAAC,EAAC,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC,GAAG,UAAU,IAAI,EAAE,EAAE,MAAM,CAAC,EAAC,CAAC,CAAC;gBAC9D,CAAC;gBAED,IAAG,QAAQ,IAAG,CAAC,EAAC,CAAC;oBAEf,2EAA2E;oBAC3E,IAAG,MAAM,CAAC,QAAQ,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;wBAC3F,OAAO,CAAC,EAAC,GAAG,KAAK,EAAE,OAAO,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,EAAC,CAAC,CAAC;oBACjF,CAAC;oBAED,0CAA0C;oBAC1C,IAAI,MAAM,CAAC,QAAQ,KAAK,SAAS,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;wBAC/H,OAAO,CAAC,EAAC,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,EAAC,CAAC,CAAC;oBAC1F,CAAC;oBAED,uBAAuB;oBACvB,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;wBAClB,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;wBAC1D,OAAO,CAAC,EAAC,GAAG,KAAK,EAAE,OAAO,EAAC,CAAC,CAAC;oBAC/B,CAAC;gBAEH,CAAC;gBAED,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC;QACD;;;;WAIG;QACH,YAAY,CAAC,KAAc;YACzB,IAAG,CAAC,KAAK;gBAAE,OAAO;YAClB,UAAU,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC1B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;gBAC9D,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC;YAC/B,CAAC,CAAC,CAAC;QACL,CAAC;QACD;;;;WAIG;QACH,kBAAkB,CAAC,IAAa;YAC9B,IAAG,CAAC,IAAI;gBAAE,OAAO;YACjB,UAAU,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC1B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;gBAC5D,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC;YAC/B,CAAC,CAAC,CAAC;QACL,CAAC;QACD;;;;;WAKG;QACH,YAAY;YACV,UAAU,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC1B,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;YACnC,CAAC,CAAC,CAAC;QACL,CAAC;QACD;;;;WAIG;QACH,KAAK,CAAC,MAAiC;YACrC,UAAU,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC1B,OAAO,EAAE,GAAG,KAAK,EAAE,GAAG,MAAM,EAAE,CAAC;YACjC,CAAC,CAAC,CAAC;QACL,CAAC;QACD;;;;;;;;;;;;;;;WAeG;QACH,SAAS,CAAC,WAAoB;YAC5B,IAAG,CAAC,WAAW;gBAAE,OAAO,IAAI,CAAC;YAE7B,IAAI,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,KAAK,WAAW,CAAC,CAAC;YAC1E,kDAAkD;YAClD,IAAG,CAAC,MAAM;gBAAE,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,WAAW,CAAC,CAAC;YAEjF,kCAAkC;YAClC,IAAG,CAAC,MAAM;gBAAE,OAAO,IAAI,CAAC;YAExB,IAAG,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;gBAC/C,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxE,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;YAC/B,CAAC;YACD,IAAG,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;gBAChD,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;YAClC,CAAC;YAED,IAAG,MAAM,IAAI,MAAM,CAAC,KAAK;gBAAE,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;YAC1D,IAAG,MAAM,IAAI,MAAM,CAAC,MAAM;gBAAE,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAC,CAAC,CAAC;YAC9E,IAAG,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,KAAK;gBAAE,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;YACrF,IAAG,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC;gBAAE,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,EAAC,CAAC,CAAC;YAE/F,OAAO,CAAC,EAAC,GAAG,MAAM,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;QACjC,CAAC;QACD;;;;;;;;;WASG;QACH,QAAQ;YACN,MAAM,EAAE,OAAO,EAAE,UAAU,GAAG,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,GAAG,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;YACpH,IAAI,IAAI,GAAG,SAAS,CAAC;YAErB,6EAA6E;YAC7E,MAAM,CAAC,eAAe,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC;YACzE,IAAI,eAAe,EAAE,CAAC;gBACpB,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC,CAAE,eAAe,CAAC,OAA0B,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAa,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,KAAK,CAAa,CAAC;gBAC3J,IAAI,GAAG,WAAW,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;YAC1C,CAAC;YAED,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC;YAC/D,MAAM,CAAC,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC;gBAC1B,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAkB;gBAC9C,CAAC,CAAC,OAAO,CAAC,CAAC,CAAiB,CAAC;YAE/B,MAAM,KAAK,GAAG,qBAAqB,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAE,UAAU,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,sBAAsB,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;YAChI,OAAO,KAAK,CAAC;QACf,CAAC;KACF,CAAC,CAAC,CACJ,CAAC;AACJ,CAAC","sourcesContent":["import { withDevtools } from '@angular-architects/ngrx-toolkit';\nimport { getState, patchState, signalStore, signalStoreFeature, withMethods, withState } from '@ngrx/signals';\n\nimport { addConcepts, LegacyFilter, Query, queryParamsFromUrl, SpellingCorrectionMode } from '@sinequa/atomic';\n\nimport { inject, Injector, runInInjectionContext } from '@angular/core';\nimport { buildQuery } from '../utils';\n\ntype QueryParamsState = Partial<Omit<Query, \"filters\">> & {\n  path?: string;\n  filters?: LegacyFilter[];\n  id?: string;\n};\n\nconst initialState: QueryParamsState = {};\n\nexport const QueryParamsStore = signalStore(\n  { providedIn: 'root' },\n  withDevtools(\"QueryParams\"),\n  withState(initialState),\n  withQueryParamsFeatures()\n)\n\nexport function withQueryParamsFeatures() {\n  return signalStoreFeature(\n    withState(initialState),\n    withMethods((store, injector = inject(Injector)) => ({\n      /**\n       * Sets the state from the given URL by extracting query parameters and updating the store.\n       *\n       * @param url - The URL containing query parameters to set the state from.\n       *\n       * The function performs the following steps:\n       * 1. Extracts the path from the URL.\n       * 2. Parses the query parameters from the URL.\n       * 3. Decodes and parses the filters from the query parameters.\n       * 4. Converts the page parameter to a number if it exists.\n       * 5. Updates the store state with the extracted and parsed values.\n       */\n      setFromUrl(url: string) {\n        const path = url.split('?')[0];\n\n        const { q: text, f, id, p, s: sort, c, t: tab } = queryParamsFromUrl(url);\n        const filters = f ? JSON.parse(decodeURIComponent(f)) : [];\n        const spellingCorrectionMode = c as SpellingCorrectionMode;\n\n        let page: number | undefined;\n        if (p) {\n          page = parseInt(p, 10);\n        }\n\n        patchState(store, (state: QueryParamsState) => {\n          return { ...state, path, text, filters, id, page, sort, spellingCorrectionMode, tab };\n        })\n      },\n      /**\n       * Adds a filter to the store's state.\n       *\n       * @param filter - The filter to be added to the state.\n       *\n       * The function calls the `updateFilter` method to add the filter to the state.\n       */\n      addFilter(filter: LegacyFilter) {\n        this.updateFilter(filter);\n      },\n      /**\n       * Updates the filter in the store's state.\n       *\n       * @param filter - The filter to be updated. If the filter is `undefined`, the state remains unchanged.\n       *\n       * The function performs the following operations:\n       * - Adds the filter to the state if it doesn't already exist and has values.\n       * - Removes the filter if the 'between' operator is selected but no values are provided.\n       * - Removes the filter if no values are selected and the operator is not 'between'.\n       * - Updates the filter values if the filter already exists.\n       *\n       * @remarks\n       * - If the filter is `undefined`, the state remains unchanged.\n       * - If the filter's operator is 'between' and both `start` and `end` are `undefined`, the filter is removed.\n       * - If the filter's operator is not 'between' and `filters`, `value`, and `values` are all `undefined`, the filter is removed.\n       * - If the filter already exists, its values are updated.\n       */\n      updateFilter(filter: LegacyFilter) {\n        patchState(store, (state) => {\n          if(filter === undefined) return state;\n\n          const allFilters = state.filters || [];\n\n          const existing = allFilters.findIndex((f) => f.field === filter.field);\n\n          // Add filter if it doesn't exist and has values\n          if (existing === -1) {\n            return ({...state, filters: [...allFilters || [], filter]});\n          }\n\n          if(existing >=0){\n\n            // remove filter if between operator is selected but no values are selected\n            if(filter.operator === 'between' && filter.start === undefined && filter.end === undefined) {\n              return ({...state, filters: allFilters.filter(f => f.field !== filter.field)});\n            }\n\n            // Remove filter if no values are selected\n            if (filter.operator !== 'between' && filter.filters === undefined && filter.value === undefined && filter.values === undefined) {\n              return ({...state, filters: (allFilters || []).filter(f => f?.field !== filter.field)});\n            }\n\n            // Update filter values\n            if (existing >= 0) {\n              const filters = allFilters.toSpliced(existing, 1, filter);\n              return ({...state, filters});\n            }\n\n          }\n\n          return state;\n        });\n      },\n      /**\n       * Removes a filter from the store based on the specified field.\n       *\n       * @param field - The field of the filter to be removed.\n       */\n      removeFilter(field?: string) {\n        if(!field) return;\n        patchState(store, (state) => {\n          const filters = state.filters?.filter(f => f.field !== field);\n          return { ...state, filters };\n        });\n      },\n      /**\n       * Removes a filter from the state by its name.\n       *\n       * @param name - The name of the filter to be removed.\n       */\n      removeFilterByName(name?: string) {\n        if(!name) return;\n        patchState(store, (state) => {\n          const filters = state.filters?.filter(f => f.name !== name);\n          return { ...state, filters };\n        });\n      },\n      /**\n       * Clears all filters from the state.\n       *\n       * This method updates the state by setting the `filters` property to an empty array.\n       * It uses the `patchState` function to apply the state change.\n       */\n      clearFilters() {\n        patchState(store, (state) => {\n          return { ...state, filters: [] };\n        });\n      },\n      /**\n       * Updates the current state with the provided query parameters.\n       *\n       * @param params - A partial object containing the query parameters to be updated.\n       */\n      patch(params: Partial<QueryParamsState>) {\n        patchState(store, (state) => {\n          return { ...state, ...params };\n        });\n      },\n      /**\n       * Retrieves a filter object based on the provided field or name.\n       *\n       * @param {string} fieldOrName - The field or name to search for in the filters.\n       * @returns {Partial<LegacyFilter & {count: number}> | null} - The filter object with an additional count property, or null if not found.\n       *\n       * The method performs the following steps:\n       * 1. Checks if the `fieldOrName` parameter is provided. If not, returns null.\n       * 2. Searches for a filter with a matching field in the store's filters.\n       * 3. If no filter is found by field, searches for a filter with a matching name.\n       * 4. If a filter is found and has a `value` property, returns the filter with a count of 1.\n       * 5. If a filter is found and does not have an array of filters, returns the filter with a count of 1.\n       * 6. If a filter is found and has a `values` property, returns the filter with the count set to the length of the `values` array.\n       * 7. If a filter is found and has an array of filters, returns the filter with the count set to the length of the `filters` array.\n       * 8. If none of the above conditions are met, returns the filter with a count of 0.\n       */\n      getFilter(fieldOrName?: string): Partial<LegacyFilter & {count: number}> | null {\n        if(!fieldOrName) return null;\n\n        let filter = getState(store).filters?.find(f => f?.field === fieldOrName);\n        // if not found, return checks for the filter name\n        if(!filter) filter = getState(store).filters?.find(f => f?.name === fieldOrName);\n\n        // if filter is found, return null\n        if(!filter) return null;\n\n        if(filter.operator && filter.operator === 'or') {\n          const count = Array.isArray(filter.filters) ? filter.filters.length : 1;\n          return ({...filter, count });\n        }\n        if(filter.operator && filter.operator === 'and') {\n          return ({...filter, count: 1 });\n        }\n\n        if(filter && filter.value) return ({...filter, count: 1});\n        if(filter && filter.values) return ({...filter, count: filter.values.length});\n        if(filter && Array.isArray(filter.filters) === false) return ({...filter, count: 1});\n        if(filter && Array.isArray(filter.filters)) return ({...filter, count: filter.filters.length});\n\n        return ({...filter, count: 0});\n      },\n      /**\n       * Constructs and returns a query object based on the current state of the store.\n       *\n       * This method retrieves various parameters from the store's state, such as filters, sort order, tab, query text, query name, and spelling correction mode.\n       * It processes the filters to separate out \"concepts\" filters and incorporates them into the query text.\n       * The remaining filters are combined appropriately.\n       * Finally, it builds and returns the query object using the processed parameters.\n       *\n       * @returns Query The constructed query object.\n       */\n      getQuery() {\n        const { filters: allFilters = [], sort, tab, text: queryText = '', name, spellingCorrectionMode } = getState(store);\n        let text = queryText;\n\n        // remove concepts filters from the query to add them in the query expression\n        const [conceptsFilters] = allFilters.filter(f => f.field === \"concepts\");\n        if (conceptsFilters) {\n          const concepts = conceptsFilters.filters ? (conceptsFilters.filters as LegacyFilter[]).map(f => f.value) as string[] : [conceptsFilters.value] as string[];\n          text = addConcepts(queryText, concepts);\n        }\n\n        const filters = allFilters.filter(f => f.field !== \"concepts\");\n        const f = filters.length > 1\n          ? { operator: \"and\", filters } as LegacyFilter\n          : filters[0] as LegacyFilter;\n\n        const query = runInInjectionContext(injector, () =>  buildQuery({ filters: f, name, sort, spellingCorrectionMode, tab, text }));\n        return query;\n      }\n    }))\n  );\n}"]}
@@ -1,46 +0,0 @@
1
- import { withDevtools } from "@angular-architects/ngrx-toolkit";
2
- import { patchState, signalStore, signalStoreFeature, withMethods, withState } from "@ngrx/signals";
3
- const initialState = {};
4
- /**
5
- * @constant
6
- * @name SelectionStore
7
- * @description
8
- * A store that manages the selection state of articles. It is provided in the root of the application and includes
9
- * development tools for easier debugging. The store maintains the state with the following properties:
10
- * - `article`: The selected article.
11
- * - `id`: The ID of the selected article.
12
- * - `queryText`: The query text associated with the selection.
13
- *
14
- * @methods
15
- * - `update(article: Article, queryText?: string)`: Updates the store with a new article and optional query text.
16
- * - `updateQueryText(queryText: string)`: Updates the query text in the store.
17
- * - `clear()`: Clears the selection state, setting `article`, `id`, and `queryText` to `undefined`.
18
- */
19
- export const SelectionStore = signalStore({ providedIn: 'root' }, withDevtools("Selection"), withState(initialState), withSelectionFeatures());
20
- export function withSelectionFeatures() {
21
- return signalStoreFeature(withState(initialState), withMethods((store) => ({
22
- /**
23
- * Updates the state with the provided article and optional query text.
24
- *
25
- * @param article - The article object to update the state with.
26
- * @param queryText - Optional query text to update the state with.
27
- */
28
- update(newState) {
29
- patchState(store, (state) => {
30
- return { ...state, ...newState };
31
- });
32
- },
33
- /**
34
- * Clears the current selection state by setting the `article`, `id`, and `queryText` properties to `undefined`.
35
- *
36
- * @remarks
37
- * This method uses the `patchState` function to update the state of the store.
38
- */
39
- clear() {
40
- patchState(store, () => {
41
- return ({ article: undefined, id: undefined, queryText: undefined, previewHighlights: undefined });
42
- });
43
- }
44
- })));
45
- }
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLnN0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXRvbWljLWFuZ3VsYXIvc3JjL2xpYi9zdG9yZXMvc2VsZWN0aW9uLnN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNoRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxrQkFBa0IsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBZ0JwRyxNQUFNLFlBQVksR0FBbUIsRUFBb0IsQ0FBQztBQUUxRDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxXQUFXLENBQ3ZDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxFQUN0QixZQUFZLENBQUMsV0FBVyxDQUFDLEVBQ3pCLFNBQVMsQ0FBQyxZQUFZLENBQUMsRUFDdkIscUJBQXFCLEVBQUUsQ0FDeEIsQ0FBQztBQUVGLE1BQU0sVUFBVSxxQkFBcUI7SUFDbkMsT0FBTyxrQkFBa0IsQ0FDdkIsU0FBUyxDQUFDLFlBQVksQ0FBQyxFQUN2QixXQUFXLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDdEI7Ozs7O1dBS0c7UUFDSCxNQUFNLENBQUMsUUFBaUM7WUFDdEMsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDLEtBQUssRUFBRSxFQUFFO2dCQUMxQixPQUFPLEVBQUUsR0FBRyxLQUFLLEVBQUUsR0FBRyxRQUFRLEVBQUUsQ0FBQztZQUNuQyxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRDs7Ozs7V0FLRztRQUNILEtBQUs7WUFDSCxVQUFVLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRTtnQkFDckIsT0FBTyxDQUFDLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztZQUNyRyxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7S0FDRixDQUFDLENBQUMsQ0FDSixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHdpdGhEZXZ0b29scyB9IGZyb20gXCJAYW5ndWxhci1hcmNoaXRlY3RzL25ncngtdG9vbGtpdFwiO1xuaW1wb3J0IHsgcGF0Y2hTdGF0ZSwgc2lnbmFsU3RvcmUsIHNpZ25hbFN0b3JlRmVhdHVyZSwgd2l0aE1ldGhvZHMsIHdpdGhTdGF0ZSB9IGZyb20gXCJAbmdyeC9zaWduYWxzXCI7XG5cbmltcG9ydCB7IEFydGljbGUsIEN1c3RvbUhpZ2hsaWdodHMgfSBmcm9tIFwiQHNpbmVxdWEvYXRvbWljXCI7XG5cbmV4cG9ydCB0eXBlIFByZXZpZXdIaWdobGlnaHRzID0ge1xuICBoaWdobGlnaHRzOiBDdXN0b21IaWdobGlnaHRzW107XG4gIHNuaXBwZXRJZD86IG51bWJlcjtcbn07XG5cbnR5cGUgU2VsZWN0aW9uU3RhdGUgPSB7XG4gIGFydGljbGU6IEFydGljbGU7XG4gIGlkOiBzdHJpbmc7XG4gIHF1ZXJ5VGV4dDogc3RyaW5nO1xuICBwcmV2aWV3SGlnaGxpZ2h0czogUHJldmlld0hpZ2hsaWdodHM7XG59O1xuXG5jb25zdCBpbml0aWFsU3RhdGU6IFNlbGVjdGlvblN0YXRlID0ge30gYXMgU2VsZWN0aW9uU3RhdGU7XG5cbi8qKlxuICogQGNvbnN0YW50XG4gKiBAbmFtZSBTZWxlY3Rpb25TdG9yZVxuICogQGRlc2NyaXB0aW9uXG4gKiBBIHN0b3JlIHRoYXQgbWFuYWdlcyB0aGUgc2VsZWN0aW9uIHN0YXRlIG9mIGFydGljbGVzLiBJdCBpcyBwcm92aWRlZCBpbiB0aGUgcm9vdCBvZiB0aGUgYXBwbGljYXRpb24gYW5kIGluY2x1ZGVzXG4gKiBkZXZlbG9wbWVudCB0b29scyBmb3IgZWFzaWVyIGRlYnVnZ2luZy4gVGhlIHN0b3JlIG1haW50YWlucyB0aGUgc3RhdGUgd2l0aCB0aGUgZm9sbG93aW5nIHByb3BlcnRpZXM6XG4gKiAtIGBhcnRpY2xlYDogVGhlIHNlbGVjdGVkIGFydGljbGUuXG4gKiAtIGBpZGA6IFRoZSBJRCBvZiB0aGUgc2VsZWN0ZWQgYXJ0aWNsZS5cbiAqIC0gYHF1ZXJ5VGV4dGA6IFRoZSBxdWVyeSB0ZXh0IGFzc29jaWF0ZWQgd2l0aCB0aGUgc2VsZWN0aW9uLlxuICpcbiAqIEBtZXRob2RzXG4gKiAtIGB1cGRhdGUoYXJ0aWNsZTogQXJ0aWNsZSwgcXVlcnlUZXh0Pzogc3RyaW5nKWA6IFVwZGF0ZXMgdGhlIHN0b3JlIHdpdGggYSBuZXcgYXJ0aWNsZSBhbmQgb3B0aW9uYWwgcXVlcnkgdGV4dC5cbiAqIC0gYHVwZGF0ZVF1ZXJ5VGV4dChxdWVyeVRleHQ6IHN0cmluZylgOiBVcGRhdGVzIHRoZSBxdWVyeSB0ZXh0IGluIHRoZSBzdG9yZS5cbiAqIC0gYGNsZWFyKClgOiBDbGVhcnMgdGhlIHNlbGVjdGlvbiBzdGF0ZSwgc2V0dGluZyBgYXJ0aWNsZWAsIGBpZGAsIGFuZCBgcXVlcnlUZXh0YCB0byBgdW5kZWZpbmVkYC5cbiAqL1xuZXhwb3J0IGNvbnN0IFNlbGVjdGlvblN0b3JlID0gc2lnbmFsU3RvcmUoXG4gIHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0sXG4gIHdpdGhEZXZ0b29scyhcIlNlbGVjdGlvblwiKSxcbiAgd2l0aFN0YXRlKGluaXRpYWxTdGF0ZSksXG4gIHdpdGhTZWxlY3Rpb25GZWF0dXJlcygpXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gd2l0aFNlbGVjdGlvbkZlYXR1cmVzKCkge1xuICByZXR1cm4gc2lnbmFsU3RvcmVGZWF0dXJlKFxuICAgIHdpdGhTdGF0ZShpbml0aWFsU3RhdGUpLFxuICAgIHdpdGhNZXRob2RzKChzdG9yZSkgPT4gKHtcbiAgICAgIC8qKlxuICAgICAgICogVXBkYXRlcyB0aGUgc3RhdGUgd2l0aCB0aGUgcHJvdmlkZWQgYXJ0aWNsZSBhbmQgb3B0aW9uYWwgcXVlcnkgdGV4dC5cbiAgICAgICAqXG4gICAgICAgKiBAcGFyYW0gYXJ0aWNsZSAtIFRoZSBhcnRpY2xlIG9iamVjdCB0byB1cGRhdGUgdGhlIHN0YXRlIHdpdGguXG4gICAgICAgKiBAcGFyYW0gcXVlcnlUZXh0IC0gT3B0aW9uYWwgcXVlcnkgdGV4dCB0byB1cGRhdGUgdGhlIHN0YXRlIHdpdGguXG4gICAgICAgKi9cbiAgICAgIHVwZGF0ZShuZXdTdGF0ZTogUGFydGlhbDxTZWxlY3Rpb25TdGF0ZT4pIHtcbiAgICAgICAgcGF0Y2hTdGF0ZShzdG9yZSwgKHN0YXRlKSA9PiB7XG4gICAgICAgICAgcmV0dXJuIHsgLi4uc3RhdGUsIC4uLm5ld1N0YXRlIH07XG4gICAgICAgIH0pO1xuICAgICAgfSxcbiAgICAgIC8qKlxuICAgICAgICogQ2xlYXJzIHRoZSBjdXJyZW50IHNlbGVjdGlvbiBzdGF0ZSBieSBzZXR0aW5nIHRoZSBgYXJ0aWNsZWAsIGBpZGAsIGFuZCBgcXVlcnlUZXh0YCBwcm9wZXJ0aWVzIHRvIGB1bmRlZmluZWRgLlxuICAgICAgICpcbiAgICAgICAqIEByZW1hcmtzXG4gICAgICAgKiBUaGlzIG1ldGhvZCB1c2VzIHRoZSBgcGF0Y2hTdGF0ZWAgZnVuY3Rpb24gdG8gdXBkYXRlIHRoZSBzdGF0ZSBvZiB0aGUgc3RvcmUuXG4gICAgICAgKi9cbiAgICAgIGNsZWFyKCkge1xuICAgICAgICBwYXRjaFN0YXRlKHN0b3JlLCAoKSA9PiB7XG4gICAgICAgICAgcmV0dXJuICh7IGFydGljbGU6IHVuZGVmaW5lZCwgaWQ6IHVuZGVmaW5lZCwgcXVlcnlUZXh0OiB1bmRlZmluZWQsIHByZXZpZXdIaWdobGlnaHRzOiB1bmRlZmluZWQgfSk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0pKVxuICApO1xufSJdfQ==
@@ -1,116 +0,0 @@
1
- import { withDevtools } from "@angular-architects/ngrx-toolkit";
2
- import { patchState, signalStore, withMethods, withState } from "@ngrx/signals";
3
- import { THEMES } from "../resources";
4
- const initialState = {
5
- scopes: {}
6
- };
7
- export const ThemeStore = signalStore({ providedIn: 'root' }, withState(initialState), withDevtools('Theme'), withMethods((store) => ({
8
- loadDefaultTheme(scope, darkMode) {
9
- this.setCurrentTheme(scope, 'Default', darkMode);
10
- },
11
- /**
12
- * Sets the current theme for a given scope.
13
- *
14
- * @param {string} scope - The scope for which the theme is being set.
15
- * @param {string} themeName - The name of the theme to be applied.
16
- * @param {boolean} [darkMode] - Optional. Specifies whether dark mode should be enabled. If not provided, it defaults to the current scope's dark mode setting or false.
17
- * @returns {void}
18
- */
19
- setCurrentTheme(scope, themeName, darkMode) {
20
- const cssVars = processCssVars(themeName);
21
- const currentScope = store.scopes()[scope];
22
- patchState(store, (state => ({
23
- ...state,
24
- scopes: {
25
- ...store.scopes(),
26
- [scope]: {
27
- cssVars,
28
- darkMode: darkMode ?? currentScope?.darkMode ?? false,
29
- themeName: themeName
30
- }
31
- }
32
- })));
33
- },
34
- /**
35
- * Sets the dark mode preference for a given scope.
36
- *
37
- * @param scope - The scope for which to set the dark mode preference.
38
- * @param darkMode - A boolean indicating whether dark mode should be enabled (true) or disabled (false).
39
- *
40
- * This function updates the state by patching it with the new dark mode setting for the specified scope.
41
- * It retains the existing CSS variables and theme name for the scope.
42
- */
43
- setDarkMode(scope, darkMode) {
44
- const currentScope = store.scopes()[scope];
45
- patchState(store, (state => ({
46
- ...state,
47
- scopes: {
48
- ...store.scopes(),
49
- [scope]: {
50
- cssVars: currentScope?.cssVars ?? {},
51
- darkMode,
52
- themeName: currentScope?.themeName
53
- }
54
- }
55
- })));
56
- },
57
- })));
58
- /**
59
- * Processes the CSS variables for a given theme name.
60
- *
61
- * @param themeName - The name of the theme to process.
62
- * @returns An object containing the CSS variables for both light and dark themes.
63
- * @throws Will throw an error if the theme with the specified name is not found.
64
- */
65
- export function processCssVars(themeName) {
66
- const theme = THEMES.find(theme => theme.name === themeName);
67
- if (!theme)
68
- throw new Error(`Theme "${themeName}" not found`);
69
- const cssVars = {
70
- light: themeColorsToCssVariables(theme.colors),
71
- dark: themeColorsToCssVariables(theme.colorsDark)
72
- };
73
- return cssVars;
74
- }
75
- /**
76
- * Converts an object of theme colors to CSS variables.
77
- *
78
- * @param colors - An object where keys are theme color names and values are the corresponding color values.
79
- * @returns An object where keys are CSS variable names and values are the corresponding color values.
80
- */
81
- export function themeColorsToCssVariables(colors) {
82
- const cssVars = colors
83
- ? Object.fromEntries(Object.entries(colors).map(([name, value]) => {
84
- if (value === undefined)
85
- return [];
86
- const cssName = themeColorNameToCssVariable(name);
87
- return [cssName, value];
88
- }))
89
- : {};
90
- return cssVars;
91
- }
92
- /**
93
- * Converts a camelCase theme color name to a CSS variable format.
94
- *
95
- * This function takes a camelCase string and transforms it into a CSS variable
96
- * name by inserting hyphens between lowercase and uppercase letters and converting
97
- * the entire string to lowercase.
98
- *
99
- * @param name - The camelCase theme color name to be converted.
100
- * @returns The corresponding CSS variable name in kebab-case.
101
- */
102
- export function themeColorNameToCssVariable(name) {
103
- return `--${name.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase()}`;
104
- }
105
- /**
106
- * Applies a set of CSS variables to a given HTML element.
107
- *
108
- * @param element - The HTML element to which the CSS variables will be applied.
109
- * @param cssVars - An optional record of CSS variable names and their corresponding values.
110
- */
111
- export function applyThemeToNativeElement(element, cssVars) {
112
- if (!cssVars)
113
- return;
114
- Object.keys(cssVars).forEach((key) => element.style.setProperty(key, cssVars[key]));
115
- }
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.store.js","sourceRoot":"","sources":["../../../../../projects/atomic-angular/src/lib/stores/theme.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { withDevtools } from \"@angular-architects/ngrx-toolkit\";\nimport { patchState, signalStore, withMethods, withState } from \"@ngrx/signals\";\n\nimport { THEMES } from \"../resources\";\n\nexport type CssVars = {\n  light?: Record<string, string>;\n  dark?: Record<string, string>;\n};\n\nexport type ThemeScope = {\n  [key: string]: {\n    cssVars: CssVars;\n    darkMode?: boolean;\n    themeName: string;\n  };\n};\n\nexport type ThemeStoreState = {\n  scopes: ThemeScope;\n};\n\nconst initialState: ThemeStoreState = {\n  scopes: {}\n};\n\nexport const ThemeStore = signalStore(\n  { providedIn: 'root' },\n  withState(initialState),\n  withDevtools('Theme'),\n\n  withMethods((store) => ({\n    loadDefaultTheme(scope: string, darkMode?: boolean): void {\n      this.setCurrentTheme(scope, 'Default', darkMode);\n    },\n\n    /**\n     * Sets the current theme for a given scope.\n     *\n     * @param {string} scope - The scope for which the theme is being set.\n     * @param {string} themeName - The name of the theme to be applied.\n     * @param {boolean} [darkMode] - Optional. Specifies whether dark mode should be enabled. If not provided, it defaults to the current scope's dark mode setting or false.\n     * @returns {void}\n     */\n    setCurrentTheme(scope: string, themeName: string, darkMode?: boolean): void {\n      const cssVars = processCssVars(themeName);\n      const currentScope = store.scopes()[scope];\n\n      patchState(store, (\n        state => ({\n          ...state,\n          scopes: {\n            ...store.scopes(),\n            [scope]: {\n              cssVars,\n              darkMode: darkMode ?? currentScope?.darkMode ?? false,\n              themeName: themeName\n            }\n          }\n        })\n      ));\n    },\n\n    /**\n     * Sets the dark mode preference for a given scope.\n     *\n     * @param scope - The scope for which to set the dark mode preference.\n     * @param darkMode - A boolean indicating whether dark mode should be enabled (true) or disabled (false).\n     *\n     * This function updates the state by patching it with the new dark mode setting for the specified scope.\n     * It retains the existing CSS variables and theme name for the scope.\n     */\n    setDarkMode(scope: string, darkMode: boolean): void {\n      const currentScope = store.scopes()[scope];\n\n      patchState(store, (\n        state => ({\n          ...state,\n          scopes: {\n            ...store.scopes(),\n            [scope]: {\n              cssVars: currentScope?.cssVars ?? {},\n              darkMode,\n              themeName: currentScope?.themeName\n            }\n          }\n        })\n      ));\n    },\n  }))\n);\n\n/**\n * Processes the CSS variables for a given theme name.\n *\n * @param themeName - The name of the theme to process.\n * @returns An object containing the CSS variables for both light and dark themes.\n * @throws Will throw an error if the theme with the specified name is not found.\n */\nexport function processCssVars(themeName: string): CssVars {\n  const theme = THEMES.find(theme => theme.name === themeName);\n\n  if (!theme) throw new Error(`Theme \"${themeName}\" not found`);\n\n  const cssVars = {\n    light: themeColorsToCssVariables(theme!.colors),\n    dark: themeColorsToCssVariables(theme!.colorsDark)\n  };\n\n  return cssVars;\n}\n\n/**\n * Converts an object of theme colors to CSS variables.\n *\n * @param colors - An object where keys are theme color names and values are the corresponding color values.\n * @returns An object where keys are CSS variable names and values are the corresponding color values.\n */\nexport function themeColorsToCssVariables(colors: any): any {\n  const cssVars = colors\n    ? Object.fromEntries(\n      Object.entries(colors).map(([name, value]) => {\n        if (value === undefined) return []\n        const cssName = themeColorNameToCssVariable(name)\n        return [cssName, value]\n      }))\n    : {};\n\n  return cssVars;\n}\n\n/**\n * Converts a camelCase theme color name to a CSS variable format.\n *\n * This function takes a camelCase string and transforms it into a CSS variable\n * name by inserting hyphens between lowercase and uppercase letters and converting\n * the entire string to lowercase.\n *\n * @param name - The camelCase theme color name to be converted.\n * @returns The corresponding CSS variable name in kebab-case.\n */\nexport function themeColorNameToCssVariable(name: string): string {\n  return `--${name.replace(/([a-z])([A-Z])/g, \"$1-$2\").toLowerCase()}`;\n}\n\n/**\n * Applies a set of CSS variables to a given HTML element.\n *\n * @param element - The HTML element to which the CSS variables will be applied.\n * @param cssVars - An optional record of CSS variable names and their corresponding values.\n */\nexport function applyThemeToNativeElement(element: HTMLElement, cssVars?: Record<string, string>): void {\n  if (!cssVars) return;\n\n  Object.keys(cssVars).forEach((key) =>\n    element.style.setProperty(key, cssVars[key])\n  );\n}\n"]}