@exodus/atoms 2.10.0 → 3.1.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 +0 -2
- package/package.json +4 -3
- package/src/enforce-rules.js +2 -2
- package/src/enhancers/combine.js +4 -1
- package/src/factories/memory.js +1 -1
- package/src/factories/remote-config.js +17 -3
- package/src/factories/storage.js +1 -1
- package/src/index.js +0 -2
- package/src/factories/disabled-assets.js +0 -17
- package/src/factories/enabled-assets.js +0 -17
package/README.md
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@exodus/atoms",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "3.1.0",
|
|
4
4
|
"main": "src/index.js",
|
|
5
5
|
"author": "Exodus Movement Inc.",
|
|
6
6
|
"scripts": {
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
"url": "https://github.com/ExodusMovement/exodus-hydra/issues?q=is%3Aissue+is%3Aopen+label%3Aatom"
|
|
22
22
|
},
|
|
23
23
|
"dependencies": {
|
|
24
|
-
"events": "^
|
|
24
|
+
"events": "^3.3.0",
|
|
25
25
|
"lodash": "^4.17.21",
|
|
26
26
|
"make-concurrent": ">=4 <6",
|
|
27
27
|
"p-defer": "^4.0.0",
|
|
@@ -30,7 +30,8 @@
|
|
|
30
30
|
"devDependencies": {
|
|
31
31
|
"@exodus/storage-memory": "^1.0.0",
|
|
32
32
|
"delay": "^5.0.0",
|
|
33
|
+
"eslint": "^8.33.0",
|
|
33
34
|
"jest": "^29.1.2"
|
|
34
35
|
},
|
|
35
|
-
"gitHead": "
|
|
36
|
+
"gitHead": "6aca43c9d371da13ffca0de1d9a0bc9c3f14ee25"
|
|
36
37
|
}
|
package/src/enforce-rules.js
CHANGED
|
@@ -35,9 +35,9 @@ const enforceObservableRules = ({ defaultValue, ...atom }) => {
|
|
|
35
35
|
|
|
36
36
|
const observe = (listener) => {
|
|
37
37
|
const deduped = withChangeDetection(listener)
|
|
38
|
-
const publishSerially = (value) => enqueue(() => deduped.listener(
|
|
38
|
+
const publishSerially = (value) => enqueue(() => deduped.listener(value))
|
|
39
39
|
// note: call observe() first to give it a chance to throw if it's not supported
|
|
40
|
-
const unsubscribe = atom.observe(publishSerially)
|
|
40
|
+
const unsubscribe = atom.observe((value) => publishSerially(postProcessValue(value)))
|
|
41
41
|
// if the subscription already fired once, ignore first get
|
|
42
42
|
get().then((value) => !deduped.called && publishSerially(value))
|
|
43
43
|
return unsubscribe
|
package/src/enhancers/combine.js
CHANGED
package/src/factories/memory.js
CHANGED
|
@@ -5,16 +5,30 @@ import enforceObservableRules from '../enforce-rules'
|
|
|
5
5
|
|
|
6
6
|
const createRemoteConfigAtomFactory =
|
|
7
7
|
({ remoteConfig }) =>
|
|
8
|
-
({ path, defaultValue }) => {
|
|
8
|
+
({ path, selector, defaultValue }) => {
|
|
9
|
+
if (path && selector) {
|
|
10
|
+
throw new Error(
|
|
11
|
+
'Provide either a path or a selector to get data from remote config - not both.'
|
|
12
|
+
)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const getValue = (value) => (selector ? selector(value) : getValueAtPath(value, path))
|
|
16
|
+
|
|
9
17
|
const { notify, observe } = createSimpleObserver()
|
|
10
18
|
|
|
11
|
-
const get = () =>
|
|
19
|
+
const get = async () => {
|
|
20
|
+
const data = await remoteConfig.getAll()
|
|
21
|
+
return getValue(data)
|
|
22
|
+
}
|
|
12
23
|
|
|
13
24
|
const set = async () => {
|
|
14
25
|
throw new Error('remoteConfig is read-only')
|
|
15
26
|
}
|
|
16
27
|
|
|
17
|
-
remoteConfig.on('sync', ({ current }) =>
|
|
28
|
+
remoteConfig.on('sync', async ({ current }) => {
|
|
29
|
+
const data = getValue(current)
|
|
30
|
+
return notify(data)
|
|
31
|
+
})
|
|
18
32
|
|
|
19
33
|
return enforceObservableRules({
|
|
20
34
|
get,
|
package/src/factories/storage.js
CHANGED
package/src/index.js
CHANGED
|
@@ -4,8 +4,6 @@ export { default as createFusionAtomFactory } from './factories/fusion'
|
|
|
4
4
|
export { default as createStorageAtomFactory } from './factories/storage'
|
|
5
5
|
export { default as createLocalConfigAtomFactory } from './factories/local-config'
|
|
6
6
|
export { default as createRemoteConfigAtomFactory } from './factories/remote-config'
|
|
7
|
-
export { default as createEnabledAssetsAtom } from './factories/enabled-assets'
|
|
8
|
-
export { default as createDisabledAssetsAtom } from './factories/disabled-assets'
|
|
9
7
|
export { default as fromEventEmitter } from './event-emitter'
|
|
10
8
|
export { default as compute } from './enhancers/compute'
|
|
11
9
|
export { default as blockUntil } from './enhancers/block-until'
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { compute } from '../index'
|
|
2
|
-
|
|
3
|
-
const createDisabledAssetsAtom = ({ enabledAndDisabledAssetsAtom }) => {
|
|
4
|
-
const selector = (values) =>
|
|
5
|
-
Object.fromEntries(
|
|
6
|
-
Object.keys(values.disabled)
|
|
7
|
-
.filter((assetName) => {
|
|
8
|
-
const disabled = values.disabled[assetName]
|
|
9
|
-
return disabled === true
|
|
10
|
-
})
|
|
11
|
-
.map((assetName) => [assetName, true])
|
|
12
|
-
)
|
|
13
|
-
|
|
14
|
-
return compute({ atom: enabledAndDisabledAssetsAtom, selector })
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export default createDisabledAssetsAtom
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { compute } from '../index'
|
|
2
|
-
|
|
3
|
-
const createEnabledAssetsAtom = ({ enabledAndDisabledAssetsAtom }) => {
|
|
4
|
-
const selector = (values) =>
|
|
5
|
-
Object.fromEntries(
|
|
6
|
-
Object.keys(values.disabled)
|
|
7
|
-
.filter((assetName) => {
|
|
8
|
-
const disabled = values.disabled[assetName]
|
|
9
|
-
return disabled === false
|
|
10
|
-
})
|
|
11
|
-
.map((assetName) => [assetName, true])
|
|
12
|
-
)
|
|
13
|
-
|
|
14
|
-
return compute({ atom: enabledAndDisabledAssetsAtom, selector })
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export default createEnabledAssetsAtom
|