@futdevpro/fsm-dynamo 1.15.17 → 1.15.20

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 (543) hide show
  1. package/.cursor/rules/__assistant_guide.mdc +30 -30
  2. package/.cursor/rules/_ag_backend-structure.mdc +85 -85
  3. package/.cursor/rules/_ag_backend.mdc +16 -16
  4. package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
  5. package/.cursor/rules/_ag_frontend.mdc +39 -39
  6. package/.cursor/rules/_ag_import-rules.mdc +44 -44
  7. package/.cursor/rules/_ag_naming.mdc +115 -115
  8. package/.cursor/rules/_ag_should-be.mdc +6 -6
  9. package/.cursor/rules/ai_development_guide.md +60 -60
  10. package/.cursor/rules/cursor-rules.md +160 -160
  11. package/.cursor/rules/default-command.mdc +464 -464
  12. package/.cursor/rules/error_code_pattern.md +39 -39
  13. package/.cursor/rules/saved rule mcp server use.md +15 -15
  14. package/.dynamo/pipeline.cicd.config.json +128 -128
  15. package/.github/workflows/main.yml +433 -433
  16. package/.vscode/settings.json +11 -11
  17. package/LICENSE +21 -21
  18. package/__documentations/2026-06-01-fr047-fc-foundation.md +48 -0
  19. package/build/_models/data-models/errors.data-model.d.ts +43 -0
  20. package/build/_models/data-models/errors.data-model.d.ts.map +1 -1
  21. package/build/_models/data-models/errors.data-model.js +30 -0
  22. package/build/_models/data-models/errors.data-model.js.map +1 -1
  23. package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts +8 -0
  24. package/build/_modules/ai/_models/ai-model-capabilities.interface.d.ts.map +1 -1
  25. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.d.ts.map +1 -1
  26. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js +3 -0
  27. package/build/_modules/ai/_modules/anthropic/_collections/aai-models.const.js.map +1 -1
  28. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.d.ts.map +1 -1
  29. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js +1 -0
  30. package/build/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.js.map +1 -1
  31. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.d.ts.map +1 -1
  32. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js +4 -0
  33. package/build/_modules/ai/_modules/google-ai/_collections/gai-models.const.js.map +1 -1
  34. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.d.ts.map +1 -1
  35. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js +2 -0
  36. package/build/_modules/ai/_modules/local-ai/_collections/lai-models.const.js.map +1 -1
  37. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.d.ts.map +1 -1
  38. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js +11 -0
  39. package/build/_modules/ai/_modules/open-ai/_collections/oai-models.const.js.map +1 -1
  40. package/build/_modules/socket/_models/sck-socket-event.control-model.js +1 -1
  41. package/eslint.config.js +4 -4
  42. package/nodemon.json +22 -22
  43. package/package.json +11 -11
  44. package/scripts/crypto/CRYPTO-STABILITY-SOLUTION.md +196 -196
  45. package/scripts/crypto/README.md +113 -113
  46. package/scripts/crypto/demo-crypto-stability.js +120 -120
  47. package/scripts/crypto/stress-test-crypto.js +379 -379
  48. package/scripts/run-coverage-tests.js +24 -24
  49. package/spec/support/helpers/ts-node-helper.js +9 -9
  50. package/spec/support/jasmine.coverage.json +23 -23
  51. package/spec/support/jasmine.json +24 -24
  52. package/src/_collections/constants/data-sizes.const.ts +40 -40
  53. package/src/_collections/constants/error-defaults.const.ts +20 -20
  54. package/src/_collections/constants/global-settings.const.ts +24 -24
  55. package/src/_collections/constants/numbers.const.ts +40 -40
  56. package/src/_collections/constants/times.const.ts +45 -45
  57. package/src/_collections/utils/array.util.spec.ts +306 -306
  58. package/src/_collections/utils/array.util.ts +813 -813
  59. package/src/_collections/utils/async.util.spec.ts +354 -354
  60. package/src/_collections/utils/async.util.ts +197 -197
  61. package/src/_collections/utils/data.util.spec.ts +345 -345
  62. package/src/_collections/utils/data.util.ts +226 -226
  63. package/src/_collections/utils/json-error-helper.util.spec.ts +521 -521
  64. package/src/_collections/utils/json-error-helper.util.ts +301 -301
  65. package/src/_collections/utils/log.util.spec.ts +975 -975
  66. package/src/_collections/utils/log.util.ts +665 -665
  67. package/src/_collections/utils/math/box-bounds.spec.ts +73 -73
  68. package/src/_collections/utils/math/box-bounds.util.ts +183 -183
  69. package/src/_collections/utils/math/math.util.spec.ts +94 -94
  70. package/src/_collections/utils/math/math.util.ts +141 -141
  71. package/src/_collections/utils/math/random.util.spec.ts +82 -82
  72. package/src/_collections/utils/math/random.util.ts +139 -139
  73. package/src/_collections/utils/math/trigonometry.util.spec.ts +57 -57
  74. package/src/_collections/utils/math/trigonometry.util.ts +102 -102
  75. package/src/_collections/utils/math/vector2.util.spec.ts +94 -94
  76. package/src/_collections/utils/math/vector2.util.ts +653 -653
  77. package/src/_collections/utils/object.util.spec.ts +646 -646
  78. package/src/_collections/utils/regex/password-regex.util.spec.ts +51 -51
  79. package/src/_collections/utils/regex/password-regex.util.ts +65 -65
  80. package/src/_collections/utils/regex/regex.util.spec.ts +42 -42
  81. package/src/_collections/utils/regex/regex.util.ts +6 -6
  82. package/src/_collections/utils/regex/username-regex.util.spec.ts +61 -61
  83. package/src/_collections/utils/regex/username-regex.util.ts +35 -35
  84. package/src/_collections/utils/round-list.util.spec.ts +79 -79
  85. package/src/_collections/utils/round-list.util.ts +162 -162
  86. package/src/_collections/utils/stack.util.spec.ts +372 -372
  87. package/src/_collections/utils/stack.util.ts +164 -164
  88. package/src/_collections/utils/string-case.util.spec.ts +441 -441
  89. package/src/_collections/utils/string-case.util.ts +362 -362
  90. package/src/_collections/utils/string.util.spec.ts +975 -975
  91. package/src/_collections/utils/string.util.ts +449 -449
  92. package/src/_collections/utils/time.util.spec.ts +50 -50
  93. package/src/_collections/utils/time.util.ts +481 -481
  94. package/src/_collections/utils/type-cloning-facility.util.spec.ts +51 -51
  95. package/src/_collections/utils/type-cloning-facility.util.ts +168 -168
  96. package/src/_collections/utils/utilities.util.spec.ts +201 -201
  97. package/src/_collections/utils/utilities.util.ts +68 -68
  98. package/src/_collections/utils/uuid.util.spec.ts +30 -30
  99. package/src/_collections/utils/uuid.util.ts +50 -50
  100. package/src/_enums/basic-property-type.enum.ts +20 -20
  101. package/src/_enums/data-model-type.enum.ts +29 -29
  102. package/src/_enums/environment-flag.enum.ts +28 -28
  103. package/src/_enums/error-level.enum.ts +28 -28
  104. package/src/_enums/http/http-call-type.enum.ts +43 -43
  105. package/src/_enums/http/http-event-type.enum.ts +40 -40
  106. package/src/_enums/http/http-response-type.enum.ts +18 -18
  107. package/src/_enums/log-style.enum.ts +44 -44
  108. package/src/_enums/server-connection-status.enum.ts +6 -6
  109. package/src/_enums/time/day-of-week.enum.ts +55 -55
  110. package/src/_enums/time/month.enum.ts +25 -25
  111. package/src/_enums/time/relative-date.enum.ts +24 -24
  112. package/src/_models/control-models/data-model-params.control-model.spec.ts +85 -85
  113. package/src/_models/control-models/data-model-params.control-model.ts +300 -300
  114. package/src/_models/control-models/data-property-params.control-model.spec.ts +93 -93
  115. package/src/_models/control-models/data-property-params.control-model.ts +201 -201
  116. package/src/_models/control-models/error.control-model.spec.ts +912 -912
  117. package/src/_models/control-models/error.control-model.ts +1215 -1215
  118. package/src/_models/control-models/http/http-error-response.control-model.spec.ts +116 -116
  119. package/src/_models/control-models/http/http-error-response.control-model.ts +52 -52
  120. package/src/_models/control-models/http/http-headers.control-model.spec.ts +25 -25
  121. package/src/_models/control-models/http/http-headers.control-model.ts +124 -124
  122. package/src/_models/control-models/http/http-response.model-base.spec.ts +46 -46
  123. package/src/_models/control-models/http/http-response.model-base.ts +57 -57
  124. package/src/_models/control-models/poll.control-model.spec.ts +63 -63
  125. package/src/_models/control-models/poll.control-model.ts +151 -151
  126. package/src/_models/control-models/range-value.control-model.spec.ts +187 -187
  127. package/src/_models/control-models/range-value.control-model.ts +289 -289
  128. package/src/_models/control-models/server-status.control-model.spec.ts +66 -66
  129. package/src/_models/control-models/server-status.control-model.ts +85 -85
  130. package/src/_models/control-models/service-endpoint-settings-base.control-model.spec.ts +145 -145
  131. package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +186 -186
  132. package/src/_models/data-models/errors.data-model.spec.ts +71 -71
  133. package/src/_models/data-models/errors.data-model.ts +148 -91
  134. package/src/_models/data-models/metadata.data-model.spec.ts +184 -184
  135. package/src/_models/data-models/metadata.data-model.ts +128 -128
  136. package/src/_models/interfaces/box-bounds.interface.ts +7 -7
  137. package/src/_models/interfaces/environment/global-log-settings.interface.ts +86 -86
  138. package/src/_models/interfaces/environment/global-settings.interface.ts +47 -47
  139. package/src/_models/interfaces/error-defaults.interface.ts +11 -11
  140. package/src/_models/interfaces/paged.interface.ts +12 -12
  141. package/src/_models/interfaces/random-weight.interface.ts +7 -7
  142. package/src/_models/interfaces/route-settings.interface.ts +15 -15
  143. package/src/_models/interfaces/search-query.interface.ts +23 -23
  144. package/src/_models/interfaces/search-result.interface.ts +5 -5
  145. package/src/_models/interfaces/server-error-statistics.interface.ts +24 -24
  146. package/src/_models/interfaces/vector2.interface.ts +20 -20
  147. package/src/_models/types/db-filter.type.ts +110 -110
  148. package/src/_models/types/db-sort.type.ts +4 -4
  149. package/src/_models/types/ds-filter.type.ts +68 -68
  150. package/src/_models/types/ds-sort.type.ts +21 -21
  151. package/src/_modules/ai/_collections/ai-model-ref.util.ts +88 -88
  152. package/src/_modules/ai/_collections/ai-model-registry.util.spec.ts +37 -37
  153. package/src/_modules/ai/_collections/ai-model-registry.util.ts +30 -30
  154. package/src/_modules/ai/_enums/ai-message-role.enum.ts +7 -7
  155. package/src/_modules/ai/_enums/ai-model-type.enum.ts +7 -7
  156. package/src/_modules/ai/_enums/ai-provider.enum.ts +7 -7
  157. package/src/_modules/ai/_models/ai-call-settings.interface.ts +84 -84
  158. package/src/_modules/ai/_models/ai-embedding-request.interface.ts +20 -20
  159. package/src/_modules/ai/_models/ai-embedding-response.interface.ts +26 -26
  160. package/src/_modules/ai/_models/ai-llm-request.interface.ts +24 -24
  161. package/src/_modules/ai/_models/ai-llm-response.interface.ts +30 -30
  162. package/src/_modules/ai/_models/ai-message.interface.ts +12 -12
  163. package/src/_modules/ai/_models/ai-model-capabilities.interface.ts +35 -27
  164. package/src/_modules/ai/_models/ai-model-info.interface.ts +63 -63
  165. package/src/_modules/ai/_models/ai-model-settings-schema.interface.ts +52 -52
  166. package/src/_modules/ai/_models/ai-provider-capabilities.interface.ts +28 -28
  167. package/src/_modules/ai/_models/ai-settings.interface.ts +17 -17
  168. package/src/_modules/ai/_models/ai-tool-call.interface.ts +18 -18
  169. package/src/_modules/ai/_models/ai-tool-handler.type.ts +11 -11
  170. package/src/_modules/ai/_models/ai-tool-result.interface.ts +16 -16
  171. package/src/_modules/ai/_models/ai-tool.interface.ts +16 -16
  172. package/src/_modules/ai/_models/ai-user-provider-config.control-model.ts +29 -29
  173. package/src/_modules/ai/_modules/anthropic/_collections/aai-models.const.ts +81 -78
  174. package/src/_modules/ai/_modules/anthropic/_enums/aai-model.enum.ts +19 -19
  175. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.spec.ts +28 -28
  176. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.ts +23 -23
  177. package/src/_modules/ai/_modules/anthropic/_models/aai-client-options.interface.ts +10 -10
  178. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.spec.ts +22 -22
  179. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.ts +27 -27
  180. package/src/_modules/ai/_modules/anthropic/_models/aai-user-provider-config.control-model.ts +20 -20
  181. package/src/_modules/ai/_modules/anthropic/index.ts +14 -14
  182. package/src/_modules/ai/_modules/document-ai/_models/dai-embedding-info.interface.ts +12 -12
  183. package/src/_modules/ai/_modules/document-ai/_models/dai-vector-search-params.interface.ts +22 -22
  184. package/src/_modules/ai/_modules/document-ai/index.ts +4 -4
  185. package/src/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.ts +34 -33
  186. package/src/_modules/ai/_modules/fdp-ai/_enums/fdpai-model.enum.ts +6 -6
  187. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-call-settings.control-model.ts +19 -19
  188. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-client-options.interface.ts +11 -11
  189. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-settings.control-model.ts +24 -24
  190. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-user-provider-config.control-model.ts +20 -20
  191. package/src/_modules/ai/_modules/fdp-ai/index.ts +11 -11
  192. package/src/_modules/ai/_modules/google-ai/_collections/gai-models.const.ts +99 -95
  193. package/src/_modules/ai/_modules/google-ai/_enums/gai-model.enum.ts +16 -16
  194. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.spec.ts +28 -28
  195. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.ts +21 -21
  196. package/src/_modules/ai/_modules/google-ai/_models/gai-client-options.interface.ts +8 -8
  197. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.spec.ts +22 -22
  198. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.ts +25 -25
  199. package/src/_modules/ai/_modules/google-ai/_models/gai-user-provider-config.control-model.ts +20 -20
  200. package/src/_modules/ai/_modules/google-ai/index.ts +14 -14
  201. package/src/_modules/ai/_modules/local-ai/_collections/lai-models.const.ts +53 -51
  202. package/src/_modules/ai/_modules/local-ai/_enums/lai-model.enum.ts +6 -6
  203. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.spec.ts +28 -28
  204. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.ts +18 -18
  205. package/src/_modules/ai/_modules/local-ai/_models/lai-client-options.interface.ts +9 -9
  206. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.spec.ts +22 -22
  207. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.ts +23 -23
  208. package/src/_modules/ai/_modules/local-ai/index.ts +14 -14
  209. package/src/_modules/ai/_modules/open-ai/_collections/oai-embedding-model-dimensions.const.ts +7 -7
  210. package/src/_modules/ai/_modules/open-ai/_collections/oai-models.const.ts +252 -241
  211. package/src/_modules/ai/_modules/open-ai/_enums/oai-model.enum.ts +179 -179
  212. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.spec.ts +28 -28
  213. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.ts +21 -21
  214. package/src/_modules/ai/_modules/open-ai/_models/oai-client-options.interface.ts +81 -81
  215. package/src/_modules/ai/_modules/open-ai/_models/oai-embedding-info.interface.ts +13 -13
  216. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.spec.ts +22 -22
  217. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.ts +25 -25
  218. package/src/_modules/ai/_modules/open-ai/_models/oai-user-provider-config.control-model.ts +21 -21
  219. package/src/_modules/ai/_modules/open-ai/index.ts +28 -28
  220. package/src/_modules/ai/index.ts +27 -27
  221. package/src/_modules/ci-tools/_enums/cit-ci-result-code.enum.ts +11 -11
  222. package/src/_modules/ci-tools/_enums/cit-ci-step-result-code.enum.ts +9 -9
  223. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.spec.ts +58 -58
  224. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.ts +77 -77
  225. package/src/_modules/ci-tools/_models/cit-ci-step-result.interface.ts +12 -12
  226. package/src/_modules/ci-tools/index.ts +8 -8
  227. package/src/_modules/crypto/_collections/crypto.util.simple.spec.ts +512 -512
  228. package/src/_modules/crypto/index.ts +13 -13
  229. package/src/_modules/custom-data/_collections/cud-module-settings.const.ts +21 -21
  230. package/src/_modules/custom-data/_models/cud.data-model.spec.ts +38 -38
  231. package/src/_modules/custom-data/_models/cud.data-model.ts +39 -39
  232. package/src/_modules/custom-data/index.ts +10 -10
  233. package/src/_modules/data-handler/_models/data-handler-settings.control-model.spec.ts +110 -110
  234. package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -110
  235. package/src/_modules/data-handler/_models/data-handler.control-model.spec.ts +445 -445
  236. package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -459
  237. package/src/_modules/data-handler/_models/data-list-handler.control-model.spec.ts +263 -263
  238. package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +252 -252
  239. package/src/_modules/data-handler/_models/data-search-handler.control-model.spec.ts +417 -417
  240. package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -390
  241. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.spec.ts +374 -374
  242. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -274
  243. package/src/_modules/data-handler/index.ts +6 -6
  244. package/src/_modules/location/_collections/assets/country-codes-ISO-3166.json +3239 -3239
  245. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166-all-list.json +19035 -19035
  246. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166.json +4993 -4993
  247. package/src/_modules/location/_collections/assets/country-phone-codes.json +1203 -1203
  248. package/src/_modules/location/_collections/assets/country-subdivisions/afghanistan.json +137 -137
  249. package/src/_modules/location/_collections/assets/country-subdivisions/albania.json +49 -49
  250. package/src/_modules/location/_collections/assets/country-subdivisions/algeria.json +193 -193
  251. package/src/_modules/location/_collections/assets/country-subdivisions/andorra.json +29 -29
  252. package/src/_modules/location/_collections/assets/country-subdivisions/angola.json +73 -73
  253. package/src/_modules/location/_collections/assets/country-subdivisions/antigua-and-barbuda.json +33 -33
  254. package/src/_modules/location/_collections/assets/country-subdivisions/argentina.json +97 -97
  255. package/src/_modules/location/_collections/assets/country-subdivisions/armenia.json +45 -45
  256. package/src/_modules/location/_collections/assets/country-subdivisions/australia.json +33 -33
  257. package/src/_modules/location/_collections/assets/country-subdivisions/austria.json +37 -37
  258. package/src/_modules/location/_collections/assets/country-subdivisions/azerbaijan.json +5 -5
  259. package/src/_modules/location/_collections/assets/country-subdivisions/bahamas.json +125 -125
  260. package/src/_modules/location/_collections/assets/country-subdivisions/bahrain.json +21 -21
  261. package/src/_modules/location/_collections/assets/country-subdivisions/bangladesh.json +29 -29
  262. package/src/_modules/location/_collections/assets/country-subdivisions/barbados.json +45 -45
  263. package/src/_modules/location/_collections/assets/country-subdivisions/belarus.json +29 -29
  264. package/src/_modules/location/_collections/assets/country-subdivisions/belgium.json +13 -13
  265. package/src/_modules/location/_collections/assets/country-subdivisions/belize.json +25 -25
  266. package/src/_modules/location/_collections/assets/country-subdivisions/benin.json +49 -49
  267. package/src/_modules/location/_collections/assets/country-subdivisions/bhutan.json +81 -81
  268. package/src/_modules/location/_collections/assets/country-subdivisions/bolivia.json +37 -37
  269. package/src/_modules/location/_collections/assets/country-subdivisions/bosnia-and-herzegovina.json +13 -13
  270. package/src/_modules/location/_collections/assets/country-subdivisions/botswana.json +65 -65
  271. package/src/_modules/location/_collections/assets/country-subdivisions/brazil.json +109 -109
  272. package/src/_modules/location/_collections/assets/country-subdivisions/brunei-darussalam.json +17 -17
  273. package/src/_modules/location/_collections/assets/country-subdivisions/bulgaria.json +113 -113
  274. package/src/_modules/location/_collections/assets/country-subdivisions/burkina-faso.json +53 -53
  275. package/src/_modules/location/_collections/assets/country-subdivisions/burundi.json +69 -69
  276. package/src/_modules/location/_collections/assets/country-subdivisions/cambodia.json +97 -97
  277. package/src/_modules/location/_collections/assets/country-subdivisions/cameroon.json +41 -41
  278. package/src/_modules/location/_collections/assets/country-subdivisions/canada.json +79 -79
  279. package/src/_modules/location/_collections/assets/country-subdivisions/cape-verde.json +9 -9
  280. package/src/_modules/location/_collections/assets/country-subdivisions/central-african-republic.json +69 -69
  281. package/src/_modules/location/_collections/assets/country-subdivisions/chad.json +89 -89
  282. package/src/_modules/location/_collections/assets/country-subdivisions/chile.json +61 -61
  283. package/src/_modules/location/_collections/assets/country-subdivisions/china.json +205 -205
  284. package/src/_modules/location/_collections/assets/country-subdivisions/colombia.json +133 -133
  285. package/src/_modules/location/_collections/assets/country-subdivisions/comoros.json +13 -13
  286. package/src/_modules/location/_collections/assets/country-subdivisions/congo-the-democratic-republic-of-the.json +45 -45
  287. package/src/_modules/location/_collections/assets/country-subdivisions/congo.json +49 -49
  288. package/src/_modules/location/_collections/assets/country-subdivisions/costa-rica.json +29 -29
  289. package/src/_modules/location/_collections/assets/country-subdivisions/cote-d-ivoire-republic-of.json +77 -77
  290. package/src/_modules/location/_collections/assets/country-subdivisions/croatia.json +85 -85
  291. package/src/_modules/location/_collections/assets/country-subdivisions/cuba.json +65 -65
  292. package/src/_modules/location/_collections/assets/country-subdivisions/cyprus.json +25 -25
  293. package/src/_modules/location/_collections/assets/country-subdivisions/czech-republic.json +57 -57
  294. package/src/_modules/location/_collections/assets/country-subdivisions/denmark.json +21 -21
  295. package/src/_modules/location/_collections/assets/country-subdivisions/djibouti.json +25 -25
  296. package/src/_modules/location/_collections/assets/country-subdivisions/dominica.json +41 -41
  297. package/src/_modules/location/_collections/assets/country-subdivisions/dominican-republic.json +41 -41
  298. package/src/_modules/location/_collections/assets/country-subdivisions/ecuador.json +97 -97
  299. package/src/_modules/location/_collections/assets/country-subdivisions/egypt.json +117 -117
  300. package/src/_modules/location/_collections/assets/country-subdivisions/el-salvador.json +57 -57
  301. package/src/_modules/location/_collections/assets/country-subdivisions/equatorial-guinea.json +9 -9
  302. package/src/_modules/location/_collections/assets/country-subdivisions/eritrea.json +25 -25
  303. package/src/_modules/location/_collections/assets/country-subdivisions/estonia.json +61 -61
  304. package/src/_modules/location/_collections/assets/country-subdivisions/ethiopia.json +45 -45
  305. package/src/_modules/location/_collections/assets/country-subdivisions/fiji.json +21 -21
  306. package/src/_modules/location/_collections/assets/country-subdivisions/finland.json +77 -77
  307. package/src/_modules/location/_collections/assets/country-subdivisions/france.json +133 -133
  308. package/src/_modules/location/_collections/assets/country-subdivisions/gabon.json +37 -37
  309. package/src/_modules/location/_collections/assets/country-subdivisions/gambia.json +25 -25
  310. package/src/_modules/location/_collections/assets/country-subdivisions/georgia.json +49 -49
  311. package/src/_modules/location/_collections/assets/country-subdivisions/germany.json +65 -65
  312. package/src/_modules/location/_collections/assets/country-subdivisions/ghana.json +41 -41
  313. package/src/_modules/location/_collections/assets/country-subdivisions/greece.json +53 -53
  314. package/src/_modules/location/_collections/assets/country-subdivisions/greenland.json +17 -17
  315. package/src/_modules/location/_collections/assets/country-subdivisions/grenada.json +29 -29
  316. package/src/_modules/location/_collections/assets/country-subdivisions/guatemala.json +89 -89
  317. package/src/_modules/location/_collections/assets/country-subdivisions/guinea-bissau.json +13 -13
  318. package/src/_modules/location/_collections/assets/country-subdivisions/guinea.json +33 -33
  319. package/src/_modules/location/_collections/assets/country-subdivisions/guyana.json +41 -41
  320. package/src/_modules/location/_collections/assets/country-subdivisions/haiti.json +41 -41
  321. package/src/_modules/location/_collections/assets/country-subdivisions/honduras.json +73 -73
  322. package/src/_modules/location/_collections/assets/country-subdivisions/hong-kong.json +4 -4
  323. package/src/_modules/location/_collections/assets/country-subdivisions/hungary.json +173 -173
  324. package/src/_modules/location/_collections/assets/country-subdivisions/iceland.json +37 -37
  325. package/src/_modules/location/_collections/assets/country-subdivisions/india.json +181 -181
  326. package/src/_modules/location/_collections/assets/country-subdivisions/indonesia.json +29 -29
  327. package/src/_modules/location/_collections/assets/country-subdivisions/iran-islamic-republic-of.json +125 -125
  328. package/src/_modules/location/_collections/assets/country-subdivisions/iraq.json +73 -73
  329. package/src/_modules/location/_collections/assets/country-subdivisions/ireland.json +17 -17
  330. package/src/_modules/location/_collections/assets/country-subdivisions/israel.json +25 -25
  331. package/src/_modules/location/_collections/assets/country-subdivisions/italy.json +81 -81
  332. package/src/_modules/location/_collections/assets/country-subdivisions/jamaica.json +57 -57
  333. package/src/_modules/location/_collections/assets/country-subdivisions/japan.json +189 -189
  334. package/src/_modules/location/_collections/assets/country-subdivisions/jordan.json +49 -49
  335. package/src/_modules/location/_collections/assets/country-subdivisions/kazakhstan.json +65 -65
  336. package/src/_modules/location/_collections/assets/country-subdivisions/kenya.json +33 -33
  337. package/src/_modules/location/_collections/assets/country-subdivisions/kiribati.json +13 -13
  338. package/src/_modules/location/_collections/assets/country-subdivisions/korea-democratic-people-s-republic-of.json +45 -45
  339. package/src/_modules/location/_collections/assets/country-subdivisions/korea-republic-of.json +69 -69
  340. package/src/_modules/location/_collections/assets/country-subdivisions/kuwait.json +25 -25
  341. package/src/_modules/location/_collections/assets/country-subdivisions/kyrgyzstan.json +33 -33
  342. package/src/_modules/location/_collections/assets/country-subdivisions/lao-people-s-democratic-republic.json +73 -73
  343. package/src/_modules/location/_collections/assets/country-subdivisions/latvia.json +477 -477
  344. package/src/_modules/location/_collections/assets/country-subdivisions/lebanon.json +33 -33
  345. package/src/_modules/location/_collections/assets/country-subdivisions/lesotho.json +41 -41
  346. package/src/_modules/location/_collections/assets/country-subdivisions/liberia.json +61 -61
  347. package/src/_modules/location/_collections/assets/country-subdivisions/libyan-arab-jamahiriya.json +89 -89
  348. package/src/_modules/location/_collections/assets/country-subdivisions/liechtenstein.json +45 -45
  349. package/src/_modules/location/_collections/assets/country-subdivisions/lithuania.json +41 -41
  350. package/src/_modules/location/_collections/assets/country-subdivisions/luxembourg.json +13 -13
  351. package/src/_modules/location/_collections/assets/country-subdivisions/macedonia-the-former-yugoslav-republic-of.json +337 -337
  352. package/src/_modules/location/_collections/assets/country-subdivisions/madagascar.json +25 -25
  353. package/src/_modules/location/_collections/assets/country-subdivisions/malawi.json +13 -13
  354. package/src/_modules/location/_collections/assets/country-subdivisions/malaysia.json +81 -81
  355. package/src/_modules/location/_collections/assets/country-subdivisions/maldives.json +33 -33
  356. package/src/_modules/location/_collections/assets/country-subdivisions/mali.json +37 -37
  357. package/src/_modules/location/_collections/assets/country-subdivisions/malta.json +273 -273
  358. package/src/_modules/location/_collections/assets/country-subdivisions/marshall-islands.json +9 -9
  359. package/src/_modules/location/_collections/assets/country-subdivisions/mauritania.json +53 -53
  360. package/src/_modules/location/_collections/assets/country-subdivisions/mauritius.json +69 -69
  361. package/src/_modules/location/_collections/assets/country-subdivisions/mexico.json +161 -161
  362. package/src/_modules/location/_collections/assets/country-subdivisions/micronesia-federated-states-of.json +17 -17
  363. package/src/_modules/location/_collections/assets/country-subdivisions/moldova-republic-of.json +149 -149
  364. package/src/_modules/location/_collections/assets/country-subdivisions/monaco.json +69 -69
  365. package/src/_modules/location/_collections/assets/country-subdivisions/mongolia.json +89 -89
  366. package/src/_modules/location/_collections/assets/country-subdivisions/montenegro.json +93 -93
  367. package/src/_modules/location/_collections/assets/country-subdivisions/morocco.json +65 -65
  368. package/src/_modules/location/_collections/assets/country-subdivisions/mozambique.json +45 -45
  369. package/src/_modules/location/_collections/assets/country-subdivisions/myanmar.json +57 -57
  370. package/src/_modules/location/_collections/assets/country-subdivisions/namibia.json +57 -57
  371. package/src/_modules/location/_collections/assets/country-subdivisions/nauru.json +57 -57
  372. package/src/_modules/location/_collections/assets/country-subdivisions/nepal.json +21 -21
  373. package/src/_modules/location/_collections/assets/country-subdivisions/netherlands.json +91 -91
  374. package/src/_modules/location/_collections/assets/country-subdivisions/new-zealand.json +111 -111
  375. package/src/_modules/location/_collections/assets/country-subdivisions/nicaragua.json +69 -69
  376. package/src/_modules/location/_collections/assets/country-subdivisions/niger.json +33 -33
  377. package/src/_modules/location/_collections/assets/country-subdivisions/nigeria.json +149 -149
  378. package/src/_modules/location/_collections/assets/country-subdivisions/norway.json +85 -85
  379. package/src/_modules/location/_collections/assets/country-subdivisions/oman.json +37 -37
  380. package/src/_modules/location/_collections/assets/country-subdivisions/pakistan.json +33 -33
  381. package/src/_modules/location/_collections/assets/country-subdivisions/palau.json +65 -65
  382. package/src/_modules/location/_collections/assets/country-subdivisions/palestinian-territory-occupied.json +65 -65
  383. package/src/_modules/location/_collections/assets/country-subdivisions/panama.json +53 -53
  384. package/src/_modules/location/_collections/assets/country-subdivisions/papua-new-guinea.json +81 -81
  385. package/src/_modules/location/_collections/assets/country-subdivisions/paraguay.json +73 -73
  386. package/src/_modules/location/_collections/assets/country-subdivisions/peru.json +105 -105
  387. package/src/_modules/location/_collections/assets/country-subdivisions/philippines.json +69 -69
  388. package/src/_modules/location/_collections/assets/country-subdivisions/poland.json +65 -65
  389. package/src/_modules/location/_collections/assets/country-subdivisions/portugal.json +81 -81
  390. package/src/_modules/location/_collections/assets/country-subdivisions/qatar.json +29 -29
  391. package/src/_modules/location/_collections/assets/country-subdivisions/romania.json +169 -169
  392. package/src/_modules/location/_collections/assets/country-subdivisions/russian-federation.json +499 -499
  393. package/src/_modules/location/_collections/assets/country-subdivisions/rwanda.json +21 -21
  394. package/src/_modules/location/_collections/assets/country-subdivisions/saint-helena-ascension-and-tristan-da-cunha.json +13 -13
  395. package/src/_modules/location/_collections/assets/country-subdivisions/saint-kitts-and-nevis.json +9 -9
  396. package/src/_modules/location/_collections/assets/country-subdivisions/saint-lucia.json +45 -45
  397. package/src/_modules/location/_collections/assets/country-subdivisions/saint-vincent-and-the-grenadines.json +25 -25
  398. package/src/_modules/location/_collections/assets/country-subdivisions/samoa.json +45 -45
  399. package/src/_modules/location/_collections/assets/country-subdivisions/san-marino.json +37 -37
  400. package/src/_modules/location/_collections/assets/country-subdivisions/sao-tome-and-principe.json +9 -9
  401. package/src/_modules/location/_collections/assets/country-subdivisions/saudi-arabia.json +53 -53
  402. package/src/_modules/location/_collections/assets/country-subdivisions/senegal.json +57 -57
  403. package/src/_modules/location/_collections/assets/country-subdivisions/serbia.json +9 -9
  404. package/src/_modules/location/_collections/assets/country-subdivisions/seychelles.json +101 -101
  405. package/src/_modules/location/_collections/assets/country-subdivisions/sierra-leone.json +17 -17
  406. package/src/_modules/location/_collections/assets/country-subdivisions/singapore.json +21 -21
  407. package/src/_modules/location/_collections/assets/country-subdivisions/slovakia.json +33 -33
  408. package/src/_modules/location/_collections/assets/country-subdivisions/slovenia.json +841 -841
  409. package/src/_modules/location/_collections/assets/country-subdivisions/solomon-islands.json +41 -41
  410. package/src/_modules/location/_collections/assets/country-subdivisions/somalia.json +73 -73
  411. package/src/_modules/location/_collections/assets/country-subdivisions/south-africa.json +37 -37
  412. package/src/_modules/location/_collections/assets/country-subdivisions/south-sudan.json +41 -41
  413. package/src/_modules/location/_collections/assets/country-subdivisions/spain.json +346 -346
  414. package/src/_modules/location/_collections/assets/country-subdivisions/sri-lanka.json +37 -37
  415. package/src/_modules/location/_collections/assets/country-subdivisions/sudan.json +69 -69
  416. package/src/_modules/location/_collections/assets/country-subdivisions/suriname.json +41 -41
  417. package/src/_modules/location/_collections/assets/country-subdivisions/swaziland.json +17 -17
  418. package/src/_modules/location/_collections/assets/country-subdivisions/sweden.json +85 -85
  419. package/src/_modules/location/_collections/assets/country-subdivisions/switzerland.json +105 -105
  420. package/src/_modules/location/_collections/assets/country-subdivisions/syrian-arab-republic.json +57 -57
  421. package/src/_modules/location/_collections/assets/country-subdivisions/taiwan-province-of-china.json +93 -93
  422. package/src/_modules/location/_collections/assets/country-subdivisions/tajikistan.json +17 -17
  423. package/src/_modules/location/_collections/assets/country-subdivisions/tanzania-united-republic-of.json +105 -105
  424. package/src/_modules/location/_collections/assets/country-subdivisions/thailand.json +313 -313
  425. package/src/_modules/location/_collections/assets/country-subdivisions/timor-leste.json +53 -53
  426. package/src/_modules/location/_collections/assets/country-subdivisions/togo.json +21 -21
  427. package/src/_modules/location/_collections/assets/country-subdivisions/tonga.json +21 -21
  428. package/src/_modules/location/_collections/assets/country-subdivisions/trinidad-and-tobago.json +65 -65
  429. package/src/_modules/location/_collections/assets/country-subdivisions/tunisia.json +97 -97
  430. package/src/_modules/location/_collections/assets/country-subdivisions/turkey.json +325 -325
  431. package/src/_modules/location/_collections/assets/country-subdivisions/turkmenistan.json +25 -25
  432. package/src/_modules/location/_collections/assets/country-subdivisions/tuvalu.json +33 -33
  433. package/src/_modules/location/_collections/assets/country-subdivisions/uganda.json +17 -17
  434. package/src/_modules/location/_collections/assets/country-subdivisions/ukraine.json +109 -109
  435. package/src/_modules/location/_collections/assets/country-subdivisions/united-arab-emirates.json +29 -29
  436. package/src/_modules/location/_collections/assets/country-subdivisions/united-kingdom.json +1196 -1196
  437. package/src/_modules/location/_collections/assets/country-subdivisions/united-states-minor-outlying-islands.json +37 -37
  438. package/src/_modules/location/_collections/assets/country-subdivisions/united-states.json +286 -286
  439. package/src/_modules/location/_collections/assets/country-subdivisions/uruguay.json +77 -77
  440. package/src/_modules/location/_collections/assets/country-subdivisions/uzbekistan.json +57 -57
  441. package/src/_modules/location/_collections/assets/country-subdivisions/vanuatu.json +25 -25
  442. package/src/_modules/location/_collections/assets/country-subdivisions/venezuela.json +101 -101
  443. package/src/_modules/location/_collections/assets/country-subdivisions/viet-nam.json +257 -257
  444. package/src/_modules/location/_collections/assets/country-subdivisions/yemen.json +85 -85
  445. package/src/_modules/location/_collections/assets/country-subdivisions/zambia.json +37 -37
  446. package/src/_modules/location/_collections/assets/country-subdivisions/zimbabwe.json +41 -41
  447. package/src/_modules/location/_collections/loc-country-divisions.const.ts +10 -10
  448. package/src/_modules/location/_collections/loc-country-isos.const.ts +8 -8
  449. package/src/_modules/location/_collections/loc-regions.util.spec.ts +61 -61
  450. package/src/_modules/location/_collections/loc-regions.util.ts +137 -137
  451. package/src/_modules/location/_collections/loc.util.spec.ts +52 -52
  452. package/src/_modules/location/_collections/loc.util.ts +74 -74
  453. package/src/_modules/location/_enums/loc-region.enum.ts +14 -14
  454. package/src/_modules/location/_enums/loc-sub-region.enum.ts +31 -31
  455. package/src/_modules/location/_enums/loc-subdivision-region-type.enum.ts +47 -47
  456. package/src/_modules/location/_models/loc-coordinates.interface.ts +7 -7
  457. package/src/_modules/location/_models/loc-country-division.interface.ts +8 -8
  458. package/src/_modules/location/_models/loc-country-iso.interface.ts +23 -23
  459. package/src/_modules/location/_models/loc-country-phone-code.interface.ts +9 -9
  460. package/src/_modules/location/_models/loc-division-collection.interface.ts +12 -12
  461. package/src/_modules/location/_models/loc-division-region-data.interface.ts +9 -9
  462. package/src/_modules/location/_models/loc-geo-ip-location.interface.ts +27 -27
  463. package/src/_modules/location/index.ts +22 -22
  464. package/src/_modules/messaging/README.md +279 -279
  465. package/src/_modules/messaging/_collections/msg-module-settings.const.ts +46 -46
  466. package/src/_modules/messaging/_enums/msg-attachment-type.enum.ts +26 -26
  467. package/src/_modules/messaging/_enums/msg-delivery-status.enum.ts +17 -17
  468. package/src/_modules/messaging/_enums/msg-event-key.enum.ts +31 -31
  469. package/src/_modules/messaging/_enums/msg-participant-role.enum.ts +20 -20
  470. package/src/_modules/messaging/_enums/msg-provider-type.enum.ts +7 -7
  471. package/src/_modules/messaging/_enums/msg-type.enum.ts +23 -23
  472. package/src/_modules/messaging/_models/msg-attachment.interface.ts +46 -46
  473. package/src/_modules/messaging/_models/msg-conversation.data-model.spec.ts +69 -69
  474. package/src/_modules/messaging/_models/msg-conversation.data-model.ts +96 -96
  475. package/src/_modules/messaging/_models/msg-mention.interface.ts +29 -29
  476. package/src/_modules/messaging/_models/msg-message.data-model.spec.ts +79 -79
  477. package/src/_modules/messaging/_models/msg-message.data-model.ts +127 -127
  478. package/src/_modules/messaging/_models/msg-participant.interface.ts +46 -46
  479. package/src/_modules/messaging/_models/msg-reaction.interface.ts +20 -20
  480. package/src/_modules/messaging/_models/msg-thread-info.interface.ts +35 -35
  481. package/src/_modules/messaging/_modules/agent/_enums/agt-process-step-type.enum.ts +35 -35
  482. package/src/_modules/messaging/_modules/agent/_enums/agt-tool-status.enum.ts +23 -23
  483. package/src/_modules/messaging/_modules/agent/_models/agt-process-step.interface.ts +55 -55
  484. package/src/_modules/messaging/_modules/agent/_models/agt-reasoning-info.interface.ts +26 -26
  485. package/src/_modules/messaging/_modules/agent/_models/agt-tool-usage.interface.ts +37 -37
  486. package/src/_modules/messaging/_modules/agent/index.ts +8 -8
  487. package/src/_modules/messaging/index.ts +28 -28
  488. package/src/_modules/pipe/_collections/pip-transforms.const.ts +42 -42
  489. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.spec.ts +47 -47
  490. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.ts +41 -41
  491. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.spec.ts +39 -39
  492. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.ts +30 -30
  493. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.spec.ts +41 -41
  494. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.ts +36 -36
  495. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.spec.ts +62 -62
  496. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.ts +17 -17
  497. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.spec.ts +34 -34
  498. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.ts +25 -25
  499. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.spec.ts +67 -67
  500. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.ts +226 -226
  501. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.spec.ts +28 -28
  502. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.ts +21 -21
  503. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.spec.ts +59 -59
  504. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.ts +106 -106
  505. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.spec.ts +31 -31
  506. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.ts +35 -35
  507. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.spec.ts +44 -44
  508. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.ts +23 -23
  509. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.spec.ts +21 -21
  510. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.ts +33 -33
  511. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.spec.ts +62 -62
  512. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.ts +80 -80
  513. package/src/_modules/pipe/_enums/pip-range-pipe-setting.enum.ts +15 -15
  514. package/src/_modules/pipe/_enums/pip.enum.ts +65 -65
  515. package/src/_modules/pipe/_models/pip-multi-pipe-settings.type.ts +8 -8
  516. package/src/_modules/pipe/_models/pip-transforms.interface.ts +30 -30
  517. package/src/_modules/pipe/index.ts +30 -30
  518. package/src/_modules/socket/_enums/sck-event-key.enum.ts +21 -21
  519. package/src/_modules/socket/_models/sck-client-params.control-model.spec.ts +67 -67
  520. package/src/_modules/socket/_models/sck-client-params.control-model.ts +50 -50
  521. package/src/_modules/socket/_models/sck-socket-event.control-model.spec.ts +66 -66
  522. package/src/_modules/socket/_models/sck-socket-event.control-model.ts +172 -172
  523. package/src/_modules/socket/_services/sck-client.service-base.spec.ts +99 -99
  524. package/src/_modules/socket/_services/sck-client.service-base.ts +353 -353
  525. package/src/_modules/socket/index.ts +14 -14
  526. package/src/_modules/test/_collections/tst-module-settings.const.ts +67 -67
  527. package/src/_modules/test/index.ts +5 -5
  528. package/src/_modules/usage/_collections/usg-module-settings.const.ts +33 -33
  529. package/src/_modules/usage/_models/usg-action.control-model.spec.ts +27 -27
  530. package/src/_modules/usage/_models/usg-action.control-model.ts +28 -28
  531. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.spec.ts +36 -36
  532. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.ts +35 -35
  533. package/src/_modules/usage/_models/usg-data.control-model.spec.ts +41 -41
  534. package/src/_modules/usage/_models/usg-data.control-model.ts +35 -35
  535. package/src/_modules/usage/_models/usg-session.data-model.spec.ts +97 -97
  536. package/src/_modules/usage/_models/usg-session.data-model.ts +72 -72
  537. package/src/_modules/usage/index.ts +11 -11
  538. package/src/index.ts +102 -102
  539. package/tsconfig.app.json +12 -12
  540. package/tsconfig.json +31 -31
  541. package/tsconfig.test.json +16 -16
  542. package/tslint.json +153 -153
  543. package/pipeline.cicd.config.json +0 -128
