@exodus/atoms 7.2.0 → 7.3.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.
- package/CHANGELOG.md +12 -0
- package/lib/enforce-rules.js +3 -1
- package/lib/factories/storage.js +5 -2
- package/package.json +4 -4
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,18 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [7.3.1](https://github.com/ExodusMovement/exodus-hydra/compare/@exodus/atoms@7.3.0...@exodus/atoms@7.3.1) (2024-05-09)
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
- atoms should not hit storage after first read or write ([#6834](https://github.com/ExodusMovement/exodus-hydra/issues/6834)) ([63e23f1](https://github.com/ExodusMovement/exodus-hydra/commit/63e23f1f0bf33732f67b70feb9e95e854a8fd90e))
|
|
11
|
+
|
|
12
|
+
## [7.3.0](https://github.com/ExodusMovement/exodus-hydra/compare/@exodus/atoms@7.2.0...@exodus/atoms@7.3.0) (2024-04-17)
|
|
13
|
+
|
|
14
|
+
### Features
|
|
15
|
+
|
|
16
|
+
- don't proxyFreeze ReadonlySet and ReadonlyMap ([#6539](https://github.com/ExodusMovement/exodus-hydra/issues/6539)) ([ed7fa30](https://github.com/ExodusMovement/exodus-hydra/commit/ed7fa30b715df0ce3a1c551f3482988dbec3ec48))
|
|
17
|
+
|
|
6
18
|
## [7.2.0](https://github.com/ExodusMovement/exodus-hydra/compare/@exodus/atoms@7.1.0...@exodus/atoms@7.2.0) (2024-04-16)
|
|
7
19
|
|
|
8
20
|
### Features
|
package/lib/enforce-rules.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import makeConcurrent from 'make-concurrent';
|
|
2
2
|
import proxyFreeze from 'proxy-freeze';
|
|
3
3
|
import { isSetter } from './utils/guards.js';
|
|
4
|
+
const isReadonlySetOrMap = (value) => ['[object ReadonlySet]', '[object ReadonlyMap]'].includes(Object.prototype.toString.call(value));
|
|
5
|
+
const freeze = (value) => (isReadonlySetOrMap(value) ? value : proxyFreeze(value));
|
|
4
6
|
const withChangeDetection = (listener) => {
|
|
5
7
|
let currentValue;
|
|
6
8
|
let called = false;
|
|
@@ -14,7 +16,7 @@ const withChangeDetection = (listener) => {
|
|
|
14
16
|
};
|
|
15
17
|
const enforceObservableRules = ({ defaultValue, getInitialized = () => true, ...atom }) => {
|
|
16
18
|
const enqueue = makeConcurrent((fn) => fn(), { concurrency: 1 });
|
|
17
|
-
const postProcessValue = (value = defaultValue) => value && typeof value === 'object' ?
|
|
19
|
+
const postProcessValue = (value = defaultValue) => value && typeof value === 'object' ? freeze(value) : value;
|
|
18
20
|
const get = () => atom.get().then(postProcessValue);
|
|
19
21
|
const observe = (listener) => {
|
|
20
22
|
let called = false;
|
package/lib/factories/storage.js
CHANGED
|
@@ -4,6 +4,7 @@ import pDefer from 'p-defer';
|
|
|
4
4
|
const createStorageAtomFactory = ({ storage }) => {
|
|
5
5
|
function createStorageAtom({ key, defaultValue, isSoleWriter, }) {
|
|
6
6
|
const { notify, observe } = createSimpleObserver({ enable: isSoleWriter });
|
|
7
|
+
let canUseCached = false;
|
|
7
8
|
let cached;
|
|
8
9
|
let writePromiseDefer;
|
|
9
10
|
const set = async (value) => {
|
|
@@ -18,22 +19,24 @@ const createStorageAtomFactory = ({ storage }) => {
|
|
|
18
19
|
writePromiseDefer.resolve();
|
|
19
20
|
if (isSoleWriter) {
|
|
20
21
|
cached = value;
|
|
22
|
+
canUseCached = value !== undefined;
|
|
21
23
|
await notify(value);
|
|
22
24
|
}
|
|
23
25
|
};
|
|
24
26
|
const get = async () => {
|
|
25
|
-
if (
|
|
27
|
+
if (canUseCached) {
|
|
26
28
|
return cached;
|
|
27
29
|
}
|
|
28
30
|
if (writePromiseDefer) {
|
|
29
31
|
await writePromiseDefer.promise;
|
|
30
32
|
}
|
|
31
|
-
if (
|
|
33
|
+
if (canUseCached) {
|
|
32
34
|
return cached;
|
|
33
35
|
}
|
|
34
36
|
const value = await storage.get(key);
|
|
35
37
|
if (isSoleWriter) {
|
|
36
38
|
cached = value;
|
|
39
|
+
canUseCached = true;
|
|
37
40
|
}
|
|
38
41
|
return value;
|
|
39
42
|
};
|
package/package.json
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@exodus/atoms",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.3.1",
|
|
4
4
|
"description": "Abstraction for encapsulating a piece of data behind a simple unified interface: get, set, observe",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "lib/index.js",
|
|
7
7
|
"exports": "./lib/index.js",
|
|
8
|
-
"author": "Exodus Movement Inc.",
|
|
8
|
+
"author": "Exodus Movement, Inc.",
|
|
9
9
|
"scripts": {
|
|
10
10
|
"build": "run -T tsc --build tsconfig.build.json",
|
|
11
11
|
"clean": "run -T tsc --build --clean",
|
|
@@ -39,11 +39,11 @@
|
|
|
39
39
|
},
|
|
40
40
|
"devDependencies": {
|
|
41
41
|
"@exodus/atom-tests": "^1.0.0",
|
|
42
|
-
"@exodus/remote-config": "^2.
|
|
42
|
+
"@exodus/remote-config": "^2.4.0",
|
|
43
43
|
"@exodus/storage-memory": "^2.1.1",
|
|
44
44
|
"@types/jest": "^29.5.11",
|
|
45
45
|
"@types/lodash": "^4.14.200",
|
|
46
46
|
"@types/minimalistic-assert": "^1.0.2"
|
|
47
47
|
},
|
|
48
|
-
"gitHead": "
|
|
48
|
+
"gitHead": "2792d27a3830bea53f036b542b34a3ddce0eee6d"
|
|
49
49
|
}
|