synstate 0.1.1 → 1.0.0
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.
- package/README.md +317 -298
- package/dist/core/class/child-observable-class.d.mts.map +1 -1
- package/dist/core/class/child-observable-class.mjs +43 -10
- package/dist/core/class/child-observable-class.mjs.map +1 -1
- package/dist/core/class/observable-base-class.d.mts +4 -4
- package/dist/core/class/observable-base-class.d.mts.map +1 -1
- package/dist/core/class/observable-base-class.mjs +8 -8
- package/dist/core/class/observable-base-class.mjs.map +1 -1
- package/dist/core/class/root-observable-class.d.mts +1 -1
- package/dist/core/class/root-observable-class.d.mts.map +1 -1
- package/dist/core/class/root-observable-class.mjs +9 -9
- package/dist/core/class/root-observable-class.mjs.map +1 -1
- package/dist/core/combine/combine.d.mts +7 -7
- package/dist/core/combine/combine.mjs +13 -14
- package/dist/core/combine/combine.mjs.map +1 -1
- package/dist/core/combine/merge.d.mts +6 -6
- package/dist/core/combine/merge.mjs +9 -9
- package/dist/core/combine/merge.mjs.map +1 -1
- package/dist/core/combine/zip.d.mts +20 -19
- package/dist/core/combine/zip.d.mts.map +1 -1
- package/dist/core/combine/zip.mjs +22 -21
- package/dist/core/combine/zip.mjs.map +1 -1
- package/dist/core/create/{interval.d.mts → counter.d.mts} +14 -12
- package/dist/core/create/counter.d.mts.map +1 -0
- package/dist/core/create/{interval.mjs → counter.mjs} +21 -23
- package/dist/core/create/counter.mjs.map +1 -0
- package/dist/core/create/from-abortable-promise.d.mts +29 -0
- package/dist/core/create/from-abortable-promise.d.mts.map +1 -0
- package/dist/core/create/from-abortable-promise.mjs +70 -0
- package/dist/core/create/from-abortable-promise.mjs.map +1 -0
- package/dist/core/create/from-promise.d.mts +9 -6
- package/dist/core/create/from-promise.d.mts.map +1 -1
- package/dist/core/create/from-promise.mjs +8 -5
- package/dist/core/create/from-promise.mjs.map +1 -1
- package/dist/core/create/from-subscribable.d.mts +4 -4
- package/dist/core/create/from-subscribable.mjs +4 -4
- package/dist/core/create/index.d.mts +3 -3
- package/dist/core/create/index.d.mts.map +1 -1
- package/dist/core/create/index.mjs +4 -4
- package/dist/core/create/just.d.mts +32 -0
- package/dist/core/create/just.d.mts.map +1 -0
- package/dist/core/create/just.mjs +44 -0
- package/dist/core/create/just.mjs.map +1 -0
- package/dist/core/create/source.d.mts +7 -12
- package/dist/core/create/source.d.mts.map +1 -1
- package/dist/core/create/source.mjs +1 -6
- package/dist/core/create/source.mjs.map +1 -1
- package/dist/core/create/timer.d.mts +6 -4
- package/dist/core/create/timer.d.mts.map +1 -1
- package/dist/core/create/timer.mjs +6 -7
- package/dist/core/create/timer.mjs.map +1 -1
- package/dist/core/index.d.mts +1 -1
- package/dist/core/index.d.mts.map +1 -1
- package/dist/core/index.mjs +21 -14
- package/dist/core/index.mjs.map +1 -1
- package/dist/core/operators/audit.d.mts +97 -0
- package/dist/core/operators/audit.d.mts.map +1 -0
- package/dist/core/operators/audit.mjs +144 -0
- package/dist/core/operators/audit.mjs.map +1 -0
- package/dist/core/operators/debounce.d.mts +88 -0
- package/dist/core/operators/debounce.d.mts.map +1 -0
- package/dist/core/operators/debounce.mjs +130 -0
- package/dist/core/operators/debounce.mjs.map +1 -0
- package/dist/core/operators/filter.d.mts +5 -5
- package/dist/core/operators/filter.mjs +3 -3
- package/dist/core/operators/filter.mjs.map +1 -1
- package/dist/core/operators/index.d.mts +4 -4
- package/dist/core/operators/index.d.mts.map +1 -1
- package/dist/core/operators/index.mjs +6 -6
- package/dist/core/operators/map.d.mts +41 -0
- package/dist/core/operators/map.d.mts.map +1 -0
- package/dist/core/operators/map.mjs +71 -0
- package/dist/core/operators/map.mjs.map +1 -0
- package/dist/core/operators/merge-map.d.mts +57 -30
- package/dist/core/operators/merge-map.d.mts.map +1 -1
- package/dist/core/operators/merge-map.mjs +59 -32
- package/dist/core/operators/merge-map.mjs.map +1 -1
- package/dist/core/operators/pairwise.d.mts +6 -6
- package/dist/core/operators/pairwise.mjs +9 -9
- package/dist/core/operators/pairwise.mjs.map +1 -1
- package/dist/core/operators/scan.d.mts +6 -6
- package/dist/core/operators/scan.mjs +9 -9
- package/dist/core/operators/scan.mjs.map +1 -1
- package/dist/core/operators/skip-if-no-change.d.mts +21 -9
- package/dist/core/operators/skip-if-no-change.d.mts.map +1 -1
- package/dist/core/operators/skip-if-no-change.mjs +25 -13
- package/dist/core/operators/skip-if-no-change.mjs.map +1 -1
- package/dist/core/operators/skip-until.d.mts +5 -5
- package/dist/core/operators/skip-until.mjs +8 -8
- package/dist/core/operators/skip-until.mjs.map +1 -1
- package/dist/core/operators/skip-while.d.mts +18 -9
- package/dist/core/operators/skip-while.d.mts.map +1 -1
- package/dist/core/operators/skip-while.mjs +28 -16
- package/dist/core/operators/skip-while.mjs.map +1 -1
- package/dist/core/operators/switch-map.d.mts +57 -26
- package/dist/core/operators/switch-map.d.mts.map +1 -1
- package/dist/core/operators/switch-map.mjs +59 -28
- package/dist/core/operators/switch-map.mjs.map +1 -1
- package/dist/core/operators/take-until.d.mts +5 -5
- package/dist/core/operators/take-until.mjs +8 -8
- package/dist/core/operators/take-until.mjs.map +1 -1
- package/dist/core/operators/take-while.d.mts +15 -8
- package/dist/core/operators/take-while.d.mts.map +1 -1
- package/dist/core/operators/take-while.mjs +19 -13
- package/dist/core/operators/take-while.mjs.map +1 -1
- package/dist/core/operators/throttle.d.mts +81 -0
- package/dist/core/operators/throttle.d.mts.map +1 -0
- package/dist/core/operators/throttle.mjs +126 -0
- package/dist/core/operators/throttle.mjs.map +1 -0
- package/dist/core/operators/with-buffered-from.d.mts +13 -9
- package/dist/core/operators/with-buffered-from.d.mts.map +1 -1
- package/dist/core/operators/with-buffered-from.mjs +17 -13
- package/dist/core/operators/with-buffered-from.mjs.map +1 -1
- package/dist/core/operators/with-current-value-from.d.mts +14 -9
- package/dist/core/operators/with-current-value-from.d.mts.map +1 -1
- package/dist/core/operators/with-current-value-from.mjs +18 -13
- package/dist/core/operators/with-current-value-from.mjs.map +1 -1
- package/dist/core/operators/with-initial-value.d.mts +5 -5
- package/dist/core/operators/with-initial-value.mjs +8 -8
- package/dist/core/operators/with-initial-value.mjs.map +1 -1
- package/dist/core/predefined/index.d.mts +2 -0
- package/dist/core/predefined/index.d.mts.map +1 -0
- package/dist/core/predefined/index.mjs +12 -0
- package/dist/core/predefined/index.mjs.map +1 -0
- package/dist/core/predefined/operators/attach-index.d.mts +57 -0
- package/dist/core/predefined/operators/attach-index.d.mts.map +1 -0
- package/dist/core/predefined/operators/attach-index.mjs +62 -0
- package/dist/core/predefined/operators/attach-index.mjs.map +1 -0
- package/dist/core/predefined/operators/index.d.mts +12 -0
- package/dist/core/predefined/operators/index.d.mts.map +1 -0
- package/dist/core/predefined/operators/index.mjs +12 -0
- package/dist/core/predefined/operators/index.mjs.map +1 -0
- package/dist/core/predefined/operators/map-optional.d.mts +51 -0
- package/dist/core/predefined/operators/map-optional.d.mts.map +1 -0
- package/dist/core/predefined/operators/map-optional.mjs +55 -0
- package/dist/core/predefined/operators/map-optional.mjs.map +1 -0
- package/dist/core/predefined/operators/map-result-err.d.mts +51 -0
- package/dist/core/predefined/operators/map-result-err.d.mts.map +1 -0
- package/dist/core/predefined/operators/map-result-err.mjs +55 -0
- package/dist/core/predefined/operators/map-result-err.mjs.map +1 -0
- package/dist/core/predefined/operators/map-result-ok.d.mts +51 -0
- package/dist/core/predefined/operators/map-result-ok.d.mts.map +1 -0
- package/dist/core/predefined/operators/map-result-ok.mjs +55 -0
- package/dist/core/predefined/operators/map-result-ok.mjs.map +1 -0
- package/dist/core/predefined/operators/map-to.d.mts +43 -0
- package/dist/core/predefined/operators/map-to.d.mts.map +1 -0
- package/dist/core/predefined/operators/map-to.mjs +48 -0
- package/dist/core/predefined/operators/map-to.mjs.map +1 -0
- package/dist/core/predefined/operators/pluck.d.mts +47 -0
- package/dist/core/predefined/operators/pluck.d.mts.map +1 -0
- package/dist/core/predefined/operators/pluck.mjs +52 -0
- package/dist/core/predefined/operators/pluck.mjs.map +1 -0
- package/dist/core/predefined/operators/skip.d.mts +50 -0
- package/dist/core/predefined/operators/skip.d.mts.map +1 -0
- package/dist/core/predefined/operators/skip.mjs +56 -0
- package/dist/core/predefined/operators/skip.mjs.map +1 -0
- package/dist/core/predefined/operators/take.d.mts +44 -0
- package/dist/core/predefined/operators/take.d.mts.map +1 -0
- package/dist/core/predefined/operators/take.mjs +49 -0
- package/dist/core/predefined/operators/take.mjs.map +1 -0
- package/dist/core/predefined/operators/unwrap-optional.d.mts +44 -0
- package/dist/core/predefined/operators/unwrap-optional.d.mts.map +1 -0
- package/dist/core/predefined/operators/unwrap-optional.mjs +50 -0
- package/dist/core/predefined/operators/unwrap-optional.mjs.map +1 -0
- package/dist/core/predefined/operators/unwrap-result-err.d.mts +44 -0
- package/dist/core/predefined/operators/unwrap-result-err.d.mts.map +1 -0
- package/dist/core/predefined/operators/unwrap-result-err.mjs +48 -0
- package/dist/core/predefined/operators/unwrap-result-err.mjs.map +1 -0
- package/dist/core/predefined/operators/unwrap-result-ok.d.mts +44 -0
- package/dist/core/predefined/operators/unwrap-result-ok.d.mts.map +1 -0
- package/dist/core/predefined/operators/unwrap-result-ok.mjs +50 -0
- package/dist/core/predefined/operators/unwrap-result-ok.mjs.map +1 -0
- package/dist/core/types/id.d.mts +1 -1
- package/dist/core/types/id.d.mts.map +1 -1
- package/dist/core/types/index.d.mts +1 -0
- package/dist/core/types/index.d.mts.map +1 -1
- package/dist/core/types/observable-family.d.mts +8 -14
- package/dist/core/types/observable-family.d.mts.map +1 -1
- package/dist/core/types/observable.d.mts +3 -3
- package/dist/core/types/observable.d.mts.map +1 -1
- package/dist/core/types/timer.d.mts +2 -0
- package/dist/core/types/timer.d.mts.map +1 -0
- package/dist/core/types/timer.mjs +2 -0
- package/dist/core/types/timer.mjs.map +1 -0
- package/dist/core/utils/id-maker.d.mts +2 -2
- package/dist/core/utils/id-maker.d.mts.map +1 -1
- package/dist/core/utils/id-maker.mjs +3 -3
- package/dist/core/utils/id-maker.mjs.map +1 -1
- package/dist/core/utils/index.mjs +1 -1
- package/dist/entry-point.mjs +24 -15
- package/dist/entry-point.mjs.map +1 -1
- package/dist/globals.d.mts +0 -3
- package/dist/index.mjs +24 -15
- package/dist/index.mjs.map +1 -1
- package/dist/utils/collect-to-array.d.mts +3 -0
- package/dist/utils/collect-to-array.d.mts.map +1 -0
- package/dist/utils/collect-to-array.mjs +11 -0
- package/dist/utils/collect-to-array.mjs.map +1 -0
- package/dist/utils/create-boolean-state.d.mts +40 -0
- package/dist/utils/create-boolean-state.d.mts.map +1 -0
- package/dist/utils/create-boolean-state.mjs +53 -0
- package/dist/utils/create-boolean-state.mjs.map +1 -0
- package/dist/utils/create-event-emitter.d.mts +4 -4
- package/dist/utils/create-event-emitter.mjs +4 -4
- package/dist/utils/create-reducer.d.mts +10 -7
- package/dist/utils/create-reducer.d.mts.map +1 -1
- package/dist/utils/create-reducer.mjs +7 -7
- package/dist/utils/create-reducer.mjs.map +1 -1
- package/dist/utils/create-state.d.mts +8 -48
- package/dist/utils/create-state.d.mts.map +1 -1
- package/dist/utils/create-state.mjs +10 -60
- package/dist/utils/create-state.mjs.map +1 -1
- package/dist/utils/index.d.mts +2 -0
- package/dist/utils/index.d.mts.map +1 -1
- package/dist/utils/index.mjs +3 -1
- package/dist/utils/index.mjs.map +1 -1
- package/package.json +17 -11
- package/src/core/class/child-observable-class.mts +65 -9
- package/src/core/class/circular-dependency-comparison.test.mts +142 -0
- package/src/core/class/circular-dependency.test.mts +251 -0
- package/src/core/class/observable-base-class.mts +9 -9
- package/src/core/class/root-observable-class.mts +14 -10
- package/src/core/combine/combine.mts +15 -15
- package/src/core/combine/merge.mts +13 -14
- package/src/core/combine/zip.mts +26 -25
- package/src/core/create/{interval.mts → counter.mts} +32 -30
- package/src/core/create/from-abortable-promise.mts +83 -0
- package/src/core/create/from-promise.mts +10 -7
- package/src/core/create/from-subscribable.mts +4 -4
- package/src/core/create/index.mts +3 -3
- package/src/core/create/just.mts +43 -0
- package/src/core/create/source.mts +10 -14
- package/src/core/create/timer.mts +12 -11
- package/src/core/index.mts +1 -1
- package/src/core/operators/audit.mts +172 -0
- package/src/core/operators/debounce.mts +154 -0
- package/src/core/operators/filter.mts +9 -9
- package/src/core/operators/index.mts +4 -4
- package/src/core/operators/map.mts +124 -0
- package/src/core/operators/merge-map.mts +60 -33
- package/src/core/operators/pairwise.mts +10 -10
- package/src/core/operators/scan.mts +10 -10
- package/src/core/operators/skip-if-no-change.mts +26 -14
- package/src/core/operators/skip-until.mts +9 -9
- package/src/core/operators/skip-while.mts +30 -28
- package/src/core/operators/switch-map.mts +60 -29
- package/src/core/operators/take-until.mts +9 -9
- package/src/core/operators/take-while.mts +21 -19
- package/src/core/operators/{throttle-time.mts → throttle.mts} +58 -38
- package/src/core/operators/with-buffered-from.mts +18 -14
- package/src/core/operators/with-current-value-from.mts +19 -14
- package/src/core/operators/with-initial-value.mts +9 -9
- package/src/core/predefined/index.mts +1 -0
- package/src/core/predefined/operators/attach-index.mts +62 -0
- package/src/core/predefined/operators/index.mts +11 -0
- package/src/core/predefined/operators/map-optional.mts +55 -0
- package/src/core/predefined/operators/map-result-err.mts +55 -0
- package/src/core/predefined/operators/map-result-ok.mts +55 -0
- package/src/core/predefined/operators/map-to.mts +45 -0
- package/src/core/predefined/operators/pluck.mts +51 -0
- package/src/core/predefined/operators/skip.mts +57 -0
- package/src/core/predefined/operators/take.mts +47 -0
- package/src/core/predefined/operators/unwrap-optional.mts +49 -0
- package/src/core/predefined/operators/unwrap-result-err.mts +48 -0
- package/src/core/predefined/operators/unwrap-result-ok.mts +49 -0
- package/src/core/types/id.mts +1 -1
- package/src/core/types/index.mts +1 -0
- package/src/core/types/observable-family.mts +8 -24
- package/src/core/types/observable.mts +3 -3
- package/src/core/types/timer.mts +2 -0
- package/src/core/utils/id-maker.mts +4 -4
- package/src/globals.d.mts +0 -3
- package/src/utils/collect-to-array.mts +17 -0
- package/src/utils/create-boolean-state.mts +68 -0
- package/src/utils/create-event-emitter.mts +4 -4
- package/src/utils/create-reducer.mts +11 -8
- package/src/utils/create-state.mts +10 -75
- package/src/utils/index.mts +2 -0
- package/dist/core/create/from-array.d.mts +0 -39
- package/dist/core/create/from-array.d.mts.map +0 -1
- package/dist/core/create/from-array.mjs +0 -65
- package/dist/core/create/from-array.mjs.map +0 -1
- package/dist/core/create/interval.d.mts.map +0 -1
- package/dist/core/create/interval.mjs.map +0 -1
- package/dist/core/create/of.d.mts +0 -39
- package/dist/core/create/of.d.mts.map +0 -1
- package/dist/core/create/of.mjs +0 -63
- package/dist/core/create/of.mjs.map +0 -1
- package/dist/core/operators/audit-time.d.mts +0 -62
- package/dist/core/operators/audit-time.d.mts.map +0 -1
- package/dist/core/operators/audit-time.mjs +0 -109
- package/dist/core/operators/audit-time.mjs.map +0 -1
- package/dist/core/operators/debounce-time.d.mts +0 -51
- package/dist/core/operators/debounce-time.d.mts.map +0 -1
- package/dist/core/operators/debounce-time.mjs +0 -93
- package/dist/core/operators/debounce-time.mjs.map +0 -1
- package/dist/core/operators/map-with-index.d.mts +0 -54
- package/dist/core/operators/map-with-index.d.mts.map +0 -1
- package/dist/core/operators/map-with-index.mjs +0 -88
- package/dist/core/operators/map-with-index.mjs.map +0 -1
- package/dist/core/operators/throttle-time.d.mts +0 -62
- package/dist/core/operators/throttle-time.d.mts.map +0 -1
- package/dist/core/operators/throttle-time.mjs +0 -107
- package/dist/core/operators/throttle-time.mjs.map +0 -1
- package/src/core/create/from-array.mts +0 -76
- package/src/core/create/of.mts +0 -73
- package/src/core/operators/audit-time.mts +0 -136
- package/src/core/operators/debounce-time.mts +0 -116
- package/src/core/operators/map-with-index.mts +0 -183
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export * from './attach-index.mjs';
|
|
2
|
+
export * from './map-optional.mjs';
|
|
3
|
+
export * from './map-result-err.mjs';
|
|
4
|
+
export * from './map-result-ok.mjs';
|
|
5
|
+
export * from './map-to.mjs';
|
|
6
|
+
export * from './pluck.mjs';
|
|
7
|
+
export * from './skip.mjs';
|
|
8
|
+
export * from './take.mjs';
|
|
9
|
+
export * from './unwrap-optional.mjs';
|
|
10
|
+
export * from './unwrap-result-err.mjs';
|
|
11
|
+
export * from './unwrap-result-ok.mjs';
|
|
12
|
+
//# sourceMappingURL=index.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/index.mts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export { attachIndex, withIndex } from './attach-index.mjs';
|
|
2
|
+
export { mapOptional } from './map-optional.mjs';
|
|
3
|
+
export { mapResultErr } from './map-result-err.mjs';
|
|
4
|
+
export { mapResultOk } from './map-result-ok.mjs';
|
|
5
|
+
export { mapTo } from './map-to.mjs';
|
|
6
|
+
export { getKey, pluck } from './pluck.mjs';
|
|
7
|
+
export { skip } from './skip.mjs';
|
|
8
|
+
export { take } from './take.mjs';
|
|
9
|
+
export { unwrapOptional } from './unwrap-optional.mjs';
|
|
10
|
+
export { unwrapResultErr } from './unwrap-result-err.mjs';
|
|
11
|
+
export { unwrapResultOk } from './unwrap-result-ok.mjs';
|
|
12
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Optional } from 'ts-data-forge';
|
|
2
|
+
import { type KeepInitialValueOperator } from '../../types/index.mjs';
|
|
3
|
+
/**
|
|
4
|
+
* Transforms the inner value of an `Optional` type emitted by the source.
|
|
5
|
+
* If the value is `Some`, the mapping function is applied; if `None`, it remains `None`.
|
|
6
|
+
*
|
|
7
|
+
* @template O - The Optional type from the source
|
|
8
|
+
* @template B - The type of the mapped inner value
|
|
9
|
+
* @param mapFn - A function to transform the unwrapped value
|
|
10
|
+
* @returns An operator that maps the inner value of Optional emissions
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* // Timeline:
|
|
15
|
+
* //
|
|
16
|
+
* // value$ Some(2) None Some(5)
|
|
17
|
+
* // doubled$ Some(4) None Some(10)
|
|
18
|
+
* //
|
|
19
|
+
* // Explanation:
|
|
20
|
+
* // - mapOptional transforms the inner value of Optional emissions
|
|
21
|
+
* // - Some values are mapped; None values pass through unchanged
|
|
22
|
+
*
|
|
23
|
+
* const value$ = source<Optional<number>>();
|
|
24
|
+
*
|
|
25
|
+
* const doubled$ = value$.pipe(mapOptional((x) => x * 2));
|
|
26
|
+
*
|
|
27
|
+
* const valueHistory: Optional<number>[] = [];
|
|
28
|
+
*
|
|
29
|
+
* doubled$.subscribe((v) => {
|
|
30
|
+
* valueHistory.push(v);
|
|
31
|
+
* });
|
|
32
|
+
*
|
|
33
|
+
* value$.next(Optional.some(2));
|
|
34
|
+
*
|
|
35
|
+
* assert.deepStrictEqual(valueHistory, [Optional.some(4)]);
|
|
36
|
+
*
|
|
37
|
+
* value$.next(Optional.none);
|
|
38
|
+
*
|
|
39
|
+
* assert.deepStrictEqual(valueHistory, [Optional.some(4), Optional.none]);
|
|
40
|
+
*
|
|
41
|
+
* value$.next(Optional.some(5));
|
|
42
|
+
*
|
|
43
|
+
* assert.deepStrictEqual(valueHistory, [
|
|
44
|
+
* Optional.some(4),
|
|
45
|
+
* Optional.none,
|
|
46
|
+
* Optional.some(10),
|
|
47
|
+
* ]);
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
export declare const mapOptional: <O extends UnknownOptional, B>(mapFn: (x: Optional.Unwrap<O>) => B) => KeepInitialValueOperator<O, Optional<B>>;
|
|
51
|
+
//# sourceMappingURL=map-optional.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-optional.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/map-optional.mts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEzC,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,eAAO,MAAM,WAAW,GAAI,CAAC,SAAS,eAAe,EAAE,CAAC,EACtD,OAAO,CAAC,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,KAClC,wBAAwB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CACN,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Optional } from 'ts-data-forge';
|
|
2
|
+
import '../../utils/id-maker.mjs';
|
|
3
|
+
import { map } from '../../operators/map.mjs';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Transforms the inner value of an `Optional` type emitted by the source.
|
|
7
|
+
* If the value is `Some`, the mapping function is applied; if `None`, it remains `None`.
|
|
8
|
+
*
|
|
9
|
+
* @template O - The Optional type from the source
|
|
10
|
+
* @template B - The type of the mapped inner value
|
|
11
|
+
* @param mapFn - A function to transform the unwrapped value
|
|
12
|
+
* @returns An operator that maps the inner value of Optional emissions
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* // Timeline:
|
|
17
|
+
* //
|
|
18
|
+
* // value$ Some(2) None Some(5)
|
|
19
|
+
* // doubled$ Some(4) None Some(10)
|
|
20
|
+
* //
|
|
21
|
+
* // Explanation:
|
|
22
|
+
* // - mapOptional transforms the inner value of Optional emissions
|
|
23
|
+
* // - Some values are mapped; None values pass through unchanged
|
|
24
|
+
*
|
|
25
|
+
* const value$ = source<Optional<number>>();
|
|
26
|
+
*
|
|
27
|
+
* const doubled$ = value$.pipe(mapOptional((x) => x * 2));
|
|
28
|
+
*
|
|
29
|
+
* const valueHistory: Optional<number>[] = [];
|
|
30
|
+
*
|
|
31
|
+
* doubled$.subscribe((v) => {
|
|
32
|
+
* valueHistory.push(v);
|
|
33
|
+
* });
|
|
34
|
+
*
|
|
35
|
+
* value$.next(Optional.some(2));
|
|
36
|
+
*
|
|
37
|
+
* assert.deepStrictEqual(valueHistory, [Optional.some(4)]);
|
|
38
|
+
*
|
|
39
|
+
* value$.next(Optional.none);
|
|
40
|
+
*
|
|
41
|
+
* assert.deepStrictEqual(valueHistory, [Optional.some(4), Optional.none]);
|
|
42
|
+
*
|
|
43
|
+
* value$.next(Optional.some(5));
|
|
44
|
+
*
|
|
45
|
+
* assert.deepStrictEqual(valueHistory, [
|
|
46
|
+
* Optional.some(4),
|
|
47
|
+
* Optional.none,
|
|
48
|
+
* Optional.some(10),
|
|
49
|
+
* ]);
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
52
|
+
const mapOptional = (mapFn) => map((a) => Optional.map(a, mapFn));
|
|
53
|
+
|
|
54
|
+
export { mapOptional };
|
|
55
|
+
//# sourceMappingURL=map-optional.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-optional.mjs","sources":["../../../../src/core/predefined/operators/map-optional.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8CG;AACI,MAAM,WAAW,GAAG,CACzB,KAAmC,KAEnC,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;;;;"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Result } from 'ts-data-forge';
|
|
2
|
+
import { type KeepInitialValueOperator } from '../../types/index.mjs';
|
|
3
|
+
/**
|
|
4
|
+
* Transforms the error value (`Err`) of a `Result` type emitted by the source.
|
|
5
|
+
* If the value is `Err`, the mapping function is applied; if `Ok`, it remains unchanged.
|
|
6
|
+
*
|
|
7
|
+
* @template R - The Result type from the source
|
|
8
|
+
* @template E2 - The type of the mapped error value
|
|
9
|
+
* @param mapFn - A function to transform the Err value
|
|
10
|
+
* @returns An operator that maps the Err side of Result emissions
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* // Timeline:
|
|
15
|
+
* //
|
|
16
|
+
* // result$ Ok(1) Err("bad") Err("fail")
|
|
17
|
+
* // mapped$ Ok(1) Err("BAD") Err("FAIL")
|
|
18
|
+
* //
|
|
19
|
+
* // Explanation:
|
|
20
|
+
* // - mapResultErr transforms the Err value of Result emissions
|
|
21
|
+
* // - Ok values pass through unchanged
|
|
22
|
+
*
|
|
23
|
+
* const result$ = source<Result<number, string>>();
|
|
24
|
+
*
|
|
25
|
+
* const mapped$ = result$.pipe(mapResultErr((e) => e.toUpperCase()));
|
|
26
|
+
*
|
|
27
|
+
* const valueHistory: Result<number, string>[] = [];
|
|
28
|
+
*
|
|
29
|
+
* mapped$.subscribe((v) => {
|
|
30
|
+
* valueHistory.push(v);
|
|
31
|
+
* });
|
|
32
|
+
*
|
|
33
|
+
* result$.next(Result.ok(1));
|
|
34
|
+
*
|
|
35
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(1)]);
|
|
36
|
+
*
|
|
37
|
+
* result$.next(Result.err('bad'));
|
|
38
|
+
*
|
|
39
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(1), Result.err('BAD')]);
|
|
40
|
+
*
|
|
41
|
+
* result$.next(Result.err('fail'));
|
|
42
|
+
*
|
|
43
|
+
* assert.deepStrictEqual(valueHistory, [
|
|
44
|
+
* Result.ok(1),
|
|
45
|
+
* Result.err('BAD'),
|
|
46
|
+
* Result.err('FAIL'),
|
|
47
|
+
* ]);
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
export declare const mapResultErr: <R extends UnknownResult, E2>(mapFn: (x: Result.UnwrapErr<R>) => E2) => KeepInitialValueOperator<R, Result<Result.UnwrapOk<R>, E2>>;
|
|
51
|
+
//# sourceMappingURL=map-result-err.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-result-err.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/map-result-err.mts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,aAAa,EAAE,EAAE,EACtD,OAAO,CAAC,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,EAAE,KACpC,wBAAwB,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CACxB,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Result } from 'ts-data-forge';
|
|
2
|
+
import '../../utils/id-maker.mjs';
|
|
3
|
+
import { map } from '../../operators/map.mjs';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Transforms the error value (`Err`) of a `Result` type emitted by the source.
|
|
7
|
+
* If the value is `Err`, the mapping function is applied; if `Ok`, it remains unchanged.
|
|
8
|
+
*
|
|
9
|
+
* @template R - The Result type from the source
|
|
10
|
+
* @template E2 - The type of the mapped error value
|
|
11
|
+
* @param mapFn - A function to transform the Err value
|
|
12
|
+
* @returns An operator that maps the Err side of Result emissions
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* // Timeline:
|
|
17
|
+
* //
|
|
18
|
+
* // result$ Ok(1) Err("bad") Err("fail")
|
|
19
|
+
* // mapped$ Ok(1) Err("BAD") Err("FAIL")
|
|
20
|
+
* //
|
|
21
|
+
* // Explanation:
|
|
22
|
+
* // - mapResultErr transforms the Err value of Result emissions
|
|
23
|
+
* // - Ok values pass through unchanged
|
|
24
|
+
*
|
|
25
|
+
* const result$ = source<Result<number, string>>();
|
|
26
|
+
*
|
|
27
|
+
* const mapped$ = result$.pipe(mapResultErr((e) => e.toUpperCase()));
|
|
28
|
+
*
|
|
29
|
+
* const valueHistory: Result<number, string>[] = [];
|
|
30
|
+
*
|
|
31
|
+
* mapped$.subscribe((v) => {
|
|
32
|
+
* valueHistory.push(v);
|
|
33
|
+
* });
|
|
34
|
+
*
|
|
35
|
+
* result$.next(Result.ok(1));
|
|
36
|
+
*
|
|
37
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(1)]);
|
|
38
|
+
*
|
|
39
|
+
* result$.next(Result.err('bad'));
|
|
40
|
+
*
|
|
41
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(1), Result.err('BAD')]);
|
|
42
|
+
*
|
|
43
|
+
* result$.next(Result.err('fail'));
|
|
44
|
+
*
|
|
45
|
+
* assert.deepStrictEqual(valueHistory, [
|
|
46
|
+
* Result.ok(1),
|
|
47
|
+
* Result.err('BAD'),
|
|
48
|
+
* Result.err('FAIL'),
|
|
49
|
+
* ]);
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
52
|
+
const mapResultErr = (mapFn) => map((a) => Result.mapErr(a, mapFn));
|
|
53
|
+
|
|
54
|
+
export { mapResultErr };
|
|
55
|
+
//# sourceMappingURL=map-result-err.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-result-err.mjs","sources":["../../../../src/core/predefined/operators/map-result-err.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8CG;AACI,MAAM,YAAY,GAAG,CAC1B,KAAqC,KAErC,GAAG,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,CAAC;;;;"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Result } from 'ts-data-forge';
|
|
2
|
+
import { type KeepInitialValueOperator } from '../../types/index.mjs';
|
|
3
|
+
/**
|
|
4
|
+
* Transforms the success value (`Ok`) of a `Result` type emitted by the source.
|
|
5
|
+
* If the value is `Ok`, the mapping function is applied; if `Err`, it remains unchanged.
|
|
6
|
+
*
|
|
7
|
+
* @template R - The Result type from the source
|
|
8
|
+
* @template S2 - The type of the mapped success value
|
|
9
|
+
* @param mapFn - A function to transform the Ok value
|
|
10
|
+
* @returns An operator that maps the Ok side of Result emissions
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* // Timeline:
|
|
15
|
+
* //
|
|
16
|
+
* // result$ Ok(2) Err("e") Ok(5)
|
|
17
|
+
* // doubled$ Ok(4) Err("e") Ok(10)
|
|
18
|
+
* //
|
|
19
|
+
* // Explanation:
|
|
20
|
+
* // - mapResultOk transforms the Ok value of Result emissions
|
|
21
|
+
* // - Err values pass through unchanged
|
|
22
|
+
*
|
|
23
|
+
* const result$ = source<Result<number, string>>();
|
|
24
|
+
*
|
|
25
|
+
* const doubled$ = result$.pipe(mapResultOk((x) => x * 2));
|
|
26
|
+
*
|
|
27
|
+
* const valueHistory: Result<number, string>[] = [];
|
|
28
|
+
*
|
|
29
|
+
* doubled$.subscribe((v) => {
|
|
30
|
+
* valueHistory.push(v);
|
|
31
|
+
* });
|
|
32
|
+
*
|
|
33
|
+
* result$.next(Result.ok(2));
|
|
34
|
+
*
|
|
35
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(4)]);
|
|
36
|
+
*
|
|
37
|
+
* result$.next(Result.err('e'));
|
|
38
|
+
*
|
|
39
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(4), Result.err('e')]);
|
|
40
|
+
*
|
|
41
|
+
* result$.next(Result.ok(5));
|
|
42
|
+
*
|
|
43
|
+
* assert.deepStrictEqual(valueHistory, [
|
|
44
|
+
* Result.ok(4),
|
|
45
|
+
* Result.err('e'),
|
|
46
|
+
* Result.ok(10),
|
|
47
|
+
* ]);
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
export declare const mapResultOk: <R extends UnknownResult, S2>(mapFn: (x: Result.UnwrapOk<R>) => S2) => KeepInitialValueOperator<R, Result<S2, Result.UnwrapErr<R>>>;
|
|
51
|
+
//# sourceMappingURL=map-result-ok.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-result-ok.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/map-result-ok.mts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,eAAO,MAAM,WAAW,GAAI,CAAC,SAAS,aAAa,EAAE,EAAE,EACrD,OAAO,CAAC,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,EAAE,KACnC,wBAAwB,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAC5B,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Result } from 'ts-data-forge';
|
|
2
|
+
import '../../utils/id-maker.mjs';
|
|
3
|
+
import { map } from '../../operators/map.mjs';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Transforms the success value (`Ok`) of a `Result` type emitted by the source.
|
|
7
|
+
* If the value is `Ok`, the mapping function is applied; if `Err`, it remains unchanged.
|
|
8
|
+
*
|
|
9
|
+
* @template R - The Result type from the source
|
|
10
|
+
* @template S2 - The type of the mapped success value
|
|
11
|
+
* @param mapFn - A function to transform the Ok value
|
|
12
|
+
* @returns An operator that maps the Ok side of Result emissions
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* // Timeline:
|
|
17
|
+
* //
|
|
18
|
+
* // result$ Ok(2) Err("e") Ok(5)
|
|
19
|
+
* // doubled$ Ok(4) Err("e") Ok(10)
|
|
20
|
+
* //
|
|
21
|
+
* // Explanation:
|
|
22
|
+
* // - mapResultOk transforms the Ok value of Result emissions
|
|
23
|
+
* // - Err values pass through unchanged
|
|
24
|
+
*
|
|
25
|
+
* const result$ = source<Result<number, string>>();
|
|
26
|
+
*
|
|
27
|
+
* const doubled$ = result$.pipe(mapResultOk((x) => x * 2));
|
|
28
|
+
*
|
|
29
|
+
* const valueHistory: Result<number, string>[] = [];
|
|
30
|
+
*
|
|
31
|
+
* doubled$.subscribe((v) => {
|
|
32
|
+
* valueHistory.push(v);
|
|
33
|
+
* });
|
|
34
|
+
*
|
|
35
|
+
* result$.next(Result.ok(2));
|
|
36
|
+
*
|
|
37
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(4)]);
|
|
38
|
+
*
|
|
39
|
+
* result$.next(Result.err('e'));
|
|
40
|
+
*
|
|
41
|
+
* assert.deepStrictEqual(valueHistory, [Result.ok(4), Result.err('e')]);
|
|
42
|
+
*
|
|
43
|
+
* result$.next(Result.ok(5));
|
|
44
|
+
*
|
|
45
|
+
* assert.deepStrictEqual(valueHistory, [
|
|
46
|
+
* Result.ok(4),
|
|
47
|
+
* Result.err('e'),
|
|
48
|
+
* Result.ok(10),
|
|
49
|
+
* ]);
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
52
|
+
const mapResultOk = (mapFn) => map((a) => Result.map(a, mapFn));
|
|
53
|
+
|
|
54
|
+
export { mapResultOk };
|
|
55
|
+
//# sourceMappingURL=map-result-ok.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-result-ok.mjs","sources":["../../../../src/core/predefined/operators/map-result-ok.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8CG;AACI,MAAM,WAAW,GAAG,CACzB,KAAoC,KAEpC,GAAG,CAAC,CAAC,CAAC,KAAK,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;;;;"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { type KeepInitialValueOperator } from '../../types/index.mjs';
|
|
2
|
+
/**
|
|
3
|
+
* Maps all emitted values to a constant value, ignoring the source values.
|
|
4
|
+
* Equivalent to `map(() => value)`.
|
|
5
|
+
*
|
|
6
|
+
* @template A - The type of values from the source
|
|
7
|
+
* @template B - The type of the constant value
|
|
8
|
+
* @param value - The constant value to emit
|
|
9
|
+
* @returns An operator that always emits the given constant
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```ts
|
|
13
|
+
* // Timeline:
|
|
14
|
+
* //
|
|
15
|
+
* // click$ MouseEvent MouseEvent MouseEvent
|
|
16
|
+
* // count$ 1 1 1
|
|
17
|
+
* //
|
|
18
|
+
* // Explanation:
|
|
19
|
+
* // - mapTo maps all emitted values to a constant value
|
|
20
|
+
* // - Ignores the source values entirely
|
|
21
|
+
* // - Useful for converting events to signals
|
|
22
|
+
*
|
|
23
|
+
* const click$ = source<string>();
|
|
24
|
+
*
|
|
25
|
+
* const one$ = click$.pipe(mapTo(1));
|
|
26
|
+
*
|
|
27
|
+
* const valueHistory: number[] = [];
|
|
28
|
+
*
|
|
29
|
+
* one$.subscribe((value) => {
|
|
30
|
+
* valueHistory.push(value);
|
|
31
|
+
* });
|
|
32
|
+
*
|
|
33
|
+
* click$.next('click1');
|
|
34
|
+
*
|
|
35
|
+
* click$.next('click2');
|
|
36
|
+
*
|
|
37
|
+
* click$.next('click3');
|
|
38
|
+
*
|
|
39
|
+
* assert.deepStrictEqual(valueHistory, [1, 1, 1]);
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
export declare const mapTo: <A, B>(value: B) => KeepInitialValueOperator<A, B>;
|
|
43
|
+
//# sourceMappingURL=map-to.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-to.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/map-to.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,eAAO,MAAM,KAAK,GAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,KAAG,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAClD,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import 'ts-data-forge';
|
|
2
|
+
import '../../utils/id-maker.mjs';
|
|
3
|
+
import { map } from '../../operators/map.mjs';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Maps all emitted values to a constant value, ignoring the source values.
|
|
7
|
+
* Equivalent to `map(() => value)`.
|
|
8
|
+
*
|
|
9
|
+
* @template A - The type of values from the source
|
|
10
|
+
* @template B - The type of the constant value
|
|
11
|
+
* @param value - The constant value to emit
|
|
12
|
+
* @returns An operator that always emits the given constant
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* // Timeline:
|
|
17
|
+
* //
|
|
18
|
+
* // click$ MouseEvent MouseEvent MouseEvent
|
|
19
|
+
* // count$ 1 1 1
|
|
20
|
+
* //
|
|
21
|
+
* // Explanation:
|
|
22
|
+
* // - mapTo maps all emitted values to a constant value
|
|
23
|
+
* // - Ignores the source values entirely
|
|
24
|
+
* // - Useful for converting events to signals
|
|
25
|
+
*
|
|
26
|
+
* const click$ = source<string>();
|
|
27
|
+
*
|
|
28
|
+
* const one$ = click$.pipe(mapTo(1));
|
|
29
|
+
*
|
|
30
|
+
* const valueHistory: number[] = [];
|
|
31
|
+
*
|
|
32
|
+
* one$.subscribe((value) => {
|
|
33
|
+
* valueHistory.push(value);
|
|
34
|
+
* });
|
|
35
|
+
*
|
|
36
|
+
* click$.next('click1');
|
|
37
|
+
*
|
|
38
|
+
* click$.next('click2');
|
|
39
|
+
*
|
|
40
|
+
* click$.next('click3');
|
|
41
|
+
*
|
|
42
|
+
* assert.deepStrictEqual(valueHistory, [1, 1, 1]);
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
45
|
+
const mapTo = (value) => map(() => value);
|
|
46
|
+
|
|
47
|
+
export { mapTo };
|
|
48
|
+
//# sourceMappingURL=map-to.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map-to.mjs","sources":["../../../../src/core/predefined/operators/map-to.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAGA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuCG;AACI,MAAM,KAAK,GAAG,CAAO,KAAQ,KAClC,GAAG,CAAC,MAAM,KAAK;;;;"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { type KeepInitialValueOperator } from '../../types/index.mjs';
|
|
2
|
+
/**
|
|
3
|
+
* Extracts a property value from each emitted object by key.
|
|
4
|
+
* Equivalent to `map(value => value[key])`.
|
|
5
|
+
*
|
|
6
|
+
* @template A - The type of the emitted object
|
|
7
|
+
* @template K - The key to extract
|
|
8
|
+
* @param key - The property key to pluck
|
|
9
|
+
* @returns An operator that emits the property value
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```ts
|
|
13
|
+
* // Timeline:
|
|
14
|
+
* //
|
|
15
|
+
* // user$ { name: "Alice", age: 25 } { name: "Bob", age: 30 }
|
|
16
|
+
* // name$ "Alice" "Bob"
|
|
17
|
+
* //
|
|
18
|
+
* // Explanation:
|
|
19
|
+
* // - getKey extracts a property value from each emitted object
|
|
20
|
+
* // - Equivalent to map(value => value[key])
|
|
21
|
+
*
|
|
22
|
+
* const user$ = source<Readonly<{ name: string; age: number }>>();
|
|
23
|
+
*
|
|
24
|
+
* const name$ = user$.pipe(getKey('name'));
|
|
25
|
+
*
|
|
26
|
+
* const valueHistory: string[] = [];
|
|
27
|
+
*
|
|
28
|
+
* name$.subscribe((n) => {
|
|
29
|
+
* valueHistory.push(n);
|
|
30
|
+
* });
|
|
31
|
+
*
|
|
32
|
+
* user$.next({ name: 'Alice', age: 25 });
|
|
33
|
+
*
|
|
34
|
+
* assert.deepStrictEqual(valueHistory, ['Alice']);
|
|
35
|
+
*
|
|
36
|
+
* user$.next({ name: 'Bob', age: 30 });
|
|
37
|
+
*
|
|
38
|
+
* assert.deepStrictEqual(valueHistory, ['Alice', 'Bob']);
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
41
|
+
export declare const pluck: <A, K extends keyof A>(key: K) => KeepInitialValueOperator<A, A[K]>;
|
|
42
|
+
/**
|
|
43
|
+
* Alias for `pluck`.
|
|
44
|
+
* @see pluck
|
|
45
|
+
*/
|
|
46
|
+
export declare const getKey: <A, K extends keyof A>(key: K) => KeepInitialValueOperator<A, A[K]>;
|
|
47
|
+
//# sourceMappingURL=pluck.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pluck.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/pluck.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCG;AACH,eAAO,MAAM,KAAK,GAAI,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,EACxC,KAAK,CAAC,KACL,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAuB,CAAC;AAE3D;;;GAGG;AACH,eAAO,MAAM,MAAM,GARG,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,OACnC,CAAC,KACL,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAMR,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import 'ts-data-forge';
|
|
2
|
+
import '../../utils/id-maker.mjs';
|
|
3
|
+
import { map } from '../../operators/map.mjs';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Extracts a property value from each emitted object by key.
|
|
7
|
+
* Equivalent to `map(value => value[key])`.
|
|
8
|
+
*
|
|
9
|
+
* @template A - The type of the emitted object
|
|
10
|
+
* @template K - The key to extract
|
|
11
|
+
* @param key - The property key to pluck
|
|
12
|
+
* @returns An operator that emits the property value
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* // Timeline:
|
|
17
|
+
* //
|
|
18
|
+
* // user$ { name: "Alice", age: 25 } { name: "Bob", age: 30 }
|
|
19
|
+
* // name$ "Alice" "Bob"
|
|
20
|
+
* //
|
|
21
|
+
* // Explanation:
|
|
22
|
+
* // - getKey extracts a property value from each emitted object
|
|
23
|
+
* // - Equivalent to map(value => value[key])
|
|
24
|
+
*
|
|
25
|
+
* const user$ = source<Readonly<{ name: string; age: number }>>();
|
|
26
|
+
*
|
|
27
|
+
* const name$ = user$.pipe(getKey('name'));
|
|
28
|
+
*
|
|
29
|
+
* const valueHistory: string[] = [];
|
|
30
|
+
*
|
|
31
|
+
* name$.subscribe((n) => {
|
|
32
|
+
* valueHistory.push(n);
|
|
33
|
+
* });
|
|
34
|
+
*
|
|
35
|
+
* user$.next({ name: 'Alice', age: 25 });
|
|
36
|
+
*
|
|
37
|
+
* assert.deepStrictEqual(valueHistory, ['Alice']);
|
|
38
|
+
*
|
|
39
|
+
* user$.next({ name: 'Bob', age: 30 });
|
|
40
|
+
*
|
|
41
|
+
* assert.deepStrictEqual(valueHistory, ['Alice', 'Bob']);
|
|
42
|
+
* ```
|
|
43
|
+
*/
|
|
44
|
+
const pluck = (key) => map((a) => a[key]);
|
|
45
|
+
/**
|
|
46
|
+
* Alias for `pluck`.
|
|
47
|
+
* @see pluck
|
|
48
|
+
*/
|
|
49
|
+
const getKey = pluck;
|
|
50
|
+
|
|
51
|
+
export { getKey, pluck };
|
|
52
|
+
//# sourceMappingURL=pluck.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pluck.mjs","sources":["../../../../src/core/predefined/operators/pluck.mts"],"sourcesContent":[null],"names":[],"mappings":";;;;AAGA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsCG;MACU,KAAK,GAAG,CACnB,GAAM,KACgC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;AAEzD;;;AAGG;AACI,MAAM,MAAM,GAAG;;;;"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { type DropInitialValueOperator } from '../../types/index.mjs';
|
|
2
|
+
/**
|
|
3
|
+
* Skips the first `n` emissions from the source observable.
|
|
4
|
+
* After `n` values are skipped, all subsequent values pass through.
|
|
5
|
+
*
|
|
6
|
+
* @template A - The type of values from the source
|
|
7
|
+
* @param n - The number of values to skip
|
|
8
|
+
* @returns An operator that skips the first n emissions
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```ts
|
|
12
|
+
* // Timeline:
|
|
13
|
+
* //
|
|
14
|
+
* // num$ 1 2 3 4 5
|
|
15
|
+
* // skipped$ 3 4 5
|
|
16
|
+
* // |skip 2|
|
|
17
|
+
* //
|
|
18
|
+
* // Explanation:
|
|
19
|
+
* // - skip ignores the first n emissions from the source
|
|
20
|
+
* // - After n values are skipped, all subsequent values pass through
|
|
21
|
+
*
|
|
22
|
+
* const num$ = source<number>();
|
|
23
|
+
*
|
|
24
|
+
* const skipped$ = num$.pipe(skip(2));
|
|
25
|
+
*
|
|
26
|
+
* const valueHistory: number[] = [];
|
|
27
|
+
*
|
|
28
|
+
* skipped$.subscribe((x) => {
|
|
29
|
+
* valueHistory.push(x);
|
|
30
|
+
* });
|
|
31
|
+
*
|
|
32
|
+
* num$.next(1); // skipped
|
|
33
|
+
*
|
|
34
|
+
* num$.next(2); // skipped
|
|
35
|
+
*
|
|
36
|
+
* assert.deepStrictEqual(valueHistory, []);
|
|
37
|
+
*
|
|
38
|
+
* num$.next(3); // logs: 3
|
|
39
|
+
*
|
|
40
|
+
* assert.deepStrictEqual(valueHistory, [3]);
|
|
41
|
+
*
|
|
42
|
+
* num$.next(4); // logs: 4
|
|
43
|
+
*
|
|
44
|
+
* num$.next(5); // logs: 5
|
|
45
|
+
*
|
|
46
|
+
* assert.deepStrictEqual(valueHistory, [3, 4, 5]);
|
|
47
|
+
* ```
|
|
48
|
+
*/
|
|
49
|
+
export declare const skip: <A>(n: PositiveSafeIntWithSmallInt) => DropInitialValueOperator<A, A>;
|
|
50
|
+
//# sourceMappingURL=skip.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skip.d.mts","sourceRoot":"","sources":["../../../../src/core/predefined/operators/skip.mts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,eAAO,MAAM,IAAI,GAAI,CAAC,EACpB,GAAG,2BAA2B,KAC7B,wBAAwB,CAAC,CAAC,EAAE,CAAC,CACyC,CAAC"}
|