@legendapp/state 3.0.0-alpha.1 → 3.0.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.DS_Store +0 -0
- package/CHANGELOG.md +1 -831
- package/LICENSE +1 -21
- package/README.md +1 -141
- package/as/arrayAsRecord.d.mts +5 -0
- package/as/arrayAsRecord.d.ts +5 -0
- package/as/arrayAsRecord.js +28 -0
- package/as/arrayAsRecord.mjs +26 -0
- package/as/arrayAsSet.d.mts +5 -0
- package/as/arrayAsSet.d.ts +5 -0
- package/as/arrayAsSet.js +13 -0
- package/as/arrayAsSet.mjs +11 -0
- package/as/arrayAsString.d.mts +5 -0
- package/as/arrayAsString.d.ts +5 -0
- package/as/arrayAsString.js +13 -0
- package/as/arrayAsString.mjs +11 -0
- package/as/numberAsString.d.mts +5 -0
- package/as/numberAsString.d.ts +5 -0
- package/as/numberAsString.js +13 -0
- package/as/numberAsString.mjs +11 -0
- package/as/recordAsArray.d.mts +5 -0
- package/as/recordAsArray.d.ts +5 -0
- package/as/recordAsArray.js +25 -0
- package/as/recordAsArray.mjs +23 -0
- package/as/recordAsString.d.mts +5 -0
- package/as/recordAsString.d.ts +5 -0
- package/as/recordAsString.js +13 -0
- package/as/recordAsString.mjs +11 -0
- package/as/setAsArray.d.mts +5 -0
- package/as/setAsArray.d.ts +5 -0
- package/as/setAsArray.js +13 -0
- package/as/setAsArray.mjs +11 -0
- package/as/setAsString.d.mts +5 -0
- package/as/setAsString.d.ts +5 -0
- package/as/setAsString.js +13 -0
- package/as/setAsString.mjs +11 -0
- package/as/stringAsArray.d.mts +5 -0
- package/as/stringAsArray.d.ts +5 -0
- package/as/stringAsArray.js +13 -0
- package/as/stringAsArray.mjs +11 -0
- package/as/stringAsNumber.d.mts +5 -0
- package/as/stringAsNumber.d.ts +5 -0
- package/as/stringAsNumber.js +16 -0
- package/as/stringAsNumber.mjs +14 -0
- package/as/stringAsRecord.d.mts +5 -0
- package/as/stringAsRecord.d.ts +5 -0
- package/as/stringAsRecord.js +15 -0
- package/as/stringAsRecord.mjs +13 -0
- package/as/stringAsSet.d.mts +5 -0
- package/as/stringAsSet.d.ts +5 -0
- package/as/stringAsSet.js +13 -0
- package/as/stringAsSet.mjs +11 -0
- package/babel.d.mts +21 -0
- package/babel.d.ts +21 -2
- package/babel.js +57 -53
- package/babel.mjs +65 -0
- package/config/enable$GetSet.js +13 -14
- package/config/enable$GetSet.mjs +13 -14
- package/config/enableReactComponents.d.mts +9 -0
- package/config/enableReactComponents.d.ts +4 -2
- package/config/enableReactComponents.js +13 -10
- package/config/enableReactComponents.mjs +13 -10
- package/config/enableReactNativeComponents.d.mts +22 -0
- package/config/enableReactNativeComponents.d.ts +6 -4
- package/config/enableReactNativeComponents.js +43 -47
- package/config/enableReactNativeComponents.mjs +43 -47
- package/config/enableReactTracking.d.mts +7 -0
- package/config/enableReactTracking.d.ts +3 -2
- package/config/enableReactTracking.js +33 -38
- package/config/enableReactTracking.mjs +33 -38
- package/config/enableReactUse.d.mts +10 -0
- package/config/enableReactUse.d.ts +4 -1
- package/config/enableReactUse.js +15 -14
- package/config/enableReactUse.mjs +15 -14
- package/config/{enable$GetSet.d.ts → enable_GetSet.d.mts} +4 -2
- package/config/enable_GetSet.d.ts +10 -0
- package/config/enable_PeekAssign.d.mts +10 -0
- package/config/enable_PeekAssign.d.ts +4 -2
- package/config/enable_PeekAssign.js +13 -14
- package/config/enable_PeekAssign.mjs +13 -14
- package/helpers/pageHash.d.mts +9 -0
- package/helpers/pageHash.d.ts +2 -0
- package/helpers/pageHash.js +25 -30
- package/helpers/pageHash.mjs +25 -30
- package/helpers/pageHashParams.d.mts +9 -0
- package/helpers/pageHashParams.d.ts +2 -0
- package/helpers/pageHashParams.js +34 -37
- package/helpers/pageHashParams.mjs +34 -37
- package/helpers/time.d.mts +6 -0
- package/helpers/time.d.ts +6 -3
- package/helpers/time.js +17 -17
- package/helpers/time.mjs +17 -17
- package/helpers/trackHistory.d.mts +6 -0
- package/helpers/trackHistory.d.ts +4 -2
- package/helpers/trackHistory.js +13 -16
- package/helpers/trackHistory.mjs +13 -16
- package/helpers/undoRedo.d.mts +37 -0
- package/helpers/undoRedo.d.ts +5 -3
- package/helpers/undoRedo.js +59 -94
- package/helpers/undoRedo.mjs +59 -94
- package/index.d.mts +404 -0
- package/index.d.ts +371 -28
- package/index.js +2015 -2166
- package/index.mjs +2015 -2166
- package/package.json +254 -195
- package/persist-plugins/async-storage.d.mts +18 -0
- package/persist-plugins/async-storage.d.ts +6 -3
- package/persist-plugins/async-storage.js +79 -86
- package/persist-plugins/async-storage.mjs +79 -86
- package/persist-plugins/indexeddb.d.mts +29 -0
- package/persist-plugins/indexeddb.d.ts +6 -3
- package/persist-plugins/indexeddb.js +331 -352
- package/persist-plugins/indexeddb.mjs +331 -352
- package/persist-plugins/local-storage.d.mts +23 -0
- package/persist-plugins/local-storage.d.ts +8 -5
- package/persist-plugins/local-storage.js +74 -76
- package/persist-plugins/local-storage.mjs +74 -76
- package/persist-plugins/mmkv.d.mts +18 -0
- package/persist-plugins/mmkv.d.ts +6 -3
- package/persist-plugins/mmkv.js +82 -86
- package/persist-plugins/mmkv.mjs +82 -86
- package/react-hooks/createObservableHook.d.mts +5 -0
- package/react-hooks/createObservableHook.d.ts +4 -1
- package/react-hooks/createObservableHook.js +29 -30
- package/react-hooks/createObservableHook.mjs +25 -30
- package/react-hooks/useHover.d.mts +5 -0
- package/react-hooks/useHover.d.ts +5 -3
- package/react-hooks/useHover.js +29 -29
- package/react-hooks/useHover.mjs +29 -29
- package/react-hooks/useMeasure.d.mts +9 -0
- package/react-hooks/useMeasure.d.ts +5 -2
- package/react-hooks/useMeasure.js +30 -32
- package/react-hooks/useMeasure.mjs +30 -32
- package/react-hooks/useObservableNextRouter.d.mts +35 -0
- package/react-hooks/useObservableNextRouter.d.ts +9 -7
- package/react-hooks/useObservableNextRouter.js +64 -77
- package/react-hooks/useObservableNextRouter.mjs +60 -77
- package/react.d.mts +157 -0
- package/react.d.ts +157 -21
- package/react.js +458 -749
- package/react.mjs +457 -752
- package/sync-plugins/crud.d.mts +54 -0
- package/sync-plugins/crud.d.ts +12 -10
- package/sync-plugins/crud.js +253 -270
- package/sync-plugins/crud.mjs +253 -270
- package/sync-plugins/fetch.d.mts +21 -0
- package/sync-plugins/fetch.d.ts +7 -4
- package/sync-plugins/fetch.js +50 -37
- package/sync-plugins/fetch.mjs +50 -37
- package/sync-plugins/keel.d.mts +108 -0
- package/sync-plugins/keel.d.ts +17 -15
- package/sync-plugins/keel.js +229 -462
- package/sync-plugins/keel.mjs +227 -464
- package/sync-plugins/supabase.d.mts +39 -0
- package/sync-plugins/supabase.d.ts +16 -14
- package/sync-plugins/supabase.js +128 -128
- package/sync-plugins/supabase.mjs +128 -128
- package/sync-plugins/tanstack-query.d.mts +14 -0
- package/sync-plugins/tanstack-query.d.ts +7 -4
- package/sync-plugins/tanstack-query.js +51 -57
- package/sync-plugins/tanstack-query.mjs +51 -57
- package/sync-plugins/tanstack-react-query.d.mts +8 -0
- package/sync-plugins/tanstack-react-query.d.ts +6 -1
- package/sync-plugins/tanstack-react-query.js +2 -2
- package/sync-plugins/tanstack-react-query.mjs +2 -2
- package/sync.d.mts +351 -0
- package/sync.d.ts +349 -9
- package/sync.js +910 -964
- package/sync.mjs +920 -974
- package/trace.d.mts +9 -0
- package/trace.d.ts +9 -4
- package/trace.js +72 -62
- package/trace.mjs +72 -62
- package/types/babel.d.ts +1 -12
- package/babel.js.map +0 -1
- package/config/enable$GetSet.js.map +0 -1
- package/config/enable$GetSet.mjs.map +0 -1
- package/config/enableReactComponents.js.map +0 -1
- package/config/enableReactComponents.mjs.map +0 -1
- package/config/enableReactNativeComponents.js.map +0 -1
- package/config/enableReactNativeComponents.mjs.map +0 -1
- package/config/enableReactTracking.js.map +0 -1
- package/config/enableReactTracking.mjs.map +0 -1
- package/config/enableReactUse.js.map +0 -1
- package/config/enableReactUse.mjs.map +0 -1
- package/config/enable_PeekAssign.js.map +0 -1
- package/config/enable_PeekAssign.mjs.map +0 -1
- package/helpers/pageHash.js.map +0 -1
- package/helpers/pageHash.mjs.map +0 -1
- package/helpers/pageHashParams.js.map +0 -1
- package/helpers/pageHashParams.mjs.map +0 -1
- package/helpers/time.js.map +0 -1
- package/helpers/time.mjs.map +0 -1
- package/helpers/trackHistory.js.map +0 -1
- package/helpers/trackHistory.mjs.map +0 -1
- package/helpers/undoRedo.js.map +0 -1
- package/helpers/undoRedo.mjs.map +0 -1
- package/history.d.ts +0 -1
- package/history.js +0 -24
- package/history.js.map +0 -1
- package/history.mjs +0 -22
- package/history.mjs.map +0 -1
- package/index.js.map +0 -1
- package/index.mjs.map +0 -1
- package/persist-plugins/async-storage.js.map +0 -1
- package/persist-plugins/async-storage.mjs.map +0 -1
- package/persist-plugins/indexeddb.js.map +0 -1
- package/persist-plugins/indexeddb.mjs.map +0 -1
- package/persist-plugins/local-storage.js.map +0 -1
- package/persist-plugins/local-storage.mjs.map +0 -1
- package/persist-plugins/mmkv.js.map +0 -1
- package/persist-plugins/mmkv.mjs.map +0 -1
- package/react-hooks/createObservableHook.js.map +0 -1
- package/react-hooks/createObservableHook.mjs.map +0 -1
- package/react-hooks/useHover.js.map +0 -1
- package/react-hooks/useHover.mjs.map +0 -1
- package/react-hooks/useMeasure.js.map +0 -1
- package/react-hooks/useMeasure.mjs.map +0 -1
- package/react-hooks/useObservableNextRouter.js.map +0 -1
- package/react-hooks/useObservableNextRouter.mjs.map +0 -1
- package/react.js.map +0 -1
- package/react.mjs.map +0 -1
- package/src/ObservableObject.ts +0 -1350
- package/src/ObservablePrimitive.ts +0 -62
- package/src/babel/index.ts +0 -83
- package/src/batching.ts +0 -357
- package/src/computed.ts +0 -18
- package/src/config/enable$GetSet.ts +0 -30
- package/src/config/enableReactComponents.ts +0 -26
- package/src/config/enableReactNativeComponents.ts +0 -102
- package/src/config/enableReactTracking.ts +0 -62
- package/src/config/enableReactUse.ts +0 -32
- package/src/config/enable_PeekAssign.ts +0 -31
- package/src/config.ts +0 -47
- package/src/createObservable.ts +0 -47
- package/src/event.ts +0 -26
- package/src/globals.ts +0 -235
- package/src/helpers/pageHash.ts +0 -41
- package/src/helpers/pageHashParams.ts +0 -55
- package/src/helpers/time.ts +0 -30
- package/src/helpers/trackHistory.ts +0 -29
- package/src/helpers/undoRedo.ts +0 -111
- package/src/helpers.ts +0 -231
- package/src/is.ts +0 -63
- package/src/linked.ts +0 -17
- package/src/observable.ts +0 -32
- package/src/observableInterfaces.ts +0 -151
- package/src/observableTypes.ts +0 -232
- package/src/observe.ts +0 -89
- package/src/old-plugins/firebase.ts +0 -1053
- package/src/onChange.ts +0 -146
- package/src/persist/configureObservablePersistence.ts +0 -7
- package/src/persist/fieldTransformer.ts +0 -149
- package/src/persist/observablePersistRemoteFunctionsAdapter.ts +0 -39
- package/src/persist/persistObservable.ts +0 -1034
- package/src/persist-plugins/async-storage.ts +0 -99
- package/src/persist-plugins/indexeddb.ts +0 -439
- package/src/persist-plugins/local-storage.ts +0 -86
- package/src/persist-plugins/mmkv.ts +0 -91
- package/src/proxy.ts +0 -28
- package/src/react/Computed.tsx +0 -8
- package/src/react/For.tsx +0 -116
- package/src/react/Memo.tsx +0 -4
- package/src/react/Reactive.tsx +0 -53
- package/src/react/Show.tsx +0 -33
- package/src/react/Switch.tsx +0 -43
- package/src/react/react-globals.ts +0 -3
- package/src/react/reactInterfaces.ts +0 -32
- package/src/react/reactive-observer.tsx +0 -210
- package/src/react/useComputed.ts +0 -36
- package/src/react/useEffectOnce.ts +0 -41
- package/src/react/useIsMounted.ts +0 -16
- package/src/react/useMount.ts +0 -15
- package/src/react/useObservable.ts +0 -24
- package/src/react/useObservableReducer.ts +0 -52
- package/src/react/useObservableState.ts +0 -30
- package/src/react/useObserve.ts +0 -54
- package/src/react/useObserveEffect.ts +0 -40
- package/src/react/usePauseProvider.tsx +0 -16
- package/src/react/useSelector.ts +0 -167
- package/src/react/useUnmount.ts +0 -8
- package/src/react/useWhen.ts +0 -9
- package/src/react-hooks/createObservableHook.ts +0 -53
- package/src/react-hooks/useHover.ts +0 -40
- package/src/react-hooks/useMeasure.ts +0 -48
- package/src/react-hooks/useObservableNextRouter.ts +0 -137
- package/src/retry.ts +0 -71
- package/src/setupTracking.ts +0 -26
- package/src/sync/activateSyncedNode.ts +0 -128
- package/src/sync/configureObservableSync.ts +0 -7
- package/src/sync/persistTypes.ts +0 -216
- package/src/sync/syncHelpers.ts +0 -180
- package/src/sync/syncObservable.ts +0 -1056
- package/src/sync/syncObservableAdapter.ts +0 -31
- package/src/sync/syncTypes.ts +0 -189
- package/src/sync/synced.ts +0 -21
- package/src/sync-plugins/crud.ts +0 -412
- package/src/sync-plugins/fetch.ts +0 -80
- package/src/sync-plugins/keel.ts +0 -495
- package/src/sync-plugins/supabase.ts +0 -249
- package/src/sync-plugins/tanstack-query.ts +0 -113
- package/src/sync-plugins/tanstack-react-query.ts +0 -12
- package/src/trace/traceHelpers.ts +0 -11
- package/src/trace/useTraceListeners.ts +0 -34
- package/src/trace/useTraceUpdates.ts +0 -24
- package/src/trace/useVerifyNotTracking.ts +0 -33
- package/src/trace/useVerifyOneRender.ts +0 -10
- package/src/trackSelector.ts +0 -52
- package/src/tracking.ts +0 -43
- package/src/types/babel.d.ts +0 -12
- package/src/when.ts +0 -75
- package/sync-plugins/crud.js.map +0 -1
- package/sync-plugins/crud.mjs.map +0 -1
- package/sync-plugins/fetch.js.map +0 -1
- package/sync-plugins/fetch.mjs.map +0 -1
- package/sync-plugins/keel.js.map +0 -1
- package/sync-plugins/keel.mjs.map +0 -1
- package/sync-plugins/supabase.js.map +0 -1
- package/sync-plugins/supabase.mjs.map +0 -1
- package/sync-plugins/tanstack-query.js.map +0 -1
- package/sync-plugins/tanstack-query.mjs.map +0 -1
- package/sync-plugins/tanstack-react-query.js.map +0 -1
- package/sync-plugins/tanstack-react-query.mjs.map +0 -1
- package/sync.js.map +0 -1
- package/sync.mjs.map +0 -1
- package/trace.js.map +0 -1
- package/trace.mjs.map +0 -1
package/helpers/undoRedo.js
CHANGED
|
@@ -2,102 +2,67 @@
|
|
|
2
2
|
|
|
3
3
|
var state = require('@legendapp/state');
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
* Usage:
|
|
7
|
-
*
|
|
8
|
-
* Use this function to add undo/redo functionality to an observable.
|
|
9
|
-
*
|
|
10
|
-
* You can monitor how many undos or redos are available to enable/disable undo/redo
|
|
11
|
-
* UI elements with undo$ and redo$.
|
|
12
|
-
*
|
|
13
|
-
* If you undo and then make a change, it'll delete any redos and add the change, as expected.
|
|
14
|
-
*
|
|
15
|
-
* If you don't pass in a limit, it will keep all history. This means it can grow indefinitely.
|
|
16
|
-
*
|
|
17
|
-
* ```typescript
|
|
18
|
-
* const obs$ = observable({ test: 'hi', test2: 'a' });
|
|
19
|
-
* const { undo, redo, undos$, redos$, getHistory } = undoRedo(obs$, { limit: 40 });
|
|
20
|
-
* obs$.test.set('hello');
|
|
21
|
-
* undo();
|
|
22
|
-
* redo();
|
|
23
|
-
* // observables for # of undos/redos available
|
|
24
|
-
* undos$.get();
|
|
25
|
-
* redos$.get();
|
|
26
|
-
* ```
|
|
27
|
-
*/
|
|
5
|
+
// src/helpers/undoRedo.ts
|
|
28
6
|
function undoRedo(obs$, options) {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
7
|
+
let history = [];
|
|
8
|
+
let historyPointer = 0;
|
|
9
|
+
let restoringFromHistory = false;
|
|
10
|
+
const undos$ = state.observable(0);
|
|
11
|
+
const redos$ = state.observable(0);
|
|
12
|
+
function updateUndoRedo() {
|
|
13
|
+
undos$.set(historyPointer);
|
|
14
|
+
redos$.set(history.length - historyPointer - 1);
|
|
15
|
+
}
|
|
16
|
+
obs$.onChange(({ getPrevious }) => {
|
|
17
|
+
if (restoringFromHistory)
|
|
18
|
+
return;
|
|
19
|
+
if (state.internal.globalState.isLoadingRemote || state.internal.globalState.isLoadingLocal)
|
|
20
|
+
return;
|
|
21
|
+
if (!history.length) {
|
|
22
|
+
const previous = getPrevious();
|
|
23
|
+
if (previous)
|
|
24
|
+
history.push(state.internal.clone(previous));
|
|
25
|
+
historyPointer = 0;
|
|
37
26
|
}
|
|
38
|
-
obs$.
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
console.warn('Already at the beginning of undo history');
|
|
80
|
-
}
|
|
81
|
-
updateUndoRedo();
|
|
82
|
-
},
|
|
83
|
-
redo() {
|
|
84
|
-
if (historyPointer < history.length - 1) {
|
|
85
|
-
historyPointer++;
|
|
86
|
-
const snapshot = state.internal.clone(history[historyPointer]);
|
|
87
|
-
restoringFromHistory = true;
|
|
88
|
-
obs$.set(snapshot);
|
|
89
|
-
restoringFromHistory = false;
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
console.warn('Already at the end of undo history');
|
|
93
|
-
}
|
|
94
|
-
updateUndoRedo();
|
|
95
|
-
},
|
|
96
|
-
undos$: undos$,
|
|
97
|
-
redos$: redos$,
|
|
98
|
-
getHistory: () => history,
|
|
99
|
-
};
|
|
27
|
+
const snapshot = state.internal.clone(obs$.get());
|
|
28
|
+
if (options == null ? void 0 : options.limit) {
|
|
29
|
+
history = history.slice(Math.max(0, history.length - options.limit));
|
|
30
|
+
} else {
|
|
31
|
+
history = history.slice(0, historyPointer + 1);
|
|
32
|
+
}
|
|
33
|
+
history.push(snapshot);
|
|
34
|
+
historyPointer = history.length - 1;
|
|
35
|
+
updateUndoRedo();
|
|
36
|
+
});
|
|
37
|
+
return {
|
|
38
|
+
undo() {
|
|
39
|
+
if (historyPointer > 0) {
|
|
40
|
+
historyPointer--;
|
|
41
|
+
const snapshot = state.internal.clone(history[historyPointer]);
|
|
42
|
+
restoringFromHistory = true;
|
|
43
|
+
obs$.set(snapshot);
|
|
44
|
+
restoringFromHistory = false;
|
|
45
|
+
} else {
|
|
46
|
+
console.warn("Already at the beginning of undo history");
|
|
47
|
+
}
|
|
48
|
+
updateUndoRedo();
|
|
49
|
+
},
|
|
50
|
+
redo() {
|
|
51
|
+
if (historyPointer < history.length - 1) {
|
|
52
|
+
historyPointer++;
|
|
53
|
+
const snapshot = state.internal.clone(history[historyPointer]);
|
|
54
|
+
restoringFromHistory = true;
|
|
55
|
+
obs$.set(snapshot);
|
|
56
|
+
restoringFromHistory = false;
|
|
57
|
+
} else {
|
|
58
|
+
console.warn("Already at the end of undo history");
|
|
59
|
+
}
|
|
60
|
+
updateUndoRedo();
|
|
61
|
+
},
|
|
62
|
+
undos$,
|
|
63
|
+
redos$,
|
|
64
|
+
getHistory: () => history
|
|
65
|
+
};
|
|
100
66
|
}
|
|
101
67
|
|
|
102
68
|
exports.undoRedo = undoRedo;
|
|
103
|
-
//# sourceMappingURL=undoRedo.js.map
|
package/helpers/undoRedo.mjs
CHANGED
|
@@ -1,101 +1,66 @@
|
|
|
1
1
|
import { observable, internal } from '@legendapp/state';
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
* Usage:
|
|
5
|
-
*
|
|
6
|
-
* Use this function to add undo/redo functionality to an observable.
|
|
7
|
-
*
|
|
8
|
-
* You can monitor how many undos or redos are available to enable/disable undo/redo
|
|
9
|
-
* UI elements with undo$ and redo$.
|
|
10
|
-
*
|
|
11
|
-
* If you undo and then make a change, it'll delete any redos and add the change, as expected.
|
|
12
|
-
*
|
|
13
|
-
* If you don't pass in a limit, it will keep all history. This means it can grow indefinitely.
|
|
14
|
-
*
|
|
15
|
-
* ```typescript
|
|
16
|
-
* const obs$ = observable({ test: 'hi', test2: 'a' });
|
|
17
|
-
* const { undo, redo, undos$, redos$, getHistory } = undoRedo(obs$, { limit: 40 });
|
|
18
|
-
* obs$.test.set('hello');
|
|
19
|
-
* undo();
|
|
20
|
-
* redo();
|
|
21
|
-
* // observables for # of undos/redos available
|
|
22
|
-
* undos$.get();
|
|
23
|
-
* redos$.get();
|
|
24
|
-
* ```
|
|
25
|
-
*/
|
|
3
|
+
// src/helpers/undoRedo.ts
|
|
26
4
|
function undoRedo(obs$, options) {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
5
|
+
let history = [];
|
|
6
|
+
let historyPointer = 0;
|
|
7
|
+
let restoringFromHistory = false;
|
|
8
|
+
const undos$ = observable(0);
|
|
9
|
+
const redos$ = observable(0);
|
|
10
|
+
function updateUndoRedo() {
|
|
11
|
+
undos$.set(historyPointer);
|
|
12
|
+
redos$.set(history.length - historyPointer - 1);
|
|
13
|
+
}
|
|
14
|
+
obs$.onChange(({ getPrevious }) => {
|
|
15
|
+
if (restoringFromHistory)
|
|
16
|
+
return;
|
|
17
|
+
if (internal.globalState.isLoadingRemote || internal.globalState.isLoadingLocal)
|
|
18
|
+
return;
|
|
19
|
+
if (!history.length) {
|
|
20
|
+
const previous = getPrevious();
|
|
21
|
+
if (previous)
|
|
22
|
+
history.push(internal.clone(previous));
|
|
23
|
+
historyPointer = 0;
|
|
35
24
|
}
|
|
36
|
-
obs$.
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
console.warn('Already at the beginning of undo history');
|
|
78
|
-
}
|
|
79
|
-
updateUndoRedo();
|
|
80
|
-
},
|
|
81
|
-
redo() {
|
|
82
|
-
if (historyPointer < history.length - 1) {
|
|
83
|
-
historyPointer++;
|
|
84
|
-
const snapshot = internal.clone(history[historyPointer]);
|
|
85
|
-
restoringFromHistory = true;
|
|
86
|
-
obs$.set(snapshot);
|
|
87
|
-
restoringFromHistory = false;
|
|
88
|
-
}
|
|
89
|
-
else {
|
|
90
|
-
console.warn('Already at the end of undo history');
|
|
91
|
-
}
|
|
92
|
-
updateUndoRedo();
|
|
93
|
-
},
|
|
94
|
-
undos$: undos$,
|
|
95
|
-
redos$: redos$,
|
|
96
|
-
getHistory: () => history,
|
|
97
|
-
};
|
|
25
|
+
const snapshot = internal.clone(obs$.get());
|
|
26
|
+
if (options == null ? void 0 : options.limit) {
|
|
27
|
+
history = history.slice(Math.max(0, history.length - options.limit));
|
|
28
|
+
} else {
|
|
29
|
+
history = history.slice(0, historyPointer + 1);
|
|
30
|
+
}
|
|
31
|
+
history.push(snapshot);
|
|
32
|
+
historyPointer = history.length - 1;
|
|
33
|
+
updateUndoRedo();
|
|
34
|
+
});
|
|
35
|
+
return {
|
|
36
|
+
undo() {
|
|
37
|
+
if (historyPointer > 0) {
|
|
38
|
+
historyPointer--;
|
|
39
|
+
const snapshot = internal.clone(history[historyPointer]);
|
|
40
|
+
restoringFromHistory = true;
|
|
41
|
+
obs$.set(snapshot);
|
|
42
|
+
restoringFromHistory = false;
|
|
43
|
+
} else {
|
|
44
|
+
console.warn("Already at the beginning of undo history");
|
|
45
|
+
}
|
|
46
|
+
updateUndoRedo();
|
|
47
|
+
},
|
|
48
|
+
redo() {
|
|
49
|
+
if (historyPointer < history.length - 1) {
|
|
50
|
+
historyPointer++;
|
|
51
|
+
const snapshot = internal.clone(history[historyPointer]);
|
|
52
|
+
restoringFromHistory = true;
|
|
53
|
+
obs$.set(snapshot);
|
|
54
|
+
restoringFromHistory = false;
|
|
55
|
+
} else {
|
|
56
|
+
console.warn("Already at the end of undo history");
|
|
57
|
+
}
|
|
58
|
+
updateUndoRedo();
|
|
59
|
+
},
|
|
60
|
+
undos$,
|
|
61
|
+
redos$,
|
|
62
|
+
getHistory: () => history
|
|
63
|
+
};
|
|
98
64
|
}
|
|
99
65
|
|
|
100
66
|
export { undoRedo };
|
|
101
|
-
//# sourceMappingURL=undoRedo.mjs.map
|