@futdevpro/fsm-dynamo 1.14.10 → 1.14.12

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 (276) hide show
  1. package/.vscode/settings.json +11 -0
  2. package/build/_collections/constants/data-sizes.const.d.ts +3 -3
  3. package/build/_collections/constants/data-sizes.const.d.ts.map +1 -1
  4. package/build/_collections/constants/data-sizes.const.js +4 -3
  5. package/build/_collections/constants/data-sizes.const.js.map +1 -1
  6. package/build/_collections/utils/array.util.d.ts +189 -0
  7. package/build/_collections/utils/array.util.d.ts.map +1 -1
  8. package/build/_collections/utils/array.util.js +189 -0
  9. package/build/_collections/utils/array.util.js.map +1 -1
  10. package/build/_collections/utils/async.util.d.ts +29 -0
  11. package/build/_collections/utils/async.util.d.ts.map +1 -1
  12. package/build/_collections/utils/async.util.js +45 -3
  13. package/build/_collections/utils/async.util.js.map +1 -1
  14. package/build/_collections/utils/json-error-helper.util.d.ts +38 -0
  15. package/build/_collections/utils/json-error-helper.util.d.ts.map +1 -1
  16. package/build/_collections/utils/json-error-helper.util.js +38 -0
  17. package/build/_collections/utils/json-error-helper.util.js.map +1 -1
  18. package/build/_collections/utils/log.util.d.ts +195 -5
  19. package/build/_collections/utils/log.util.d.ts.map +1 -1
  20. package/build/_collections/utils/log.util.js +245 -53
  21. package/build/_collections/utils/log.util.js.map +1 -1
  22. package/build/_collections/utils/math/box-bounds.util.d.ts +36 -0
  23. package/build/_collections/utils/math/box-bounds.util.d.ts.map +1 -1
  24. package/build/_collections/utils/math/box-bounds.util.js +38 -6
  25. package/build/_collections/utils/math/box-bounds.util.js.map +1 -1
  26. package/build/_collections/utils/math/math.util.d.ts +48 -12
  27. package/build/_collections/utils/math/math.util.d.ts.map +1 -1
  28. package/build/_collections/utils/math/math.util.js +51 -15
  29. package/build/_collections/utils/math/math.util.js.map +1 -1
  30. package/build/_collections/utils/math/math.util.spec.js +0 -9
  31. package/build/_collections/utils/math/math.util.spec.js.map +1 -1
  32. package/build/_collections/utils/math/random.util.d.ts +30 -0
  33. package/build/_collections/utils/math/random.util.d.ts.map +1 -1
  34. package/build/_collections/utils/math/random.util.js +30 -0
  35. package/build/_collections/utils/math/random.util.js.map +1 -1
  36. package/build/_collections/utils/math/trigonometry.util.d.ts +30 -0
  37. package/build/_collections/utils/math/trigonometry.util.d.ts.map +1 -1
  38. package/build/_collections/utils/math/trigonometry.util.js +30 -0
  39. package/build/_collections/utils/math/trigonometry.util.js.map +1 -1
  40. package/build/_collections/utils/math/vector2.util.d.ts +247 -17
  41. package/build/_collections/utils/math/vector2.util.d.ts.map +1 -1
  42. package/build/_collections/utils/math/vector2.util.js +309 -79
  43. package/build/_collections/utils/math/vector2.util.js.map +1 -1
  44. package/build/_collections/utils/object.util.js +9 -7
  45. package/build/_collections/utils/object.util.js.map +1 -1
  46. package/build/_collections/utils/regex/password-regex.util.d.ts +12 -0
  47. package/build/_collections/utils/regex/password-regex.util.d.ts.map +1 -1
  48. package/build/_collections/utils/regex/password-regex.util.js +12 -0
  49. package/build/_collections/utils/regex/password-regex.util.js.map +1 -1
  50. package/build/_collections/utils/round-list.util.d.ts +39 -0
  51. package/build/_collections/utils/round-list.util.d.ts.map +1 -1
  52. package/build/_collections/utils/round-list.util.js +39 -0
  53. package/build/_collections/utils/round-list.util.js.map +1 -1
  54. package/build/_collections/utils/stack.util.d.ts +19 -0
  55. package/build/_collections/utils/stack.util.d.ts.map +1 -1
  56. package/build/_collections/utils/stack.util.js +22 -2
  57. package/build/_collections/utils/stack.util.js.map +1 -1
  58. package/build/_collections/utils/stack.util.spec.js +0 -13
  59. package/build/_collections/utils/stack.util.spec.js.map +1 -1
  60. package/build/_collections/utils/string.util.d.ts +17 -0
  61. package/build/_collections/utils/string.util.d.ts.map +1 -1
  62. package/build/_collections/utils/string.util.js +17 -0
  63. package/build/_collections/utils/string.util.js.map +1 -1
  64. package/build/_collections/utils/time.util.d.ts +136 -0
  65. package/build/_collections/utils/time.util.d.ts.map +1 -1
  66. package/build/_collections/utils/time.util.js +164 -28
  67. package/build/_collections/utils/time.util.js.map +1 -1
  68. package/build/_collections/utils/utilities.util.d.ts +17 -1
  69. package/build/_collections/utils/utilities.util.d.ts.map +1 -1
  70. package/build/_collections/utils/utilities.util.js +17 -1
  71. package/build/_collections/utils/utilities.util.js.map +1 -1
  72. package/build/_collections/utils/uuid.util.d.ts +6 -0
  73. package/build/_collections/utils/uuid.util.d.ts.map +1 -1
  74. package/build/_collections/utils/uuid.util.js +6 -0
  75. package/build/_collections/utils/uuid.util.js.map +1 -1
  76. package/build/_enums/data-model-type.enum.d.ts +6 -0
  77. package/build/_enums/data-model-type.enum.d.ts.map +1 -1
  78. package/build/_enums/data-model-type.enum.js +6 -0
  79. package/build/_enums/data-model-type.enum.js.map +1 -1
  80. package/build/_enums/http/http-call-type.enum.d.ts +8 -0
  81. package/build/_enums/http/http-call-type.enum.d.ts.map +1 -1
  82. package/build/_enums/http/http-call-type.enum.js +8 -0
  83. package/build/_enums/http/http-call-type.enum.js.map +1 -1
  84. package/build/_enums/http/http-event-type.enum.d.ts +5 -0
  85. package/build/_enums/http/http-event-type.enum.d.ts.map +1 -1
  86. package/build/_enums/http/http-event-type.enum.js +5 -0
  87. package/build/_enums/http/http-event-type.enum.js.map +1 -1
  88. package/build/_enums/time/day-of-week.enum.d.ts +14 -1
  89. package/build/_enums/time/day-of-week.enum.d.ts.map +1 -1
  90. package/build/_enums/time/day-of-week.enum.js +14 -1
  91. package/build/_enums/time/day-of-week.enum.js.map +1 -1
  92. package/build/_models/control-models/data-model-params.control-model.d.ts.map +1 -1
  93. package/build/_models/control-models/data-model-params.control-model.js +11 -22
  94. package/build/_models/control-models/data-model-params.control-model.js.map +1 -1
  95. package/build/_models/control-models/data-property-params.control-model.d.ts +8 -0
  96. package/build/_models/control-models/data-property-params.control-model.d.ts.map +1 -1
  97. package/build/_models/control-models/data-property-params.control-model.js +11 -59
  98. package/build/_models/control-models/data-property-params.control-model.js.map +1 -1
  99. package/build/_models/control-models/error.control-model.js +8 -25
  100. package/build/_models/control-models/error.control-model.js.map +1 -1
  101. package/build/_models/control-models/http/http-error-response.control-model.d.ts +25 -0
  102. package/build/_models/control-models/http/http-error-response.control-model.d.ts.map +1 -1
  103. package/build/_models/control-models/http/http-error-response.control-model.js +30 -7
  104. package/build/_models/control-models/http/http-error-response.control-model.js.map +1 -1
  105. package/build/_models/control-models/http/http-headers.control-model.d.ts +8 -0
  106. package/build/_models/control-models/http/http-headers.control-model.d.ts.map +1 -1
  107. package/build/_models/control-models/http/http-headers.control-model.js +12 -17
  108. package/build/_models/control-models/http/http-headers.control-model.js.map +1 -1
  109. package/build/_models/control-models/http/http-response.model-base.d.ts +9 -0
  110. package/build/_models/control-models/http/http-response.model-base.d.ts.map +1 -1
  111. package/build/_models/control-models/http/http-response.model-base.js +23 -26
  112. package/build/_models/control-models/http/http-response.model-base.js.map +1 -1
  113. package/build/_models/control-models/poll.control-model.d.ts +18 -0
  114. package/build/_models/control-models/poll.control-model.d.ts.map +1 -1
  115. package/build/_models/control-models/poll.control-model.js +22 -26
  116. package/build/_models/control-models/poll.control-model.js.map +1 -1
  117. package/build/_models/control-models/range-value.control-model.d.ts +141 -0
  118. package/build/_models/control-models/range-value.control-model.d.ts.map +1 -1
  119. package/build/_models/control-models/range-value.control-model.js +143 -4
  120. package/build/_models/control-models/range-value.control-model.js.map +1 -1
  121. package/build/_models/control-models/server-status.control-model.d.ts +10 -0
  122. package/build/_models/control-models/server-status.control-model.d.ts.map +1 -1
  123. package/build/_models/control-models/server-status.control-model.js +10 -12
  124. package/build/_models/control-models/server-status.control-model.js.map +1 -1
  125. package/build/_models/control-models/service-endpoint-settings-base.control-model.d.ts +34 -1
  126. package/build/_models/control-models/service-endpoint-settings-base.control-model.d.ts.map +1 -1
  127. package/build/_models/control-models/service-endpoint-settings-base.control-model.js +26 -5
  128. package/build/_models/control-models/service-endpoint-settings-base.control-model.js.map +1 -1
  129. package/build/_models/data-models/errors.data-model.d.ts +10 -0
  130. package/build/_models/data-models/errors.data-model.d.ts.map +1 -1
  131. package/build/_models/data-models/errors.data-model.js +13 -18
  132. package/build/_models/data-models/errors.data-model.js.map +1 -1
  133. package/build/_models/data-models/metadata.data-model.d.ts +26 -0
  134. package/build/_models/data-models/metadata.data-model.d.ts.map +1 -1
  135. package/build/_models/data-models/metadata.data-model.js +26 -12
  136. package/build/_models/data-models/metadata.data-model.js.map +1 -1
  137. package/build/_modules/ai/_models/ai-call-settings.interface.js +46 -49
  138. package/build/_modules/ai/_models/ai-call-settings.interface.js.map +1 -1
  139. package/build/_modules/ai/_models/ai-settings.interface.js +0 -3
  140. package/build/_modules/ai/_models/ai-settings.interface.js.map +1 -1
  141. package/build/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.js +2 -2
  142. package/build/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.js.map +1 -1
  143. package/build/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.js +3 -3
  144. package/build/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.js.map +1 -1
  145. package/build/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.js +2 -2
  146. package/build/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.js.map +1 -1
  147. package/build/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.js +3 -3
  148. package/build/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.js.map +1 -1
  149. package/build/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.js +1 -1
  150. package/build/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.js.map +1 -1
  151. package/build/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.js +3 -3
  152. package/build/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.js.map +1 -1
  153. package/build/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.js +2 -2
  154. package/build/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.js.map +1 -1
  155. package/build/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.js +3 -3
  156. package/build/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.js.map +1 -1
  157. package/build/_modules/ai/_modules/open-ai/index.d.ts.map +1 -1
  158. package/build/_modules/ai/_modules/open-ai/index.js +7 -7
  159. package/build/_modules/ai/_modules/open-ai/index.js.map +1 -1
  160. package/build/_modules/ci-tools/_models/cit-ci-result-info.data-models.d.ts +23 -0
  161. package/build/_modules/ci-tools/_models/cit-ci-result-info.data-models.d.ts.map +1 -1
  162. package/build/_modules/ci-tools/_models/cit-ci-result-info.data-models.js +24 -12
  163. package/build/_modules/ci-tools/_models/cit-ci-result-info.data-models.js.map +1 -1
  164. package/build/_modules/crypto/_collections/crypto-2-non-stable.util.js +2 -2
  165. package/build/_modules/crypto/_collections/crypto-2-non-stable.util.js.map +1 -1
  166. package/build/_modules/crypto/_collections/crypto-old.util.d.ts.map +1 -1
  167. package/build/_modules/crypto/_collections/crypto-old.util.js +16 -16
  168. package/build/_modules/crypto/_collections/crypto-old.util.js.map +1 -1
  169. package/build/_modules/crypto/_collections/crypto.util.js +9 -9
  170. package/build/_modules/crypto/_collections/crypto.util.js.map +1 -1
  171. package/build/_modules/custom-data/_models/cud.data-model.d.ts +7 -0
  172. package/build/_modules/custom-data/_models/cud.data-model.d.ts.map +1 -1
  173. package/build/_modules/custom-data/_models/cud.data-model.js +7 -1
  174. package/build/_modules/custom-data/_models/cud.data-model.js.map +1 -1
  175. package/build/_modules/data-handler/_models/data-handler-settings.control-model.d.ts +73 -0
  176. package/build/_modules/data-handler/_models/data-handler-settings.control-model.d.ts.map +1 -0
  177. package/build/_modules/data-handler/_models/data-handler-settings.control-model.js +41 -0
  178. package/build/_modules/data-handler/_models/data-handler-settings.control-model.js.map +1 -0
  179. package/build/_modules/data-handler/_models/data-handler.control-model.d.ts +136 -0
  180. package/build/_modules/data-handler/_models/data-handler.control-model.d.ts.map +1 -0
  181. package/build/_modules/data-handler/_models/data-handler.control-model.js +293 -0
  182. package/build/_modules/data-handler/_models/data-handler.control-model.js.map +1 -0
  183. package/build/_modules/data-handler/_models/data-list-handler.control-model.d.ts +111 -0
  184. package/build/_modules/data-handler/_models/data-list-handler.control-model.d.ts.map +1 -0
  185. package/build/_modules/data-handler/_models/data-list-handler.control-model.js +197 -0
  186. package/build/_modules/data-handler/_models/data-list-handler.control-model.js.map +1 -0
  187. package/build/_modules/data-handler/_models/data-search-handler.control-model.d.ts +172 -0
  188. package/build/_modules/data-handler/_models/data-search-handler.control-model.d.ts.map +1 -0
  189. package/build/_modules/data-handler/_models/data-search-handler.control-model.js +319 -0
  190. package/build/_modules/data-handler/_models/data-search-handler.control-model.js.map +1 -0
  191. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.d.ts +116 -0
  192. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.d.ts.map +1 -0
  193. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.js +220 -0
  194. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.js.map +1 -0
  195. package/build/_modules/data-handler/index.d.ts +6 -0
  196. package/build/_modules/data-handler/index.d.ts.map +1 -0
  197. package/build/_modules/data-handler/index.js +10 -0
  198. package/build/_modules/data-handler/index.js.map +1 -0
  199. package/build/_modules/location/_collections/loc-regions.util.d.ts +33 -0
  200. package/build/_modules/location/_collections/loc-regions.util.d.ts.map +1 -1
  201. package/build/_modules/location/_collections/loc-regions.util.js +37 -4
  202. package/build/_modules/location/_collections/loc-regions.util.js.map +1 -1
  203. package/build/_modules/location/_collections/loc.util.d.ts +10 -0
  204. package/build/_modules/location/_collections/loc.util.d.ts.map +1 -1
  205. package/build/_modules/location/_collections/loc.util.js +10 -0
  206. package/build/_modules/location/_collections/loc.util.js.map +1 -1
  207. package/build/_modules/messaging/_models/msg-conversation.data-model.js +0 -23
  208. package/build/_modules/messaging/_models/msg-conversation.data-model.js.map +1 -1
  209. package/build/_modules/messaging/_models/msg-message.data-model.js +0 -34
  210. package/build/_modules/messaging/_models/msg-message.data-model.js.map +1 -1
  211. package/build/_modules/socket/_models/sck-client-params.control-model.js +2 -7
  212. package/build/_modules/socket/_models/sck-client-params.control-model.js.map +1 -1
  213. package/build/_modules/socket/_models/sck-socket-event.control-model.js +0 -8
  214. package/build/_modules/socket/_models/sck-socket-event.control-model.js.map +1 -1
  215. package/build/_modules/socket/_services/sck-client.service-base.js +69 -72
  216. package/build/_modules/socket/_services/sck-client.service-base.js.map +1 -1
  217. package/build/_modules/usage/_models/usg-action.control-model.js +0 -4
  218. package/build/_modules/usage/_models/usg-action.control-model.js.map +1 -1
  219. package/build/_modules/usage/_models/usg-daily-usage-data.control-model.js +10 -12
  220. package/build/_modules/usage/_models/usg-daily-usage-data.control-model.js.map +1 -1
  221. package/build/_modules/usage/_models/usg-data.control-model.js +2 -8
  222. package/build/_modules/usage/_models/usg-data.control-model.js.map +1 -1
  223. package/build/_modules/usage/_models/usg-session.data-model.js +2 -18
  224. package/build/_modules/usage/_models/usg-session.data-model.js.map +1 -1
  225. package/eslint.config.js +4 -0
  226. package/futdevpro-fsm-dynamo-01.14.12.tgz +0 -0
  227. package/package.json +22 -3
  228. package/src/_collections/constants/data-sizes.const.ts +4 -4
  229. package/src/_collections/utils/array.util.ts +189 -0
  230. package/src/_collections/utils/async.util.ts +40 -0
  231. package/src/_collections/utils/json-error-helper.util.ts +43 -3
  232. package/src/_collections/utils/log.util.ts +194 -4
  233. package/src/_collections/utils/math/box-bounds.util.ts +36 -0
  234. package/src/_collections/utils/math/math.util.spec.ts +0 -10
  235. package/src/_collections/utils/math/math.util.ts +48 -16
  236. package/src/_collections/utils/math/random.util.ts +30 -0
  237. package/src/_collections/utils/math/trigonometry.util.ts +30 -0
  238. package/src/_collections/utils/math/vector2.util.ts +254 -24
  239. package/src/_collections/utils/regex/password-regex.util.ts +12 -0
  240. package/src/_collections/utils/round-list.util.ts +39 -0
  241. package/src/_collections/utils/stack.util.ts +27 -4
  242. package/src/_collections/utils/string.util.ts +17 -0
  243. package/src/_collections/utils/time.util.ts +136 -0
  244. package/src/_collections/utils/utilities.util.ts +17 -1
  245. package/src/_collections/utils/uuid.util.ts +6 -0
  246. package/src/_enums/data-model-type.enum.ts +6 -0
  247. package/src/_enums/http/http-call-type.enum.ts +8 -0
  248. package/src/_enums/http/http-event-type.enum.ts +5 -0
  249. package/src/_enums/time/day-of-week.enum.ts +14 -1
  250. package/src/_models/control-models/data-model-params.control-model.ts +11 -1
  251. package/src/_models/control-models/data-property-params.control-model.ts +8 -0
  252. package/src/_models/control-models/http/http-error-response.control-model.ts +25 -0
  253. package/src/_models/control-models/http/http-headers.control-model.ts +8 -0
  254. package/src/_models/control-models/http/http-response.model-base.ts +9 -0
  255. package/src/_models/control-models/poll.control-model.ts +18 -0
  256. package/src/_models/control-models/range-value.control-model.ts +141 -0
  257. package/src/_models/control-models/server-status.control-model.ts +10 -0
  258. package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +53 -4
  259. package/src/_models/data-models/errors.data-model.ts +10 -0
  260. package/src/_models/data-models/metadata.data-model.ts +27 -0
  261. package/src/_modules/ai/_modules/open-ai/index.ts +4 -3
  262. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.ts +23 -0
  263. package/src/_modules/crypto/_collections/crypto-old.util.ts +17 -9
  264. package/src/_modules/custom-data/_models/cud.data-model.ts +7 -0
  265. package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -0
  266. package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -0
  267. package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +245 -0
  268. package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -0
  269. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -0
  270. package/src/_modules/data-handler/index.ts +6 -0
  271. package/src/_modules/location/_collections/loc-regions.util.ts +34 -1
  272. package/src/_modules/location/_collections/loc.util.ts +10 -0
  273. package/src/_modules/usage/_collections/usg-module-settings.const.ts +1 -1
  274. package/tsconfig.json +2 -2
  275. package/.eslintrc.json +0 -155
  276. package/futdevpro-fsm-dynamo-01.14.10.tgz +0 -0
