@zajno/common 2.7.1 → 2.7.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (264) hide show
  1. package/cjs/api/call.js +5 -5
  2. package/cjs/api/call.js.map +1 -1
  3. package/cjs/api/config.js +30 -5
  4. package/cjs/api/config.js.map +1 -1
  5. package/cjs/api/index.js +5 -8
  6. package/cjs/api/index.js.map +1 -1
  7. package/cjs/api/interceptor.js +1 -1
  8. package/cjs/api/logging.js +3 -3
  9. package/cjs/api/logging.js.map +1 -1
  10. package/cjs/functions/assert.js +2 -4
  11. package/cjs/functions/assert.js.map +1 -1
  12. package/cjs/functions/disposer.js +10 -18
  13. package/cjs/functions/disposer.js.map +1 -1
  14. package/cjs/functions/throttle.js +8 -17
  15. package/cjs/functions/throttle.js.map +1 -1
  16. package/cjs/localization/LocalizationManager.js +9 -0
  17. package/cjs/localization/LocalizationManager.js.map +1 -1
  18. package/cjs/localization/index.js +0 -2
  19. package/cjs/localization/index.js.map +1 -1
  20. package/cjs/logger/batch.js +23 -3
  21. package/cjs/logger/batch.js.map +1 -1
  22. package/cjs/logger/buffered/base.js +52 -0
  23. package/cjs/logger/buffered/base.js.map +1 -0
  24. package/cjs/logger/buffered/buffered.logger.js +40 -0
  25. package/cjs/logger/buffered/buffered.logger.js.map +1 -0
  26. package/cjs/logger/buffered/buffered.memory.js +71 -0
  27. package/cjs/logger/buffered/buffered.memory.js.map +1 -0
  28. package/cjs/logger/buffered/file/buffered.file.js +43 -0
  29. package/cjs/logger/buffered/file/buffered.file.js.map +1 -0
  30. package/cjs/logger/buffered/file/index.js +5 -0
  31. package/cjs/logger/buffered/file/index.js.map +1 -0
  32. package/cjs/logger/buffered/index.js +7 -0
  33. package/cjs/logger/buffered/index.js.map +1 -0
  34. package/cjs/logger/console.js +1 -39
  35. package/cjs/logger/console.js.map +1 -1
  36. package/cjs/logger/empty.js +11 -0
  37. package/cjs/logger/empty.js.map +1 -0
  38. package/cjs/logger/index.js +5 -7
  39. package/cjs/logger/index.js.map +1 -1
  40. package/cjs/logger/loggable.js +39 -0
  41. package/cjs/logger/loggable.js.map +1 -0
  42. package/cjs/logger/manager.js +70 -20
  43. package/cjs/logger/manager.js.map +1 -1
  44. package/cjs/logger/named.js +15 -12
  45. package/cjs/logger/named.js.map +1 -1
  46. package/cjs/logger/provider.js +33 -0
  47. package/cjs/logger/provider.js.map +1 -0
  48. package/cjs/logger/proxy.js +3 -7
  49. package/cjs/logger/proxy.js.map +1 -1
  50. package/cjs/logger/types.js +9 -0
  51. package/cjs/logger/types.js.map +1 -0
  52. package/cjs/math/arrays.js.map +1 -1
  53. package/cjs/math/object/ops.composite.js.map +1 -1
  54. package/cjs/models/LogicModel.js +13 -11
  55. package/cjs/models/LogicModel.js.map +1 -1
  56. package/cjs/observing/event.js +5 -18
  57. package/cjs/observing/event.js.map +1 -1
  58. package/cjs/observing/event.late.js.map +1 -1
  59. package/cjs/observing/progressTracker.js +8 -15
  60. package/cjs/observing/progressTracker.js.map +1 -1
  61. package/cjs/observing/timer.js.map +1 -1
  62. package/cjs/observing/transition.js +177 -0
  63. package/cjs/observing/transition.js.map +1 -0
  64. package/cjs/structures/path/utils.js +4 -0
  65. package/cjs/structures/path/utils.js.map +1 -1
  66. package/cjs/structures/promiseCache.js +14 -20
  67. package/cjs/structures/promiseCache.js.map +1 -1
  68. package/cjs/structures/queue/parallel.js +11 -13
  69. package/cjs/structures/queue/parallel.js.map +1 -1
  70. package/cjs/structures/subscribersMap.js +9 -7
  71. package/cjs/structures/subscribersMap.js.map +1 -1
  72. package/cjs/validation/helpers.js +2 -2
  73. package/cjs/validation/helpers.js.map +1 -1
  74. package/cjs/validation/index.js +1 -1
  75. package/cjs/validation/index.js.map +1 -1
  76. package/cjs/validation/types.js +0 -9
  77. package/cjs/validation/types.js.map +1 -1
  78. package/cjs/validation/validationError.js +12 -0
  79. package/cjs/validation/validationError.js.map +1 -0
  80. package/esm/api/builder.js +1 -0
  81. package/esm/api/builder.js.map +1 -1
  82. package/esm/api/call.config.js +1 -0
  83. package/esm/api/call.config.js.map +1 -1
  84. package/esm/api/call.js +6 -5
  85. package/esm/api/call.js.map +1 -1
  86. package/esm/api/call.types.js +1 -1
  87. package/esm/api/call.types.js.map +1 -1
  88. package/esm/api/config.js +28 -4
  89. package/esm/api/config.js.map +1 -1
  90. package/esm/api/endpoint.types.js +1 -1
  91. package/esm/api/endpoint.types.js.map +1 -1
  92. package/esm/api/error.js +1 -0
  93. package/esm/api/error.js.map +1 -1
  94. package/esm/api/extensions/contentType.js +1 -0
  95. package/esm/api/extensions/contentType.js.map +1 -1
  96. package/esm/api/extensions/validation.js +2 -0
  97. package/esm/api/extensions/validation.js.map +1 -1
  98. package/esm/api/index.js +3 -3
  99. package/esm/api/index.js.map +1 -1
  100. package/esm/api/interceptor.js +1 -1
  101. package/esm/api/logging.js +4 -3
  102. package/esm/api/logging.js.map +1 -1
  103. package/esm/dates/calc.js +1 -0
  104. package/esm/dates/calc.js.map +1 -1
  105. package/esm/dates/format.js +1 -0
  106. package/esm/dates/format.js.map +1 -1
  107. package/esm/dates/period.js +1 -0
  108. package/esm/dates/period.js.map +1 -1
  109. package/esm/fields/update.js +1 -0
  110. package/esm/fields/update.js.map +1 -1
  111. package/esm/functions/assert.js +3 -3
  112. package/esm/functions/assert.js.map +1 -1
  113. package/esm/functions/disposer.js +11 -17
  114. package/esm/functions/disposer.js.map +1 -1
  115. package/esm/functions/throttle.js +7 -15
  116. package/esm/functions/throttle.js.map +1 -1
  117. package/esm/localization/LocalizationManager.js +9 -0
  118. package/esm/localization/LocalizationManager.js.map +1 -1
  119. package/esm/localization/defaults/ValidationErrorsLocalization.js +2 -0
  120. package/esm/localization/defaults/ValidationErrorsLocalization.js.map +1 -1
  121. package/esm/localization/index.js +0 -1
  122. package/esm/localization/index.js.map +1 -1
  123. package/esm/logger/batch.js +23 -3
  124. package/esm/logger/batch.js.map +1 -1
  125. package/esm/logger/buffered/base.js +48 -0
  126. package/esm/logger/buffered/base.js.map +1 -0
  127. package/esm/logger/buffered/buffered.logger.js +36 -0
  128. package/esm/logger/buffered/buffered.logger.js.map +1 -0
  129. package/esm/logger/buffered/buffered.memory.js +67 -0
  130. package/esm/logger/buffered/buffered.memory.js.map +1 -0
  131. package/esm/logger/buffered/file/buffered.file.js +38 -0
  132. package/esm/logger/buffered/file/buffered.file.js.map +1 -0
  133. package/esm/logger/buffered/file/index.js +2 -0
  134. package/esm/logger/buffered/file/index.js.map +1 -0
  135. package/esm/logger/buffered/index.js +4 -0
  136. package/esm/logger/buffered/index.js.map +1 -0
  137. package/esm/logger/console.js +0 -37
  138. package/esm/logger/console.js.map +1 -1
  139. package/esm/logger/empty.js +7 -0
  140. package/esm/logger/empty.js.map +1 -0
  141. package/esm/logger/index.js +3 -7
  142. package/esm/logger/index.js.map +1 -1
  143. package/esm/logger/loggable.js +35 -0
  144. package/esm/logger/loggable.js.map +1 -0
  145. package/esm/logger/manager.js +70 -20
  146. package/esm/logger/manager.js.map +1 -1
  147. package/esm/logger/named.js +8 -4
  148. package/esm/logger/named.js.map +1 -1
  149. package/esm/logger/provider.js +29 -0
  150. package/esm/logger/provider.js.map +1 -0
  151. package/esm/logger/proxy.js +2 -6
  152. package/esm/logger/proxy.js.map +1 -1
  153. package/esm/logger/types.js +6 -0
  154. package/esm/logger/types.js.map +1 -0
  155. package/esm/math/arrays.js.map +1 -1
  156. package/esm/math/object/ops.composite.js.map +1 -1
  157. package/esm/models/LogicModel.js +13 -11
  158. package/esm/models/LogicModel.js.map +1 -1
  159. package/esm/observing/event.js +5 -18
  160. package/esm/observing/event.js.map +1 -1
  161. package/esm/observing/event.late.js.map +1 -1
  162. package/esm/observing/progressTracker.js +9 -14
  163. package/esm/observing/progressTracker.js.map +1 -1
  164. package/esm/observing/timer.js.map +1 -1
  165. package/esm/observing/transition.js +172 -0
  166. package/esm/observing/transition.js.map +1 -0
  167. package/esm/structures/path/builder.js +1 -1
  168. package/esm/structures/path/builder.js.map +1 -1
  169. package/esm/structures/path/utils.js +4 -0
  170. package/esm/structures/path/utils.js.map +1 -1
  171. package/esm/structures/promiseCache.js +14 -20
  172. package/esm/structures/promiseCache.js.map +1 -1
  173. package/esm/structures/queue/parallel.js +11 -13
  174. package/esm/structures/queue/parallel.js.map +1 -1
  175. package/esm/structures/subscribersMap.js +9 -7
  176. package/esm/structures/subscribersMap.js.map +1 -1
  177. package/esm/validation/helpers.js +1 -1
  178. package/esm/validation/helpers.js.map +1 -1
  179. package/esm/validation/index.js +1 -1
  180. package/esm/validation/index.js.map +1 -1
  181. package/esm/validation/types.js +1 -7
  182. package/esm/validation/types.js.map +1 -1
  183. package/esm/validation/validationError.js +8 -0
  184. package/esm/validation/validationError.js.map +1 -0
  185. package/package.json +13 -1
  186. package/tsconfig.cjs.tsbuildinfo +1 -1
  187. package/tsconfig.esm.tsbuildinfo +1 -1
  188. package/tsconfig.types.tsbuildinfo +1 -1
  189. package/types/api/builder.d.ts +1 -1
  190. package/types/api/call.config.d.ts +1 -1
  191. package/types/api/call.types.d.ts +2 -2
  192. package/types/api/config.d.ts +11 -4
  193. package/types/api/endpoint.types.d.ts +1 -1
  194. package/types/api/extensions/endpointHooks.d.ts +1 -1
  195. package/types/api/extensions/validation.d.ts +1 -1
  196. package/types/api/index.d.ts +3 -3
  197. package/types/api/interceptor.d.ts +1 -1
  198. package/types/api/logging.d.ts +8 -6
  199. package/types/functions/assert.d.ts +3 -3
  200. package/types/functions/disposer.d.ts +7 -6
  201. package/types/functions/safe.d.ts +1 -1
  202. package/types/functions/throttle.d.ts +4 -5
  203. package/types/localization/LocalizationManager.d.ts +7 -0
  204. package/types/localization/LocalizedValidationErrors.d.ts +1 -1
  205. package/types/localization/index.d.ts +1 -1
  206. package/types/logger/batch.d.ts +3 -2
  207. package/types/logger/buffered/base.d.ts +23 -0
  208. package/types/logger/buffered/buffered.logger.d.ts +8 -0
  209. package/types/logger/buffered/buffered.memory.d.ts +19 -0
  210. package/types/logger/buffered/file/buffered.file.d.ts +9 -0
  211. package/types/logger/buffered/file/index.d.ts +1 -0
  212. package/types/logger/buffered/index.d.ts +3 -0
  213. package/types/logger/console.d.ts +1 -13
  214. package/types/logger/empty.d.ts +3 -0
  215. package/types/logger/index.d.ts +6 -10
  216. package/types/logger/loggable.d.ts +13 -0
  217. package/types/logger/manager.d.ts +31 -7
  218. package/types/logger/named.d.ts +4 -3
  219. package/types/logger/provider.d.ts +11 -0
  220. package/types/logger/proxy.d.ts +1 -2
  221. package/types/logger/types.d.ts +21 -0
  222. package/types/math/arrays.d.ts +1 -1
  223. package/types/math/object/helpers.d.ts +2 -2
  224. package/types/math/object/math.composite.d.ts +3 -3
  225. package/types/math/object/math.d.ts +2 -2
  226. package/types/math/object/ops.composite.d.ts +3 -3
  227. package/types/math/object/ops.d.ts +2 -2
  228. package/types/math/object/types.d.ts +1 -1
  229. package/types/models/LogicModel.d.ts +4 -4
  230. package/types/models/Model.d.ts +1 -1
  231. package/types/observing/event.d.ts +3 -6
  232. package/types/observing/event.late.d.ts +1 -1
  233. package/types/observing/progressTracker.d.ts +3 -4
  234. package/types/observing/timer.d.ts +2 -2
  235. package/types/observing/transition.d.ts +40 -0
  236. package/types/structures/path/builder.d.ts +1 -1
  237. package/types/structures/path/utils.d.ts +1 -1
  238. package/types/structures/promiseCache.d.ts +4 -5
  239. package/types/structures/promiseProxy.d.ts +1 -1
  240. package/types/structures/queue/parallel.d.ts +3 -3
  241. package/types/structures/subscribersMap.d.ts +4 -3
  242. package/types/types/deep.d.ts +1 -1
  243. package/types/types/functions.d.ts +1 -1
  244. package/types/types/ident.d.ts +0 -1
  245. package/types/validation/helpers.d.ts +2 -2
  246. package/types/validation/index.d.ts +2 -1
  247. package/types/validation/types.d.ts +1 -5
  248. package/types/validation/validationError.d.ts +5 -0
  249. package/types/validation/wrappers.d.ts +1 -1
  250. package/cjs/logger/abstractions.js +0 -3
  251. package/cjs/logger/abstractions.js.map +0 -1
  252. package/cjs/logger/file.js +0 -65
  253. package/cjs/logger/file.js.map +0 -1
  254. package/cjs/logger/shared.js +0 -18
  255. package/cjs/logger/shared.js.map +0 -1
  256. package/esm/logger/abstractions.js +0 -2
  257. package/esm/logger/abstractions.js.map +0 -1
  258. package/esm/logger/file.js +0 -60
  259. package/esm/logger/file.js.map +0 -1
  260. package/esm/logger/shared.js +0 -15
  261. package/esm/logger/shared.js.map +0 -1
  262. package/types/logger/abstractions.d.ts +0 -10
  263. package/types/logger/file.d.ts +0 -15
  264. package/types/logger/shared.d.ts +0 -15
