@futdevpro/fsm-dynamo 1.15.18 → 1.15.20

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