@yaasl/core 0.12.1 → 0.13.0-alpha.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.
|
@@ -17,7 +17,7 @@ export interface EffectActions<Options, AtomValue> {
|
|
|
17
17
|
/** Action to be called after the init phase */
|
|
18
18
|
didInit?: (payload: EffectPayload<Options, AtomValue>) => PromiseLike<any> | void;
|
|
19
19
|
/** Action to be called when the atom's value is set */
|
|
20
|
-
set?: (payload: EffectPayload<Options, AtomValue>) => void;
|
|
20
|
+
set?: (payload: EffectPayload<Options, AtomValue>) => PromiseLike<any> | void;
|
|
21
21
|
}
|
|
22
22
|
interface EffectSetupProps<Options, AtomValue> {
|
|
23
23
|
atom: Atom<AtomValue>;
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
export interface IndexedDbOptions {
|
|
2
2
|
/** Use your own store key. Will be `atom.name` by default. */
|
|
3
3
|
key?: string;
|
|
4
|
+
/** Disable the synchronization of values over browser tabs */
|
|
5
|
+
noTabSync?: boolean;
|
|
4
6
|
}
|
|
5
7
|
/** Middleware to save and load atom values to an indexedDb.
|
|
6
8
|
*
|
|
@@ -10,10 +10,37 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.indexedDb = void 0;
|
|
13
|
+
const utils_1 = require("@yaasl/utils");
|
|
13
14
|
const create_effect_1 = require("./create-effect");
|
|
14
15
|
const base_1 = require("../base");
|
|
15
16
|
const idb_store_1 = require("../utils/idb-store");
|
|
16
17
|
let atomDb = null;
|
|
18
|
+
const createSync = (storeKey, onTabSync) => {
|
|
19
|
+
var _a;
|
|
20
|
+
const observingKey = storeKey + "/last-change";
|
|
21
|
+
let changeTrigger = null;
|
|
22
|
+
(_a = (0, utils_1.getWindow)()) === null || _a === void 0 ? void 0 : _a.addEventListener("storage", ({ key }) => {
|
|
23
|
+
if (observingKey !== key)
|
|
24
|
+
return;
|
|
25
|
+
if (changeTrigger === "push") {
|
|
26
|
+
changeTrigger = null;
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
changeTrigger = "sync";
|
|
30
|
+
onTabSync();
|
|
31
|
+
});
|
|
32
|
+
return {
|
|
33
|
+
pushSync: () => {
|
|
34
|
+
var _a;
|
|
35
|
+
if (changeTrigger === "sync") {
|
|
36
|
+
changeTrigger = null;
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
changeTrigger = "push";
|
|
40
|
+
(_a = (0, utils_1.getWindow)()) === null || _a === void 0 ? void 0 : _a.localStorage.setItem(observingKey, Date.now().toString());
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
};
|
|
17
44
|
/** Middleware to save and load atom values to an indexedDb.
|
|
18
45
|
*
|
|
19
46
|
* Will use one database and store for all atoms with your `CONFIG.name`
|
|
@@ -27,6 +54,15 @@ let atomDb = null;
|
|
|
27
54
|
exports.indexedDb = (0, create_effect_1.createEffect)(({ atom, options }) => {
|
|
28
55
|
var _a;
|
|
29
56
|
const key = (_a = options === null || options === void 0 ? void 0 : options.key) !== null && _a !== void 0 ? _a : atom.name;
|
|
57
|
+
const { pushSync } = (options === null || options === void 0 ? void 0 : options.noTabSync)
|
|
58
|
+
? {}
|
|
59
|
+
: createSync(key, () => {
|
|
60
|
+
void (atomDb === null || atomDb === void 0 ? void 0 : atomDb.get(key).then(value => {
|
|
61
|
+
if (!value)
|
|
62
|
+
return;
|
|
63
|
+
atom.set(value);
|
|
64
|
+
}));
|
|
65
|
+
});
|
|
30
66
|
return {
|
|
31
67
|
sort: "pre",
|
|
32
68
|
init: (_a) => __awaiter(void 0, [_a], void 0, function* ({ atom, set }) {
|
|
@@ -42,8 +78,9 @@ exports.indexedDb = (0, create_effect_1.createEffect)(({ atom, options }) => {
|
|
|
42
78
|
yield atomDb.set(key, atom.defaultValue);
|
|
43
79
|
}
|
|
44
80
|
}),
|
|
45
|
-
set: ({ value })
|
|
46
|
-
|
|
47
|
-
|
|
81
|
+
set: (_a) => __awaiter(void 0, [_a], void 0, function* ({ value }) {
|
|
82
|
+
yield (atomDb === null || atomDb === void 0 ? void 0 : atomDb.set(key, value));
|
|
83
|
+
pushSync === null || pushSync === void 0 ? void 0 : pushSync();
|
|
84
|
+
}),
|
|
48
85
|
};
|
|
49
86
|
});
|
|
@@ -1,7 +1,32 @@
|
|
|
1
|
+
import { getWindow } from "@yaasl/utils";
|
|
1
2
|
import { createEffect } from "./create-effect";
|
|
2
3
|
import { CONFIG } from "../base";
|
|
3
4
|
import { IdbStore } from "../utils/idb-store";
|
|
4
5
|
let atomDb = null;
|
|
6
|
+
const createSync = (storeKey, onTabSync) => {
|
|
7
|
+
const observingKey = storeKey + "/last-change";
|
|
8
|
+
let changeTrigger = null;
|
|
9
|
+
getWindow()?.addEventListener("storage", ({ key }) => {
|
|
10
|
+
if (observingKey !== key)
|
|
11
|
+
return;
|
|
12
|
+
if (changeTrigger === "push") {
|
|
13
|
+
changeTrigger = null;
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
changeTrigger = "sync";
|
|
17
|
+
onTabSync();
|
|
18
|
+
});
|
|
19
|
+
return {
|
|
20
|
+
pushSync: () => {
|
|
21
|
+
if (changeTrigger === "sync") {
|
|
22
|
+
changeTrigger = null;
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
changeTrigger = "push";
|
|
26
|
+
getWindow()?.localStorage.setItem(observingKey, Date.now().toString());
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
};
|
|
5
30
|
/** Middleware to save and load atom values to an indexedDb.
|
|
6
31
|
*
|
|
7
32
|
* Will use one database and store for all atoms with your `CONFIG.name`
|
|
@@ -14,6 +39,15 @@ let atomDb = null;
|
|
|
14
39
|
**/
|
|
15
40
|
export const indexedDb = createEffect(({ atom, options }) => {
|
|
16
41
|
const key = options?.key ?? atom.name;
|
|
42
|
+
const { pushSync } = options?.noTabSync
|
|
43
|
+
? {}
|
|
44
|
+
: createSync(key, () => {
|
|
45
|
+
void atomDb?.get(key).then(value => {
|
|
46
|
+
if (!value)
|
|
47
|
+
return;
|
|
48
|
+
atom.set(value);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
17
51
|
return {
|
|
18
52
|
sort: "pre",
|
|
19
53
|
init: async ({ atom, set }) => {
|
|
@@ -28,8 +62,9 @@ export const indexedDb = createEffect(({ atom, options }) => {
|
|
|
28
62
|
await atomDb.set(key, atom.defaultValue);
|
|
29
63
|
}
|
|
30
64
|
},
|
|
31
|
-
set: ({ value }) => {
|
|
32
|
-
|
|
65
|
+
set: async ({ value }) => {
|
|
66
|
+
await atomDb?.set(key, value);
|
|
67
|
+
pushSync?.();
|
|
33
68
|
},
|
|
34
69
|
};
|
|
35
70
|
});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@yaasl/core",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.13.0-alpha.1",
|
|
4
4
|
"description": "yet another atomic store library (vanilla-js)",
|
|
5
5
|
"author": "PrettyCoffee",
|
|
6
6
|
"license": "MIT",
|
|
@@ -39,7 +39,10 @@
|
|
|
39
39
|
"lint:fix": "eslint ./src --fix",
|
|
40
40
|
"validate": "run-s lint test build"
|
|
41
41
|
},
|
|
42
|
-
"
|
|
42
|
+
"peerDependencies": {
|
|
43
|
+
"@yaasl/utils": "^0.12.1"
|
|
44
|
+
},
|
|
45
|
+
"devDependencies": {
|
|
43
46
|
"@yaasl/utils": "^0.12.1"
|
|
44
47
|
},
|
|
45
48
|
"lint-staged": {
|