@futdevpro/fsm-dynamo 1.15.18 → 1.15.21

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 (534) 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-dc-rev-fsm-results.json +17445 -0
  19. package/__documentations/2026-06-01-fr047-fc-foundation.md +48 -0
  20. package/__documentations/2026-06-01-fr047-fr048-code-review-findings.json +159 -0
  21. package/__documentations/2026-06-01-fr047-fr048-code-review.md +153 -0
  22. package/_review_tmp/r.json +17445 -0
  23. package/build/_enums/error-level.enum.d.ts +14 -1
  24. package/build/_enums/error-level.enum.d.ts.map +1 -1
  25. package/build/_enums/error-level.enum.js +13 -0
  26. package/build/_enums/error-level.enum.js.map +1 -1
  27. package/build/_models/data-models/errors.data-model.d.ts +51 -0
  28. package/build/_models/data-models/errors.data-model.d.ts.map +1 -1
  29. package/build/_models/data-models/errors.data-model.js +39 -0
  30. package/build/_models/data-models/errors.data-model.js.map +1 -1
  31. package/build/_modules/socket/_models/sck-socket-event.control-model.js +1 -1
  32. package/eslint.config.js +4 -4
  33. package/nodemon.json +22 -22
  34. package/package.json +11 -11
  35. package/scripts/crypto/CRYPTO-STABILITY-SOLUTION.md +196 -196
  36. package/scripts/crypto/README.md +113 -113
  37. package/scripts/crypto/demo-crypto-stability.js +120 -120
  38. package/scripts/crypto/stress-test-crypto.js +379 -379
  39. package/scripts/run-coverage-tests.js +24 -24
  40. package/spec/support/helpers/ts-node-helper.js +9 -9
  41. package/spec/support/jasmine.coverage.json +23 -23
  42. package/spec/support/jasmine.json +24 -24
  43. package/src/_collections/constants/data-sizes.const.ts +40 -40
  44. package/src/_collections/constants/error-defaults.const.ts +20 -20
  45. package/src/_collections/constants/global-settings.const.ts +24 -24
  46. package/src/_collections/constants/numbers.const.ts +40 -40
  47. package/src/_collections/constants/times.const.ts +45 -45
  48. package/src/_collections/utils/array.util.spec.ts +306 -306
  49. package/src/_collections/utils/array.util.ts +813 -813
  50. package/src/_collections/utils/async.util.spec.ts +354 -354
  51. package/src/_collections/utils/async.util.ts +197 -197
  52. package/src/_collections/utils/data.util.spec.ts +345 -345
  53. package/src/_collections/utils/data.util.ts +226 -226
  54. package/src/_collections/utils/json-error-helper.util.spec.ts +521 -521
  55. package/src/_collections/utils/json-error-helper.util.ts +301 -301
  56. package/src/_collections/utils/log.util.spec.ts +975 -975
  57. package/src/_collections/utils/log.util.ts +665 -665
  58. package/src/_collections/utils/math/box-bounds.spec.ts +73 -73
  59. package/src/_collections/utils/math/box-bounds.util.ts +183 -183
  60. package/src/_collections/utils/math/math.util.spec.ts +94 -94
  61. package/src/_collections/utils/math/math.util.ts +141 -141
  62. package/src/_collections/utils/math/random.util.spec.ts +82 -82
  63. package/src/_collections/utils/math/random.util.ts +139 -139
  64. package/src/_collections/utils/math/trigonometry.util.spec.ts +57 -57
  65. package/src/_collections/utils/math/trigonometry.util.ts +102 -102
  66. package/src/_collections/utils/math/vector2.util.spec.ts +94 -94
  67. package/src/_collections/utils/math/vector2.util.ts +653 -653
  68. package/src/_collections/utils/object.util.spec.ts +646 -646
  69. package/src/_collections/utils/regex/password-regex.util.spec.ts +51 -51
  70. package/src/_collections/utils/regex/password-regex.util.ts +65 -65
  71. package/src/_collections/utils/regex/regex.util.spec.ts +42 -42
  72. package/src/_collections/utils/regex/regex.util.ts +6 -6
  73. package/src/_collections/utils/regex/username-regex.util.spec.ts +61 -61
  74. package/src/_collections/utils/regex/username-regex.util.ts +35 -35
  75. package/src/_collections/utils/round-list.util.spec.ts +79 -79
  76. package/src/_collections/utils/round-list.util.ts +162 -162
  77. package/src/_collections/utils/stack.util.spec.ts +372 -372
  78. package/src/_collections/utils/stack.util.ts +164 -164
  79. package/src/_collections/utils/string-case.util.spec.ts +441 -441
  80. package/src/_collections/utils/string-case.util.ts +362 -362
  81. package/src/_collections/utils/string.util.spec.ts +975 -975
  82. package/src/_collections/utils/string.util.ts +449 -449
  83. package/src/_collections/utils/time.util.spec.ts +50 -50
  84. package/src/_collections/utils/time.util.ts +481 -481
  85. package/src/_collections/utils/type-cloning-facility.util.spec.ts +51 -51
  86. package/src/_collections/utils/type-cloning-facility.util.ts +168 -168
  87. package/src/_collections/utils/utilities.util.spec.ts +201 -201
  88. package/src/_collections/utils/utilities.util.ts +68 -68
  89. package/src/_collections/utils/uuid.util.spec.ts +30 -30
  90. package/src/_collections/utils/uuid.util.ts +50 -50
  91. package/src/_enums/basic-property-type.enum.ts +20 -20
  92. package/src/_enums/data-model-type.enum.ts +29 -29
  93. package/src/_enums/environment-flag.enum.ts +28 -28
  94. package/src/_enums/error-level.enum.ts +43 -28
  95. package/src/_enums/http/http-call-type.enum.ts +43 -43
  96. package/src/_enums/http/http-event-type.enum.ts +40 -40
  97. package/src/_enums/http/http-response-type.enum.ts +18 -18
  98. package/src/_enums/log-style.enum.ts +44 -44
  99. package/src/_enums/server-connection-status.enum.ts +6 -6
  100. package/src/_enums/time/day-of-week.enum.ts +55 -55
  101. package/src/_enums/time/month.enum.ts +25 -25
  102. package/src/_enums/time/relative-date.enum.ts +24 -24
  103. package/src/_models/control-models/data-model-params.control-model.spec.ts +85 -85
  104. package/src/_models/control-models/data-model-params.control-model.ts +300 -300
  105. package/src/_models/control-models/data-property-params.control-model.spec.ts +93 -93
  106. package/src/_models/control-models/data-property-params.control-model.ts +201 -201
  107. package/src/_models/control-models/error.control-model.spec.ts +912 -912
  108. package/src/_models/control-models/error.control-model.ts +1215 -1215
  109. package/src/_models/control-models/http/http-error-response.control-model.spec.ts +116 -116
  110. package/src/_models/control-models/http/http-error-response.control-model.ts +52 -52
  111. package/src/_models/control-models/http/http-headers.control-model.spec.ts +25 -25
  112. package/src/_models/control-models/http/http-headers.control-model.ts +124 -124
  113. package/src/_models/control-models/http/http-response.model-base.spec.ts +46 -46
  114. package/src/_models/control-models/http/http-response.model-base.ts +57 -57
  115. package/src/_models/control-models/poll.control-model.spec.ts +63 -63
  116. package/src/_models/control-models/poll.control-model.ts +151 -151
  117. package/src/_models/control-models/range-value.control-model.spec.ts +187 -187
  118. package/src/_models/control-models/range-value.control-model.ts +289 -289
  119. package/src/_models/control-models/server-status.control-model.spec.ts +66 -66
  120. package/src/_models/control-models/server-status.control-model.ts +85 -85
  121. package/src/_models/control-models/service-endpoint-settings-base.control-model.spec.ts +145 -145
  122. package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +186 -186
  123. package/src/_models/data-models/errors.data-model.spec.ts +71 -71
  124. package/src/_models/data-models/errors.data-model.ts +158 -91
  125. package/src/_models/data-models/metadata.data-model.spec.ts +184 -184
  126. package/src/_models/data-models/metadata.data-model.ts +128 -128
  127. package/src/_models/interfaces/box-bounds.interface.ts +7 -7
  128. package/src/_models/interfaces/environment/global-log-settings.interface.ts +86 -86
  129. package/src/_models/interfaces/environment/global-settings.interface.ts +47 -47
  130. package/src/_models/interfaces/error-defaults.interface.ts +11 -11
  131. package/src/_models/interfaces/paged.interface.ts +12 -12
  132. package/src/_models/interfaces/random-weight.interface.ts +7 -7
  133. package/src/_models/interfaces/route-settings.interface.ts +15 -15
  134. package/src/_models/interfaces/search-query.interface.ts +23 -23
  135. package/src/_models/interfaces/search-result.interface.ts +5 -5
  136. package/src/_models/interfaces/server-error-statistics.interface.ts +24 -24
  137. package/src/_models/interfaces/vector2.interface.ts +20 -20
  138. package/src/_models/types/db-filter.type.ts +110 -110
  139. package/src/_models/types/db-sort.type.ts +4 -4
  140. package/src/_models/types/ds-filter.type.ts +68 -68
  141. package/src/_models/types/ds-sort.type.ts +21 -21
  142. package/src/_modules/ai/_collections/ai-model-ref.util.ts +88 -88
  143. package/src/_modules/ai/_collections/ai-model-registry.util.spec.ts +37 -37
  144. package/src/_modules/ai/_collections/ai-model-registry.util.ts +30 -30
  145. package/src/_modules/ai/_enums/ai-message-role.enum.ts +7 -7
  146. package/src/_modules/ai/_enums/ai-model-type.enum.ts +7 -7
  147. package/src/_modules/ai/_enums/ai-provider.enum.ts +7 -7
  148. package/src/_modules/ai/_models/ai-call-settings.interface.ts +84 -84
  149. package/src/_modules/ai/_models/ai-embedding-request.interface.ts +20 -20
  150. package/src/_modules/ai/_models/ai-embedding-response.interface.ts +26 -26
  151. package/src/_modules/ai/_models/ai-llm-request.interface.ts +24 -24
  152. package/src/_modules/ai/_models/ai-llm-response.interface.ts +30 -30
  153. package/src/_modules/ai/_models/ai-message.interface.ts +12 -12
  154. package/src/_modules/ai/_models/ai-model-capabilities.interface.ts +35 -35
  155. package/src/_modules/ai/_models/ai-model-info.interface.ts +63 -63
  156. package/src/_modules/ai/_models/ai-model-settings-schema.interface.ts +52 -52
  157. package/src/_modules/ai/_models/ai-provider-capabilities.interface.ts +28 -28
  158. package/src/_modules/ai/_models/ai-settings.interface.ts +17 -17
  159. package/src/_modules/ai/_models/ai-tool-call.interface.ts +18 -18
  160. package/src/_modules/ai/_models/ai-tool-handler.type.ts +11 -11
  161. package/src/_modules/ai/_models/ai-tool-result.interface.ts +16 -16
  162. package/src/_modules/ai/_models/ai-tool.interface.ts +16 -16
  163. package/src/_modules/ai/_models/ai-user-provider-config.control-model.ts +29 -29
  164. package/src/_modules/ai/_modules/anthropic/_collections/aai-models.const.ts +81 -81
  165. package/src/_modules/ai/_modules/anthropic/_enums/aai-model.enum.ts +19 -19
  166. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.spec.ts +28 -28
  167. package/src/_modules/ai/_modules/anthropic/_models/aai-call-settings.control-model.ts +23 -23
  168. package/src/_modules/ai/_modules/anthropic/_models/aai-client-options.interface.ts +10 -10
  169. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.spec.ts +22 -22
  170. package/src/_modules/ai/_modules/anthropic/_models/aai-settings.control-model.ts +27 -27
  171. package/src/_modules/ai/_modules/anthropic/_models/aai-user-provider-config.control-model.ts +20 -20
  172. package/src/_modules/ai/_modules/anthropic/index.ts +14 -14
  173. package/src/_modules/ai/_modules/document-ai/_models/dai-embedding-info.interface.ts +12 -12
  174. package/src/_modules/ai/_modules/document-ai/_models/dai-vector-search-params.interface.ts +22 -22
  175. package/src/_modules/ai/_modules/document-ai/index.ts +4 -4
  176. package/src/_modules/ai/_modules/fdp-ai/_collections/fdpai-models.const.ts +34 -34
  177. package/src/_modules/ai/_modules/fdp-ai/_enums/fdpai-model.enum.ts +6 -6
  178. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-call-settings.control-model.ts +19 -19
  179. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-client-options.interface.ts +11 -11
  180. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-settings.control-model.ts +24 -24
  181. package/src/_modules/ai/_modules/fdp-ai/_models/fdpai-user-provider-config.control-model.ts +20 -20
  182. package/src/_modules/ai/_modules/fdp-ai/index.ts +11 -11
  183. package/src/_modules/ai/_modules/google-ai/_collections/gai-models.const.ts +99 -99
  184. package/src/_modules/ai/_modules/google-ai/_enums/gai-model.enum.ts +16 -16
  185. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.spec.ts +28 -28
  186. package/src/_modules/ai/_modules/google-ai/_models/gai-call-settings.control-model.ts +21 -21
  187. package/src/_modules/ai/_modules/google-ai/_models/gai-client-options.interface.ts +8 -8
  188. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.spec.ts +22 -22
  189. package/src/_modules/ai/_modules/google-ai/_models/gai-settings.control-model.ts +25 -25
  190. package/src/_modules/ai/_modules/google-ai/_models/gai-user-provider-config.control-model.ts +20 -20
  191. package/src/_modules/ai/_modules/google-ai/index.ts +14 -14
  192. package/src/_modules/ai/_modules/local-ai/_collections/lai-models.const.ts +53 -53
  193. package/src/_modules/ai/_modules/local-ai/_enums/lai-model.enum.ts +6 -6
  194. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.spec.ts +28 -28
  195. package/src/_modules/ai/_modules/local-ai/_models/lai-call-settings.control-model.ts +18 -18
  196. package/src/_modules/ai/_modules/local-ai/_models/lai-client-options.interface.ts +9 -9
  197. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.spec.ts +22 -22
  198. package/src/_modules/ai/_modules/local-ai/_models/lai-settings.control-model.ts +23 -23
  199. package/src/_modules/ai/_modules/local-ai/index.ts +14 -14
  200. package/src/_modules/ai/_modules/open-ai/_collections/oai-embedding-model-dimensions.const.ts +7 -7
  201. package/src/_modules/ai/_modules/open-ai/_collections/oai-models.const.ts +252 -252
  202. package/src/_modules/ai/_modules/open-ai/_enums/oai-model.enum.ts +179 -179
  203. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.spec.ts +28 -28
  204. package/src/_modules/ai/_modules/open-ai/_models/oai-call-settings.control-model.ts +21 -21
  205. package/src/_modules/ai/_modules/open-ai/_models/oai-client-options.interface.ts +81 -81
  206. package/src/_modules/ai/_modules/open-ai/_models/oai-embedding-info.interface.ts +13 -13
  207. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.spec.ts +22 -22
  208. package/src/_modules/ai/_modules/open-ai/_models/oai-settings.control-model.ts +25 -25
  209. package/src/_modules/ai/_modules/open-ai/_models/oai-user-provider-config.control-model.ts +21 -21
  210. package/src/_modules/ai/_modules/open-ai/index.ts +28 -28
  211. package/src/_modules/ai/index.ts +27 -27
  212. package/src/_modules/ci-tools/_enums/cit-ci-result-code.enum.ts +11 -11
  213. package/src/_modules/ci-tools/_enums/cit-ci-step-result-code.enum.ts +9 -9
  214. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.spec.ts +58 -58
  215. package/src/_modules/ci-tools/_models/cit-ci-result-info.data-models.ts +77 -77
  216. package/src/_modules/ci-tools/_models/cit-ci-step-result.interface.ts +12 -12
  217. package/src/_modules/ci-tools/index.ts +8 -8
  218. package/src/_modules/crypto/_collections/crypto.util.simple.spec.ts +512 -512
  219. package/src/_modules/crypto/index.ts +13 -13
  220. package/src/_modules/custom-data/_collections/cud-module-settings.const.ts +21 -21
  221. package/src/_modules/custom-data/_models/cud.data-model.spec.ts +38 -38
  222. package/src/_modules/custom-data/_models/cud.data-model.ts +39 -39
  223. package/src/_modules/custom-data/index.ts +10 -10
  224. package/src/_modules/data-handler/_models/data-handler-settings.control-model.spec.ts +110 -110
  225. package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -110
  226. package/src/_modules/data-handler/_models/data-handler.control-model.spec.ts +445 -445
  227. package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -459
  228. package/src/_modules/data-handler/_models/data-list-handler.control-model.spec.ts +263 -263
  229. package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +252 -252
  230. package/src/_modules/data-handler/_models/data-search-handler.control-model.spec.ts +417 -417
  231. package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -390
  232. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.spec.ts +374 -374
  233. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -274
  234. package/src/_modules/data-handler/index.ts +6 -6
  235. package/src/_modules/location/_collections/assets/country-codes-ISO-3166.json +3239 -3239
  236. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166-all-list.json +19035 -19035
  237. package/src/_modules/location/_collections/assets/country-divisions-ISO-3166.json +4993 -4993
  238. package/src/_modules/location/_collections/assets/country-phone-codes.json +1203 -1203
  239. package/src/_modules/location/_collections/assets/country-subdivisions/afghanistan.json +137 -137
  240. package/src/_modules/location/_collections/assets/country-subdivisions/albania.json +49 -49
  241. package/src/_modules/location/_collections/assets/country-subdivisions/algeria.json +193 -193
  242. package/src/_modules/location/_collections/assets/country-subdivisions/andorra.json +29 -29
  243. package/src/_modules/location/_collections/assets/country-subdivisions/angola.json +73 -73
  244. package/src/_modules/location/_collections/assets/country-subdivisions/antigua-and-barbuda.json +33 -33
  245. package/src/_modules/location/_collections/assets/country-subdivisions/argentina.json +97 -97
  246. package/src/_modules/location/_collections/assets/country-subdivisions/armenia.json +45 -45
  247. package/src/_modules/location/_collections/assets/country-subdivisions/australia.json +33 -33
  248. package/src/_modules/location/_collections/assets/country-subdivisions/austria.json +37 -37
  249. package/src/_modules/location/_collections/assets/country-subdivisions/azerbaijan.json +5 -5
  250. package/src/_modules/location/_collections/assets/country-subdivisions/bahamas.json +125 -125
  251. package/src/_modules/location/_collections/assets/country-subdivisions/bahrain.json +21 -21
  252. package/src/_modules/location/_collections/assets/country-subdivisions/bangladesh.json +29 -29
  253. package/src/_modules/location/_collections/assets/country-subdivisions/barbados.json +45 -45
  254. package/src/_modules/location/_collections/assets/country-subdivisions/belarus.json +29 -29
  255. package/src/_modules/location/_collections/assets/country-subdivisions/belgium.json +13 -13
  256. package/src/_modules/location/_collections/assets/country-subdivisions/belize.json +25 -25
  257. package/src/_modules/location/_collections/assets/country-subdivisions/benin.json +49 -49
  258. package/src/_modules/location/_collections/assets/country-subdivisions/bhutan.json +81 -81
  259. package/src/_modules/location/_collections/assets/country-subdivisions/bolivia.json +37 -37
  260. package/src/_modules/location/_collections/assets/country-subdivisions/bosnia-and-herzegovina.json +13 -13
  261. package/src/_modules/location/_collections/assets/country-subdivisions/botswana.json +65 -65
  262. package/src/_modules/location/_collections/assets/country-subdivisions/brazil.json +109 -109
  263. package/src/_modules/location/_collections/assets/country-subdivisions/brunei-darussalam.json +17 -17
  264. package/src/_modules/location/_collections/assets/country-subdivisions/bulgaria.json +113 -113
  265. package/src/_modules/location/_collections/assets/country-subdivisions/burkina-faso.json +53 -53
  266. package/src/_modules/location/_collections/assets/country-subdivisions/burundi.json +69 -69
  267. package/src/_modules/location/_collections/assets/country-subdivisions/cambodia.json +97 -97
  268. package/src/_modules/location/_collections/assets/country-subdivisions/cameroon.json +41 -41
  269. package/src/_modules/location/_collections/assets/country-subdivisions/canada.json +79 -79
  270. package/src/_modules/location/_collections/assets/country-subdivisions/cape-verde.json +9 -9
  271. package/src/_modules/location/_collections/assets/country-subdivisions/central-african-republic.json +69 -69
  272. package/src/_modules/location/_collections/assets/country-subdivisions/chad.json +89 -89
  273. package/src/_modules/location/_collections/assets/country-subdivisions/chile.json +61 -61
  274. package/src/_modules/location/_collections/assets/country-subdivisions/china.json +205 -205
  275. package/src/_modules/location/_collections/assets/country-subdivisions/colombia.json +133 -133
  276. package/src/_modules/location/_collections/assets/country-subdivisions/comoros.json +13 -13
  277. package/src/_modules/location/_collections/assets/country-subdivisions/congo-the-democratic-republic-of-the.json +45 -45
  278. package/src/_modules/location/_collections/assets/country-subdivisions/congo.json +49 -49
  279. package/src/_modules/location/_collections/assets/country-subdivisions/costa-rica.json +29 -29
  280. package/src/_modules/location/_collections/assets/country-subdivisions/cote-d-ivoire-republic-of.json +77 -77
  281. package/src/_modules/location/_collections/assets/country-subdivisions/croatia.json +85 -85
  282. package/src/_modules/location/_collections/assets/country-subdivisions/cuba.json +65 -65
  283. package/src/_modules/location/_collections/assets/country-subdivisions/cyprus.json +25 -25
  284. package/src/_modules/location/_collections/assets/country-subdivisions/czech-republic.json +57 -57
  285. package/src/_modules/location/_collections/assets/country-subdivisions/denmark.json +21 -21
  286. package/src/_modules/location/_collections/assets/country-subdivisions/djibouti.json +25 -25
  287. package/src/_modules/location/_collections/assets/country-subdivisions/dominica.json +41 -41
  288. package/src/_modules/location/_collections/assets/country-subdivisions/dominican-republic.json +41 -41
  289. package/src/_modules/location/_collections/assets/country-subdivisions/ecuador.json +97 -97
  290. package/src/_modules/location/_collections/assets/country-subdivisions/egypt.json +117 -117
  291. package/src/_modules/location/_collections/assets/country-subdivisions/el-salvador.json +57 -57
  292. package/src/_modules/location/_collections/assets/country-subdivisions/equatorial-guinea.json +9 -9
  293. package/src/_modules/location/_collections/assets/country-subdivisions/eritrea.json +25 -25
  294. package/src/_modules/location/_collections/assets/country-subdivisions/estonia.json +61 -61
  295. package/src/_modules/location/_collections/assets/country-subdivisions/ethiopia.json +45 -45
  296. package/src/_modules/location/_collections/assets/country-subdivisions/fiji.json +21 -21
  297. package/src/_modules/location/_collections/assets/country-subdivisions/finland.json +77 -77
  298. package/src/_modules/location/_collections/assets/country-subdivisions/france.json +133 -133
  299. package/src/_modules/location/_collections/assets/country-subdivisions/gabon.json +37 -37
  300. package/src/_modules/location/_collections/assets/country-subdivisions/gambia.json +25 -25
  301. package/src/_modules/location/_collections/assets/country-subdivisions/georgia.json +49 -49
  302. package/src/_modules/location/_collections/assets/country-subdivisions/germany.json +65 -65
  303. package/src/_modules/location/_collections/assets/country-subdivisions/ghana.json +41 -41
  304. package/src/_modules/location/_collections/assets/country-subdivisions/greece.json +53 -53
  305. package/src/_modules/location/_collections/assets/country-subdivisions/greenland.json +17 -17
  306. package/src/_modules/location/_collections/assets/country-subdivisions/grenada.json +29 -29
  307. package/src/_modules/location/_collections/assets/country-subdivisions/guatemala.json +89 -89
  308. package/src/_modules/location/_collections/assets/country-subdivisions/guinea-bissau.json +13 -13
  309. package/src/_modules/location/_collections/assets/country-subdivisions/guinea.json +33 -33
  310. package/src/_modules/location/_collections/assets/country-subdivisions/guyana.json +41 -41
  311. package/src/_modules/location/_collections/assets/country-subdivisions/haiti.json +41 -41
  312. package/src/_modules/location/_collections/assets/country-subdivisions/honduras.json +73 -73
  313. package/src/_modules/location/_collections/assets/country-subdivisions/hong-kong.json +4 -4
  314. package/src/_modules/location/_collections/assets/country-subdivisions/hungary.json +173 -173
  315. package/src/_modules/location/_collections/assets/country-subdivisions/iceland.json +37 -37
  316. package/src/_modules/location/_collections/assets/country-subdivisions/india.json +181 -181
  317. package/src/_modules/location/_collections/assets/country-subdivisions/indonesia.json +29 -29
  318. package/src/_modules/location/_collections/assets/country-subdivisions/iran-islamic-republic-of.json +125 -125
  319. package/src/_modules/location/_collections/assets/country-subdivisions/iraq.json +73 -73
  320. package/src/_modules/location/_collections/assets/country-subdivisions/ireland.json +17 -17
  321. package/src/_modules/location/_collections/assets/country-subdivisions/israel.json +25 -25
  322. package/src/_modules/location/_collections/assets/country-subdivisions/italy.json +81 -81
  323. package/src/_modules/location/_collections/assets/country-subdivisions/jamaica.json +57 -57
  324. package/src/_modules/location/_collections/assets/country-subdivisions/japan.json +189 -189
  325. package/src/_modules/location/_collections/assets/country-subdivisions/jordan.json +49 -49
  326. package/src/_modules/location/_collections/assets/country-subdivisions/kazakhstan.json +65 -65
  327. package/src/_modules/location/_collections/assets/country-subdivisions/kenya.json +33 -33
  328. package/src/_modules/location/_collections/assets/country-subdivisions/kiribati.json +13 -13
  329. package/src/_modules/location/_collections/assets/country-subdivisions/korea-democratic-people-s-republic-of.json +45 -45
  330. package/src/_modules/location/_collections/assets/country-subdivisions/korea-republic-of.json +69 -69
  331. package/src/_modules/location/_collections/assets/country-subdivisions/kuwait.json +25 -25
  332. package/src/_modules/location/_collections/assets/country-subdivisions/kyrgyzstan.json +33 -33
  333. package/src/_modules/location/_collections/assets/country-subdivisions/lao-people-s-democratic-republic.json +73 -73
  334. package/src/_modules/location/_collections/assets/country-subdivisions/latvia.json +477 -477
  335. package/src/_modules/location/_collections/assets/country-subdivisions/lebanon.json +33 -33
  336. package/src/_modules/location/_collections/assets/country-subdivisions/lesotho.json +41 -41
  337. package/src/_modules/location/_collections/assets/country-subdivisions/liberia.json +61 -61
  338. package/src/_modules/location/_collections/assets/country-subdivisions/libyan-arab-jamahiriya.json +89 -89
  339. package/src/_modules/location/_collections/assets/country-subdivisions/liechtenstein.json +45 -45
  340. package/src/_modules/location/_collections/assets/country-subdivisions/lithuania.json +41 -41
  341. package/src/_modules/location/_collections/assets/country-subdivisions/luxembourg.json +13 -13
  342. package/src/_modules/location/_collections/assets/country-subdivisions/macedonia-the-former-yugoslav-republic-of.json +337 -337
  343. package/src/_modules/location/_collections/assets/country-subdivisions/madagascar.json +25 -25
  344. package/src/_modules/location/_collections/assets/country-subdivisions/malawi.json +13 -13
  345. package/src/_modules/location/_collections/assets/country-subdivisions/malaysia.json +81 -81
  346. package/src/_modules/location/_collections/assets/country-subdivisions/maldives.json +33 -33
  347. package/src/_modules/location/_collections/assets/country-subdivisions/mali.json +37 -37
  348. package/src/_modules/location/_collections/assets/country-subdivisions/malta.json +273 -273
  349. package/src/_modules/location/_collections/assets/country-subdivisions/marshall-islands.json +9 -9
  350. package/src/_modules/location/_collections/assets/country-subdivisions/mauritania.json +53 -53
  351. package/src/_modules/location/_collections/assets/country-subdivisions/mauritius.json +69 -69
  352. package/src/_modules/location/_collections/assets/country-subdivisions/mexico.json +161 -161
  353. package/src/_modules/location/_collections/assets/country-subdivisions/micronesia-federated-states-of.json +17 -17
  354. package/src/_modules/location/_collections/assets/country-subdivisions/moldova-republic-of.json +149 -149
  355. package/src/_modules/location/_collections/assets/country-subdivisions/monaco.json +69 -69
  356. package/src/_modules/location/_collections/assets/country-subdivisions/mongolia.json +89 -89
  357. package/src/_modules/location/_collections/assets/country-subdivisions/montenegro.json +93 -93
  358. package/src/_modules/location/_collections/assets/country-subdivisions/morocco.json +65 -65
  359. package/src/_modules/location/_collections/assets/country-subdivisions/mozambique.json +45 -45
  360. package/src/_modules/location/_collections/assets/country-subdivisions/myanmar.json +57 -57
  361. package/src/_modules/location/_collections/assets/country-subdivisions/namibia.json +57 -57
  362. package/src/_modules/location/_collections/assets/country-subdivisions/nauru.json +57 -57
  363. package/src/_modules/location/_collections/assets/country-subdivisions/nepal.json +21 -21
  364. package/src/_modules/location/_collections/assets/country-subdivisions/netherlands.json +91 -91
  365. package/src/_modules/location/_collections/assets/country-subdivisions/new-zealand.json +111 -111
  366. package/src/_modules/location/_collections/assets/country-subdivisions/nicaragua.json +69 -69
  367. package/src/_modules/location/_collections/assets/country-subdivisions/niger.json +33 -33
  368. package/src/_modules/location/_collections/assets/country-subdivisions/nigeria.json +149 -149
  369. package/src/_modules/location/_collections/assets/country-subdivisions/norway.json +85 -85
  370. package/src/_modules/location/_collections/assets/country-subdivisions/oman.json +37 -37
  371. package/src/_modules/location/_collections/assets/country-subdivisions/pakistan.json +33 -33
  372. package/src/_modules/location/_collections/assets/country-subdivisions/palau.json +65 -65
  373. package/src/_modules/location/_collections/assets/country-subdivisions/palestinian-territory-occupied.json +65 -65
  374. package/src/_modules/location/_collections/assets/country-subdivisions/panama.json +53 -53
  375. package/src/_modules/location/_collections/assets/country-subdivisions/papua-new-guinea.json +81 -81
  376. package/src/_modules/location/_collections/assets/country-subdivisions/paraguay.json +73 -73
  377. package/src/_modules/location/_collections/assets/country-subdivisions/peru.json +105 -105
  378. package/src/_modules/location/_collections/assets/country-subdivisions/philippines.json +69 -69
  379. package/src/_modules/location/_collections/assets/country-subdivisions/poland.json +65 -65
  380. package/src/_modules/location/_collections/assets/country-subdivisions/portugal.json +81 -81
  381. package/src/_modules/location/_collections/assets/country-subdivisions/qatar.json +29 -29
  382. package/src/_modules/location/_collections/assets/country-subdivisions/romania.json +169 -169
  383. package/src/_modules/location/_collections/assets/country-subdivisions/russian-federation.json +499 -499
  384. package/src/_modules/location/_collections/assets/country-subdivisions/rwanda.json +21 -21
  385. package/src/_modules/location/_collections/assets/country-subdivisions/saint-helena-ascension-and-tristan-da-cunha.json +13 -13
  386. package/src/_modules/location/_collections/assets/country-subdivisions/saint-kitts-and-nevis.json +9 -9
  387. package/src/_modules/location/_collections/assets/country-subdivisions/saint-lucia.json +45 -45
  388. package/src/_modules/location/_collections/assets/country-subdivisions/saint-vincent-and-the-grenadines.json +25 -25
  389. package/src/_modules/location/_collections/assets/country-subdivisions/samoa.json +45 -45
  390. package/src/_modules/location/_collections/assets/country-subdivisions/san-marino.json +37 -37
  391. package/src/_modules/location/_collections/assets/country-subdivisions/sao-tome-and-principe.json +9 -9
  392. package/src/_modules/location/_collections/assets/country-subdivisions/saudi-arabia.json +53 -53
  393. package/src/_modules/location/_collections/assets/country-subdivisions/senegal.json +57 -57
  394. package/src/_modules/location/_collections/assets/country-subdivisions/serbia.json +9 -9
  395. package/src/_modules/location/_collections/assets/country-subdivisions/seychelles.json +101 -101
  396. package/src/_modules/location/_collections/assets/country-subdivisions/sierra-leone.json +17 -17
  397. package/src/_modules/location/_collections/assets/country-subdivisions/singapore.json +21 -21
  398. package/src/_modules/location/_collections/assets/country-subdivisions/slovakia.json +33 -33
  399. package/src/_modules/location/_collections/assets/country-subdivisions/slovenia.json +841 -841
  400. package/src/_modules/location/_collections/assets/country-subdivisions/solomon-islands.json +41 -41
  401. package/src/_modules/location/_collections/assets/country-subdivisions/somalia.json +73 -73
  402. package/src/_modules/location/_collections/assets/country-subdivisions/south-africa.json +37 -37
  403. package/src/_modules/location/_collections/assets/country-subdivisions/south-sudan.json +41 -41
  404. package/src/_modules/location/_collections/assets/country-subdivisions/spain.json +346 -346
  405. package/src/_modules/location/_collections/assets/country-subdivisions/sri-lanka.json +37 -37
  406. package/src/_modules/location/_collections/assets/country-subdivisions/sudan.json +69 -69
  407. package/src/_modules/location/_collections/assets/country-subdivisions/suriname.json +41 -41
  408. package/src/_modules/location/_collections/assets/country-subdivisions/swaziland.json +17 -17
  409. package/src/_modules/location/_collections/assets/country-subdivisions/sweden.json +85 -85
  410. package/src/_modules/location/_collections/assets/country-subdivisions/switzerland.json +105 -105
  411. package/src/_modules/location/_collections/assets/country-subdivisions/syrian-arab-republic.json +57 -57
  412. package/src/_modules/location/_collections/assets/country-subdivisions/taiwan-province-of-china.json +93 -93
  413. package/src/_modules/location/_collections/assets/country-subdivisions/tajikistan.json +17 -17
  414. package/src/_modules/location/_collections/assets/country-subdivisions/tanzania-united-republic-of.json +105 -105
  415. package/src/_modules/location/_collections/assets/country-subdivisions/thailand.json +313 -313
  416. package/src/_modules/location/_collections/assets/country-subdivisions/timor-leste.json +53 -53
  417. package/src/_modules/location/_collections/assets/country-subdivisions/togo.json +21 -21
  418. package/src/_modules/location/_collections/assets/country-subdivisions/tonga.json +21 -21
  419. package/src/_modules/location/_collections/assets/country-subdivisions/trinidad-and-tobago.json +65 -65
  420. package/src/_modules/location/_collections/assets/country-subdivisions/tunisia.json +97 -97
  421. package/src/_modules/location/_collections/assets/country-subdivisions/turkey.json +325 -325
  422. package/src/_modules/location/_collections/assets/country-subdivisions/turkmenistan.json +25 -25
  423. package/src/_modules/location/_collections/assets/country-subdivisions/tuvalu.json +33 -33
  424. package/src/_modules/location/_collections/assets/country-subdivisions/uganda.json +17 -17
  425. package/src/_modules/location/_collections/assets/country-subdivisions/ukraine.json +109 -109
  426. package/src/_modules/location/_collections/assets/country-subdivisions/united-arab-emirates.json +29 -29
  427. package/src/_modules/location/_collections/assets/country-subdivisions/united-kingdom.json +1196 -1196
  428. package/src/_modules/location/_collections/assets/country-subdivisions/united-states-minor-outlying-islands.json +37 -37
  429. package/src/_modules/location/_collections/assets/country-subdivisions/united-states.json +286 -286
  430. package/src/_modules/location/_collections/assets/country-subdivisions/uruguay.json +77 -77
  431. package/src/_modules/location/_collections/assets/country-subdivisions/uzbekistan.json +57 -57
  432. package/src/_modules/location/_collections/assets/country-subdivisions/vanuatu.json +25 -25
  433. package/src/_modules/location/_collections/assets/country-subdivisions/venezuela.json +101 -101
  434. package/src/_modules/location/_collections/assets/country-subdivisions/viet-nam.json +257 -257
  435. package/src/_modules/location/_collections/assets/country-subdivisions/yemen.json +85 -85
  436. package/src/_modules/location/_collections/assets/country-subdivisions/zambia.json +37 -37
  437. package/src/_modules/location/_collections/assets/country-subdivisions/zimbabwe.json +41 -41
  438. package/src/_modules/location/_collections/loc-country-divisions.const.ts +10 -10
  439. package/src/_modules/location/_collections/loc-country-isos.const.ts +8 -8
  440. package/src/_modules/location/_collections/loc-regions.util.spec.ts +61 -61
  441. package/src/_modules/location/_collections/loc-regions.util.ts +137 -137
  442. package/src/_modules/location/_collections/loc.util.spec.ts +52 -52
  443. package/src/_modules/location/_collections/loc.util.ts +74 -74
  444. package/src/_modules/location/_enums/loc-region.enum.ts +14 -14
  445. package/src/_modules/location/_enums/loc-sub-region.enum.ts +31 -31
  446. package/src/_modules/location/_enums/loc-subdivision-region-type.enum.ts +47 -47
  447. package/src/_modules/location/_models/loc-coordinates.interface.ts +7 -7
  448. package/src/_modules/location/_models/loc-country-division.interface.ts +8 -8
  449. package/src/_modules/location/_models/loc-country-iso.interface.ts +23 -23
  450. package/src/_modules/location/_models/loc-country-phone-code.interface.ts +9 -9
  451. package/src/_modules/location/_models/loc-division-collection.interface.ts +12 -12
  452. package/src/_modules/location/_models/loc-division-region-data.interface.ts +9 -9
  453. package/src/_modules/location/_models/loc-geo-ip-location.interface.ts +27 -27
  454. package/src/_modules/location/index.ts +22 -22
  455. package/src/_modules/messaging/README.md +279 -279
  456. package/src/_modules/messaging/_collections/msg-module-settings.const.ts +46 -46
  457. package/src/_modules/messaging/_enums/msg-attachment-type.enum.ts +26 -26
  458. package/src/_modules/messaging/_enums/msg-delivery-status.enum.ts +17 -17
  459. package/src/_modules/messaging/_enums/msg-event-key.enum.ts +31 -31
  460. package/src/_modules/messaging/_enums/msg-participant-role.enum.ts +20 -20
  461. package/src/_modules/messaging/_enums/msg-provider-type.enum.ts +7 -7
  462. package/src/_modules/messaging/_enums/msg-type.enum.ts +23 -23
  463. package/src/_modules/messaging/_models/msg-attachment.interface.ts +46 -46
  464. package/src/_modules/messaging/_models/msg-conversation.data-model.spec.ts +69 -69
  465. package/src/_modules/messaging/_models/msg-conversation.data-model.ts +96 -96
  466. package/src/_modules/messaging/_models/msg-mention.interface.ts +29 -29
  467. package/src/_modules/messaging/_models/msg-message.data-model.spec.ts +79 -79
  468. package/src/_modules/messaging/_models/msg-message.data-model.ts +127 -127
  469. package/src/_modules/messaging/_models/msg-participant.interface.ts +46 -46
  470. package/src/_modules/messaging/_models/msg-reaction.interface.ts +20 -20
  471. package/src/_modules/messaging/_models/msg-thread-info.interface.ts +35 -35
  472. package/src/_modules/messaging/_modules/agent/_enums/agt-process-step-type.enum.ts +35 -35
  473. package/src/_modules/messaging/_modules/agent/_enums/agt-tool-status.enum.ts +23 -23
  474. package/src/_modules/messaging/_modules/agent/_models/agt-process-step.interface.ts +55 -55
  475. package/src/_modules/messaging/_modules/agent/_models/agt-reasoning-info.interface.ts +26 -26
  476. package/src/_modules/messaging/_modules/agent/_models/agt-tool-usage.interface.ts +37 -37
  477. package/src/_modules/messaging/_modules/agent/index.ts +8 -8
  478. package/src/_modules/messaging/index.ts +28 -28
  479. package/src/_modules/pipe/_collections/pip-transforms.const.ts +42 -42
  480. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.spec.ts +47 -47
  481. package/src/_modules/pipe/_collections/utils/pip-country-pipe.util.ts +41 -41
  482. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.spec.ts +39 -39
  483. package/src/_modules/pipe/_collections/utils/pip-custom-pipe.util.ts +30 -30
  484. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.spec.ts +41 -41
  485. package/src/_modules/pipe/_collections/utils/pip-division-pipe.util.ts +36 -36
  486. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.spec.ts +62 -62
  487. package/src/_modules/pipe/_collections/utils/pip-json-pipe.util.ts +17 -17
  488. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.spec.ts +34 -34
  489. package/src/_modules/pipe/_collections/utils/pip-list-pipe.util.ts +25 -25
  490. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.spec.ts +67 -67
  491. package/src/_modules/pipe/_collections/utils/pip-multi-pipe-pipe.util.ts +226 -226
  492. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.spec.ts +28 -28
  493. package/src/_modules/pipe/_collections/utils/pip-obj-key-pipe.util.ts +21 -21
  494. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.spec.ts +59 -59
  495. package/src/_modules/pipe/_collections/utils/pip-range-pipe.util.ts +106 -106
  496. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.spec.ts +31 -31
  497. package/src/_modules/pipe/_collections/utils/pip-region-pipe.util.ts +35 -35
  498. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.spec.ts +44 -44
  499. package/src/_modules/pipe/_collections/utils/pip-replace-pipe.util.ts +23 -23
  500. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.spec.ts +21 -21
  501. package/src/_modules/pipe/_collections/utils/pip-slider-pipe.util.ts +33 -33
  502. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.spec.ts +62 -62
  503. package/src/_modules/pipe/_collections/utils/pip-smart-replace-pipe.util.ts +80 -80
  504. package/src/_modules/pipe/_enums/pip-range-pipe-setting.enum.ts +15 -15
  505. package/src/_modules/pipe/_enums/pip.enum.ts +65 -65
  506. package/src/_modules/pipe/_models/pip-multi-pipe-settings.type.ts +8 -8
  507. package/src/_modules/pipe/_models/pip-transforms.interface.ts +30 -30
  508. package/src/_modules/pipe/index.ts +30 -30
  509. package/src/_modules/socket/_enums/sck-event-key.enum.ts +21 -21
  510. package/src/_modules/socket/_models/sck-client-params.control-model.spec.ts +67 -67
  511. package/src/_modules/socket/_models/sck-client-params.control-model.ts +50 -50
  512. package/src/_modules/socket/_models/sck-socket-event.control-model.spec.ts +66 -66
  513. package/src/_modules/socket/_models/sck-socket-event.control-model.ts +172 -172
  514. package/src/_modules/socket/_services/sck-client.service-base.spec.ts +99 -99
  515. package/src/_modules/socket/_services/sck-client.service-base.ts +353 -353
  516. package/src/_modules/socket/index.ts +14 -14
  517. package/src/_modules/test/_collections/tst-module-settings.const.ts +67 -67
  518. package/src/_modules/test/index.ts +5 -5
  519. package/src/_modules/usage/_collections/usg-module-settings.const.ts +33 -33
  520. package/src/_modules/usage/_models/usg-action.control-model.spec.ts +27 -27
  521. package/src/_modules/usage/_models/usg-action.control-model.ts +28 -28
  522. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.spec.ts +36 -36
  523. package/src/_modules/usage/_models/usg-daily-usage-data.control-model.ts +35 -35
  524. package/src/_modules/usage/_models/usg-data.control-model.spec.ts +41 -41
  525. package/src/_modules/usage/_models/usg-data.control-model.ts +35 -35
  526. package/src/_modules/usage/_models/usg-session.data-model.spec.ts +97 -97
  527. package/src/_modules/usage/_models/usg-session.data-model.ts +72 -72
  528. package/src/_modules/usage/index.ts +11 -11
  529. package/src/index.ts +102 -102
  530. package/tsconfig.app.json +12 -12
  531. package/tsconfig.json +31 -31
  532. package/tsconfig.test.json +16 -16
  533. package/tslint.json +153 -153
  534. 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
+