@@ -0,0 +1,390 @@
1
+ import { debounceTime, Subject } from 'rxjs';
2
+
3
+ import { DyFM_DataSearchHandler_Settings } from './data-handler-settings.control-model';
4
+
5
+ import { DyFM_DataListHandler } from './data-list-handler.control-model';
6
+ import { DyFM_Object } from '../../../_collections/utils/object.util';
7
+ import { DyFM_Metadata } from '../../../_models/data-models/metadata.data-model';
8
+ import { DyFM_SearchQuery } from '../../../_models/interfaces/search-query.interface';
9
+ import { DyFM_SearchResult } from '../../../_models/interfaces/search-result.interface';
10
+ import { DyFM_DSFilter } from '../../../_models/types/ds-filter.type';
11
+ import { DyFM_DSSort, DyFM_DSPropertySort } from '../../../_models/types/ds-sort.type';
12
+
13
+ interface SearchCache<T> {
14
+ page: number;
15
+ loadPageSize: number;
16
+ data: T[];
17
+ }
18
+
19
+ /**
20
+ * A specialized data handler for managing searchable data with pagination and caching.
21
+ * Extends DyFM_DataListHandler to provide additional functionality for handling search results.
22
+ *
23
+ * @template T_Data - The type of data items in the search results
24
+ * @template T_DataLoadBy - The type of search query (must extend DyFM_SearchQuery)
25
+ * @template T_Result - The type of search result (must extend DyFM_SearchResult)
26
+ * @template T_DependencyData - The type of dependency data (defaults to any)
27
+ *
28
+ * @example
29
+ * ```typescript
30
+ * // Create a search handler for flow runs
31
+ * const flowRunsHandler = new DyFM_DataSearchHandler<FlowRun_Preview>({
32
+ * name: 'myRuns',
33
+ * get: async (query?: DyFM_SearchQuery<FlowRun>): Promise<DyFM_SearchResult<FlowRun_Preview>> => {
34
+ * return await flowRunService.searchFlowRuns(query);
35
+ * },
36
+ * defaultQuery: {
37
+ * filterBy: { userId: currentUserId },
38
+ * pageSize: 20
39
+ * },
40
+ * queryUpdateDebounceTime: 500
41
+ * });
42
+ *
43
+ * // Update search query
44
+ * flowRunsHandler.updateQuery({
45
+ * page: 0,
46
+ * pageSize: 10,
47
+ * filterBy: { status: 'completed' }
48
+ * });
49
+ *
50
+ * // Access search results
51
+ * const runs = flowRunsHandler.dataList;
52
+ *
53
+ * // Get total items count
54
+ * const totalItems = flowRunsHandler.totalItems;
55
+ * ```
56
+ */
57
+ export class DyFM_DataSearchHandler<
58
+ T_Data,
59
+ T_DataLoadBy extends DyFM_SearchQuery<any> = DyFM_SearchQuery<T_Data>,
60
+ T_Result extends DyFM_SearchResult<any> = DyFM_SearchResult<T_Data>,
61
+ T_DependencyData extends DyFM_Metadata = any,
62
+ > extends DyFM_DataListHandler<T_Data, T_DependencyData, T_DataLoadBy> {
63
+
64
+ /**
65
+ * Subject for handling fresh search queries with debouncing.
66
+ * Used internally to manage query updates.
67
+ */
68
+ protected readonly _freshQuery_S = new Subject<T_DataLoadBy>();
69
+
70
+ /**
71
+ * Cache of search results for different pages.
72
+ * Helps optimize performance by storing previously loaded results.
73
+ */
74
+ protected cache: SearchCache<T_Data>[] = [];
75
+
76
+ /**
77
+ * Override of the get method to handle search queries.
78
+ * Must be implemented to fetch search results from the data source.
79
+ */
80
+ // this is redundant, because the base class has the get method and it uses Generic type
81
+ /* override get: (query?: T_DataLoadBy) => Promise<T_Result>; */
82
+
83
+ /**
84
+ * Maximum number of cached pages to keep in memory.
85
+ * Default is 5 pages.
86
+ */
87
+ protected cacheSize: number = 5;
88
+
89
+ /**
90
+ * Default number of items per page.
91
+ * Used when no pageSize is specified in the query.
92
+ */
93
+ protected defaultPageSize: number = 10;
94
+
95
+ /**
96
+ * Default search query to use when no query is provided.
97
+ * Can include default filters, sorting, and pagination settings.
98
+ */
99
+ protected get defaultQuery(): T_DataLoadBy {
100
+ return DyFM_Object.clone(this._defaultQuery);
101
+ }
102
+
103
+ protected _defaultQuery?: T_DataLoadBy;
104
+
105
+ /**
106
+ * Total number of items available in the search results.
107
+ * Updated after each successful search.
108
+ */
109
+ protected totalItems: number;
110
+
111
+ /**
112
+ * Debounce time in milliseconds for query updates.
113
+ * Helps prevent too frequent API calls when query changes rapidly.
114
+ */
115
+ protected queryUpdateDebounceTime: number = 500;
116
+
117
+ /**
118
+ * Whether to perform initial search when handler is created.
119
+ * If true, will use defaultQuery for initial search.
120
+ */
121
+ protected searchOnInit: boolean = true;
122
+
123
+ /**
124
+ * Creates a new instance of DyFM_DataSearchHandler.
125
+ *
126
+ * @param set - Configuration settings for the search handler
127
+ */
128
+ constructor(
129
+ set: DyFM_DataSearchHandler_Settings<T_Data, T_DataLoadBy, T_DependencyData>
130
+ ) {
131
+ super({
132
+ ...set,
133
+ noId: true,
134
+ });
135
+
136
+ if (set.queryUpdateDebounceTime) {
137
+ this.queryUpdateDebounceTime = set.queryUpdateDebounceTime;
138
+ }
139
+
140
+ if (set.defaultQuery) {
141
+ this._defaultQuery = set.defaultQuery;
142
+ }
143
+
144
+ // 3
145
+ // Add post-processing for search results
146
+ this.getPostProcesses.unshift(
147
+ (searchResult: T_Result, loadedBy: T_DataLoadBy): T_Data[] => {
148
+ console.warn('WTF DyFM_Search_DataHandler getPostProcess', searchResult, this.lastLoadedBy);
149
+
150
+ this.cache = this.cache.filter((c) => c.loadPageSize !== this.lastLoadedBy?.pageSize);
151
+
152
+ if (this.cache.length >= this.cacheSize) {
153
+ this.cache.shift();
154
+ }
155
+
156
+ this.cache.push({
157
+ page: this.lastLoadedBy?.page,
158
+ loadPageSize: this.lastLoadedBy?.pageSize,
159
+ data: searchResult.results,
160
+ });
161
+
162
+ this.totalItems = searchResult.totalItems;
163
+
164
+ return searchResult.results;
165
+ }
166
+ );
167
+
168
+ // 2
169
+ // Set up query update handling with debouncing
170
+ this._freshQuery_S.pipe(
171
+ debounceTime(this.queryUpdateDebounceTime),
172
+ ).subscribe((query: T_DataLoadBy) => {
173
+ console.warn('asd', query, this.lastLoadedBy);
174
+
175
+ if (!query) {
176
+ if (!this._defaultQuery) {
177
+ this.reloadData();
178
+ return;
179
+ }
180
+
181
+ query = this.defaultQuery;
182
+ }
183
+
184
+ if (!query.page) {
185
+ query.page = 0;
186
+ }
187
+
188
+ if (!query.pageSize) {
189
+ query.pageSize = this.defaultPageSize;
190
+ }
191
+
192
+ if (this._defaultQuery?.filterBy) {
193
+ if (!query.filterBy) {
194
+ query.filterBy = {};
195
+ }
196
+
197
+ for (const key in this._defaultQuery.filterBy) {
198
+ if (!query.filterBy[key] && query.filterBy[key] !== null) {
199
+ query.filterBy[key] = this._defaultQuery.filterBy[key];
200
+ }
201
+ }
202
+ }
203
+
204
+ if (this._defaultQuery?.sortBy) {
205
+ if (!query.sortBy) {
206
+ query.sortBy = [];
207
+ }
208
+
209
+ if (!query.sortBy.length) {
210
+ query.sortBy = DyFM_Object.clone(this._defaultQuery.sortBy);
211
+ }
212
+ }
213
+
214
+ this.reloadData(query);
215
+ });
216
+
217
+ if (this.searchOnInit) {
218
+ this._freshQuery_S.next(this.defaultQuery);
219
+ }
220
+ }
221
+
222
+ // 1
223
+ /**
224
+ * Updates the search query and triggers a new search.
225
+ * The search will be debounced according to queryUpdateDebounceTime.
226
+ *
227
+ * @param query - The new search query to use
228
+ */
229
+ updateQuery(query: T_DataLoadBy): void {
230
+ this._freshQuery_S.next(query);
231
+ }
232
+
233
+ /**
234
+ * Override to prevent adding dependent data handlers.
235
+ * Search handlers cannot have dependencies.
236
+ *
237
+ * @throws Error - Always throws as search handlers cannot have dependencies
238
+ */
239
+ override addDependentDataHandlers(dependentDataHandlers: any[]): void {
240
+ throw new Error('Cannot add dependent data handlers to a search data handler');
241
+ }
242
+
243
+ /**
244
+ * Filters the current search query
245
+ *
246
+ * @param filterBy - The filter to apply to the current search query
247
+ */
248
+ filter(filterBy: DyFM_DSFilter<T_Data>): void {
249
+ const query = this.lastLoadedBy ?? this.defaultQuery;
250
+ if (query) {
251
+ query.filterBy = filterBy;
252
+ this.reloadData(query);
253
+ }
254
+ }
255
+
256
+ /**
257
+ * Adds a filter to the current search query
258
+ *
259
+ * @param filterBy - The filter to add to the current search query
260
+ */
261
+ addFiler(filterBy: DyFM_DSFilter<T_Data>): void {
262
+ const query = this.lastLoadedBy ?? this.defaultQuery;
263
+ if (query) {
264
+ Object.assign(query.filterBy, filterBy);
265
+ this.reloadData(query);
266
+ }
267
+ }
268
+
269
+ /**
270
+ * Removes a filter from the current search query
271
+ *
272
+ * @param keys - The keys of the filter to remove from the current search query
273
+ */
274
+ removeFilter(keys: (keyof T_Data)[]): void {
275
+ const query = this.lastLoadedBy ?? this.defaultQuery;
276
+ if (query) {
277
+ keys.forEach((key) => {
278
+ delete query.filterBy[key];
279
+ });
280
+
281
+ this.reloadData(query);
282
+ }
283
+ }
284
+
285
+ clearFilters(): void {
286
+ const query = this.lastLoadedBy ?? this.defaultQuery;
287
+ if (query) {
288
+ query.filterBy = {};
289
+ this.reloadData(query);
290
+ }
291
+ }
292
+
293
+ /**
294
+ * Sorts the current search query
295
+ *
296
+ * @param sortBy - The sort to apply to the current search query
297
+ */
298
+ sort(sortBy: DyFM_DSSort[]): void {
299
+ const query = this.lastLoadedBy ?? this.defaultQuery;
300
+ if (query) {
301
+ query.sortBy = sortBy;
302
+ this.reloadData(query);
303
+ }
304
+ }
305
+
306
+ /**
307
+ * Adds a sort to the current search query
308
+ *
309
+ * @param sortBy - The sort to add to the current search query
310
+ */
311
+ addSort(sortBy: DyFM_DSSort[]): void {
312
+ const query = this.lastLoadedBy ?? this.defaultQuery;
313
+ if (query) {
314
+ query.sortBy.push(...sortBy);
315
+ this.reloadData(query);
316
+ }
317
+ }
318
+
319
+ /**
320
+ * Removes a sort from the current search query
321
+ *
322
+ * @param keys - The keys of the sort to remove from the current search query
323
+ */
324
+ removeSort(keys: string[]): void {
325
+ const query = this.lastLoadedBy ?? this.defaultQuery;
326
+ if (query) {
327
+ query.sortBy = query.sortBy.filter((sort) => !keys.includes((sort as DyFM_DSPropertySort).key));
328
+ this.reloadData(query);
329
+ }
330
+ }
331
+
332
+ clearSorts(): void {
333
+ const query = this.lastLoadedBy ?? this.defaultQuery;
334
+ if (query) {
335
+ query.sortBy = [];
336
+ this.reloadData(query);
337
+ }
338
+ }
339
+
340
+ /**
341
+ * Sets the page of the current search query
342
+ *
343
+ * @param page - The page to set to the current search query
344
+ */
345
+ page(page: number, pageSize?: number): void {
346
+ const query = this.lastLoadedBy ?? this.defaultQuery;
347
+ if (query) {
348
+ query.page = page;
349
+ if (pageSize) {
350
+ query.pageSize = pageSize;
351
+ }
352
+ this.reloadData(query);
353
+ }
354
+ }
355
+
356
+ /**
357
+ * Sets the page size of the current search query
358
+ *
359
+ * @param pageSize - The page size to set to the current search query
360
+ */
361
+ pageSize(pageSize: number): void {
362
+ const query = this.lastLoadedBy ?? this.defaultQuery;
363
+ if (query) {
364
+ query.pageSize = pageSize;
365
+ this.reloadData(query);
366
+ }
367
+ }
368
+
369
+ resetPage(): void {
370
+ const query = this.lastLoadedBy ?? this.defaultQuery;
371
+ if (query) {
372
+ query.page = 0;
373
+ query.pageSize = this.defaultPageSize;
374
+ this.reloadData(query);
375
+ }
376
+ }
377
+
378
+ resetQuery(): void {
379
+ const query = this.defaultQuery;
380
+ if (query) {
381
+ this.reloadData(query);
382
+ } else {
383
+ query.filterBy = {};
384
+ query.sortBy = [];
385
+ query.page = 0;
386
+ query.pageSize = this.defaultPageSize;
387
+ this.reloadData(query);
388
+ }
389
+ }
390
+ }
@@ -0,0 +1,274 @@
1
+ import { BehaviorSubject, Observable } from 'rxjs';
2
+
3
+ import { DyFM_ListCollectorDataHandler_Settings } from './data-handler-settings.control-model';
4
+
5
+ import { DyFM_DataHandler } from './data-handler.control-model';
6
+ import { DyFM_Error } from '../../../_models/control-models/error.control-model';
7
+ import { DyFM_Metadata } from '../../../_models/data-models/metadata.data-model';
8
+
9
+ /**
10
+ * A specialized data handler for managing list collections within a parent data object.
11
+ * Extends DyFM_DataHandler to provide functionality for handling lists within a collector object.
12
+ *
13
+ * @template T_ListCollectorData - The type of the parent collector data object
14
+ * @template T_DataItem - The type of individual items in the list (must extend DyFM_Metadata)
15
+ * @template T_DependencyData - The type of dependency data (defaults to any)
16
+ * @template T_DataLoadBy - The type used to identify how data should be loaded (defaults to string)
17
+ *
18
+ * @example
19
+ * ```typescript
20
+ * // Create a list collector handler for user's projects
21
+ * const userProjectsHandler = new DyFM_ListCollectorDataHandler<User, Project>({
22
+ * listKey: 'projects',
23
+ * get: async (userId: string): Promise<User> => {
24
+ * return await userService.getUserWithProjects(userId);
25
+ * }
26
+ * });
27
+ *
28
+ * // Access the data list
29
+ * const projects = userProjectsHandler.dataList;
30
+ *
31
+ * // Add a new project
32
+ * userProjectsHandler.addItem(newProject);
33
+ *
34
+ * // Update an existing project
35
+ * userProjectsHandler.updateItem(updatedProject);
36
+ *
37
+ * // Subscribe to changes
38
+ * userProjectsHandler.dataList$.subscribe(projects => {
39
+ * console.log('Projects updated:', projects);
40
+ * });
41
+ * ```
42
+ */
43
+ export class DyFM_ListCollectorDataHandler<
44
+ T_ListCollectorData extends DyFM_Metadata,
45
+ T_DataItem extends DyFM_Metadata,
46
+ T_DependencyData extends DyFM_Metadata = any,
47
+ T_DataLoadBy = string,
48
+ > extends DyFM_DataHandler<T_ListCollectorData, T_DependencyData, T_DataLoadBy> {
49
+
50
+ /** this is only for data list handlers,
51
+ * while creating arrow function for this, dont forget to use async n await! */
52
+ protected readonly setItem?: (item: T_DataItem, collectorId?: string) => Promise<T_DataItem>;
53
+ /** this is only for data list handlers,
54
+ * while creating arrow function for this, dont forget to use async n await! */
55
+ protected readonly deleteItem?: (id: string, collectorId?: string) => Promise<void>;
56
+
57
+ protected readonly listKey: string;
58
+
59
+ /**
60
+ * BehaviorSubject that holds the current data list.
61
+ * Computed from the base data_BS BehaviorSubject, ensuring it always returns an array.
62
+ */
63
+ protected readonly dataList_BS: BehaviorSubject<T_DataItem[]>;
64
+
65
+ /**
66
+ * Observable that holds the current data list.
67
+ * Computed from the base data$ Observable, ensuring it always returns an array.
68
+ */
69
+ readonly dataList$: Observable<T_DataItem[]>;
70
+
71
+ /**
72
+ * BehaviorSubject that holds the currently active item.
73
+ */
74
+ readonly activeItem_BS: BehaviorSubject<T_DataItem>;
75
+
76
+ /**
77
+ * Observable that holds the currently active item.
78
+ */
79
+ readonly activeItem$: Observable<T_DataItem>;
80
+
81
+ /**
82
+ * Gets the current data value.
83
+ * @returns The current data value
84
+ */
85
+ override get data(): T_ListCollectorData {
86
+ return this.data_BS.value;
87
+ }
88
+
89
+ /**
90
+ * Gets the current data list.
91
+ * Alias for data getter.
92
+ * @returns The current array of data items
93
+ */
94
+ get dataList(): T_DataItem[] {
95
+ return this.dataList_BS.value;
96
+ }
97
+
98
+ /**
99
+ * Creates a new instance of DyFM_ListCollectorDataHandler.
100
+ *
101
+ * @param set - Configuration settings for the data handler
102
+ * @param skipDependencyConnections - Optional flag to skip dependency connections during construction
103
+ */
104
+ constructor(
105
+ set: DyFM_ListCollectorDataHandler_Settings<T_ListCollectorData, T_DataItem, T_DependencyData, T_DataLoadBy>,
106
+ /** is in construct?
107
+ * so the dependent data handlers are not added here, but in the extended class */
108
+ skipDependencyConnections?: boolean,
109
+ ) {
110
+ super(set, skipDependencyConnections);
111
+
112
+ this.listKey = set.listKey;
113
+
114
+ // Initialize dataList BehaviorSubject and Observable
115
+ this.dataList_BS = new BehaviorSubject<T_DataItem[]>([]);
116
+ this.dataList$ = this.dataList_BS.asObservable();
117
+
118
+ // Initialize activeItem BehaviorSubject and Observable
119
+ this.activeItem_BS = new BehaviorSubject<T_DataItem>(null);
120
+ this.activeItem$ = this.activeItem_BS.asObservable();
121
+
122
+ // Subscribe to data changes to update dataList
123
+ this.data$.subscribe(data => {
124
+ const dataList = Array.isArray(data?.[this.listKey]) ? data[this.listKey] : [];
125
+ this.dataList_BS.next(dataList);
126
+ });
127
+
128
+ if (set.setItem) {
129
+ this.setItem = set.setItem;
130
+ }
131
+
132
+ if (set.deleteItem) {
133
+ this.deleteItem = set.deleteItem;
134
+ }
135
+
136
+ this.getPostProcesses.push((data: T_DataItem[]) => {
137
+ // check if data is an array
138
+ if (!Array.isArray(data) ) {
139
+ console.error(
140
+ `DYNAMO DynamoDataHandler (${this.name}) ERROR: ` +
141
+ `\nData is not an array!:` +
142
+ '\n\n', data
143
+ );
144
+ throw new Error(`Data is not an array! (${this.name})`);
145
+ }
146
+
147
+ return data;
148
+ });
149
+
150
+ if (!skipDependencyConnections) {
151
+ if (set.dependencyDataHandler) {
152
+ this.addDependencyDataHandler(set.dependencyDataHandler);
153
+ }
154
+
155
+ if (set.dependentDataHandlers) {
156
+ this.addDependentDataHandlers(set.dependentDataHandlers, true);
157
+ }
158
+ }
159
+ }
160
+
161
+ override clear(dontClearDependents?: boolean): void {
162
+ super.clear(dontClearDependents);
163
+ this.activeItem_BS.next(null);
164
+ }
165
+
166
+ /**
167
+ * Adds a new item to the data list.
168
+ *
169
+ * @param item - The item to add to the list
170
+ * @param collectorId - Optional collector ID for tracking
171
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
172
+ */
173
+ async addItem(item: T_DataItem, collectorId?: string, dontSendUpdate?: boolean): Promise<void> {
174
+ if (!this.data) {
175
+ throw new DyFM_Error({
176
+ error: new Error(`Data not found! (${this.name})`),
177
+ errorCode: 'DyFM-LCDH-AI1',
178
+ additionalContent: {
179
+ listKey: this.listKey,
180
+ },
181
+ });
182
+ }
183
+ this.data[this.listKey] ??= [];
184
+ this.data[this.listKey].push(item);
185
+ if (this.setItem && !dontSendUpdate) {
186
+ await this.setItem(item, collectorId);
187
+ // dont send update because we already sent it to the setItem function
188
+ await this.updateData(this.data_BS.value, true);
189
+ } else {
190
+ await this.updateData(this.data_BS.value, dontSendUpdate);
191
+ }
192
+ this.activeItem_BS.next(item);
193
+ }
194
+
195
+ /**
196
+ * Removes an item from the data list.
197
+ * The item is identified by its _id property.
198
+ *
199
+ * @param id - The id of the item to remove from the list
200
+ * @param collectorId - Optional collector ID for tracking
201
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
202
+ */
203
+ async removeItem(id: string, collectorId?: string, dontSendUpdate?: boolean): Promise<void> {
204
+ if (!this.data?.[this.listKey]?.length) {
205
+ throw new DyFM_Error({
206
+ error: new Error(`List not found! (${this.name})`),
207
+ errorCode: 'DyFM-LCDH-RI1',
208
+ additionalContent: {
209
+ listKey: this.listKey,
210
+ },
211
+ });
212
+ }
213
+ const index = this.data[this.listKey].findIndex(i => i._id === id);
214
+ if (index !== -1) {
215
+ this.data[this.listKey].splice(index, 1);
216
+ if (this.deleteItem) {
217
+ await this.deleteItem(id, collectorId);
218
+ await this.updateData(this.data_BS.value, true);
219
+ } else {
220
+ await this.updateData(this.data_BS.value, dontSendUpdate);
221
+ }
222
+ }
223
+ if (this.activeItem_BS.value?._id === id) {
224
+ this.activeItem_BS.next(null);
225
+ }
226
+ }
227
+
228
+ /**
229
+ * Updates an existing item in the data list.
230
+ * The item is identified by its _id property.
231
+ *
232
+ * @param item - The updated item
233
+ * @param collectorId - Optional collector ID for tracking
234
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
235
+ * @throws Error if the item is not found in the list
236
+ */
237
+ async updateItem(item: T_DataItem, collectorId?: string, dontSendUpdate?: boolean): Promise<void> {
238
+ if (!this.data?.[this.listKey]?.length) {
239
+ throw new DyFM_Error({
240
+ error: new Error(`List not found! (${this.name})`),
241
+ errorCode: 'DyFM-LCDH-UI0',
242
+ additionalContent: {
243
+ listKey: this.listKey,
244
+ },
245
+ });
246
+ }
247
+ // check if item is in the list
248
+ const index = this.data[this.listKey].findIndex(i => i._id === item._id);
249
+ if (index !== -1) {
250
+ // update the item
251
+ this.data[this.listKey][index] = item;
252
+ if (this.setItem) {
253
+ // send update to API
254
+ await this.setItem(item, collectorId);
255
+ await this.updateData(this.data_BS.value, true);
256
+ } else {
257
+ // send update to API
258
+ await this.updateData(this.data_BS.value, dontSendUpdate);
259
+ }
260
+ } else {
261
+ throw new DyFM_Error({
262
+ error: new Error(`Item not found! (${this.name})`),
263
+ errorCode: 'DyFM-LCDH-UI1',
264
+ additionalContent: {
265
+ item: item,
266
+ },
267
+ });
268
+ }
269
+ }
270
+
271
+ setActiveItem(item: T_DataItem): void {
272
+ this.activeItem_BS.next(item);
273
+ }
274
+ }
@@ -0,0 +1,6 @@
1
+ // MODELS
2
+ export * from './_models/data-handler.control-model';
3
+ export * from './_models/data-handler-settings.control-model';
4
+ export * from './_models/data-list-handler.control-model';
5
+ export * from './_models/data-search-handler.control-model';
6
+ export * from './_models/list-collector-data-handler.control-model';