@exodus/atoms 5.2.2 → 5.3.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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@exodus/atoms",
3
- "version": "5.2.2",
3
+ "version": "5.3.0",
4
4
  "main": "src/index.js",
5
5
  "description": "Abstraction for encapsulating a piece of data behind a simple unified interface: get, set, observe",
6
6
  "author": "Exodus Movement Inc.",
@@ -19,7 +19,7 @@
19
19
  "homepage": "https://github.com/ExodusMovement/exodus-hydra/tree/master/libraries/atoms",
20
20
  "license": "UNLICENSED",
21
21
  "bugs": {
22
- "url": "https://github.com/ExodusMovement/exodus-hydra/issues?q=is%3Aissue+is%3Aopen+label%3Aatom"
22
+ "url": "https://github.com/ExodusMovement/exodus-hydra/issues?q=is%3Aissue+is%3Aopen+label%3Aatoms"
23
23
  },
24
24
  "dependencies": {
25
25
  "events": "^3.3.0",
@@ -35,5 +35,5 @@
35
35
  "eslint": "^8.44.0",
36
36
  "jest": "^29.1.2"
37
37
  },
38
- "gitHead": "4b2c9803b5d53c65b77475187777ae5633e5d619"
38
+ "gitHead": "b7ceeec5c94d0d7c9236e7d73275b6e54bd675ac"
39
39
  }
@@ -25,4 +25,5 @@ const waitUntil = ({ atom, predicate, rejectAfter }) => {
25
25
 
26
26
  return promise
27
27
  }
28
+
28
29
  export default waitUntil
@@ -1,7 +1,13 @@
1
1
  import { isEqual } from 'lodash'
2
2
 
3
3
  const dedupe = (atom) => {
4
- const set = (value) => atom.set((previous) => (isEqual(previous, value) ? previous : value))
4
+ const set = (value) => {
5
+ // avoid triggering a get() when we're resetting the atom
6
+ // TODO: add atom.unset and stop using atom.set(undefined)
7
+ if (value === undefined) return atom.set(value)
8
+
9
+ return atom.set((previous) => (isEqual(previous, value) ? previous : value))
10
+ }
5
11
 
6
12
  return {
7
13
  ...atom,
@@ -9,6 +9,7 @@ const createAtomMock = (options = {}) => {
9
9
  let latestValue = defaultValue
10
10
 
11
11
  const emitter = new EventEmitter()
12
+ emitter.setMaxListeners(Number.POSITIVE_INFINITY)
12
13
 
13
14
  const initialized = pDefer()
14
15
 
@@ -16,6 +17,7 @@ const createAtomMock = (options = {}) => {
16
17
  if (!('defaultValue' in options)) {
17
18
  await initialized.promise
18
19
  }
20
+
19
21
  return latestValue
20
22
  }
21
23
 
@@ -25,6 +27,7 @@ const createAtomMock = (options = {}) => {
25
27
  initialized.resolve()
26
28
  initialized.resolved = true
27
29
  }
30
+
28
31
  if (initialized.resolved) {
29
32
  emitter.emit('data', data)
30
33
  }
@@ -17,6 +17,7 @@ const createStorageAtomFactory =
17
17
  writePromiseDefer = pDefer()
18
18
  await storage.set(key, value)
19
19
  }
20
+
20
21
  writePromiseDefer.resolve()
21
22
 
22
23
  if (isSoleWriter) {
@@ -33,6 +34,7 @@ const createStorageAtomFactory =
33
34
  if (writePromiseDefer) {
34
35
  await writePromiseDefer.promise
35
36
  }
37
+
36
38
  if (cached) {
37
39
  return cached
38
40
  }
@@ -7,6 +7,7 @@ const createSimpleObserver = ({ enable = true } = {}) => {
7
7
  if (!enable) {
8
8
  throw new Error('observe method is not supported')
9
9
  }
10
+
10
11
  listeners.push(listener)
11
12
  return () => {
12
13
  listeners = listeners.filter((fn) => fn !== listener)