synstate 0.1.2 → 1.0.1

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 (323) hide show
  1. package/README.md +200 -147
  2. package/assets/old/synstate-icon-square.png +0 -0
  3. package/assets/synstate-logo.png +0 -0
  4. package/dist/core/class/child-observable-class.d.mts +2 -0
  5. package/dist/core/class/child-observable-class.d.mts.map +1 -1
  6. package/dist/core/class/child-observable-class.mjs +44 -13
  7. package/dist/core/class/child-observable-class.mjs.map +1 -1
  8. package/dist/core/class/observable-base-class.d.mts +4 -4
  9. package/dist/core/class/observable-base-class.d.mts.map +1 -1
  10. package/dist/core/class/observable-base-class.mjs +8 -8
  11. package/dist/core/class/observable-base-class.mjs.map +1 -1
  12. package/dist/core/class/root-observable-class.d.mts +3 -1
  13. package/dist/core/class/root-observable-class.d.mts.map +1 -1
  14. package/dist/core/class/root-observable-class.mjs +9 -9
  15. package/dist/core/class/root-observable-class.mjs.map +1 -1
  16. package/dist/core/combine/combine.d.mts +7 -6
  17. package/dist/core/combine/combine.d.mts.map +1 -1
  18. package/dist/core/combine/combine.mjs +11 -12
  19. package/dist/core/combine/combine.mjs.map +1 -1
  20. package/dist/core/combine/merge.d.mts +7 -6
  21. package/dist/core/combine/merge.d.mts.map +1 -1
  22. package/dist/core/combine/merge.mjs +9 -9
  23. package/dist/core/combine/merge.mjs.map +1 -1
  24. package/dist/core/combine/zip.d.mts +21 -19
  25. package/dist/core/combine/zip.d.mts.map +1 -1
  26. package/dist/core/combine/zip.mjs +22 -21
  27. package/dist/core/combine/zip.mjs.map +1 -1
  28. package/dist/core/create/{interval.d.mts → counter.d.mts} +14 -12
  29. package/dist/core/create/counter.d.mts.map +1 -0
  30. package/dist/core/create/{interval.mjs → counter.mjs} +21 -23
  31. package/dist/core/create/counter.mjs.map +1 -0
  32. package/dist/core/create/from-abortable-promise.d.mts +29 -0
  33. package/dist/core/create/from-abortable-promise.d.mts.map +1 -0
  34. package/dist/core/create/from-abortable-promise.mjs +70 -0
  35. package/dist/core/create/from-abortable-promise.mjs.map +1 -0
  36. package/dist/core/create/from-promise.d.mts +9 -6
  37. package/dist/core/create/from-promise.d.mts.map +1 -1
  38. package/dist/core/create/from-promise.mjs +8 -5
  39. package/dist/core/create/from-promise.mjs.map +1 -1
  40. package/dist/core/create/from-subscribable.d.mts +4 -4
  41. package/dist/core/create/from-subscribable.mjs +4 -4
  42. package/dist/core/create/index.d.mts +3 -3
  43. package/dist/core/create/index.d.mts.map +1 -1
  44. package/dist/core/create/index.mjs +4 -4
  45. package/dist/core/create/just.d.mts +32 -0
  46. package/dist/core/create/just.d.mts.map +1 -0
  47. package/dist/core/create/just.mjs +44 -0
  48. package/dist/core/create/just.mjs.map +1 -0
  49. package/dist/core/create/source.d.mts +7 -12
  50. package/dist/core/create/source.d.mts.map +1 -1
  51. package/dist/core/create/source.mjs +1 -6
  52. package/dist/core/create/source.mjs.map +1 -1
  53. package/dist/core/create/timer.d.mts +6 -4
  54. package/dist/core/create/timer.d.mts.map +1 -1
  55. package/dist/core/create/timer.mjs +6 -7
  56. package/dist/core/create/timer.mjs.map +1 -1
  57. package/dist/core/index.d.mts +0 -1
  58. package/dist/core/index.d.mts.map +1 -1
  59. package/dist/core/index.mjs +8 -13
  60. package/dist/core/index.mjs.map +1 -1
  61. package/dist/core/operators/audit.d.mts +97 -0
  62. package/dist/core/operators/audit.d.mts.map +1 -0
  63. package/dist/core/operators/audit.mjs +144 -0
  64. package/dist/core/operators/audit.mjs.map +1 -0
  65. package/dist/core/operators/debounce.d.mts +88 -0
  66. package/dist/core/operators/debounce.d.mts.map +1 -0
  67. package/dist/core/operators/debounce.mjs +130 -0
  68. package/dist/core/operators/debounce.mjs.map +1 -0
  69. package/dist/core/operators/filter.d.mts +6 -5
  70. package/dist/core/operators/filter.d.mts.map +1 -1
  71. package/dist/core/operators/filter.mjs +3 -3
  72. package/dist/core/operators/filter.mjs.map +1 -1
  73. package/dist/core/operators/index.d.mts +4 -4
  74. package/dist/core/operators/index.d.mts.map +1 -1
  75. package/dist/core/operators/index.mjs +4 -4
  76. package/dist/core/operators/{map-with-index.d.mts → map.d.mts} +12 -11
  77. package/dist/core/operators/map.d.mts.map +1 -0
  78. package/dist/core/operators/{map-with-index.mjs → map.mjs} +17 -17
  79. package/dist/core/operators/map.mjs.map +1 -0
  80. package/dist/core/operators/merge-map.d.mts +56 -29
  81. package/dist/core/operators/merge-map.d.mts.map +1 -1
  82. package/dist/core/operators/merge-map.mjs +58 -31
  83. package/dist/core/operators/merge-map.mjs.map +1 -1
  84. package/dist/core/operators/pairwise.d.mts +6 -6
  85. package/dist/core/operators/pairwise.mjs +9 -9
  86. package/dist/core/operators/pairwise.mjs.map +1 -1
  87. package/dist/core/operators/scan.d.mts +6 -6
  88. package/dist/core/operators/scan.mjs +9 -9
  89. package/dist/core/operators/scan.mjs.map +1 -1
  90. package/dist/core/operators/skip-if-no-change.d.mts +20 -8
  91. package/dist/core/operators/skip-if-no-change.d.mts.map +1 -1
  92. package/dist/core/operators/skip-if-no-change.mjs +23 -11
  93. package/dist/core/operators/skip-if-no-change.mjs.map +1 -1
  94. package/dist/core/operators/skip-until.d.mts +5 -5
  95. package/dist/core/operators/skip-until.mjs +8 -8
  96. package/dist/core/operators/skip-until.mjs.map +1 -1
  97. package/dist/core/operators/skip-while.d.mts +19 -8
  98. package/dist/core/operators/skip-while.d.mts.map +1 -1
  99. package/dist/core/operators/skip-while.mjs +26 -11
  100. package/dist/core/operators/skip-while.mjs.map +1 -1
  101. package/dist/core/operators/switch-map.d.mts +57 -26
  102. package/dist/core/operators/switch-map.d.mts.map +1 -1
  103. package/dist/core/operators/switch-map.mjs +59 -28
  104. package/dist/core/operators/switch-map.mjs.map +1 -1
  105. package/dist/core/operators/take-until.d.mts +5 -5
  106. package/dist/core/operators/take-until.mjs +8 -8
  107. package/dist/core/operators/take-until.mjs.map +1 -1
  108. package/dist/core/operators/take-while.d.mts +16 -7
  109. package/dist/core/operators/take-while.d.mts.map +1 -1
  110. package/dist/core/operators/take-while.mjs +18 -10
  111. package/dist/core/operators/take-while.mjs.map +1 -1
  112. package/dist/core/operators/throttle.d.mts +81 -0
  113. package/dist/core/operators/throttle.d.mts.map +1 -0
  114. package/dist/core/operators/throttle.mjs +126 -0
  115. package/dist/core/operators/throttle.mjs.map +1 -0
  116. package/dist/core/operators/with-buffered-from.d.mts +9 -9
  117. package/dist/core/operators/with-buffered-from.mjs +12 -12
  118. package/dist/core/operators/with-buffered-from.mjs.map +1 -1
  119. package/dist/core/operators/with-current-value-from.d.mts +10 -9
  120. package/dist/core/operators/with-current-value-from.d.mts.map +1 -1
  121. package/dist/core/operators/with-current-value-from.mjs +13 -12
  122. package/dist/core/operators/with-current-value-from.mjs.map +1 -1
  123. package/dist/core/operators/with-initial-value.d.mts +5 -5
  124. package/dist/core/operators/with-initial-value.mjs +8 -8
  125. package/dist/core/operators/with-initial-value.mjs.map +1 -1
  126. package/dist/core/predefined/index.mjs +0 -1
  127. package/dist/core/predefined/index.mjs.map +1 -1
  128. package/dist/core/predefined/operators/attach-index.d.mts +50 -0
  129. package/dist/core/predefined/operators/attach-index.d.mts.map +1 -1
  130. package/dist/core/predefined/operators/attach-index.mjs +51 -2
  131. package/dist/core/predefined/operators/attach-index.mjs.map +1 -1
  132. package/dist/core/predefined/operators/index.d.mts +0 -1
  133. package/dist/core/predefined/operators/index.d.mts.map +1 -1
  134. package/dist/core/predefined/operators/index.mjs +0 -1
  135. package/dist/core/predefined/operators/index.mjs.map +1 -1
  136. package/dist/core/predefined/operators/map-optional.d.mts +48 -1
  137. package/dist/core/predefined/operators/map-optional.d.mts.map +1 -1
  138. package/dist/core/predefined/operators/map-optional.mjs +49 -1
  139. package/dist/core/predefined/operators/map-optional.mjs.map +1 -1
  140. package/dist/core/predefined/operators/map-result-err.d.mts +48 -1
  141. package/dist/core/predefined/operators/map-result-err.d.mts.map +1 -1
  142. package/dist/core/predefined/operators/map-result-err.mjs +49 -1
  143. package/dist/core/predefined/operators/map-result-err.mjs.map +1 -1
  144. package/dist/core/predefined/operators/map-result-ok.d.mts +48 -1
  145. package/dist/core/predefined/operators/map-result-ok.d.mts.map +1 -1
  146. package/dist/core/predefined/operators/map-result-ok.mjs +49 -1
  147. package/dist/core/predefined/operators/map-result-ok.mjs.map +1 -1
  148. package/dist/core/predefined/operators/map-to.d.mts +40 -0
  149. package/dist/core/predefined/operators/map-to.d.mts.map +1 -1
  150. package/dist/core/predefined/operators/map-to.mjs +43 -1
  151. package/dist/core/predefined/operators/map-to.mjs.map +1 -1
  152. package/dist/core/predefined/operators/pluck.d.mts +39 -0
  153. package/dist/core/predefined/operators/pluck.d.mts.map +1 -1
  154. package/dist/core/predefined/operators/pluck.mjs +42 -1
  155. package/dist/core/predefined/operators/pluck.mjs.map +1 -1
  156. package/dist/core/predefined/operators/skip.d.mts +48 -0
  157. package/dist/core/predefined/operators/skip.d.mts.map +1 -1
  158. package/dist/core/predefined/operators/skip.mjs +47 -0
  159. package/dist/core/predefined/operators/skip.mjs.map +1 -1
  160. package/dist/core/predefined/operators/take.d.mts +42 -0
  161. package/dist/core/predefined/operators/take.d.mts.map +1 -1
  162. package/dist/core/predefined/operators/take.mjs +41 -0
  163. package/dist/core/predefined/operators/take.mjs.map +1 -1
  164. package/dist/core/predefined/operators/unwrap-optional.d.mts +41 -1
  165. package/dist/core/predefined/operators/unwrap-optional.d.mts.map +1 -1
  166. package/dist/core/predefined/operators/unwrap-optional.mjs +42 -1
  167. package/dist/core/predefined/operators/unwrap-optional.mjs.map +1 -1
  168. package/dist/core/predefined/operators/unwrap-result-err.d.mts +41 -1
  169. package/dist/core/predefined/operators/unwrap-result-err.d.mts.map +1 -1
  170. package/dist/core/predefined/operators/unwrap-result-err.mjs +42 -1
  171. package/dist/core/predefined/operators/unwrap-result-err.mjs.map +1 -1
  172. package/dist/core/predefined/operators/unwrap-result-ok.d.mts +41 -1
  173. package/dist/core/predefined/operators/unwrap-result-ok.d.mts.map +1 -1
  174. package/dist/core/predefined/operators/unwrap-result-ok.mjs +42 -1
  175. package/dist/core/predefined/operators/unwrap-result-ok.mjs.map +1 -1
  176. package/dist/core/types/id.d.mts +2 -1
  177. package/dist/core/types/id.d.mts.map +1 -1
  178. package/dist/core/types/index.d.mts +1 -0
  179. package/dist/core/types/index.d.mts.map +1 -1
  180. package/dist/core/types/observable-family.d.mts +10 -14
  181. package/dist/core/types/observable-family.d.mts.map +1 -1
  182. package/dist/core/types/observable-kind.d.mts +1 -0
  183. package/dist/core/types/observable-kind.d.mts.map +1 -1
  184. package/dist/core/types/observable.d.mts +5 -3
  185. package/dist/core/types/observable.d.mts.map +1 -1
  186. package/dist/core/types/observable.mjs.map +1 -1
  187. package/dist/core/types/timer.d.mts +2 -0
  188. package/dist/core/types/timer.d.mts.map +1 -0
  189. package/dist/core/types/timer.mjs +2 -0
  190. package/dist/core/types/timer.mjs.map +1 -0
  191. package/dist/core/utils/id-maker.d.mts +2 -2
  192. package/dist/core/utils/id-maker.d.mts.map +1 -1
  193. package/dist/core/utils/id-maker.mjs +3 -3
  194. package/dist/core/utils/id-maker.mjs.map +1 -1
  195. package/dist/core/utils/index.mjs +1 -1
  196. package/dist/core/utils/utils.d.mts +2 -0
  197. package/dist/core/utils/utils.d.mts.map +1 -1
  198. package/dist/core/utils/utils.mjs.map +1 -1
  199. package/dist/entry-point.mjs +11 -14
  200. package/dist/entry-point.mjs.map +1 -1
  201. package/dist/index.mjs +11 -14
  202. package/dist/index.mjs.map +1 -1
  203. package/dist/types.d.mts +1 -2
  204. package/dist/utils/collect-to-array.d.mts +3 -0
  205. package/dist/utils/collect-to-array.d.mts.map +1 -0
  206. package/dist/utils/collect-to-array.mjs +11 -0
  207. package/dist/utils/collect-to-array.mjs.map +1 -0
  208. package/dist/utils/create-boolean-state.d.mts +40 -0
  209. package/dist/utils/create-boolean-state.d.mts.map +1 -0
  210. package/dist/utils/create-boolean-state.mjs +53 -0
  211. package/dist/utils/create-boolean-state.mjs.map +1 -0
  212. package/dist/utils/create-event-emitter.d.mts +4 -4
  213. package/dist/utils/create-event-emitter.mjs +4 -4
  214. package/dist/utils/create-reducer.d.mts +11 -7
  215. package/dist/utils/create-reducer.d.mts.map +1 -1
  216. package/dist/utils/create-reducer.mjs +7 -7
  217. package/dist/utils/create-reducer.mjs.map +1 -1
  218. package/dist/utils/create-state.d.mts +8 -48
  219. package/dist/utils/create-state.d.mts.map +1 -1
  220. package/dist/utils/create-state.mjs +10 -60
  221. package/dist/utils/create-state.mjs.map +1 -1
  222. package/dist/utils/index.d.mts +2 -0
  223. package/dist/utils/index.d.mts.map +1 -1
  224. package/dist/utils/index.mjs +3 -1
  225. package/dist/utils/index.mjs.map +1 -1
  226. package/package.json +21 -14
  227. package/src/core/class/child-observable-class.mts +68 -14
  228. package/src/core/class/circular-dependency-comparison.test.mts +142 -0
  229. package/src/core/class/circular-dependency.test.mts +251 -0
  230. package/src/core/class/observable-base-class.mts +10 -9
  231. package/src/core/class/root-observable-class.mts +15 -10
  232. package/src/core/combine/combine.mts +14 -13
  233. package/src/core/combine/merge.mts +14 -14
  234. package/src/core/combine/zip.mts +27 -25
  235. package/src/core/create/{interval.mts → counter.mts} +32 -30
  236. package/src/core/create/from-abortable-promise.mts +83 -0
  237. package/src/core/create/from-promise.mts +10 -7
  238. package/src/core/create/from-subscribable.mts +4 -4
  239. package/src/core/create/index.mts +3 -3
  240. package/src/core/create/just.mts +43 -0
  241. package/src/core/create/source.mts +10 -14
  242. package/src/core/create/timer.mts +12 -11
  243. package/src/core/index.mts +0 -1
  244. package/src/core/operators/audit.mts +172 -0
  245. package/src/core/operators/debounce.mts +154 -0
  246. package/src/core/operators/filter.mts +9 -9
  247. package/src/core/operators/index.mts +4 -4
  248. package/src/core/operators/{map-with-index.mts → map.mts} +20 -20
  249. package/src/core/operators/merge-map.mts +59 -32
  250. package/src/core/operators/pairwise.mts +10 -10
  251. package/src/core/operators/scan.mts +10 -10
  252. package/src/core/operators/skip-if-no-change.mts +24 -12
  253. package/src/core/operators/skip-until.mts +9 -9
  254. package/src/core/operators/skip-while.mts +29 -12
  255. package/src/core/operators/switch-map.mts +60 -29
  256. package/src/core/operators/take-until.mts +9 -9
  257. package/src/core/operators/take-while.mts +19 -11
  258. package/src/core/operators/{throttle-time.mts → throttle.mts} +58 -38
  259. package/src/core/operators/with-buffered-from.mts +13 -13
  260. package/src/core/operators/with-current-value-from.mts +14 -13
  261. package/src/core/operators/with-initial-value.mts +9 -9
  262. package/src/core/predefined/operators/attach-index.mts +52 -2
  263. package/src/core/predefined/operators/index.mts +0 -1
  264. package/src/core/predefined/operators/map-optional.mts +49 -2
  265. package/src/core/predefined/operators/map-result-err.mts +49 -2
  266. package/src/core/predefined/operators/map-result-ok.mts +49 -2
  267. package/src/core/predefined/operators/map-to.mts +41 -1
  268. package/src/core/predefined/operators/pluck.mts +40 -1
  269. package/src/core/predefined/operators/skip.mts +48 -0
  270. package/src/core/predefined/operators/take.mts +42 -0
  271. package/src/core/predefined/operators/unwrap-optional.mts +43 -2
  272. package/src/core/predefined/operators/unwrap-result-err.mts +43 -2
  273. package/src/core/predefined/operators/unwrap-result-ok.mts +43 -2
  274. package/src/core/types/id.mts +3 -1
  275. package/src/core/types/index.mts +1 -0
  276. package/src/core/types/observable-family.mts +13 -24
  277. package/src/core/types/observable-kind.mts +2 -0
  278. package/src/core/types/observable.mts +5 -4
  279. package/src/core/types/timer.mts +2 -0
  280. package/src/core/utils/id-maker.mts +4 -4
  281. package/src/core/utils/utils.mts +1 -0
  282. package/src/utils/collect-to-array.mts +17 -0
  283. package/src/utils/create-boolean-state.mts +68 -0
  284. package/src/utils/create-event-emitter.mts +4 -4
  285. package/src/utils/create-reducer.mts +12 -8
  286. package/src/utils/create-state.mts +10 -75
  287. package/src/utils/index.mts +2 -0
  288. package/dist/core/create/from-array.d.mts +0 -39
  289. package/dist/core/create/from-array.d.mts.map +0 -1
  290. package/dist/core/create/from-array.mjs +0 -65
  291. package/dist/core/create/from-array.mjs.map +0 -1
  292. package/dist/core/create/interval.d.mts.map +0 -1
  293. package/dist/core/create/interval.mjs.map +0 -1
  294. package/dist/core/create/of.d.mts +0 -39
  295. package/dist/core/create/of.d.mts.map +0 -1
  296. package/dist/core/create/of.mjs +0 -63
  297. package/dist/core/create/of.mjs.map +0 -1
  298. package/dist/core/operators/audit-time.d.mts +0 -62
  299. package/dist/core/operators/audit-time.d.mts.map +0 -1
  300. package/dist/core/operators/audit-time.mjs +0 -109
  301. package/dist/core/operators/audit-time.mjs.map +0 -1
  302. package/dist/core/operators/debounce-time.d.mts +0 -51
  303. package/dist/core/operators/debounce-time.d.mts.map +0 -1
  304. package/dist/core/operators/debounce-time.mjs +0 -93
  305. package/dist/core/operators/debounce-time.mjs.map +0 -1
  306. package/dist/core/operators/map-with-index.d.mts.map +0 -1
  307. package/dist/core/operators/map-with-index.mjs.map +0 -1
  308. package/dist/core/operators/throttle-time.d.mts +0 -62
  309. package/dist/core/operators/throttle-time.d.mts.map +0 -1
  310. package/dist/core/operators/throttle-time.mjs +0 -107
  311. package/dist/core/operators/throttle-time.mjs.map +0 -1
  312. package/dist/core/predefined/operators/map.d.mts +0 -3
  313. package/dist/core/predefined/operators/map.d.mts.map +0 -1
  314. package/dist/core/predefined/operators/map.mjs +0 -8
  315. package/dist/core/predefined/operators/map.mjs.map +0 -1
  316. package/dist/globals.d.mts +0 -4
  317. package/src/core/create/from-array.mts +0 -76
  318. package/src/core/create/of.mts +0 -73
  319. package/src/core/operators/audit-time.mts +0 -136
  320. package/src/core/operators/debounce-time.mts +0 -116
  321. package/src/core/predefined/operators/map.mts +0 -5
  322. package/src/globals.d.mts +0 -4
  323. /package/assets/{synstate-icon.png → old/synstate-icon.png} +0 -0