@@ -1 +1 @@
1
- {"version":3,"file":"ops.composite.js","sourceRoot":"","sources":["../../../../src/math/object/ops.composite.ts"],"names":[],"mappings":";;;AAEA,6CAAqD;AAGrD,MAAa,kBAAkB;IAClB,KAAK,CAAc;IAEX,IAAI,CAAe;IAEpC,YAAY,QAAwB;QAEhC,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;aAC/B,GAAG,CAAC,IAAI,CAAC,EAAE;YACR,MAAM,MAAM,GAAe;gBACvB,GAAG,EAAE,IAAI,CAAC,CAAC,CAAS;gBACpB,GAAG,EAAE,IAAI,CAAC,CAAC,CAAwB;aACtC,CAAC;YACF,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,OAAO,CAAC,CAAkB;QACtB,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAA,2BAAc,EAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,QAAQ;QACJ,OAAO,IAAA,kBAAK,EAAC,IAAI,CAAC,IAAI,EAAE,EAAsB,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED,KAAK,CAAC,CAAkB;QACpB,OAAO,IAAA,kBAAK,EAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,CAAC,CAAkB;QACtB,OAAO,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAA,2BAAc,EAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACzF,CAAC;IAED,QAAQ,CAAC,CAAkB,EAAE,CAAkB;QAC3C,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACX,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAC5C,IAAA,2BAAc,EAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAC3B,IAAA,2BAAc,EAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAC9B,CAAC,CAAC;IACP,CAAC;IAED,MAAM,CAAC,EAAK,EAAE,KAAsB;QAChC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACrB,MAAM,GAAG,GAAG,IAAA,2BAAc,EAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5C,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;gBACpB,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;YACvB,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;CACJ;AAxDD,gDAwDC"}
1
+ {"version":3,"file":"ops.composite.js","sourceRoot":"","sources":["../../../../src/math/object/ops.composite.ts"],"names":[],"mappings":";;;AAGA,6CAAqD;AAErD,MAAa,kBAAkB;IAClB,KAAK,CAAc;IAEX,IAAI,CAAe;IAEpC,YAAY,QAAwB;QAEhC,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;aAC/B,GAAG,CAAC,IAAI,CAAC,EAAE;YACR,MAAM,MAAM,GAAe;gBACvB,GAAG,EAAE,IAAI,CAAC,CAAC,CAAS;gBACpB,GAAG,EAAE,IAAI,CAAC,CAAC,CAAwB;aACtC,CAAC;YACF,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,OAAO,CAAC,CAAkB;QACtB,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAA,2BAAc,EAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,QAAQ;QACJ,OAAO,IAAA,kBAAK,EAAC,IAAI,CAAC,IAAI,EAAE,EAAsB,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED,KAAK,CAAC,CAAkB;QACpB,OAAO,IAAA,kBAAK,EAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,CAAC,CAAkB;QACtB,OAAO,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAA,2BAAc,EAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACzF,CAAC;IAED,QAAQ,CAAC,CAAkB,EAAE,CAAkB;QAC3C,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACX,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAC5C,IAAA,2BAAc,EAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAC3B,IAAA,2BAAc,EAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAC9B,CAAC,CAAC;IACP,CAAC;IAED,MAAM,CAAC,EAAK,EAAE,KAAsB;QAChC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACrB,MAAM,GAAG,GAAG,IAAA,2BAAc,EAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5C,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;gBACpB,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;YACvB,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;CACJ;AAxDD,gDAwDC"}
@@ -4,17 +4,19 @@ exports.ActionResult = exports.LogicModel = void 0;
4
4
  const Loading_js_1 = require("./Loading.js");
