@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 CHANGED
@@ -1,7 +1,5 @@
1
1
  # `@exodus/atoms`
2
2
 
3
- Module to store and manage wallet accounts instances.
4
-
5
3
  ## Install
6
4
 
7
5
  ```sh
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@exodus/atoms",
3
- "version": "2.10.0",
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": "^1.1.1",
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": "a98fe18a3362a8006fad096cbc31360fa9ad7263"
36
+ "gitHead": "6aca43c9d371da13ffca0de1d9a0bc9c3f14ee25"
36
37
  }
@@ -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(postProcessValue(value)))
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
@@ -10,7 +10,10 @@ const combine = (atoms) => {
10
10
 
11
11
  for (const name in atoms) {
12
12
  atoms[name].observe(async (value) => {
13
- values[name] = value
13
+ values = {
14
+ ...values,
15
+ [name]: value,
16
+ }
14
17
  if (countdownLock.unlock()) await notify(values)
15
18
  })
16
19
  }
@@ -1,4 +1,4 @@
1
- import EventEmitter from 'events/' // '/' forces it to use the module from node_modules
1
+ import EventEmitter from 'events/'
2
2
 
3
3
  import fromEventEmitter from '../event-emitter'
4
4
  import pDefer from 'p-defer'
@@ -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 = () => remoteConfig.get(path)
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 }) => notify(getValueAtPath(current, path)))
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,
@@ -8,7 +8,7 @@ const createStorageAtomFactory =
8
8
 
9
9
  let cached
10
10
  const set = async (value) => {
11
- if (typeof value === 'undefined') {
11
+ if (value === undefined) {
12
12
  await storage.delete(key)
13
13
  } else {
14
14
  await storage.set(key, value)
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