@@ -19,12 +19,12 @@ import { type TimerObservable } from '../types/index.mjs';
19
19
  *
20
20
  * const delayed$ = timer(100);
21
21
  *
22
- * const mut_history: number[] = [];
22
+ * const valueHistory: number[] = [];
23
23
  *
24
24
  * await new Promise<void>((resolve) => {
25
25
  * delayed$.subscribe(
26
26
  * () => {
27
- * mut_history.push(1);
27
+ * valueHistory.push(1);
28
28
  * },
29
29
  * () => {
30
30
  * resolve();
@@ -32,8 +32,10 @@ import { type TimerObservable } from '../types/index.mjs';
32
32
  * );
33
33
  * });
34
34
  *
35
- * assert.deepStrictEqual(mut_history, [1]);
35
+ * assert.deepStrictEqual(valueHistory, [1]);
36
36
  * ```
37
37
  */
38
- export declare const timer: (milliSeconds: number, startManually?: boolean) => TimerObservable;
38
+ export declare const timer: (milliSeconds: number, options?: Readonly<{
39
+ startManually?: boolean;
40
+ }>) => TimerObservable;
39
41
  //# sourceMappingURL=timer.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"timer.d.mts","sourceRoot":"","sources":["../../../src/core/create/timer.mts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAE1D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,eAAO,MAAM,KAAK,GAChB,cAAc,MAAM,EACpB,gBAAe,OAAe,KAC7B,eAAwE,CAAC"}
1
+ {"version":3,"file":"timer.d.mts","sourceRoot":"","sources":["../../../src/core/create/timer.mts"],"names":[],"mappings":"AAEA,OAAO,EAAgB,KAAK,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAExE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,eAAO,MAAM,KAAK,GAChB,cAAc,MAAM,EACpB,UAAU,QAAQ,CAAC;IACjB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB,CAAC,KACD,eACsE,CAAC"}
@@ -22,12 +22,12 @@ import { RootObservableClass } from '../class/root-observable-class.mjs';
22
22
  *
23
23
  * const delayed$ = timer(100);
24
24
  *
25
- * const mut_history: number[] = [];
25
+ * const valueHistory: number[] = [];
26
26
  *
27
27
  * await new Promise<void>((resolve) => {
28
28
  * delayed$.subscribe(
29
29
  * () => {
30
- * mut_history.push(1);
30
+ * valueHistory.push(1);
31
31
  * },
32
32
  * () => {
33
33
  * resolve();
@@ -35,10 +35,10 @@ import { RootObservableClass } from '../class/root-observable-class.mjs';
35
35
  * );
36
36
  * });
37
37
  *
38
- * assert.deepStrictEqual(mut_history, [1]);
38
+ * assert.deepStrictEqual(valueHistory, [1]);
39
39
  * ```
40
40
  */
41
- const timer = (milliSeconds, startManually = false) => new TimerObservableClass(milliSeconds, startManually);
41
+ const timer = (milliSeconds, options) => new TimerObservableClass(milliSeconds, options?.startManually ?? false);
42
42
  class TimerObservableClass extends RootObservableClass {
43
43
  #milliSeconds;
44
44
  #mut_timerId;
@@ -55,18 +55,17 @@ class TimerObservableClass extends RootObservableClass {
55
55
  start() {
56
56
  if (this.#mut_isStarted) {
57
57
  console.warn('cannot start twice');
58
- return this;
58
+ return;
59
59
  }
60
60
  this.#mut_isStarted = true;
61
61
  if (this.isCompleted) {
62
62
  console.warn('cannot restart stopped TimerObservable');
63
- return this;
63
+ return;
64
64
  }
65
65
  this.#mut_timerId = setTimeout(() => {
66
66
  this.startUpdate(0);
67
67
  this.complete();
68
68
  }, this.#milliSeconds);
69
- return this;
70
69
  }
71
70
  #resetTimer() {
72
71
  if (this.#mut_timerId !== undefined) {
@@ -1 +1 @@
1
- {"version":3,"file":"timer.mjs","sources":["../../../src/core/create/timer.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmCG;AACI,MAAM,KAAK,GAAG,CACnB,YAAoB,EACpB,aAAA,GAAyB,KAAK,KACV,IAAI,oBAAoB,CAAC,YAAY,EAAE,aAAa;AAE1E,MAAM,oBACJ,SAAQ,mBAAsB,CAAA;AAGrB,IAAA,aAAa;AACtB,IAAA,YAAY;AACZ,IAAA,cAAc;IAEd,WAAA,CAAY,YAAoB,EAAE,aAAsB,EAAA;QACtD,KAAK,CAAC,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC;AAEtC,QAAA,IAAI,CAAC,aAAa,GAAG,YAAY;AAEjC,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS;AAE7B,QAAA,IAAI,CAAC,cAAc,GAAG,KAAK;QAE3B,IAAI,CAAC,aAAa,EAAE;YAClB,IAAI,CAAC,KAAK,EAAE;QACd;IACF;IAEA,KAAK,GAAA;AACH,QAAA,IAAI,IAAI,CAAC,cAAc,EAAE;AACvB,YAAA,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC;AAElC,YAAA,OAAO,IAAI;QACb;AAEA,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI;AAE1B,QAAA,IAAI,IAAI,CAAC,WAAW,EAAE;AACpB,YAAA,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC;AAEtD,YAAA,OAAO,IAAI;QACb;AAEA,QAAA,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,MAAK;AAClC,YAAA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YAEnB,IAAI,CAAC,QAAQ,EAAE;AACjB,QAAA,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;AAEtB,QAAA,OAAO,IAAI;IACb;IAEA,WAAW,GAAA;AACT,QAAA,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;AACnC,YAAA,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;QACjC;IACF;IAES,QAAQ,GAAA;QACf,IAAI,CAAC,WAAW,EAAE;QAElB,KAAK,CAAC,QAAQ,EAAE;IAClB;AACD;;;;"}
1
+ {"version":3,"file":"timer.mjs","sources":["../../../src/core/create/timer.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmCG;MACU,KAAK,GAAG,CACnB,YAAoB,EACpB,OAEE,KAEF,IAAI,oBAAoB,CAAC,YAAY,EAAE,OAAO,EAAE,aAAa,IAAI,KAAK;AAExE,MAAM,oBACJ,SAAQ,mBAAsB,CAAA;AAGrB,IAAA,aAAa;AACtB,IAAA,YAAY;AACZ,IAAA,cAAc;IAEd,WAAA,CAAY,YAAoB,EAAE,aAAsB,EAAA;QACtD,KAAK,CAAC,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC;AAEtC,QAAA,IAAI,CAAC,aAAa,GAAG,YAAY;AAEjC,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS;AAE7B,QAAA,IAAI,CAAC,cAAc,GAAG,KAAK;QAE3B,IAAI,CAAC,aAAa,EAAE;YAClB,IAAI,CAAC,KAAK,EAAE;QACd;IACF;IAEA,KAAK,GAAA;AACH,QAAA,IAAI,IAAI,CAAC,cAAc,EAAE;AACvB,YAAA,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC;YAElC;QACF;AAEA,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI;AAE1B,QAAA,IAAI,IAAI,CAAC,WAAW,EAAE;AACpB,YAAA,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC;YAEtD;QACF;AAEA,QAAA,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,MAAK;AAClC,YAAA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YAEnB,IAAI,CAAC,QAAQ,EAAE;AACjB,QAAA,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;IACxB;IAEA,WAAW,GAAA;AACT,QAAA,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;AACnC,YAAA,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;QACjC;IACF;IAES,QAAQ,GAAA;QACf,IAAI,CAAC,WAAW,EAAE;QAElB,KAAK,CAAC,QAAQ,EAAE;IAClB;AACD;;;;"}
@@ -4,5 +4,4 @@ export * from './create/index.mjs';
4
4
  export * from './operators/index.mjs';
5
5
  export * from './predefined/index.mjs';
6
6
  export * from './types/index.mjs';
7
- export * from './utils/index.mjs';
8
7
  //# sourceMappingURL=index.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../src/core/index.mts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../src/core/index.mts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC"}
@@ -4,17 +4,17 @@ export { RootObservableClass } from './class/root-observable-class.mjs';
4
4
  export { combine, combineLatest } from './combine/combine.mjs';
5
5
  export { merge } from './combine/merge.mjs';
6
6
  export { zip } from './combine/zip.mjs';
7
- export { fromArray } from './create/from-array.mjs';
7
+ export { counter } from './create/counter.mjs';
8
+ export { fromAbortablePromise } from './create/from-abortable-promise.mjs';
8
9
  export { fromPromise } from './create/from-promise.mjs';
9
10
  export { fromSubscribable } from './create/from-subscribable.mjs';
10
- export { interval } from './create/interval.mjs';
11
- export { of } from './create/of.mjs';
12
- export { source, subject } from './create/source.mjs';
11
+ export { just } from './create/just.mjs';
12
+ export { source } from './create/source.mjs';
13
13
  export { timer } from './create/timer.mjs';
14
- export { auditTime } from './operators/audit-time.mjs';
15
- export { debounceTime } from './operators/debounce-time.mjs';
14
+ export { audit } from './operators/audit.mjs';
15
+ export { debounce } from './operators/debounce.mjs';
16
16
  export { filter } from './operators/filter.mjs';
17
- export { mapWithIndex } from './operators/map-with-index.mjs';
17
+ export { map } from './operators/map.mjs';
18
18
  export { flatMap, mergeMap } from './operators/merge-map.mjs';
19
19
  export { pairwise } from './operators/pairwise.mjs';
20
20
  export { scan } from './operators/scan.mjs';
@@ -24,7 +24,7 @@ export { skipWhile } from './operators/skip-while.mjs';
24
24
  export { switchMap } from './operators/switch-map.mjs';
25
25
  export { takeUntil } from './operators/take-until.mjs';
26
26
  export { takeWhile } from './operators/take-while.mjs';
27
- export { throttleTime } from './operators/throttle-time.mjs';
27
+ export { throttle } from './operators/throttle.mjs';
28
28
  export { withBuffered, withBufferedFrom } from './operators/with-buffered-from.mjs';
29
29
  export { withCurrentValueFrom, withLatestFrom } from './operators/with-current-value-from.mjs';
30
30
  export { withInitialValue } from './operators/with-initial-value.mjs';
@@ -33,7 +33,6 @@ export { mapOptional } from './predefined/operators/map-optional.mjs';
33
33
  export { mapResultErr } from './predefined/operators/map-result-err.mjs';
34
34
  export { mapResultOk } from './predefined/operators/map-result-ok.mjs';
35
35
  export { mapTo } from './predefined/operators/map-to.mjs';
36
- export { map } from './predefined/operators/map.mjs';
37
36
  export { getKey, pluck } from './predefined/operators/pluck.mjs';
38
37
  export { skip } from './predefined/operators/skip.mjs';
39
38
  export { take } from './predefined/operators/take.mjs';
@@ -42,8 +41,4 @@ export { unwrapResultErr } from './predefined/operators/unwrap-result-err.mjs';
42
41
  export { unwrapResultOk } from './predefined/operators/unwrap-result-ok.mjs';
43
42
  import 'ts-data-forge';
44
43
  export { isChildObservable, isManagerObservable, isRootObservable } from './types/observable.mjs';
45
- export { issueObservableId, issueSubscriberId, issueUpdaterSymbol } from './utils/id-maker.mjs';
46
- export { maxDepth } from './utils/max-depth.mjs';
47
- export { toSubscriber } from './utils/observable-utils.mjs';
48
- export { binarySearch, halfInt } from './utils/utils.mjs';
49
44
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,97 @@
1
+ import { type KeepInitialValueOperator } from '../types/index.mjs';
2
+ /**
3
+ * Ignores source values for duration milliseconds, then emits the most recent value from the source Observable, then repeats this process.
4
+ *
5
+ * Unlike `throttle` which emits the first value, `audit` emits the last value.
6
+ *
7
+ * @template A - The type of values from the source
8
+ * @param milliSeconds - The audit time window in milliseconds
9
+ * @returns An operator that audits emissions from the observable
10
+ *
11
+ * @example
12
+ * ```ts
13
+ * // Timeline (250ms audit):
14
+ * //
15
+ * // Time(x50ms) 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0
16
+ * //
17
+ * // input$ 0 2 3 9 10 11 12 13 14
18
+ * // |- 250ms -> |- 250ms -> |- 250ms -> |- 250ms ->
19
+ * // audited$ 2 3 11 14 (emitted at end of window)
20
+ * //
21
+ * // Explanation:
22
+ * // - audit emits the LAST value received during each time window
23
+ * // - Unlike throttle (which emits the FIRST value), audit emits the LAST
24
+ * // - Useful when you want the most recent value after a burst of events
25
+ *
26
+ * const input$ = source<number>();
27
+ *
28
+ * const audited$ = input$.pipe(audit(250));
29
+ *
30
+ * const valueHistory: number[] = [];
31
+ *
32
+ * audited$.subscribe((value) => {
33
+ * valueHistory.push(value);
34
+ * });
35
+ *
36
+ * const sleep = (ms: number): Promise<void> =>
37
+ * new Promise((resolve) => {
38
+ * setTimeout(resolve, ms);
39
+ * });
40
+ *
41
+ * input$.next(0);
42
+ *
43
+ * await sleep(200);
44
+ *
45
+ * input$.next(2);
46
+ *
47
+ * assert.deepStrictEqual(valueHistory, []);
48
+ *
49
+ * await sleep(100);
50
+ *
51
+ * assert.deepStrictEqual(valueHistory, [2]);
52
+ *
53
+ * input$.next(3);
54
+ *
55
+ * await sleep(300);
56
+ *
57
+ * assert.deepStrictEqual(valueHistory, [2, 3]);
58
+ *
59
+ * await sleep(300);
60
+ *
61
+ * input$.next(9);
62
+ *
63
+ * await sleep(100);
64
+ *
65
+ * input$.next(10);
66
+ *
67
+ * await sleep(100);
68
+ *
69
+ * input$.next(11);
70
+ *
71
+ * assert.deepStrictEqual(valueHistory, [2, 3]);
72
+ *
73
+ * await sleep(100);
74
+ *
75
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11]);
76
+ *
77
+ * input$.next(12);
78
+ *
79
+ * await sleep(100);
80
+ *
81
+ * input$.next(13);
82
+ *
83
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11]);
84
+ *
85
+ * await sleep(100);
86
+ *
87
+ * input$.next(14);
88
+ *
89
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11]);
90
+ *
91
+ * await sleep(100);
92
+ *
93
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11, 14]);
94
+ * ```
95
+ */
96
+ export declare const audit: <A>(milliSeconds: number) => KeepInitialValueOperator<A, A>;
97
+ //# sourceMappingURL=audit.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit.d.mts","sourceRoot":"","sources":["../../../src/core/operators/audit.mts"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,wBAAwB,EAI9B,MAAM,oBAAoB,CAAC;AAE5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6FG;AACH,eAAO,MAAM,KAAK,GAAI,CAAC,EACrB,cAAc,MAAM,KACnB,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAMQ,CAAC"}
@@ -0,0 +1,144 @@
1
+ import { Optional } from 'ts-data-forge';
2
+ import { AsyncChildObservableClass } from '../class/child-observable-class.mjs';
3
+ import '../utils/id-maker.mjs';
4
+
5
+ /**
6
+ * Ignores source values for duration milliseconds, then emits the most recent value from the source Observable, then repeats this process.
7
+ *
8
+ * Unlike `throttle` which emits the first value, `audit` emits the last value.
9
+ *
10
+ * @template A - The type of values from the source
11
+ * @param milliSeconds - The audit time window in milliseconds
12
+ * @returns An operator that audits emissions from the observable
13
+ *
14
+ * @example
15
+ * ```ts
16
+ * // Timeline (250ms audit):
17
+ * //
18
+ * // Time(x50ms) 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0
19
+ * //
20
+ * // input$ 0 2 3 9 10 11 12 13 14
21
+ * // |- 250ms -> |- 250ms -> |- 250ms -> |- 250ms ->
22
+ * // audited$ 2 3 11 14 (emitted at end of window)
23
+ * //
24
+ * // Explanation:
25
+ * // - audit emits the LAST value received during each time window
26
+ * // - Unlike throttle (which emits the FIRST value), audit emits the LAST
27
+ * // - Useful when you want the most recent value after a burst of events
28
+ *
29
+ * const input$ = source<number>();
30
+ *
31
+ * const audited$ = input$.pipe(audit(250));
32
+ *
33
+ * const valueHistory: number[] = [];
34
+ *
35
+ * audited$.subscribe((value) => {
36
+ * valueHistory.push(value);
37
+ * });
38
+ *
39
+ * const sleep = (ms: number): Promise<void> =>
40
+ * new Promise((resolve) => {
41
+ * setTimeout(resolve, ms);
42
+ * });
43
+ *
44
+ * input$.next(0);
45
+ *
46
+ * await sleep(200);
47
+ *
48
+ * input$.next(2);
49
+ *
50
+ * assert.deepStrictEqual(valueHistory, []);
51
+ *
52
+ * await sleep(100);
53
+ *
54
+ * assert.deepStrictEqual(valueHistory, [2]);
55
+ *
56
+ * input$.next(3);
57
+ *
58
+ * await sleep(300);
59
+ *
60
+ * assert.deepStrictEqual(valueHistory, [2, 3]);
61
+ *
62
+ * await sleep(300);
63
+ *
64
+ * input$.next(9);
65
+ *
66
+ * await sleep(100);
67
+ *
68
+ * input$.next(10);
69
+ *
70
+ * await sleep(100);
71
+ *
72
+ * input$.next(11);
73
+ *
74
+ * assert.deepStrictEqual(valueHistory, [2, 3]);
75
+ *
76
+ * await sleep(100);
77
+ *
78
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11]);
79
+ *
80
+ * input$.next(12);
81
+ *
82
+ * await sleep(100);
83
+ *
84
+ * input$.next(13);
85
+ *
86
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11]);
87
+ *
88
+ * await sleep(100);
89
+ *
90
+ * input$.next(14);
91
+ *
92
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11]);
93
+ *
94
+ * await sleep(100);
95
+ *
96
+ * assert.deepStrictEqual(valueHistory, [2, 3, 11, 14]);
97
+ * ```
98
+ */
99
+ const audit = (milliSeconds) =>
100
+ // eslint-disable-next-line total-functions/no-unsafe-type-assertion
101
+ ((parentObservable) => new AuditObservableClass(parentObservable, milliSeconds));
102
+ class AuditObservableClass extends AsyncChildObservableClass {
103
+ #milliSeconds;
104
+ #mut_timerId;
105
+ #mut_isSkipping;
106
+ constructor(parentObservable, milliSeconds) {
107
+ super({
108
+ parents: [parentObservable],
109
+ initialValue: parentObservable.getSnapshot(),
110
+ });
111
+ this.#mut_isSkipping = false;
112
+ this.#mut_timerId = undefined;
113
+ this.#milliSeconds = milliSeconds;
114
+ }
115
+ tryUpdate(updateToken) {
116
+ const par = this.parents[0];
117
+ if (par.updateToken !== updateToken ||
118
+ Optional.isNone(par.getSnapshot()) ||
119
+ this.#mut_isSkipping) {
120
+ return; // skip update
121
+ }
122
+ // set timer
123
+ this.#mut_isSkipping = true;
124
+ this.#mut_timerId = setTimeout(() => {
125
+ const sn = par.getSnapshot();
126
+ if (Optional.isNone(sn))
127
+ return;
128
+ this.startUpdate(sn.value);
129
+ this.#mut_isSkipping = false;
130
+ }, this.#milliSeconds);
131
+ }
132
+ #resetTimer() {
133
+ if (this.#mut_timerId !== undefined) {
134
+ clearTimeout(this.#mut_timerId);
135
+ }
136
+ }
137
+ complete() {
138
+ this.#resetTimer();
139
+ super.complete();
140
+ }
141
+ }
142
+
143
+ export { audit };
144
+ //# sourceMappingURL=audit.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit.mjs","sources":["../../../src/core/operators/audit.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAUA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6FG;AACI,MAAM,KAAK,GAAG,CACnB,YAAoB;AAEpB;AACA,CAAC,CAAC,gBAAgB,KAChB,IAAI,oBAAoB,CACtB,gBAAgB,EAChB,YAAY,CACb;AAEL,MAAM,oBACJ,SAAQ,yBAA0C,CAAA;AAGzC,IAAA,aAAa;AACtB,IAAA,YAAY;AACZ,IAAA,eAAe;IAEf,WAAA,CAAY,gBAA+B,EAAE,YAAoB,EAAA;AAC/D,QAAA,KAAK,CAAC;YACJ,OAAO,EAAE,CAAC,gBAAgB,CAAC;AAC3B,YAAA,YAAY,EAAE,gBAAgB,CAAC,WAAW,EAAE;AAC7C,SAAA,CAAC;AAEF,QAAA,IAAI,CAAC,eAAe,GAAG,KAAK;AAE5B,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS;AAE7B,QAAA,IAAI,CAAC,aAAa,GAAG,YAAY;IACnC;AAES,IAAA,SAAS,CAAC,WAAwB,EAAA;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;AAE3B,QAAA,IACE,GAAG,CAAC,WAAW,KAAK,WAAW;AAC/B,YAAA,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;YAClC,IAAI,CAAC,eAAe,EACpB;AACA,YAAA,OAAO;QACT;;AAGA,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI;AAE3B,QAAA,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,MAAK;AAClC,YAAA,MAAM,EAAE,GAAG,GAAG,CAAC,WAAW,EAAE;AAE5B,YAAA,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;gBAAE;AAEzB,YAAA,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC;AAE1B,YAAA,IAAI,CAAC,eAAe,GAAG,KAAK;AAC9B,QAAA,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;IACxB;IAEA,WAAW,GAAA;AACT,QAAA,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;AACnC,YAAA,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;QACjC;IACF;IAES,QAAQ,GAAA;QACf,IAAI,CAAC,WAAW,EAAE;QAElB,KAAK,CAAC,QAAQ,EAAE;IAClB;AACD;;;;"}
@@ -0,0 +1,88 @@
1
+ import { type KeepInitialValueOperator } from '../types/index.mjs';
2
+ /**
3
+ * Delays emissions from the source observable until a specified time has passed without another emission.
4
+ * Useful for handling user input events like typing or scrolling.
5
+ *
6
+ * @template A - The type of values from the source
7
+ * @param milliSeconds - The debounce duration in milliseconds
8
+ * @returns An operator that debounces the observable
9
+ *
10
+ * @example
11
+ * ```ts
12
+ * // Timeline (250ms debounce):
13
+ * //
14
+ * // Time(x50ms) 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0
15
+ * //
16
+ * // input$ 0 2 3 9 10 11 12 13 14
17
+ * // |- 250ms -> |- 250ms ->
18
+ * // debounced$ 3 14 (emitted after 250ms silence)
19
+ * //
20
+ * // Explanation:
21
+ * // - debounce emits the latest value AFTER a quiet period with no new emissions
22
+ * // - Unlike audit (which uses a fixed window), debounce resets the timer on every emission
23
+ * // - Useful for search-as-you-type and form validation
24
+ *
25
+ * const input$ = source<number>();
26
+ *
27
+ * const debounced$ = input$.pipe(debounce(250));
28
+ *
29
+ * const valueHistory: number[] = [];
30
+ *
31
+ * debounced$.subscribe((value) => {
32
+ * valueHistory.push(value);
33
+ * });
34
+ *
35
+ * const sleep = (ms: number): Promise<void> =>
36
+ * new Promise((resolve) => {
37
+ * setTimeout(resolve, ms);
38
+ * });
39
+ *
40
+ * input$.next(0);
41
+ *
42
+ * await sleep(200);
43
+ *
44
+ * input$.next(2);
45
+ *
46
+ * await sleep(100);
47
+ *
48
+ * input$.next(3);
49
+ *
50
+ * assert.deepStrictEqual(valueHistory, []);
51
+ *
52
+ * await sleep(300);
53
+ *
54
+ * assert.deepStrictEqual(valueHistory, [3]);
55
+ *
56
+ * await sleep(300);
57
+ *
58
+ * input$.next(9);
59
+ *
60
+ * await sleep(100);
61
+ *
62
+ * input$.next(10);
63
+ *
64
+ * await sleep(100);
65
+ *
66
+ * input$.next(11);
67
+ *
68
+ * await sleep(100);
69
+ *
70
+ * input$.next(12);
71
+ *
72
+ * await sleep(100);
73
+ *
74
+ * input$.next(13);
75
+ *
76
+ * await sleep(100);
77
+ *
78
+ * input$.next(14);
79
+ *
80
+ * assert.deepStrictEqual(valueHistory, [3]);
81
+ *
82
+ * await sleep(300);
83
+ *
84
+ * assert.deepStrictEqual(valueHistory, [3, 14]);
85
+ * ```
86
+ */
87
+ export declare const debounce: <A>(milliSeconds: number) => KeepInitialValueOperator<A, A>;
88
+ //# sourceMappingURL=debounce.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debounce.d.mts","sourceRoot":"","sources":["../../../src/core/operators/debounce.mts"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,wBAAwB,EAI9B,MAAM,oBAAoB,CAAC;AAE5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoFG;AACH,eAAO,MAAM,QAAQ,GAAI,CAAC,EACxB,cAAc,MAAM,KACnB,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAMQ,CAAC"}
@@ -0,0 +1,130 @@
1
+ import { Optional } from 'ts-data-forge';
2
+ import { AsyncChildObservableClass } from '../class/child-observable-class.mjs';
3
+ import '../utils/id-maker.mjs';
4
+
5
+ /**
6
+ * Delays emissions from the source observable until a specified time has passed without another emission.
7
+ * Useful for handling user input events like typing or scrolling.
8
+ *
9
+ * @template A - The type of values from the source
10
+ * @param milliSeconds - The debounce duration in milliseconds
11
+ * @returns An operator that debounces the observable
12
+ *
13
+ * @example
14
+ * ```ts
15
+ * // Timeline (250ms debounce):
16
+ * //
17
+ * // Time(x50ms) 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0
18
+ * //
19
+ * // input$ 0 2 3 9 10 11 12 13 14
20
+ * // |- 250ms -> |- 250ms ->
21
+ * // debounced$ 3 14 (emitted after 250ms silence)
22
+ * //
23
+ * // Explanation:
24
+ * // - debounce emits the latest value AFTER a quiet period with no new emissions
25
+ * // - Unlike audit (which uses a fixed window), debounce resets the timer on every emission
26
+ * // - Useful for search-as-you-type and form validation
27
+ *
28
+ * const input$ = source<number>();
29
+ *
30
+ * const debounced$ = input$.pipe(debounce(250));
31
+ *
32
+ * const valueHistory: number[] = [];
33
+ *
34
+ * debounced$.subscribe((value) => {
35
+ * valueHistory.push(value);
36
+ * });
37
+ *
38
+ * const sleep = (ms: number): Promise<void> =>
39
+ * new Promise((resolve) => {
40
+ * setTimeout(resolve, ms);
41
+ * });
42
+ *
43
+ * input$.next(0);
44
+ *
45
+ * await sleep(200);
46
+ *
47
+ * input$.next(2);
48
+ *
49
+ * await sleep(100);
50
+ *
51
+ * input$.next(3);
52
+ *
53
+ * assert.deepStrictEqual(valueHistory, []);
54
+ *
55
+ * await sleep(300);
56
+ *
57
+ * assert.deepStrictEqual(valueHistory, [3]);
58
+ *
59
+ * await sleep(300);
60
+ *
61
+ * input$.next(9);
62
+ *
63
+ * await sleep(100);
64
+ *
65
+ * input$.next(10);
66
+ *
67
+ * await sleep(100);
68
+ *
69
+ * input$.next(11);
70
+ *
71
+ * await sleep(100);
72
+ *
73
+ * input$.next(12);
74
+ *
75
+ * await sleep(100);
76
+ *
77
+ * input$.next(13);
78
+ *
79
+ * await sleep(100);
80
+ *
81
+ * input$.next(14);
82
+ *
83
+ * assert.deepStrictEqual(valueHistory, [3]);
84
+ *
85
+ * await sleep(300);
86
+ *
87
+ * assert.deepStrictEqual(valueHistory, [3, 14]);
88
+ * ```
89
+ */
90
+ const debounce = (milliSeconds) =>
91
+ // eslint-disable-next-line total-functions/no-unsafe-type-assertion
92
+ ((parentObservable) => new DebounceObservableClass(parentObservable, milliSeconds));
93
+ class DebounceObservableClass extends AsyncChildObservableClass {
94
+ #milliSeconds;
95
+ #mut_timerId;
96
+ constructor(parentObservable, milliSeconds) {
97
+ super({
98
+ parents: [parentObservable],
99
+ initialValue: parentObservable.getSnapshot(),
100
+ });
101
+ this.#mut_timerId = undefined;
102
+ this.#milliSeconds = milliSeconds;
103
+ }
104
+ tryUpdate(updateToken) {
105
+ const par = this.parents[0];
106
+ const sn = par.getSnapshot();
107
+ if (par.updateToken !== updateToken || Optional.isNone(sn)) {
108
+ return; // skip update
109
+ }
110
+ this.#resetTimer();
111
+ // set timer
112
+ this.#mut_timerId = setTimeout(() => {
113
+ if (Optional.isNone(sn))
114
+ return;
115
+ this.startUpdate(sn.value);
116
+ }, this.#milliSeconds);
117
+ }
118
+ #resetTimer() {
119
+ if (this.#mut_timerId !== undefined) {
120
+ clearTimeout(this.#mut_timerId);
121
+ }
122
+ }
123
+ complete() {
124
+ this.#resetTimer();
125
+ super.complete();
126
+ }
127
+ }
128
+
129
+ export { debounce };
130
+ //# sourceMappingURL=debounce.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debounce.mjs","sources":["../../../src/core/operators/debounce.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAUA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoFG;AACI,MAAM,QAAQ,GAAG,CACtB,YAAoB;AAEpB;AACA,CAAC,CAAC,gBAAgB,KAChB,IAAI,uBAAuB,CACzB,gBAAgB,EAChB,YAAY,CACb;AAEL,MAAM,uBACJ,SAAQ,yBAA0C,CAAA;AAGzC,IAAA,aAAa;AACtB,IAAA,YAAY;IAEZ,WAAA,CAAY,gBAA+B,EAAE,YAAoB,EAAA;AAC/D,QAAA,KAAK,CAAC;YACJ,OAAO,EAAE,CAAC,gBAAgB,CAAC;AAC3B,YAAA,YAAY,EAAE,gBAAgB,CAAC,WAAW,EAAE;AAC7C,SAAA,CAAC;AAEF,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS;AAE7B,QAAA,IAAI,CAAC,aAAa,GAAG,YAAY;IACnC;AAES,IAAA,SAAS,CAAC,WAAwB,EAAA;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;AAE3B,QAAA,MAAM,EAAE,GAAG,GAAG,CAAC,WAAW,EAAE;AAE5B,QAAA,IAAI,GAAG,CAAC,WAAW,KAAK,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE;AAC1D,YAAA,OAAO;QACT;QAEA,IAAI,CAAC,WAAW,EAAE;;AAGlB,QAAA,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,MAAK;AAClC,YAAA,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;gBAAE;AAEzB,YAAA,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,CAAC;AAC5B,QAAA,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;IACxB;IAEA,WAAW,GAAA;AACT,QAAA,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;AACnC,YAAA,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;QACjC;IACF;IAES,QAAQ,GAAA;QACf,IAAI,CAAC,WAAW,EAAE;QAElB,KAAK,CAAC,QAAQ,EAAE;IAClB;AACD;;;;"}
@@ -1,3 +1,4 @@
1
+ import { SafeUint } from 'ts-data-forge';
1
2
  import { type DropInitialValueOperator } from '../types/index.mjs';
2
3
  /**
3
4
  * Filters values emitted by the source observable based on a predicate function.
@@ -23,29 +24,29 @@ import { type DropInitialValueOperator } from '../types/index.mjs';
23
24
  *
24
25
  * const even$ = num$.pipe(filter((x) => x % 2 === 0));
25
26
  *
26
- * const mut_history: number[] = [];
27
+ * const valueHistory: number[] = [];
27
28
  *
28
29
  * even$.subscribe((x) => {
29
- * mut_history.push(x);
30
+ * valueHistory.push(x);
30
31
  * });
31
32
  *
32
33
  * num$.next(1); // nothing logged
33
34
  *
34
35
  * num$.next(2); // logs: 2
35
36
  *
36
- * assert.deepStrictEqual(mut_history, [2]);
37
+ * assert.deepStrictEqual(valueHistory, [2]);
37
38
  *
38
39
  * num$.next(3); // nothing logged
39
40
  *
40
41
  * num$.next(4); // logs: 4
41
42
  *
42
- * assert.deepStrictEqual(mut_history, [2, 4]);
43
+ * assert.deepStrictEqual(valueHistory, [2, 4]);
43
44
  *
44
45
  * num$.next(5);
45
46
  *
46
47
  * num$.next(6);
47
48
  *
48
- * assert.deepStrictEqual(mut_history, [2, 4, 6]);
49
+ * assert.deepStrictEqual(valueHistory, [2, 4, 6]);
49
50
  * ```
50
51
  */
51
52
  export declare function filter<A, B extends A>(predicate: (value: A, index: SafeUint | -1) => value is B): DropInitialValueOperator<A, B>;