@@ -1,813 +1,813 @@
1
-
2
- import { DyFM_LogStyle } from '../../_enums/log-style.enum';
3
- import { DyFM_Paged } from '../../_models/interfaces/paged.interface';
4
- import { DyFM_Log } from './log.util';
5
-
6
- /**
7
- * the return type of the sortForTrue function
8
- */
9
- export type DyFM_SortDirection = 0 | 1 | -1
10
-
11
-
12
- export type DyFM_List = DyFM_Array;
13
-
14
- export class DyFM_Array {
15
-
16
- /**
17
- * Asynchronously iterates over an array and applies a function to each element.
18
- * @param list - The array to iterate over.
19
- * @param func - The function to apply to each element.
20
- * @returns A promise that resolves when all elements have been processed.
21
- *
22
- * @example
23
- * ```ts
24
- * const list: number[] = [ 1, 2, 3 ];
25
- * await DyFM_Array.asyncForEach(list, async (element: number, index?: number, array?: number[]): Promise<void> => {
26
- * console.log(element, index, array);
27
- * });
28
- * ```
29
- */
30
- static async asyncForEach<T>(
31
- list: T[],
32
- func: (element: T, index?: number, array?: T[]) => Promise<void>
33
- ): Promise<void> {
34
- if (!list) {
35
- console.trace(
36
- DyFM_Log.addStyle('DyFM_Array.asyncForEach: List is required', [ DyFM_LogStyle.red ])
37
- );
38
- return;
39
- }
40
-
41
- for (let i = 0; i < list.length; i++) {
42
- await func(list[i], i, list);
43
- }
44
- }
45
-
46
- /**
47
- * Asynchronously iterates over an array and applies a function to each element, returning a single result.
48
- * @param startData - The initial data to pass to the function.
49
- * @param list - The array to iterate over.
50
- * @param func - The function to apply to each element.
51
- * @returns A promise that resolves to the final result.
52
- *
53
- * @example
54
- * ```ts
55
- * const list: number[] = [ 1, 2, 3 ];
56
- * const result = await DyFM_Array.asyncForEachReturnToOne(0, list, async (element: number, dataCurrent: number, index?: number, array?: number[]): Promise<number> => {
57
- * return dataCurrent + element;
58
- * });
59
- * ```
60
- */
61
- static async asyncForEachReturnToOne<T, K>(
62
- startData: K,
63
- list: T[],
64
- func: (element: T, dataCurrent: K, index?: number, array?: T[]) => Promise<K>
65
- ): Promise<K> {
66
- if (!list) {
67
- console.trace(
68
- DyFM_Log.addStyle('DyFM_Array.asyncForEachReturnToOne: List is required', [ DyFM_LogStyle.red ])
69
- );
70
- return startData;
71
- }
72
-
73
- let result: K = startData;
74
-
75
- for (let i = 0; i < list.length; i++) {
76
- result = await func(list[i], result, i, list);
77
- }
78
-
79
- return result;
80
- }
81
-
82
- /**
83
- * Asynchronously iterates over an array and applies a function to each element, returning an array of results.
84
- * @param list - The array to iterate over.
85
- * @param func - The function to apply to each element.
86
- * @returns A promise that resolves to an array of results.
87
- *
88
- * @example
89
- * ```ts
90
- * const list: number[] = [ 1, 2, 3 ];
91
- * const result = await DyFM_Array.asyncForEachReturnToAll(list, async (element: number, index?: number, array?: number[]): Promise<number> => {
92
- * return element * 2;
93
- * });
94
- * ```
95
- */
96
- static async asyncForEachReturnToAll<T, K>(
97
- list: T[],
98
- func: (element: T, index?: number, array?: T[]) => Promise<K>
99
- ): Promise<K[]> {
100
- if (!list) {
101
- console.trace(
102
- DyFM_Log.addStyle('DyFM_Array.asyncForEachReturnToAll: List is required', [ DyFM_LogStyle.red ])
103
- );
104
- return [];
105
- }
106
-
107
- const resultList: K[] = [];
108
-
109
- for (let i = 0; i < list.length; i++) {
110
- resultList.push(await func(list[i], i, list));
111
- }
112
-
113
- return resultList;
114
- }
115
-
116
- /**
117
- * Asynchronously iterates over an array and applies a function to each element, returning an array of results.
118
- * @param list - The array to iterate over.
119
- * @param func - The function to apply to each element.
120
- * @returns A promise that resolves to an array of results.
121
- *
122
- * @example
123
- * ```ts
124
- * const list: number[] = [ 1, 2, 3 ];
125
- * const result = await DyFM_Array.asyncForEachAllAtOnce(list, async (element: number, index?: number, array?: number[]): Promise<number> => {
126
- * return [ element * 2, element * 3 ];
127
- * });
128
- * console.log(result); // [ [ 2, 3 ], [ 4, 6 ], [ 6, 9 ] ]
129
- * ```
130
- */
131
- static async asyncForEachAllAtOnce<T, R>(
132
- list: T[],
133
- func: (element: T, index?: number, array?: T[]) => Promise<R>
134
- ): Promise<R[]> {
135
- if (!list) {
136
- console.trace(
137
- DyFM_Log.addStyle('DyFM_Array.asyncForEachAllAtOnce: List is required', [ DyFM_LogStyle.red ])
138
- );
139
- return [];
140
- }
141
-
142
- return await Promise.all(list.map(func));
143
- }
144
-
145
- /**
146
- * Asynchronously filters an array based on a function.
147
- * @param list - The array to filter.
148
- * @param filterFunc - The function to apply to each element.
149
- * @returns A promise that resolves to an array of results.
150
- *
151
- * @example
152
- * ```ts
153
- * const list: number[] = [ 1, 2, 3 ];
154
- * const result = await DyFM_Array.asyncFilter(list, async (element: number, index?: number, array?: number[]): Promise<boolean> => {
155
- * return element % 2 === 0;
156
- * });
157
- * console.log(result); // [ 2 ]
158
- * ```
159
- */
160
- static async asyncFilter<T>(
161
- list: T[],
162
- filterFunc: (element: T, index?: number, array?: T[]) => Promise<boolean>
163
- ): Promise<T[]> {
164
- if (!list) {
165
- console.trace(
166
- DyFM_Log.addStyle('DyFM_Array.asyncFilter: List is required', [ DyFM_LogStyle.red ])
167
- );
168
- return [];
169
- }
170
-
171
- const resultList: T[] = [];
172
-
173
- for (let i = 0; i < list.length; i++) {
174
- if (await filterFunc(list[i], i, list)) {
175
- resultList.push(list[i]);
176
- }
177
- }
178
-
179
- return resultList;
180
- }
181
-
182
- /**
183
- * Asynchronously maps an array based on a function.
184
- * @param list - The array to map.
185
- * @param mapFunc - The function to apply to each element.
186
- * @returns A promise that resolves to an array of results.
187
- *
188
- * @example
189
- * ```ts
190
- * const list: number[] = [ 1, 2, 3 ];
191
- * const result = await DyFM_Array.asyncMap(list, async (element: number, index?: number, array?: number[]): Promise<number> => {
192
- * return element * 2;
193
- * });
194
- * console.log(result); // [ 2, 4, 6 ]
195
- * ```
196
- */
197
- static async asyncMap<T, R>(
198
- list: T[],
199
- mapFunc: (element: T, index?: number, array?: T[]) => Promise<R>
200
- ): Promise<R[]> {
201
- if (!list) {
202
- console.trace(
203
- DyFM_Log.addStyle('DyFM_Array.asyncMap: List is required', [ DyFM_LogStyle.red ])
204
- );
205
- return [];
206
- }
207
-
208
- const resultList: R[] = [];
209
-
210
- for (let i = 0; i < list.length; i++) {
211
- resultList.push(await mapFunc(list[i], i, list));
212
- }
213
-
214
- return resultList;
215
- }
216
-
217
- /**
218
- * Returns the last element of an array.
219
- * @param array - The array to get the last element from.
220
- * @returns The last element of the array, or null if the array is empty.
221
- *
222
- * @example
223
- * ```ts
224
- * const list: number[] = [ 1, 2, 3 ];
225
- * const result = DyFM_Array.last(list);
226
- * console.log(result); // 3
227
- * ```
228
- */
229
- static last<T>(array: T[]): T | null {
230
- if (!array) {
231
- console.trace(
232
- DyFM_Log.addStyle('DyFM_Array.last: Array is required', [ DyFM_LogStyle.red ])
233
- );
234
- return null;
235
- }
236
-
237
- return array.length ? array[array.length - 1] : null;
238
- }
239
-
240
- /**
241
- * Returns true if the string is the last element of the array.
242
- * @param string - The string to check.
243
- * @param array - The array to check.
244
- * @returns True if the string is the last element of the array, false otherwise.
245
- *
246
- * @example
247
- * ```ts
248
- * const list: number[] = [ 1, 2, 3 ];
249
- * const result = DyFM_Array.isLast(3, list);
250
- * console.log(result); // true
251
- * ```
252
- */
253
- static isLast<T>(element: T, array: T[]): boolean {
254
- if (!array) {
255
- console.trace(
256
- DyFM_Log.addStyle('DyFM_Array.isLast: Array is required', [ DyFM_LogStyle.red ])
257
- );
258
- return false;
259
- }
260
-
261
- return array.indexOf(element) === array.length - 1;
262
- }
263
-
264
- /**
265
- * Returns true if the string is the last element of the array.
266
- * @param string - The string to check.
267
- * @param array - The array to check.
268
- * @returns True if the string is the last element of the array, false otherwise.
269
- *
270
- * @example
271
- * ```ts
272
- * const list: number[] = [ 1, 2, 3 ];
273
- * const result = DyFM_Array.isLastIndex(2, list);
274
- * console.log(result); // true
275
- * ```
276
- */
277
- static isLastIndex<T>(index: number, array: T[]): boolean {
278
- if (!array) {
279
- console.trace(
280
- DyFM_Log.addStyle('DyFM_Array.isLastIndex: Array is required', [ DyFM_LogStyle.red ])
281
- );
282
- return false;
283
- }
284
-
285
- return index === array.length - 1;
286
- }
287
-
288
- /**
289
- * Returns true if the string is the first element of the array.
290
- * @param string - The string to check.
291
- * @param array - The array to check.
292
- * @returns True if the string is the first element of the array, false otherwise.
293
- *
294
- * @example
295
- * ```ts
296
- * const list: number[] = [ 1, 2, 3 ];
297
- * const result = DyFM_Array.isFirst(1, list);
298
- * console.log(result); // true
299
- * ```
300
- */
301
- static isFirst<T>(element: T, array: T[]): boolean {
302
- if (!array) {
303
- console.trace(
304
- DyFM_Log.addStyle('DyFM_Array.isFirst: Array is required', [ DyFM_LogStyle.red ])
305
- );
306
- return false;
307
- }
308
-
309
- return array.indexOf(element) === 0;
310
- }
311
-
312
- /**
313
- * Returns the last character of a string.
314
- * @param string - The string to get the last character from.
315
- * @returns The last character of the string, or null if the string is empty.
316
- *
317
- * @example
318
- * ```ts
319
- * const string = 'hello';
320
- * const result = DyFM_Array.lastCharacter(string);
321
- * console.log(result); // 'o'
322
- * ```
323
- */
324
- static lastCharacter(string: string): string | null {
325
- if (!string) {
326
- console.trace(
327
- DyFM_Log.addStyle('DyFM_Array.lastCharacter: String is required', [ DyFM_LogStyle.red ])
328
- );
329
- return null;
330
- }
331
-
332
- return string.length ? string[string.length - 1] : null;
333
- }
334
-
335
- /**
336
- * Returns the first element of an array.
337
- * @param array - The array to get the first element from.
338
- * @returns The first element of the array, or null if the array is empty.
339
- *
340
- * @example
341
- * ```ts
342
- * const list: number[] = [ 1, 2, 3 ];
343
- * const result = DyFM_Array.first(list);
344
- * console.log(result); // 1
345
- * ```
346
- */
347
- static first<T>(array: T[]): T | null {
348
- if (!array) {
349
- console.trace(
350
- DyFM_Log.addStyle('DyFM_Array.first: Array is required', [ DyFM_LogStyle.red ])
351
- );
352
- return null;
353
- }
354
-
355
- return array.length ? array[0] : null;
356
- }
357
-
358
- /**
359
- * Removes an element from an array.
360
- * @param array - The array to remove the element from.
361
- * @param element - The element to remove from the array.
362
- * @returns The array with the element removed.
363
- *
364
- * @example
365
- * ```ts
366
- * const list: number[] = [ 1, 2, 3 ];
367
- * const result = DyFM_Array.remove(list, 2);
368
- * console.log(result); // [ 1, 3 ]
369
- * ```
370
- */
371
- static remove<T>(array: T[], element: T): T[] {
372
- if (!array) {
373
- console.trace(
374
- DyFM_Log.addStyle('DyFM_Array.remove: Array is required', [ DyFM_LogStyle.red ])
375
- );
376
- return [];
377
- }
378
-
379
- const index = array.indexOf(element);
380
-
381
- if (-1 < index) {
382
- array.splice(index, 1);
383
- }
384
-
385
- return array;
386
- }
387
-
388
- /**
389
- * Finds an element in an array and removes it.
390
- * @param array - The array to find and remove the element from.
391
- * @param func - The function to apply to each element.
392
- * @returns The array with the element removed.
393
- *
394
- * @example
395
- * ```ts
396
- * const list: number[] = [ 1, 2, 3 ];
397
- * const result = DyFM_Array.findNRemove(list, (element: number, index?: number, array?: number[]): boolean => {
398
- * return element === 2;
399
- * });
400
- * console.log(result); // [ 1, 3 ]
401
- * ```
402
- */
403
- static findNRemove<T>(
404
- array: T[],
405
- func: (element: T, index?: number, array?: T[]) => boolean
406
- ): T[] {
407
- if (!array) {
408
- console.trace(
409
- DyFM_Log.addStyle('DyFM_Array.findNRemove: Array is required', [ DyFM_LogStyle.red ])
410
- );
411
- return [];
412
- }
413
-
414
- const index = array.findIndex(func);
415
-
416
- if (-1 < index) {
417
- array.splice(index, 1);
418
- }
419
-
420
- return array;
421
- }
422
-
423
- /**
424
- * Shuffles an array.
425
- * @param array - The array to shuffle.
426
- * @returns The shuffled array.
427
- *
428
- * @example
429
- * ```ts
430
- * const list: number[] = [ 1, 2, 3 ];
431
- * const result = DyFM_Array.shuffle(list);
432
- * console.log(result); // [ 3, 1, 2 ]
433
- * ```
434
- */
435
- static shuffle<T>(array: T[]): T[] {
436
- if (!array) {
437
- console.trace(
438
- DyFM_Log.addStyle('DyFM_Array.shuffle: Array is required', [ DyFM_LogStyle.red ])
439
- );
440
- return [];
441
- }
442
-
443
- let currentIndex = array.length;
444
- let randomIndex: number;
445
-
446
- while (0 < currentIndex) {
447
- currentIndex--;
448
-
449
- randomIndex = Math.floor(Math.random() * (array.length - 1));
450
- this.swap(array, currentIndex, randomIndex);
451
- }
452
-
453
- return array;
454
- }
455
-
456
- /**
457
- * Pages an array.
458
- * @param array - The array to page.
459
- * @param pageIndex - The index of the page to return.
460
- * @param pageSize - The size of the page.
461
- * @returns The page of the array.
462
- *
463
- * @example
464
- * ```ts
465
- * const list: number[] = [ 1, 2, 3, 4, 5, 6, 7, 8 ];
466
- * const result = DyFM_Array.page(list, 0, 2);
467
- * console.log(result); // [ 1, 2 ]
468
- * ```
469
- */
470
- static page<T>(array: T[], pageIndex: number, pageSize: number): T[] {
471
- if (!array) {
472
- console.trace(
473
- DyFM_Log.addStyle('DyFM_Array.page: Array is required', [ DyFM_LogStyle.red ])
474
- );
475
- return [];
476
- }
477
-
478
- return array.slice(pageIndex * pageSize, (pageIndex + 1) * pageSize);
479
- }
480
-
481
- /**
482
- * Pages an array.
483
- * @param array - The array to page.
484
- * @param pageIndex - The index of the page to return.
485
- * @param pageSize - The size of the page.
486
- * @returns The page of the array.
487
- *
488
- * @example
489
- * ```ts
490
- * const list: number[] = [ 1, 2, 3, 4, 5, 6, 7, 8 ];
491
- * const result = DyFM_Array.paged(list, 0, 2);
492
- * console.log(result); // { pageIndex: 0, pageSize: 2, total: 8, totalPageCount: 4, items: [ 1, 2 ] }
493
- * ```
494
- */
495
- static paged<T>(array: T[], pageIndex: number, pageSize: number): DyFM_Paged<T> {
496
- if (!array) {
497
- console.trace(
498
- DyFM_Log.addStyle('DyFM_Array.paged: Array is required', [ DyFM_LogStyle.red ])
499
- );
500
- return {
501
- pageIndex: 0,
502
- pageSize: 0,
503
- total: 0,
504
- totalPageCount: 0,
505
- items: [],
506
- };
507
- }
508
-
509
- return {
510
- pageIndex,
511
- pageSize,
512
- total: array.length,
513
- totalPageCount: Math.ceil(array.length / pageSize),
514
- items: this.page(array, pageIndex, pageSize),
515
- };
516
- }
517
-
518
- /**
519
- * Swaps two elements in an array.
520
- * @param array - The array to swap the elements in.
521
- * @param indexA - The index of the first element to swap.
522
- * @param indexB - The index of the second element to swap.
523
- * @returns The array with the elements swapped.
524
- *
525
- * @example
526
- * ```ts
527
- * const list: number[] = [ 1, 2, 3 ];
528
- * const result = DyFM_Array.swap(list, 0, 2);
529
- * console.log(result); // [ 3, 2, 1 ]
530
- * ```
531
- */
532
- static swap<T>(array: T[], indexA: number, indexB: number): T[] {
533
- if (!array) {
534
- console.trace(
535
- DyFM_Log.addStyle('DyFM_Array.swap: Array is required', [ DyFM_LogStyle.red ])
536
- );
537
- return [];
538
- }
539
-
540
- [ array[indexA], array[indexB] ] = [ array[indexB], array[indexA] ];
541
-
542
- return array;
543
- }
544
-
545
- /**
546
- * Checks if a string list has multiplications.
547
- * @param stringList - The string list to check.
548
- * @returns True if the string list has multiplications, false otherwise.
549
- *
550
- * @example
551
- * ```ts
552
- * const list: string[] = [ 'a', 'b', 'c', 'a' ];
553
- * const result = DyFM_Array.stringListHasMultiplications(list);
554
- * console.log(result); // true
555
- * ```
556
- */
557
- static stringListHasMultiplications(stringList: string[]): boolean {
558
- if (!stringList) {
559
- console.trace(
560
- DyFM_Log.addStyle('DyFM_Array.stringListHasMultiplications: String list is required', [ DyFM_LogStyle.red ])
561
- );
562
- return false;
563
- }
564
-
565
- return stringList.some((str: string, index: number): boolean => {
566
- return stringList.findIndex((strItem: string): boolean => strItem === str) !== index;
567
- });
568
- }
569
-
570
- /**
571
- * Filters a string list to remove multiplications.
572
- * @param stringList - The string list to filter.
573
- * @returns The filtered string list.
574
- *
575
- * @example
576
- * ```ts
577
- * const list: string[] = [ 'a', 'b', 'c', 'a' ];
578
- * const result = DyFM_Array.filterStringMultiplications(list);
579
- * console.log(result); // [ 'a', 'b', 'c' ]
580
- * ```
581
- */
582
- static filterStringMultiplications(stringList: string[]): string[] {
583
- if (!stringList) {
584
- console.trace(
585
- DyFM_Log.addStyle('DyFM_Array.filterStringMultiplications: String list is required', [ DyFM_LogStyle.red ])
586
- );
587
- return [];
588
- }
589
-
590
- return stringList.filter((str: string, index: number): boolean => {
591
- return stringList.findIndex((strItem: string): boolean => strItem === str) !== index;
592
- });
593
- }
594
-
595
- /**
596
- * Gathers multiplications from a string list.
597
- * @param stringList - The string list to gather multiplications from.
598
- * @returns The gathered multiplications.
599
- *
600
- * @example
601
- * ```ts
602
- * const list: string[] = [ 'a', 'b', 'c', 'a' ];
603
- * const result = DyFM_Array.gatherStringMultiplications(list);
604
- * console.log(result); // [ [ 'a', 'a' ] ]
605
- * ```
606
- */
607
- static gatherStringMultiplications(stringList: string[]): string[][] {
608
- if (!stringList) {
609
- console.trace(
610
- DyFM_Log.addStyle('DyFM_Array.gatherStringMultiplications: String list is required', [ DyFM_LogStyle.red ])
611
- );
612
- return [];
613
- }
614
-
615
- const multiplications: string[][] = [];
616
-
617
- stringList.forEach((str: string, index: number): void => {
618
- if (multiplications.find(
619
- (multiplication: string[]): boolean => multiplication.includes(str))
620
- ) {
621
- return;
622
- }
623
-
624
- const sameStrings = stringList.filter((strItem: string): boolean => strItem === str);
625
-
626
- if (sameStrings.length > 1) {
627
- multiplications.push(sameStrings);
628
- }
629
- });
630
-
631
- return multiplications;
632
- }
633
-
634
- /**
635
- * Checks if a data list has multiplications.
636
- * @param dataList - The data list to check.
637
- * @param byKey - The key to check for multiplications.
638
- * @returns True if the data list has multiplications, false otherwise.
639
- *
640
- * @example
641
- * ```ts
642
- * const list: { _id: number, name: string }[] = [ { _id: 1, name: 'John' }, { _id: 2, name: 'Jane' }, { _id: 1, name: 'Bob' } ];
643
- * const result = DyFM_Array.haveMultiplications(list, '_id');
644
- * console.log(result); // true
645
- * ```
646
- */
647
- static haveMultiplications<T extends object>(dataList: T[], byKey: keyof T = '_id' as keyof T): boolean {
648
- if (!dataList) {
649
- console.trace(
650
- DyFM_Log.addStyle('DyFM_Array.haveMultiplications: Data list is required', [ DyFM_LogStyle.red ])
651
- );
652
- return false;
653
- }
654
-
655
- return dataList.some((data: T, index: number): boolean => {
656
- return dataList.findIndex(
657
- (listItem: T): boolean => listItem[byKey] === data[byKey]
658
- ) !== index;
659
- });
660
- }
661
-
662
- /**
663
- * Filters a data list to remove multiplications.
664
- * @param dataList - The data list to filter.
665
- * @param byKey - The key to filter for multiplications.
666
- * @returns The filtered data list.
667
- *
668
- * @example
669
- * ```ts
670
- * const list: { _id: number, name: string }[] = [ { _id: 1, name: 'John' }, { _id: 2, name: 'Jane' }, { _id: 1, name: 'Bob' } ];
671
- * const result = DyFM_Array.filterMultiplications(list, '_id');
672
- * console.log(result); // [ { _id: 1, name: 'John' } , { _id: 2, name: 'Jane' } ]
673
- * ```
674
- */
675
- static filterMultiplications<T extends object>(dataList: T[], byKey: keyof T = '_id' as keyof T): T[] {
676
- if (!dataList) {
677
- console.trace(
678
- DyFM_Log.addStyle('DyFM_Array.filterMultiplications: Data list is required', [ DyFM_LogStyle.red ])
679
- );
680
- return [];
681
- }
682
-
683
- return dataList.filter((data: T, index: number): boolean => {
684
- return dataList.findIndex(
685
- (listItem: T): boolean => listItem[byKey] === data[byKey]
686
- ) !== index;
687
- });
688
- }
689
-
690
- /**
691
- * Gathers multiplications from a data list.
692
- * @param dataList - The data list to gather multiplications from.
693
- * @param byKey - The key to gather multiplications from.
694
- * @returns The gathered multiplications.
695
- *
696
- * @example
697
- * ```ts
698
- * const list: { _id: number, name: string }[] = [ { _id: 1, name: 'John' }, { _id: 2, name: 'Jane' }, { _id: 1, name: 'Bob' } ];
699
- * const result = DyFM_Array.gatherMultiplications(list, '_id');
700
- * console.log(result); // [ [ { _id: 1, name: 'John' }, { _id: 1, name: 'Bob' } ] ]
701
- * ```
702
- */
703
- static gatherMultiplications<T extends object>(dataList: T[], byKey: keyof T = '_id' as keyof T): T[][] {
704
- if (!dataList) {
705
- console.trace(
706
- DyFM_Log.addStyle('DyFM_Array.gatherMultiplications: Data list is required', [ DyFM_LogStyle.red ])
707
- );
708
- return [];
709
- }
710
-
711
- const multiplications: T[][] = [];
712
-
713
- dataList.forEach((data: T, index: number): void => {
714
- if (multiplications.find((multiplication: T[]): boolean => multiplication.includes(data))) {
715
- return;
716
- }
717
-
718
- const sameData = dataList.filter((listItem: T): boolean => listItem[byKey] === data[byKey]);
719
-
720
- if (sameData.length > 1) {
721
- multiplications.push(sameData);
722
- }
723
- });
724
-
725
- return multiplications;
726
- }
727
-
728
- /**
729
- * Finds an element in an array from the end.
730
- * @param array - The array to find the element in.
731
- * @param func - The function to apply to each element.
732
- * @returns The element found, or null if no element is found.
733
- *
734
- * @example
735
- * ```ts
736
- * const list: number[] = [ 1, 2, 3 ];
737
- * const result = DyFM_Array.findFromEnd(list, (element: number, index?: number, array?: number[]): boolean => {
738
- * return element === 2;
739
- * });
740
- * console.log(result); // 2
741
- * ```
742
- */
743
- static findFromEnd<T>(
744
- array: T[],
745
- func: (element: T, index?: number,
746
- array?: T[]) => boolean
747
- ): T | null {
748
- if (!array) {
749
- console.trace(
750
- DyFM_Log.addStyle('DyFM_Array.findFromEnd: Array is required', [ DyFM_LogStyle.red ])
751
- );
752
- return null;
753
- }
754
-
755
- for (let i = array.length - 1; i >= 0; i--) {
756
- if (func(array[i], i, array)) {
757
- return array[i];
758
- }
759
- }
760
-
761
- return null;
762
- }
763
-
764
- /**
765
- * returns a function that can be used to sort an array of objects
766
- * sorts so that the objects that have the value true for the checkFor function are at the beginning of the array
767
- * @param checkFor
768
- * @returns
769
- *
770
- */
771
- static getSortForTrueFn<T>(
772
- checkFor: (a: T) => boolean
773
- ): (a: T, b: T) => DyFM_SortDirection {
774
- return (a: T, b: T): DyFM_SortDirection => this.sortForTrue<T>(a, b, checkFor);
775
- }
776
-
777
-
778
- /**
779
- * You might be use getSortForTrueFn instead for a shorter expression
780
- *
781
- * @param a
782
- * @param b
783
- * @param check
784
- * @returns
785
- *
786
- * @example
787
- * codes.sort((a,b) => sortForTrue(a,b,(c: Code) => c.haveImg));
788
- */
789
- static sortForTrue<T>(
790
- a: T,
791
- b: T,
792
- check: (a: T) => boolean
793
- ): DyFM_SortDirection {
794
- if (!check) {
795
- console.trace(
796
- DyFM_Log.addStyle('DyFM_Array.sortForTrue: Check is required', [ DyFM_LogStyle.red ])
797
- );
798
- return 0;
799
- }
800
-
801
- const isA = check(a);
802
-
803
- if (isA === check(b)) {
804
- return 0;
805
- } else if (isA) {
806
- return -1;
807
- } else {
808
- return 1;
809
- }
810
- }
811
- }
812
-
813
-
1
+
2
+ import { DyFM_LogStyle } from '../../_enums/log-style.enum';
3
+ import { DyFM_Paged } from '../../_models/interfaces/paged.interface';
4
+ import { DyFM_Log } from './log.util';
5
+
6
+ /**
7
+ * the return type of the sortForTrue function
8
+ */
9
+ export type DyFM_SortDirection = 0 | 1 | -1
10
+
11
+
12
+ export type DyFM_List = DyFM_Array;
13
+
14
+ export class DyFM_Array {
15
+
16
+ /**
17
+ * Asynchronously iterates over an array and applies a function to each element.
18
+ * @param list - The array to iterate over.
19
+ * @param func - The function to apply to each element.
20
+ * @returns A promise that resolves when all elements have been processed.
21
+ *
22
+ * @example
23
+ * ```ts
24
+ * const list: number[] = [ 1, 2, 3 ];
25
+ * await DyFM_Array.asyncForEach(list, async (element: number, index?: number, array?: number[]): Promise<void> => {
26
+ * console.log(element, index, array);
27
+ * });
28
+ * ```
29
+ */
30
+ static async asyncForEach<T>(
31
+ list: T[],
32
+ func: (element: T, index?: number, array?: T[]) => Promise<void>
33
+ ): Promise<void> {
34
+ if (!list) {
35
+ console.trace(
36
+ DyFM_Log.addStyle('DyFM_Array.asyncForEach: List is required', [ DyFM_LogStyle.red ])
37
+ );
38
+ return;
39
+ }
40
+
41
+ for (let i = 0; i < list.length; i++) {
42
+ await func(list[i], i, list);
43
+ }
44
+ }
45
+
46
+ /**
47
+ * Asynchronously iterates over an array and applies a function to each element, returning a single result.
48
+ * @param startData - The initial data to pass to the function.
49
+ * @param list - The array to iterate over.
50
+ * @param func - The function to apply to each element.
51
+ * @returns A promise that resolves to the final result.
52
+ *
53
+ * @example
54
+ * ```ts
55
+ * const list: number[] = [ 1, 2, 3 ];
56
+ * const result = await DyFM_Array.asyncForEachReturnToOne(0, list, async (element: number, dataCurrent: number, index?: number, array?: number[]): Promise<number> => {
57
+ * return dataCurrent + element;
58
+ * });
59
+ * ```
60
+ */
61
+ static async asyncForEachReturnToOne<T, K>(
62
+ startData: K,
63
+ list: T[],
64
+ func: (element: T, dataCurrent: K, index?: number, array?: T[]) => Promise<K>
65
+ ): Promise<K> {
66
+ if (!list) {
67
+ console.trace(
68
+ DyFM_Log.addStyle('DyFM_Array.asyncForEachReturnToOne: List is required', [ DyFM_LogStyle.red ])
69
+ );
70
+ return startData;
71
+ }
72
+
73
+ let result: K = startData;
74
+
75
+ for (let i = 0; i < list.length; i++) {
76
+ result = await func(list[i], result, i, list);
77
+ }
78
+
79
+ return result;
80
+ }
81
+
82
+ /**
83
+ * Asynchronously iterates over an array and applies a function to each element, returning an array of results.
84
+ * @param list - The array to iterate over.
85
+ * @param func - The function to apply to each element.
86
+ * @returns A promise that resolves to an array of results.
87
+ *
88
+ * @example
89
+ * ```ts
90
+ * const list: number[] = [ 1, 2, 3 ];
91
+ * const result = await DyFM_Array.asyncForEachReturnToAll(list, async (element: number, index?: number, array?: number[]): Promise<number> => {
92
+ * return element * 2;
93
+ * });
94
+ * ```
95
+ */
96
+ static async asyncForEachReturnToAll<T, K>(
97
+ list: T[],
98
+ func: (element: T, index?: number, array?: T[]) => Promise<K>
99
+ ): Promise<K[]> {
100
+ if (!list) {
101
+ console.trace(
102
+ DyFM_Log.addStyle('DyFM_Array.asyncForEachReturnToAll: List is required', [ DyFM_LogStyle.red ])
103
+ );
104
+ return [];
105
+ }
106
+
107
+ const resultList: K[] = [];
108
+
109
+ for (let i = 0; i < list.length; i++) {
110
+ resultList.push(await func(list[i], i, list));
111
+ }
112
+
113
+ return resultList;
114
+ }
115
+
116
+ /**
117
+ * Asynchronously iterates over an array and applies a function to each element, returning an array of results.
118
+ * @param list - The array to iterate over.
119
+ * @param func - The function to apply to each element.
120
+ * @returns A promise that resolves to an array of results.
121
+ *
122
+ * @example
123
+ * ```ts
124
+ * const list: number[] = [ 1, 2, 3 ];
125
+ * const result = await DyFM_Array.asyncForEachAllAtOnce(list, async (element: number, index?: number, array?: number[]): Promise<number> => {
126
+ * return [ element * 2, element * 3 ];
127
+ * });
128
+ * console.log(result); // [ [ 2, 3 ], [ 4, 6 ], [ 6, 9 ] ]
129
+ * ```
130
+ */
131
+ static async asyncForEachAllAtOnce<T, R>(
132
+ list: T[],
133
+ func: (element: T, index?: number, array?: T[]) => Promise<R>
134
+ ): Promise<R[]> {
135
+ if (!list) {
136
+ console.trace(
137
+ DyFM_Log.addStyle('DyFM_Array.asyncForEachAllAtOnce: List is required', [ DyFM_LogStyle.red ])
138
+ );
139
+ return [];
140
+ }
141
+
142
+ return await Promise.all(list.map(func));
143
+ }
144
+
145
+ /**
146
+ * Asynchronously filters an array based on a function.
147
+ * @param list - The array to filter.
148
+ * @param filterFunc - The function to apply to each element.
149
+ * @returns A promise that resolves to an array of results.
150
+ *
151
+ * @example
152
+ * ```ts
153
+ * const list: number[] = [ 1, 2, 3 ];
154
+ * const result = await DyFM_Array.asyncFilter(list, async (element: number, index?: number, array?: number[]): Promise<boolean> => {
155
+ * return element % 2 === 0;
156
+ * });
157
+ * console.log(result); // [ 2 ]
158
+ * ```
159
+ */
160
+ static async asyncFilter<T>(
161
+ list: T[],
162
+ filterFunc: (element: T, index?: number, array?: T[]) => Promise<boolean>
163
+ ): Promise<T[]> {
164
+ if (!list) {
165
+ console.trace(
166
+ DyFM_Log.addStyle('DyFM_Array.asyncFilter: List is required', [ DyFM_LogStyle.red ])
167
+ );
168
+ return [];
169
+ }
170
+
171
+ const resultList: T[] = [];
172
+
173
+ for (let i = 0; i < list.length; i++) {
174
+ if (await filterFunc(list[i], i, list)) {
175
+ resultList.push(list[i]);
176
+ }
177
+ }
178
+
179
+ return resultList;
180
+ }
181
+
182
+ /**
183
+ * Asynchronously maps an array based on a function.
184
+ * @param list - The array to map.
185
+ * @param mapFunc - The function to apply to each element.
186
+ * @returns A promise that resolves to an array of results.
187
+ *
188
+ * @example
189
+ * ```ts
190
+ * const list: number[] = [ 1, 2, 3 ];
191
+ * const result = await DyFM_Array.asyncMap(list, async (element: number, index?: number, array?: number[]): Promise<number> => {
192
+ * return element * 2;
193
+ * });
194
+ * console.log(result); // [ 2, 4, 6 ]
195
+ * ```
196
+ */
197
+ static async asyncMap<T, R>(
198
+ list: T[],
199
+ mapFunc: (element: T, index?: number, array?: T[]) => Promise<R>
200
+ ): Promise<R[]> {
201
+ if (!list) {
202
+ console.trace(
203
+ DyFM_Log.addStyle('DyFM_Array.asyncMap: List is required', [ DyFM_LogStyle.red ])
204
+ );
205
+ return [];
206
+ }
207
+
208
+ const resultList: R[] = [];
209
+
210
+ for (let i = 0; i < list.length; i++) {
211
+ resultList.push(await mapFunc(list[i], i, list));
212
+ }
213
+
214
+ return resultList;
215
+ }
216
+
217
+ /**
218
+ * Returns the last element of an array.
219
+ * @param array - The array to get the last element from.
220
+ * @returns The last element of the array, or null if the array is empty.
221
+ *
222
+ * @example
223
+ * ```ts
224
+ * const list: number[] = [ 1, 2, 3 ];
225
+ * const result = DyFM_Array.last(list);
226
+ * console.log(result); // 3
227
+ * ```
228
+ */
229
+ static last<T>(array: T[]): T | null {
230
+ if (!array) {
231
+ console.trace(
232
+ DyFM_Log.addStyle('DyFM_Array.last: Array is required', [ DyFM_LogStyle.red ])
233
+ );
234
+ return null;
235
+ }
236
+
237
+ return array.length ? array[array.length - 1] : null;
238
+ }
239
+
240
+ /**
241
+ * Returns true if the string is the last element of the array.
242
+ * @param string - The string to check.
243
+ * @param array - The array to check.
244
+ * @returns True if the string is the last element of the array, false otherwise.
245
+ *
246
+ * @example
247
+ * ```ts
248
+ * const list: number[] = [ 1, 2, 3 ];
249
+ * const result = DyFM_Array.isLast(3, list);
250
+ * console.log(result); // true
251
+ * ```
252
+ */
253
+ static isLast<T>(element: T, array: T[]): boolean {
254
+ if (!array) {
255
+ console.trace(
256
+ DyFM_Log.addStyle('DyFM_Array.isLast: Array is required', [ DyFM_LogStyle.red ])
257
+ );
258
+ return false;
259
+ }
260
+
261
+ return array.indexOf(element) === array.length - 1;
262
+ }
263
+
264
+ /**
265
+ * Returns true if the string is the last element of the array.
266
+ * @param string - The string to check.
267
+ * @param array - The array to check.
268
+ * @returns True if the string is the last element of the array, false otherwise.
269
+ *
270
+ * @example
271
+ * ```ts
272
+ * const list: number[] = [ 1, 2, 3 ];
273
+ * const result = DyFM_Array.isLastIndex(2, list);
274
+ * console.log(result); // true
275
+ * ```
276
+ */
277
+ static isLastIndex<T>(index: number, array: T[]): boolean {
278
+ if (!array) {
279
+ console.trace(
280
+ DyFM_Log.addStyle('DyFM_Array.isLastIndex: Array is required', [ DyFM_LogStyle.red ])
281
+ );
282
+ return false;
283
+ }
284
+
285
+ return index === array.length - 1;
286
+ }
287
+
288
+ /**
289
+ * Returns true if the string is the first element of the array.
290
+ * @param string - The string to check.
291
+ * @param array - The array to check.
292
+ * @returns True if the string is the first element of the array, false otherwise.
293
+ *
294
+ * @example
295
+ * ```ts
296
+ * const list: number[] = [ 1, 2, 3 ];
297
+ * const result = DyFM_Array.isFirst(1, list);
298
+ * console.log(result); // true
299
+ * ```
300
+ */
301
+ static isFirst<T>(element: T, array: T[]): boolean {
302
+ if (!array) {
303
+ console.trace(
304
+ DyFM_Log.addStyle('DyFM_Array.isFirst: Array is required', [ DyFM_LogStyle.red ])
305
+ );
306
+ return false;
307
+ }
308
+
309
+ return array.indexOf(element) === 0;
310
+ }
311
+
312
+ /**
313
+ * Returns the last character of a string.
314
+ * @param string - The string to get the last character from.
315
+ * @returns The last character of the string, or null if the string is empty.
316
+ *
317
+ * @example
318
+ * ```ts
319
+ * const string = 'hello';
320
+ * const result = DyFM_Array.lastCharacter(string);
321
+ * console.log(result); // 'o'
322
+ * ```
323
+ */
324
+ static lastCharacter(string: string): string | null {
325
+ if (!string) {
326
+ console.trace(
327
+ DyFM_Log.addStyle('DyFM_Array.lastCharacter: String is required', [ DyFM_LogStyle.red ])
328
+ );
329
+ return null;
330
+ }
331
+
332
+ return string.length ? string[string.length - 1] : null;
333
+ }
334
+
335
+ /**
336
+ * Returns the first element of an array.
337
+ * @param array - The array to get the first element from.
338
+ * @returns The first element of the array, or null if the array is empty.
339
+ *
340
+ * @example
341
+ * ```ts
342
+ * const list: number[] = [ 1, 2, 3 ];
343
+ * const result = DyFM_Array.first(list);
344
+ * console.log(result); // 1
345
+ * ```
346
+ */
347
+ static first<T>(array: T[]): T | null {
348
+ if (!array) {
349
+ console.trace(
350
+ DyFM_Log.addStyle('DyFM_Array.first: Array is required', [ DyFM_LogStyle.red ])
351
+ );
352
+ return null;
353
+ }
354
+
355
+ return array.length ? array[0] : null;
356
+ }
357
+
358
+ /**
359
+ * Removes an element from an array.
360
+ * @param array - The array to remove the element from.
361
+ * @param element - The element to remove from the array.
362
+ * @returns The array with the element removed.
363
+ *
364
+ * @example
365
+ * ```ts
366
+ * const list: number[] = [ 1, 2, 3 ];
367
+ * const result = DyFM_Array.remove(list, 2);
368
+ * console.log(result); // [ 1, 3 ]
369
+ * ```
370
+ */
371
+ static remove<T>(array: T[], element: T): T[] {
372
+ if (!array) {
373
+ console.trace(
374
+ DyFM_Log.addStyle('DyFM_Array.remove: Array is required', [ DyFM_LogStyle.red ])
375
+ );
376
+ return [];
377
+ }
378
+
379
+ const index = array.indexOf(element);
380
+
381
+ if (-1 < index) {
382
+ array.splice(index, 1);
383
+ }
384
+
385
+ return array;
386
+ }
387
+
388
+ /**
389
+ * Finds an element in an array and removes it.
390
+ * @param array - The array to find and remove the element from.
391
+ * @param func - The function to apply to each element.
392
+ * @returns The array with the element removed.
393
+ *
394
+ * @example
395
+ * ```ts
396
+ * const list: number[] = [ 1, 2, 3 ];
397
+ * const result = DyFM_Array.findNRemove(list, (element: number, index?: number, array?: number[]): boolean => {
398
+ * return element === 2;
399
+ * });
400
+ * console.log(result); // [ 1, 3 ]
401
+ * ```
402
+ */
403
+ static findNRemove<T>(
404
+ array: T[],
405
+ func: (element: T, index?: number, array?: T[]) => boolean
406
+ ): T[] {
407
+ if (!array) {
408
+ console.trace(
409
+ DyFM_Log.addStyle('DyFM_Array.findNRemove: Array is required', [ DyFM_LogStyle.red ])
410
+ );
411
+ return [];
412
+ }
413
+
414
+ const index = array.findIndex(func);
415
+
416
+ if (-1 < index) {
417
+ array.splice(index, 1);
418
+ }
419
+
420
+ return array;
421
+ }
422
+
423
+ /**
424
+ * Shuffles an array.
425
+ * @param array - The array to shuffle.
426
+ * @returns The shuffled array.
427
+ *
428
+ * @example
429
+ * ```ts
430
+ * const list: number[] = [ 1, 2, 3 ];
431
+ * const result = DyFM_Array.shuffle(list);
432
+ * console.log(result); // [ 3, 1, 2 ]
433
+ * ```
434
+ */
435
+ static shuffle<T>(array: T[]): T[] {
436
+ if (!array) {
437
+ console.trace(
438
+ DyFM_Log.addStyle('DyFM_Array.shuffle: Array is required', [ DyFM_LogStyle.red ])
439
+ );
440
+ return [];
441
+ }
442
+
443
+ let currentIndex = array.length;
444
+ let randomIndex: number;
445
+
446
+ while (0 < currentIndex) {
447
+ currentIndex--;
448
+
449
+ randomIndex = Math.floor(Math.random() * (array.length - 1));
450
+ this.swap(array, currentIndex, randomIndex);
451
+ }
452
+
453
+ return array;
454
+ }
455
+
456
+ /**
457
+ * Pages an array.
458
+ * @param array - The array to page.
459
+ * @param pageIndex - The index of the page to return.
460
+ * @param pageSize - The size of the page.
461
+ * @returns The page of the array.
462
+ *
463
+ * @example
464
+ * ```ts
465
+ * const list: number[] = [ 1, 2, 3, 4, 5, 6, 7, 8 ];
466
+ * const result = DyFM_Array.page(list, 0, 2);
467
+ * console.log(result); // [ 1, 2 ]
468
+ * ```
469
+ */
470
+ static page<T>(array: T[], pageIndex: number, pageSize: number): T[] {
471
+ if (!array) {
472
+ console.trace(
473
+ DyFM_Log.addStyle('DyFM_Array.page: Array is required', [ DyFM_LogStyle.red ])
474
+ );
475
+ return [];
476
+ }
477
+
478
+ return array.slice(pageIndex * pageSize, (pageIndex + 1) * pageSize);
479
+ }
480
+
481
+ /**
482
+ * Pages an array.
483
+ * @param array - The array to page.
484
+ * @param pageIndex - The index of the page to return.
485
+ * @param pageSize - The size of the page.
486
+ * @returns The page of the array.
487
+ *
488
+ * @example
489
+ * ```ts
490
+ * const list: number[] = [ 1, 2, 3, 4, 5, 6, 7, 8 ];
491
+ * const result = DyFM_Array.paged(list, 0, 2);
492
+ * console.log(result); // { pageIndex: 0, pageSize: 2, total: 8, totalPageCount: 4, items: [ 1, 2 ] }
493
+ * ```
494
+ */
495
+ static paged<T>(array: T[], pageIndex: number, pageSize: number): DyFM_Paged<T> {
496
+ if (!array) {
497
+ console.trace(
498
+ DyFM_Log.addStyle('DyFM_Array.paged: Array is required', [ DyFM_LogStyle.red ])
499
+ );
500
+ return {
501
+ pageIndex: 0,
502
+ pageSize: 0,
503
+ total: 0,
504
+ totalPageCount: 0,
505
+ items: [],
506
+ };
507
+ }
508
+
509
+ return {
510
+ pageIndex,
511
+ pageSize,
512
+ total: array.length,
513
+ totalPageCount: Math.ceil(array.length / pageSize),
514
+ items: this.page(array, pageIndex, pageSize),
515
+ };
516
+ }
517
+
518
+ /**
519
+ * Swaps two elements in an array.
520
+ * @param array - The array to swap the elements in.
521
+ * @param indexA - The index of the first element to swap.
522
+ * @param indexB - The index of the second element to swap.
523
+ * @returns The array with the elements swapped.
524
+ *
525
+ * @example
526
+ * ```ts
527
+ * const list: number[] = [ 1, 2, 3 ];
528
+ * const result = DyFM_Array.swap(list, 0, 2);
529
+ * console.log(result); // [ 3, 2, 1 ]
530
+ * ```
531
+ */
532
+ static swap<T>(array: T[], indexA: number, indexB: number): T[] {
533
+ if (!array) {
534
+ console.trace(
535
+ DyFM_Log.addStyle('DyFM_Array.swap: Array is required', [ DyFM_LogStyle.red ])
536
+ );
537
+ return [];
538
+ }
539
+
540
+ [ array[indexA], array[indexB] ] = [ array[indexB], array[indexA] ];
541
+
542
+ return array;
543
+ }
544
+
545
+ /**
546
+ * Checks if a string list has multiplications.
547
+ * @param stringList - The string list to check.
548
+ * @returns True if the string list has multiplications, false otherwise.
549
+ *
550
+ * @example
551
+ * ```ts
552
+ * const list: string[] = [ 'a', 'b', 'c', 'a' ];
553
+ * const result = DyFM_Array.stringListHasMultiplications(list);
554
+ * console.log(result); // true
555
+ * ```
556
+ */
557
+ static stringListHasMultiplications(stringList: string[]): boolean {
558
+ if (!stringList) {
559
+ console.trace(
560
+ DyFM_Log.addStyle('DyFM_Array.stringListHasMultiplications: String list is required', [ DyFM_LogStyle.red ])
561
+ );
562
+ return false;
563
+ }
564
+
565
+ return stringList.some((str: string, index: number): boolean => {
566
+ return stringList.findIndex((strItem: string): boolean => strItem === str) !== index;
567
+ });
568
+ }
569
+
570
+ /**
571
+ * Filters a string list to remove multiplications.
572
+ * @param stringList - The string list to filter.
573
+ * @returns The filtered string list.
574
+ *
575
+ * @example
576
+ * ```ts
577
+ * const list: string[] = [ 'a', 'b', 'c', 'a' ];
578
+ * const result = DyFM_Array.filterStringMultiplications(list);
579
+ * console.log(result); // [ 'a', 'b', 'c' ]
580
+ * ```
581
+ */
582
+ static filterStringMultiplications(stringList: string[]): string[] {
583
+ if (!stringList) {
584
+ console.trace(
585
+ DyFM_Log.addStyle('DyFM_Array.filterStringMultiplications: String list is required', [ DyFM_LogStyle.red ])
586
+ );
587
+ return [];
588
+ }
589
+
590
+ return stringList.filter((str: string, index: number): boolean => {
591
+ return stringList.findIndex((strItem: string): boolean => strItem === str) !== index;
592
+ });
593
+ }
594
+
595
+ /**
596
+ * Gathers multiplications from a string list.
597
+ * @param stringList - The string list to gather multiplications from.
598
+ * @returns The gathered multiplications.
599
+ *
600
+ * @example
601
+ * ```ts
602
+ * const list: string[] = [ 'a', 'b', 'c', 'a' ];
603
+ * const result = DyFM_Array.gatherStringMultiplications(list);
604
+ * console.log(result); // [ [ 'a', 'a' ] ]
605
+ * ```
606
+ */
607
+ static gatherStringMultiplications(stringList: string[]): string[][] {
608
+ if (!stringList) {
609
+ console.trace(
610
+ DyFM_Log.addStyle('DyFM_Array.gatherStringMultiplications: String list is required', [ DyFM_LogStyle.red ])
611
+ );
612
+ return [];
613
+ }
614
+
615
+ const multiplications: string[][] = [];
616
+
617
+ stringList.forEach((str: string, index: number): void => {
618
+ if (multiplications.find(
619
+ (multiplication: string[]): boolean => multiplication.includes(str))
620
+ ) {
621
+ return;
622
+ }
623
+
624
+ const sameStrings = stringList.filter((strItem: string): boolean => strItem === str);
625
+
626
+ if (sameStrings.length > 1) {
627
+ multiplications.push(sameStrings);
628
+ }
629
+ });
630
+
631
+ return multiplications;
632
+ }
633
+
634
+ /**
635
+ * Checks if a data list has multiplications.
636
+ * @param dataList - The data list to check.
637
+ * @param byKey - The key to check for multiplications.
638
+ * @returns True if the data list has multiplications, false otherwise.
639
+ *
640
+ * @example
641
+ * ```ts
642
+ * const list: { _id: number, name: string }[] = [ { _id: 1, name: 'John' }, { _id: 2, name: 'Jane' }, { _id: 1, name: 'Bob' } ];
643
+ * const result = DyFM_Array.haveMultiplications(list, '_id');
644
+ * console.log(result); // true
645
+ * ```
646
+ */
647
+ static haveMultiplications<T extends object>(dataList: T[], byKey: keyof T = '_id' as keyof T): boolean {
648
+ if (!dataList) {
649
+ console.trace(
650
+ DyFM_Log.addStyle('DyFM_Array.haveMultiplications: Data list is required', [ DyFM_LogStyle.red ])
651
+ );
652
+ return false;
653
+ }
654
+
655
+ return dataList.some((data: T, index: number): boolean => {
656
+ return dataList.findIndex(
657
+ (listItem: T): boolean => listItem[byKey] === data[byKey]
658
+ ) !== index;
659
+ });
660
+ }
661
+
662
+ /**
663
+ * Filters a data list to remove multiplications.
664
+ * @param dataList - The data list to filter.
665
+ * @param byKey - The key to filter for multiplications.
666
+ * @returns The filtered data list.
667
+ *
668
+ * @example
669
+ * ```ts
670
+ * const list: { _id: number, name: string }[] = [ { _id: 1, name: 'John' }, { _id: 2, name: 'Jane' }, { _id: 1, name: 'Bob' } ];
671
+ * const result = DyFM_Array.filterMultiplications(list, '_id');
672
+ * console.log(result); // [ { _id: 1, name: 'John' } , { _id: 2, name: 'Jane' } ]
673
+ * ```
674
+ */
675
+ static filterMultiplications<T extends object>(dataList: T[], byKey: keyof T = '_id' as keyof T): T[] {
676
+ if (!dataList) {
677
+ console.trace(
678
+ DyFM_Log.addStyle('DyFM_Array.filterMultiplications: Data list is required', [ DyFM_LogStyle.red ])
679
+ );
680
+ return [];
681
+ }
682
+
683
+ return dataList.filter((data: T, index: number): boolean => {
684
+ return dataList.findIndex(
685
+ (listItem: T): boolean => listItem[byKey] === data[byKey]
686
+ ) !== index;
687
+ });
688
+ }
689
+
690
+ /**
691
+ * Gathers multiplications from a data list.
692
+ * @param dataList - The data list to gather multiplications from.
693
+ * @param byKey - The key to gather multiplications from.
694
+ * @returns The gathered multiplications.
695
+ *
696
+ * @example
697
+ * ```ts
698
+ * const list: { _id: number, name: string }[] = [ { _id: 1, name: 'John' }, { _id: 2, name: 'Jane' }, { _id: 1, name: 'Bob' } ];
699
+ * const result = DyFM_Array.gatherMultiplications(list, '_id');
700
+ * console.log(result); // [ [ { _id: 1, name: 'John' }, { _id: 1, name: 'Bob' } ] ]
701
+ * ```
702
+ */
703
+ static gatherMultiplications<T extends object>(dataList: T[], byKey: keyof T = '_id' as keyof T): T[][] {
704
+ if (!dataList) {
705
+ console.trace(
706
+ DyFM_Log.addStyle('DyFM_Array.gatherMultiplications: Data list is required', [ DyFM_LogStyle.red ])
707
+ );
708
+ return [];
709
+ }
710
+
711
+ const multiplications: T[][] = [];
712
+
713
+ dataList.forEach((data: T, index: number): void => {
714
+ if (multiplications.find((multiplication: T[]): boolean => multiplication.includes(data))) {
715
+ return;
716
+ }
717
+
718
+ const sameData = dataList.filter((listItem: T): boolean => listItem[byKey] === data[byKey]);
719
+
720
+ if (sameData.length > 1) {
721
+ multiplications.push(sameData);
722
+ }
723
+ });
724
+
725
+ return multiplications;
726
+ }
727
+
728
+ /**
729
+ * Finds an element in an array from the end.
730
+ * @param array - The array to find the element in.
731
+ * @param func - The function to apply to each element.
732
+ * @returns The element found, or null if no element is found.
733
+ *
734
+ * @example
735
+ * ```ts
736
+ * const list: number[] = [ 1, 2, 3 ];
737
+ * const result = DyFM_Array.findFromEnd(list, (element: number, index?: number, array?: number[]): boolean => {
738
+ * return element === 2;
739
+ * });
740
+ * console.log(result); // 2
741
+ * ```
742
+ */
743
+ static findFromEnd<T>(
744
+ array: T[],
745
+ func: (element: T, index?: number,
746
+ array?: T[]) => boolean
747
+ ): T | null {
748
+ if (!array) {
749
+ console.trace(
750
+ DyFM_Log.addStyle('DyFM_Array.findFromEnd: Array is required', [ DyFM_LogStyle.red ])
751
+ );
752
+ return null;
753
+ }
754
+
755
+ for (let i = array.length - 1; i >= 0; i--) {
756
+ if (func(array[i], i, array)) {
757
+ return array[i];
758
+ }
759
+ }
760
+
761
+ return null;
762
+ }
763
+
764
+ /**
765
+ * returns a function that can be used to sort an array of objects
766
+ * sorts so that the objects that have the value true for the checkFor function are at the beginning of the array
767
+ * @param checkFor
768
+ * @returns
769
+ *
770
+ */
771
+ static getSortForTrueFn<T>(
772
+ checkFor: (a: T) => boolean
773
+ ): (a: T, b: T) => DyFM_SortDirection {
774
+ return (a: T, b: T): DyFM_SortDirection => this.sortForTrue<T>(a, b, checkFor);
775
+ }
776
+
777
+
778
+ /**
779
+ * You might be use getSortForTrueFn instead for a shorter expression
780
+ *
781
+ * @param a
782
+ * @param b
783
+ * @param check
784
+ * @returns
785
+ *
786
+ * @example
787
+ * codes.sort((a,b) => sortForTrue(a,b,(c: Code) => c.haveImg));
788
+ */
789
+ static sortForTrue<T>(
790
+ a: T,
791
+ b: T,
792
+ check: (a: T) => boolean
793
+ ): DyFM_SortDirection {
794
+ if (!check) {
795
+ console.trace(
796
+ DyFM_Log.addStyle('DyFM_Array.sortForTrue: Check is required', [ DyFM_LogStyle.red ])
797
+ );
798
+ return 0;
799
+ }
800
+
801
+ const isA = check(a);
802
+
803
+ if (isA === check(b)) {
804
+ return 0;
805
+ } else if (isA) {
806
+ return -1;
807
+ } else {
808
+ return 1;
809
+ }
810
+ }
811
+ }
812
+
813
+