react-native-onyx 1.0.93 → 1.0.94
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/dist/web.development.js +11 -7
- package/dist/web.development.js.map +1 -1
- package/dist/web.min.js +1 -1
- package/dist/web.min.js.map +1 -1
- package/lib/OnyxCache.js +11 -7
- package/package.json +1 -1
package/lib/OnyxCache.js
CHANGED
|
@@ -34,9 +34,11 @@ class OnyxCache {
|
|
|
34
34
|
/**
|
|
35
35
|
* @private
|
|
36
36
|
* Captured pending tasks for already running storage methods
|
|
37
|
-
*
|
|
37
|
+
* Using a map yields better performance on operations such a delete
|
|
38
|
+
* https://www.zhenghao.io/posts/object-vs-map
|
|
39
|
+
* @type {Map<string, Promise>}
|
|
38
40
|
*/
|
|
39
|
-
this.pendingPromises =
|
|
41
|
+
this.pendingPromises = new Map();
|
|
40
42
|
|
|
41
43
|
// bind all public methods to prevent problems with `this`
|
|
42
44
|
_.bindAll(
|
|
@@ -133,7 +135,7 @@ class OnyxCache {
|
|
|
133
135
|
* @returns {*}
|
|
134
136
|
*/
|
|
135
137
|
hasPendingTask(taskName) {
|
|
136
|
-
return isDefined(this.pendingPromises
|
|
138
|
+
return isDefined(this.pendingPromises.get(taskName));
|
|
137
139
|
}
|
|
138
140
|
|
|
139
141
|
/**
|
|
@@ -145,7 +147,7 @@ class OnyxCache {
|
|
|
145
147
|
* @returns {Promise<T>}
|
|
146
148
|
*/
|
|
147
149
|
getTaskPromise(taskName) {
|
|
148
|
-
return this.pendingPromises
|
|
150
|
+
return this.pendingPromises.get(taskName);
|
|
149
151
|
}
|
|
150
152
|
|
|
151
153
|
/**
|
|
@@ -157,11 +159,13 @@ class OnyxCache {
|
|
|
157
159
|
* @returns {Promise<T>}
|
|
158
160
|
*/
|
|
159
161
|
captureTask(taskName, promise) {
|
|
160
|
-
|
|
161
|
-
|
|
162
|
+
const returnPromise = promise.finally(() => {
|
|
163
|
+
this.pendingPromises.delete(taskName);
|
|
162
164
|
});
|
|
163
165
|
|
|
164
|
-
|
|
166
|
+
this.pendingPromises.set(taskName, returnPromise);
|
|
167
|
+
|
|
168
|
+
return returnPromise;
|
|
165
169
|
}
|
|
166
170
|
|
|
167
171
|
/**
|