5
5
  const index_js_1 = require("../types/index.js");
6
6
  const promiseExtended_js_1 = require("../structures/promiseExtended.js");
7
- const shared_js_1 = require("../logger/shared.js");
8
- class LogicModel {
7
+ const loggable_js_1 = require("../logger/loggable.js");
8
+ class LogicModel extends loggable_js_1.Loggable {
9
9
  _loading;
10
10
  get isLoading() { return this._loading.isLoading; }
11
- logger;
12
11
  _namedRunners = new Map();
13
12
  _runningActionNames = new Set();
14
- constructor(name, useFirstInit = true) {
15
- this.logger = (0, shared_js_1.createLogger)(`[${name || this.constructor.name}]`);
13
+ constructor(useFirstInit = true) {
14
+ super();
16
15
  this._loading = this.pureConstructLoadingModel(useFirstInit);
17
16
  }
17
+ getLoggerName(name) {
18
+ return `[${name || this.constructor.name}]`;
19
+ }
18
20
  pureConstructLoadingModel(useFirstInit) {
19
21
  return new Loading_js_1.LoadingModel(useFirstInit);
20
22
  }
@@ -22,7 +24,7 @@ class LogicModel {
22
24
  const started = Date.now();
23
25
  const name = options.name;
24
26
  if (name && !options.noLogs) {
25
- this.logger.log(`runAction "${name}" started...`);
27
+ this.logger?.log(`runAction "${name}" started...`);
26
28
  }
27
29
  const runner = async () => {
28
30
  const { exclusive = false, noLoading = false, join } = options;
@@ -32,13 +34,13 @@ class LogicModel {
32
34
  if (existingRunner != null) {
33
35
  if (join === 'cancel') {
34
36
  if (!options.noLogs) {
35
- this.logger.warn(`runAction "${name}" has been skipped because another instance of it is in progress`);
37
+ this.logger?.warn(`runAction "${name}" has been skipped because another instance of it is in progress`);
36
38
  }
37
39
  return undefined;
38
40
  }
39
41
  else if (join === 'merge') {
40
42
  if (!options.noLogs) {
41
- this.logger.log(`runAction "${name}" merging with existing instance...`);
43
+ this.logger?.log(`runAction "${name}" merging with existing instance...`);
42
44
  }
43
45
  return existingRunner;
44
46
  }
@@ -57,7 +59,7 @@ class LogicModel {
57
59
  if (exclusive === 'throw') {
58
60
  throw new Loading_js_1.ExclusiveLoadingError(message, storedName);
59
61
  }
60
- this.logger.warn(message);
62
+ this.logger?.warn(message);
61
63
  return undefined;
62
64
  }
63
65
  result = resultWithLoading.result;
@@ -66,7 +68,7 @@ class LogicModel {
66
68
  result = await worker();
67
69
  }
68
70
  if (name && !options.noLogs) {
69
- this.logger.log(`runAction "${storedName}" succeed in ${Date.now() - started}ms`);
71
+ this.logger?.log(`runAction "${storedName}" succeed in ${Date.now() - started}ms`);
70
72
  }
71
73
  return result;
72
74
  }
@@ -88,7 +90,7 @@ class LogicModel {
88
90
  };
89
91
  return ActionResult.expectExclusive(promiseExtended_js_1.PromiseExtended.run(runner))
90
92
  .onError(data => {
91
- this.logger.error(...formatError({
93
+ this.logger?.error(...formatError({
92
94
  name,
93
95
  err: data.source,
94
96
  errorCtx,
@@ -1 +1 @@
1
- {"version":3,"file":"LogicModel.js","sourceRoot":"","sources":["../../../src/models/LogicModel.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"LogicModel.js","sourceRoot":"","sources":["../../../src/models/LogicModel.ts"],"names":[],"mappings":"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"}
@@ -3,26 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Event = void 0;
4
4
  exports.oneTimeSubscription = oneTimeSubscription;
5
5
  const arrays_js_1 = require("../async/arrays.js");
6
- const shared_js_1 = require("../logger/shared.js");
7
6
  const safe_js_1 = require("../functions/safe.js");
8
- class Event {
7
+ const loggable_js_1 = require("../logger/loggable.js");
8
+ class Event extends loggable_js_1.Loggable {
9
9
  _handlers = [];
10
- _logger = null;
11
- constructor(withDefaultLogger = true) {
12
- if (withDefaultLogger) {
13
- this.withLogger('');
14
- }
15
- }
16
10
  get isEmpty() { return this._handlers.length === 0; }
17
- withLogger(loggerOrName) {
18
- if (loggerOrName == null) {
19
- this._logger = null;
20
- return this;
21
- }
22
- this._logger = typeof loggerOrName === 'string'
23
- ? (0, shared_js_1.createLogger)(`[Event:${loggerOrName || '?'}]`)
24
- : loggerOrName;
25
- return this;
11
+ getLoggerName(name) {
12
+ return `[Event:${name || '?'}]`;
26
13
  }
27
14
  /** Clears handlers list */
28
15
  resetHandlers = () => {
@@ -80,7 +67,7 @@ class Event {
80
67
  return this;
81
68
  }
82
69
  logError(data, cb, err) {
83
- this._logger?.error(`[Event.${typeof data}] Handler ${cb.name} thrown an exception: `, err);
70
+ this.logger?.error(`type:${typeof data} Handler ${cb.name} thrown an exception: `, err);
84
71
  }
85
72
  }
86
73
  exports.Event = Event;
@@ -1 +1 @@
1
- {"version":3,"file":"event.js","sourceRoot":"","sources":["../../../src/observing/event.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"event.js","sourceRoot":"","sources":["../../../src/observing/event.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"event.late.js","sourceRoot":"","sources":["../../../src/observing/event.late.ts"],"names":[],"mappings":";;;AAAA,kDAAoD;AACpD,yCAAiD;AAEjD;;;;;;;GAOG;AACH,MAAa,gBAA0B,SAAQ,gBAAQ;IAE3C,cAAc,GAAkB,SAAS,CAAC;IAC1C,UAAU,GAAG,KAAK,CAAC;IAE3B,OAAO,CAAC,IAAQ;QACZ,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,YAAY,CAAC,IAAQ;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO,OAAO,CAAC,OAAO,CAAC,EAAa,CAAC,CAAC;QAC1C,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,OAAO,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,EAAE,CAAC,OAAwB;QACvB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAA,sBAAY,EACR,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC;YACF,iEAAiE;QACrE,CAAC;QAED,OAAO,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAED,qFAAqF;IACrF,KAAK,GAAG,GAAG,EAAE;QACT,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IACpC,CAAC,CAAC;CACL;AA3CD,4CA2CC"}
1
+ {"version":3,"file":"event.late.js","sourceRoot":"","sources":["../../../src/observing/event.late.ts"],"names":[],"mappings":";;;AAAA,kDAAoD;AACpD,yCAAsD;AAEtD;;;;;;;GAOG;AACH,MAAa,gBAA0B,SAAQ,gBAAQ;IAE3C,cAAc,GAAkB,SAAS,CAAC;IAC1C,UAAU,GAAG,KAAK,CAAC;IAE3B,OAAO,CAAC,IAAQ;QACZ,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,YAAY,CAAC,IAAQ;QACjB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO,OAAO,CAAC,OAAO,CAAC,EAAa,CAAC,CAAC;QAC1C,CAAC;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,OAAO,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,EAAE,CAAC,OAAwB;QACvB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAA,sBAAY,EACR,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC;YACF,iEAAiE;QACrE,CAAC;QAED,OAAO,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAED,qFAAqF;IACrF,KAAK,GAAG,GAAG,EAAE;QACT,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IACpC,CAAC,CAAC;CACL;AA3CD,4CA2CC"}
@@ -1,13 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ProgressTracker = void 0;
4
- const tslib_1 = require("tslib");
5
- const DateHelpers = tslib_1.__importStar(require("../dates/index.js"));
6
- const MathHelpers = tslib_1.__importStar(require("../math/index.js"));
7
- const shared_js_1 = tslib_1.__importDefault(require("../logger/shared.js"));
4
+ const decompose_js_1 = require("../dates/decompose.js");
5
+ const arrays_js_1 = require("../math/arrays.js");
8
6
  const event_js_1 = require("./event.js");
9
7
  class ProgressTracker {
10
- log;
8
+ logger;
11
9
  _firstTimestamp = Date.now();
12
10
  _lastTimestamp = null;
13
11
  _lastCompleted = null;
@@ -16,18 +14,13 @@ class ProgressTracker {
16
14
  _currentProgress = 0;
17
15
  _deltas = [];
18
16
  _changed = new event_js_1.Event();
19
- constructor(log = true) {
20
- this.log = log;
17
+ constructor(logger) {
18
+ this.logger = logger;
21
19
  }
22
20
  get changed() { return this._changed.expose(); }
23
21
  get total() { return this._total; }
24
22
  get completed() { return this._completed; }
25
23
  get current() { return this._currentProgress; }
26
- get logger() {
27
- return this.log === true
28
- ? shared_js_1.default
29
- : (this.log || null);
30
- }
31
24
  setTotal(total) {
32
25
  this._total = total;
33
26
  return this;
@@ -51,10 +44,10 @@ class ProgressTracker {
51
44
  }
52
45
  this._currentProgress = Math.floor(completed / (total || 100) * 100);
53
46
  const itemsLeft = total - completed;
54
- const leftProgressTime = itemsLeft * (MathHelpers.arrayAverage(this._deltas, true) || 1000);
47
+ const leftProgressTime = itemsLeft * ((0, arrays_js_1.arrayAverage)(this._deltas, true) || 1000);
55
48
  this._lastTimestamp = Date.now();
56
49
  const totalElapsedMs = this._lastTimestamp - this._firstTimestamp;
57
- if (this.log) {
50
+ if (this.logger) {
58
51
  const totalElapsed = msToString(totalElapsedMs);
59
52
  const totalEstimated = msToString(leftProgressTime);
60
53
  this.logger.log(`Progress: ${completed}/${total} ${totalElapsed}/${totalEstimated} => ${this._currentProgress}%`);
@@ -70,7 +63,7 @@ class ProgressTracker {
70
63
  }
71
64
  exports.ProgressTracker = ProgressTracker;
72
65
  function msToString(ms) {
73
- const decs = DateHelpers.decomposeMs(ms, 'second', 'minute', 'hour');
66
+ const decs = (0, decompose_js_1.decomposeMs)(ms, 'second', 'minute', 'hour');
74
67
  const nf = (n) => n.toString().padStart(2, '0');
75
68
  return `${nf(decs.hour)}:${nf(decs.minute)}:${nf(decs.second)}`;
76
69
  }
@@ -1 +1 @@
1
- {"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"timer.js","sourceRoot":"","sources":["../../../src/observing/timer.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"timer.js","sourceRoot":"","sources":["../../../src/observing/timer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TransitionObserver = void 0;
4
+ exports.waitFor = waitFor;
5
+ const event_js_1 = require("./event.js");
6
+ const getter_js_1 = require("../types/getter.js");
7
+ const loggable_js_1 = require("../logger/loggable.js");
8
+ class TransitionObserver extends loggable_js_1.Loggable {
9
+ reaction;
10
+ _event;
11
+ _getter = null;
12
+ _filter = null;
13
+ _disposer;
14
+ _prev;
15
+ _from;
16
+ _to;
17
+ _cb;
18
+ _fireOnce = false;
19
+ _promise;
20
+ _promiseReject;
21
+ constructor(reaction, getter) {
22
+ super();
23
+ this.reaction = reaction;
24
+ if (getter) {
25
+ this.observe(getter);
26
+ }
27
+ }
28
+ get event() {
29
+ // lazy created just to save up some memory in case it's not needed
30
+ if (!this._event) {
31
+ this._event = new event_js_1.Event().setLogger(this.logger);
32
+ }
33
+ return this._event;
34
+ }
35
+ get currentValue() { return this._prev; }
36
+ get isObserving() { return this._disposer != null; }
37
+ get isPromising() { return this._promiseReject != null; }
38
+ observe(getter) {
39
+ this.dispose();
40
+ this._getter = getter;
41
+ this._prev = this._getter();
42
+ this._disposer = this.reaction(this._getter, this._checkValue);
43
+ return this;
44
+ }
45
+ from(from) {
46
+ this._from = from;
47
+ return this;
48
+ }
49
+ to(to) {
50
+ this._to = to;
51
+ return this;
52
+ }
53
+ filter(filter) {
54
+ this._filter = filter;
55
+ return this;
56
+ }
57
+ cb(cb) {
58
+ if (this.isPromising) {
59
+ throw new Error('Cannot set callback when promise is running');
60
+ }
61
+ this._cb = cb;
62
+ return this;
63
+ }
64
+ forceCall() {
65
+ if (this._cb) {
66
+ this._cb(this._prev);
67
+ }
68
+ return this;
69
+ }
70
+ fireOnce(enable = true) {
71
+ this._fireOnce = enable;
72
+ return this;
73
+ }
74
+ forceCheck() {
75
+ if (!this._getter) {
76
+ return false;
77
+ }
78
+ return this._checkValue(this._getter());
79
+ }
80
+ andForceCheck() {
81
+ this.forceCheck();
82
+ return this;
83
+ }
84
+ getPromise(timeout = null) {
85
+ if (this._promise == null) {
86
+ if (!this.isObserving) {
87
+ return Promise.reject(new Error('Cannot get promise for disposed TransitionObserver'));
88
+ }
89
+ this._promise = new Promise((resolve, reject) => {
90
+ this._promiseReject = reject;
91
+ let timeoutHandle = null;
92
+ if (timeout) {
93
+ timeoutHandle = setTimeout(() => {
94
+ this._finishPromise(reject, new Error(`TransitionObserver Aborted – timed out after ${timeout}ms`));
95
+ }, timeout);
96
+ }
97
+ this._cb = (v => {
98
+ clearTimeout(timeoutHandle);
99
+ this._finishPromise(resolve, v);
100
+ });
101
+ this.forceCheck();
102
+ });
103
+ this.logger?.log('started a new promise...');
104
+ }
105
+ return this._promise;
106
+ }
107
+ reverse() {
108
+ if (!this._getter) {
109
+ throw new Error('Cannot reverse TransitionObserver without getter being set');
110
+ }
111
+ return new TransitionObserver(this.reaction, this._getter)
112
+ .from(this._to)
113
+ .to(this._from);
114
+ }
115
+ dispose = () => {
116
+ this.logger?.log(' disposing... ');
117
+ if (this._disposer) {
118
+ this._disposer();
119
+ this._disposer = undefined;
120
+ }
121
+ if (this.isPromising) {
122
+ this._finishPromise(this._promiseReject ?? (() => { }), new Error('TransitionObserver Aborted'));
123
+ }
124
+ };
125
+ _checkValue = (v) => {
126
+ let trigger = false;
127
+ const from = getter_js_1.Getter.getValue(this._from);
128
+ const to = getter_js_1.Getter.getValue(this._to);
129
+ if (this._filter && !this._filter(v, this._prev)) {
130
+ trigger = false;
131
+ }
132
+ else if (from !== undefined && to !== undefined) {
133
+ // both 'from' and 'two' should be matched
134
+ trigger = this._prev === from && v === to;
135
+ }
136
+ else if (from !== undefined || to !== undefined) {
137
+ // at least one match – 'from' or 'to'
138
+ trigger = (from !== undefined && from === this._prev)
139
+ || (to !== undefined && to === v);
140
+ }
141
+ else {
142
+ // if both 'from' and 'to' are undefined – trigger for any change
143
+ // this._from === undefined && this._to === undefined;
144
+ trigger = true;
145
+ }
146
+ this.logger?.log('Checked value:', v, ' ==> will trigger:', trigger);
147
+ this._prev = v;
148
+ if (trigger) {
149
+ // will actually trigger only if someone subscribed to the event
150
+ // Use triggerAsync to catch and log all errors
151
+ this._event?.triggerAsync(v);
152
+ if (this._cb) {
153
+ this._cb(v);
154
+ }
155
+ if (this._fireOnce) {
156
+ this.dispose();
157
+ }
158
+ }
159
+ return trigger;
160
+ };
161
+ _finishPromise(cb, arg) {
162
+ this._promise = null;
163
+ this._promiseReject = null;
164
+ this._cb = null;
165
+ if (cb) {
166
+ cb(arg);
167
+ }
168
+ }
169
+ }
170
+ exports.TransitionObserver = TransitionObserver;
171
+ function waitFor(reaction, current, toBe) {
172
+ return new TransitionObserver(reaction, current)
173
+ .to(toBe)
174
+ .fireOnce()
175
+ .getPromise();
176
+ }
177
+ //# sourceMappingURL=transition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transition.js","sourceRoot":"","sources":["../../../src/observing/transition.ts"],"names":[],"mappings":"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"}
@@ -44,6 +44,10 @@ function combineUrls(...parts) {
44
44
  }
45
45
  }
46
46
  let result = _parts.join(separator);
47
+ // edge case: for empty result if both start/end separators requested – add only one
48
+ if (!result && (options?.addStart === true || options?.addTrail === true)) {
49
+ return separator;
50
+ }
47
51
  if (options?.addTrail) {
48
52
  const char = typeof options.addTrail === 'string'
49
53
  ? options.addTrail
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/structures/path/utils.ts"],"names":[],"mappings":";;;AAEA,8BAgBC;AAoBD,kCA2CC;AA/ED,SAAgB,SAAS,CAAC,GAA8B,EAAE,EAAU;IAChE,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC;QAC5B,OAAO,EAAE,CAAC;IACd,CAAC;IAED,IAAI,KAAK,GAAG,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC;IAEhC,OAAO,KAAK,GAAG,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE;QACnC,EAAE,KAAK,CAAC;IAEZ,OAAO,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,EAAE;QACrC,EAAE,GAAG,CAAC;IAEV,OAAO,CAAC,KAAK,GAAG,CAAC,IAAI,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC;QAClC,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,CAAC;QAC3B,CAAC,CAAC,GAAG,CAAC;AACd,CAAC;AAWD,IAAiB,cAAc,CAI9B;AAJD,WAAiB,cAAc;IAC3B,SAAgB,KAAK,CAAC,GAAG,OAAmC;QACxD,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC;IACzC,CAAC;IAFe,oBAAK,QAEpB,CAAA;AACL,CAAC,EAJgB,cAAc,8BAAd,cAAc,QAI9B;AAKD,SAAgB,WAAW,CAAC,GAAG,KAA0C;IACrE,MAAM,OAAO,GAAG,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ;QACxC,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,KAAK,CAAC,CAAC,CAA6B,CAAC;IAE3C,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,GAAG,CAAC;IAC5C,MAAM,UAAU,GAAG,OAAO,EAAE,UAAU,IAAI,GAAG,CAAC;IAE9C,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,IAAI,KAAK,CAAC;IACxC,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;QACpB,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;YACxB,SAAS;QACb,CAAC;QAED,IAAI,IAAI,GAAG,CAAC,CAAC;QACb,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,IAAI,GAAG,SAAS,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;QACpC,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACP,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC;IACL,CAAC;IAED,IAAI,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAEpC,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ;YAC7C,CAAC,CAAC,OAAO,CAAC,QAAQ;YAClB,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,IAAI,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;QACpB,MAAM,IAAI,GAAG,OAAO,OAAO,CAAC,QAAQ,KAAK,QAAQ;YAC7C,CAAC,CAAC,OAAO,CAAC,QAAQ;YAClB,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,GAAG,IAAI,GAAG,MAAM,CAAC;IAC3B,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/structures/path/utils.ts"],"names":[],"mappings":"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"}
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.PromiseCache = exports.DeferredGetter = void 0;
4
4
  const throttle_js_1 = require("../functions/throttle.js");
5
- const shared_js_1 = require("../logger/shared.js");
5
+ const loggable_js_1 = require("../logger/loggable.js");
6
6
  const Model_js_1 = require("../models/Model.js");
7
7
  var DeferredGetter;
8
8
  (function (DeferredGetter) {
@@ -21,7 +21,7 @@ const BATCHING_DELAY = 200;
21
21
  * - batching of fetches.
22
22
  * - auto-invalidation of cached items.
23
23
  */
24
- class PromiseCache {
24
+ class PromiseCache extends loggable_js_1.Loggable {
25
25
  fetcher;
26
26
  keyAdapter;
27
27
  keyParser;
@@ -33,9 +33,9 @@ class PromiseCache {
33
33
  _batch = null;
34
34
  _invalidationTimeMs = null;
35
35
  _keepInstanceDuringInvalidation = false;
36
- _logger = null;
37
36
  _version = 0;
38
37
  constructor(fetcher, keyAdapter, keyParser) {
38
+ super();
39
39
  this.fetcher = fetcher;
40
40
  this.keyAdapter = keyAdapter;
41
41
  this.keyParser = keyParser;
@@ -69,14 +69,8 @@ class PromiseCache {
69
69
  }
70
70
  return this.keyAdapter(k);
71
71
  }
72
- useLogger(nameOrLogger) {
73
- if (nameOrLogger != null && typeof nameOrLogger !== 'string') {
74
- this._logger = nameOrLogger;
75
- }
76
- else {
77
- this._logger = (0, shared_js_1.createLogger)(`[PromiseCache:${nameOrLogger || '?'}]`);
78
- }
79
- return this;
72
+ getLoggerName(name) {
73
+ return `[PromiseCache:${name || '?'}]`;
80
74
  }
81
75
  /**
82
76
  * Provide a fetcher function that takes multiple ids and returns multiple results at once. Will be called with a slight delay to allow multiple ids to be collected.
@@ -123,7 +117,7 @@ class PromiseCache {
123
117
  // make sure current item is hooked here from the cache (required by observers)
124
118
  const item = this._itemsCache.get(key);
125
119
  if (isInvalid) {
126
- this._logger?.log(key, 'item is invalidated');
120
+ this.logger?.log(key, 'item is invalidated');
127
121
  }
128
122
  return {
129
123
  item: (isInvalid && !this._keepInstanceDuringInvalidation) ? undefined : item,
@@ -137,19 +131,19 @@ class PromiseCache {
137
131
  // spin fetch
138
132
  this.get(id);
139
133
  }
140
- this._logger?.log(key, 'getCurrent: returns', item);
134
+ this.logger?.log(key, 'getCurrent: returns', item);
141
135
  return item;
142
136
  }
143
137
  get(id) {
144
138
  const { item, key, isInvalid } = this._getCurrent(id);
145
139
  // return cached item if it's not invalidated
146
140
  if (item !== undefined && !isInvalid) {
147
- this._logger?.log(key, 'get: item resolved to', item, isInvalid ? '(invalidated)' : '');
141
+ this.logger?.log(key, 'get: item resolved to', item, isInvalid ? '(invalidated)' : '');
148
142
  return Promise.resolve(item);
149
143
  }
150
144
  let promise = this._fetchCache.get(key);
151
145
  if (promise != null) {
152
- this._logger?.log(key, 'get: item resolved to <promise>');
146
+ this.logger?.log(key, 'get: item resolved to <promise>');
153
147
  return promise;
154
148
  }
155
149
  this.setStatus(key, true);
@@ -169,7 +163,7 @@ class PromiseCache {
169
163
  return res;
170
164
  }
171
165
  if (this._fetchCache.get(key) != null) {
172
- this._logger?.log(key, 'item\'s <promise> resolved to', res);
166
+ this.logger?.log(key, 'item\'s <promise> resolved to', res);
173
167
  res = this.prepareResult(res);
174
168
  this.storeResult(key, res);
175
169
  }
@@ -180,7 +174,7 @@ class PromiseCache {
180
174
  this.onFetchComplete(key);
181
175
  }
182
176
  else {
183
- this._logger?.log(key, 'skipping item\'s resolve due to version change ("clear()" has been called)');
177
+ this.logger?.log(key, 'skipping item\'s resolve due to version change ("clear()" has been called)');
184
178
  }
185
179
  }
186
180
  };
@@ -239,7 +233,7 @@ class PromiseCache {
239
233
  }
240
234
  /** @override */
241
235
  setStatus(key, status) {
242
- this._logger?.log(key, 'status update:', status);
236
+ this.logger?.log(key, 'status update:', status);
243
237
  this._itemsStatus.set(key, status);
244
238
  }
245
239
  /** @override */
@@ -268,7 +262,7 @@ class PromiseCache {
268
262
  /** @pure */
269
263
  async tryFetchInBatch(id) {
270
264
  const fetchWrap = () => this.fetcher(id).catch(err => {
271
- this._logger?.warn('fetcher failed', id, err);
265
+ this.logger?.warn('fetcher failed', id, err);
272
266
  return null;
273
267
  });
274
268
  if (!this._batch) {
@@ -276,7 +270,7 @@ class PromiseCache {
276
270
  }
277
271
  const res = await this._batch.push(id)
278
272
  .catch(err => {
279
- this._logger?.warn('batch fetch failed', id, err);
273
+ this.logger?.warn('batch fetch failed', id, err);
280
274
  return null;
281
275
  });
282
276
  if (!res || !res.result || res.result[res.index] === undefined) {