@osdk/client 2.5.0-beta.5 → 2.5.0-beta.7

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.
Files changed (211) hide show
  1. package/CHANGELOG.md +31 -0
  2. package/build/browser/MinimalClientContext.js.map +1 -1
  3. package/build/browser/actions/applyAction.js +4 -0
  4. package/build/browser/actions/applyAction.js.map +1 -1
  5. package/build/browser/createClient.js +2 -1
  6. package/build/browser/createClient.js.map +1 -1
  7. package/build/browser/createMinimalClient.js +2 -1
  8. package/build/browser/createMinimalClient.js.map +1 -1
  9. package/build/browser/object/aggregate.js +2 -0
  10. package/build/browser/object/aggregate.js.map +1 -1
  11. package/build/browser/object/fetchPage.js +5 -2
  12. package/build/browser/object/fetchPage.js.map +1 -1
  13. package/build/browser/observable/internal/AbstractHelper.js +8 -4
  14. package/build/browser/observable/internal/AbstractHelper.js.map +1 -1
  15. package/build/browser/observable/internal/BatchContext.js +2 -0
  16. package/build/browser/observable/internal/BatchContext.js.map +1 -0
  17. package/build/browser/observable/internal/CacheKeys.js +61 -36
  18. package/build/browser/observable/internal/CacheKeys.js.map +1 -1
  19. package/build/browser/observable/internal/Layer.js +0 -8
  20. package/build/browser/observable/internal/Layer.js.map +1 -1
  21. package/build/browser/observable/internal/Layers.js +151 -0
  22. package/build/browser/observable/internal/Layers.js.map +1 -0
  23. package/build/browser/observable/internal/ObservableClientImpl.js +3 -1
  24. package/build/browser/observable/internal/ObservableClientImpl.js.map +1 -1
  25. package/build/browser/observable/internal/Queries.js +40 -0
  26. package/build/browser/observable/internal/Queries.js.map +1 -0
  27. package/build/browser/observable/internal/Query.js +30 -3
  28. package/build/browser/observable/internal/Query.js.map +1 -1
  29. package/build/browser/observable/internal/QuerySubscription.js +7 -0
  30. package/build/browser/observable/internal/QuerySubscription.js.map +1 -1
  31. package/build/browser/observable/internal/Store.js +36 -225
  32. package/build/browser/observable/internal/Store.js.map +1 -1
  33. package/build/browser/observable/internal/Store.test.js +11 -9
  34. package/build/browser/observable/internal/Store.test.js.map +1 -1
  35. package/build/browser/observable/internal/SubjectPayload.js +2 -0
  36. package/build/browser/observable/internal/SubjectPayload.js.map +1 -0
  37. package/build/browser/observable/internal/Subjects.js +55 -0
  38. package/build/browser/observable/internal/Subjects.js.map +1 -0
  39. package/build/browser/observable/internal/actions/ActionApplication.js +2 -2
  40. package/build/browser/observable/internal/actions/ActionApplication.js.map +1 -1
  41. package/build/browser/observable/internal/actions/OptimisticJob.js +1 -1
  42. package/build/browser/observable/internal/actions/OptimisticJob.js.map +1 -1
  43. package/build/browser/observable/internal/base-list/BaseListQuery.js +6 -9
  44. package/build/browser/observable/internal/base-list/BaseListQuery.js.map +1 -1
  45. package/build/browser/observable/internal/base-list/createCollectionConnectable.js +2 -2
  46. package/build/browser/observable/internal/base-list/createCollectionConnectable.js.map +1 -1
  47. package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js +23 -25
  48. package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -1
  49. package/build/browser/observable/internal/base-list/removeDuplicates.js.map +1 -1
  50. package/build/browser/observable/internal/createInitEntry.js +25 -0
  51. package/build/browser/observable/internal/createInitEntry.js.map +1 -0
  52. package/build/browser/observable/internal/links/LinksHelper.js +5 -5
  53. package/build/browser/observable/internal/links/LinksHelper.js.map +1 -1
  54. package/build/browser/observable/internal/links/SpecificLinkQuery.js.map +1 -1
  55. package/build/browser/observable/internal/list/ListQuery.js +5 -5
  56. package/build/browser/observable/internal/list/ListQuery.js.map +1 -1
  57. package/build/browser/observable/internal/list/ListsHelper.js +5 -5
  58. package/build/browser/observable/internal/list/ListsHelper.js.map +1 -1
  59. package/build/browser/observable/internal/object/ObjectQuery.js.map +1 -1
  60. package/build/browser/observable/internal/object/ObjectsHelper.js +2 -2
  61. package/build/browser/observable/internal/object/ObjectsHelper.js.map +1 -1
  62. package/build/browser/observable/internal/sorting/SortingStrategy.js.map +1 -1
  63. package/build/browser/observable/internal/testUtils/invalidateList.js +2 -2
  64. package/build/browser/observable/internal/testUtils/invalidateList.js.map +1 -1
  65. package/build/browser/observable/internal/testUtils.js +1 -1
  66. package/build/browser/observable/internal/testUtils.js.map +1 -1
  67. package/build/browser/ontology/loadActionMetadata.js +3 -1
  68. package/build/browser/ontology/loadActionMetadata.js.map +1 -1
  69. package/build/browser/ontology/loadFullObjectMetadata.js +2 -1
  70. package/build/browser/ontology/loadFullObjectMetadata.js.map +1 -1
  71. package/build/browser/ontology/loadInterfaceMetadata.js +2 -1
  72. package/build/browser/ontology/loadInterfaceMetadata.js.map +1 -1
  73. package/build/browser/queries/applyQuery.js +2 -2
  74. package/build/browser/queries/applyQuery.js.map +1 -1
  75. package/build/browser/util/UserAgent.js +2 -2
  76. package/build/cjs/{chunk-ELAA4C2C.cjs → chunk-5KDG5ZET.cjs} +9 -4
  77. package/build/cjs/chunk-5KDG5ZET.cjs.map +1 -0
  78. package/build/cjs/{chunk-KCMGIMVC.cjs → chunk-BY2PQEYA.cjs} +70 -60
  79. package/build/cjs/chunk-BY2PQEYA.cjs.map +1 -0
  80. package/build/cjs/{createClient-BJo8T7Js.d.cts → createClient-mOlFts15.d.cts} +1 -0
  81. package/build/cjs/index.cjs +7 -7
  82. package/build/cjs/index.d.cts +1 -1
  83. package/build/cjs/public/internal.cjs +8 -8
  84. package/build/cjs/public/unstable-do-not-use.cjs +396 -302
  85. package/build/cjs/public/unstable-do-not-use.cjs.map +1 -1
  86. package/build/cjs/public/unstable-do-not-use.d.cts +1 -1
  87. package/build/esm/MinimalClientContext.js.map +1 -1
  88. package/build/esm/actions/applyAction.js +4 -0
  89. package/build/esm/actions/applyAction.js.map +1 -1
  90. package/build/esm/createClient.js +2 -1
  91. package/build/esm/createClient.js.map +1 -1
  92. package/build/esm/createMinimalClient.js +2 -1
  93. package/build/esm/createMinimalClient.js.map +1 -1
  94. package/build/esm/object/aggregate.js +2 -0
  95. package/build/esm/object/aggregate.js.map +1 -1
  96. package/build/esm/object/fetchPage.js +5 -2
  97. package/build/esm/object/fetchPage.js.map +1 -1
  98. package/build/esm/observable/internal/AbstractHelper.js +8 -4
  99. package/build/esm/observable/internal/AbstractHelper.js.map +1 -1
  100. package/build/esm/observable/internal/BatchContext.js +2 -0
  101. package/build/esm/observable/internal/BatchContext.js.map +1 -0
  102. package/build/esm/observable/internal/CacheKeys.js +61 -36
  103. package/build/esm/observable/internal/CacheKeys.js.map +1 -1
  104. package/build/esm/observable/internal/Layer.js +0 -8
  105. package/build/esm/observable/internal/Layer.js.map +1 -1
  106. package/build/esm/observable/internal/Layers.js +151 -0
  107. package/build/esm/observable/internal/Layers.js.map +1 -0
  108. package/build/esm/observable/internal/ObservableClientImpl.js +3 -1
  109. package/build/esm/observable/internal/ObservableClientImpl.js.map +1 -1
  110. package/build/esm/observable/internal/Queries.js +40 -0
  111. package/build/esm/observable/internal/Queries.js.map +1 -0
  112. package/build/esm/observable/internal/Query.js +30 -3
  113. package/build/esm/observable/internal/Query.js.map +1 -1
  114. package/build/esm/observable/internal/QuerySubscription.js +7 -0
  115. package/build/esm/observable/internal/QuerySubscription.js.map +1 -1
  116. package/build/esm/observable/internal/Store.js +36 -225
  117. package/build/esm/observable/internal/Store.js.map +1 -1
  118. package/build/esm/observable/internal/Store.test.js +11 -9
  119. package/build/esm/observable/internal/Store.test.js.map +1 -1
  120. package/build/esm/observable/internal/SubjectPayload.js +2 -0
  121. package/build/esm/observable/internal/SubjectPayload.js.map +1 -0
  122. package/build/esm/observable/internal/Subjects.js +55 -0
  123. package/build/esm/observable/internal/Subjects.js.map +1 -0
  124. package/build/esm/observable/internal/actions/ActionApplication.js +2 -2
  125. package/build/esm/observable/internal/actions/ActionApplication.js.map +1 -1
  126. package/build/esm/observable/internal/actions/OptimisticJob.js +1 -1
  127. package/build/esm/observable/internal/actions/OptimisticJob.js.map +1 -1
  128. package/build/esm/observable/internal/base-list/BaseListQuery.js +6 -9
  129. package/build/esm/observable/internal/base-list/BaseListQuery.js.map +1 -1
  130. package/build/esm/observable/internal/base-list/createCollectionConnectable.js +2 -2
  131. package/build/esm/observable/internal/base-list/createCollectionConnectable.js.map +1 -1
  132. package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js +23 -25
  133. package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -1
  134. package/build/esm/observable/internal/base-list/removeDuplicates.js.map +1 -1
  135. package/build/esm/observable/internal/createInitEntry.js +25 -0
  136. package/build/esm/observable/internal/createInitEntry.js.map +1 -0
  137. package/build/esm/observable/internal/links/LinksHelper.js +5 -5
  138. package/build/esm/observable/internal/links/LinksHelper.js.map +1 -1
  139. package/build/esm/observable/internal/links/SpecificLinkQuery.js.map +1 -1
  140. package/build/esm/observable/internal/list/ListQuery.js +5 -5
  141. package/build/esm/observable/internal/list/ListQuery.js.map +1 -1
  142. package/build/esm/observable/internal/list/ListsHelper.js +5 -5
  143. package/build/esm/observable/internal/list/ListsHelper.js.map +1 -1
  144. package/build/esm/observable/internal/object/ObjectQuery.js.map +1 -1
  145. package/build/esm/observable/internal/object/ObjectsHelper.js +2 -2
  146. package/build/esm/observable/internal/object/ObjectsHelper.js.map +1 -1
  147. package/build/esm/observable/internal/sorting/SortingStrategy.js.map +1 -1
  148. package/build/esm/observable/internal/testUtils/invalidateList.js +2 -2
  149. package/build/esm/observable/internal/testUtils/invalidateList.js.map +1 -1
  150. package/build/esm/observable/internal/testUtils.js +1 -1
  151. package/build/esm/observable/internal/testUtils.js.map +1 -1
  152. package/build/esm/ontology/loadActionMetadata.js +3 -1
  153. package/build/esm/ontology/loadActionMetadata.js.map +1 -1
  154. package/build/esm/ontology/loadFullObjectMetadata.js +2 -1
  155. package/build/esm/ontology/loadFullObjectMetadata.js.map +1 -1
  156. package/build/esm/ontology/loadInterfaceMetadata.js +2 -1
  157. package/build/esm/ontology/loadInterfaceMetadata.js.map +1 -1
  158. package/build/esm/queries/applyQuery.js +2 -2
  159. package/build/esm/queries/applyQuery.js.map +1 -1
  160. package/build/esm/util/UserAgent.js +2 -2
  161. package/build/types/MinimalClientContext.d.ts +1 -0
  162. package/build/types/MinimalClientContext.d.ts.map +1 -1
  163. package/build/types/actions/applyAction.d.ts.map +1 -1
  164. package/build/types/createClient.d.ts +1 -0
  165. package/build/types/createClient.d.ts.map +1 -1
  166. package/build/types/observable/internal/AbstractHelper.d.ts +3 -1
  167. package/build/types/observable/internal/AbstractHelper.d.ts.map +1 -1
  168. package/build/types/observable/internal/BatchContext.d.ts +11 -0
  169. package/build/types/observable/internal/BatchContext.d.ts.map +1 -0
  170. package/build/types/observable/internal/CacheKeys.d.ts +9 -9
  171. package/build/types/observable/internal/CacheKeys.d.ts.map +1 -1
  172. package/build/types/observable/internal/Layer.d.ts +1 -2
  173. package/build/types/observable/internal/Layer.d.ts.map +1 -1
  174. package/build/types/observable/internal/Layers.d.ts +26 -0
  175. package/build/types/observable/internal/Layers.d.ts.map +1 -0
  176. package/build/types/observable/internal/Queries.d.ts +9 -0
  177. package/build/types/observable/internal/Queries.d.ts.map +1 -0
  178. package/build/types/observable/internal/Query.d.ts +17 -1
  179. package/build/types/observable/internal/Query.d.ts.map +1 -1
  180. package/build/types/observable/internal/Store.d.ts +19 -34
  181. package/build/types/observable/internal/Store.d.ts.map +1 -1
  182. package/build/types/observable/internal/Store.test.d.ts.map +1 -1
  183. package/build/types/observable/internal/SubjectPayload.d.ts +5 -0
  184. package/build/types/observable/internal/SubjectPayload.d.ts.map +1 -0
  185. package/build/types/observable/internal/Subjects.d.ts +16 -0
  186. package/build/types/observable/internal/Subjects.d.ts.map +1 -0
  187. package/build/types/observable/internal/base-list/BaseListQuery.d.ts +2 -1
  188. package/build/types/observable/internal/base-list/BaseListQuery.d.ts.map +1 -1
  189. package/build/types/observable/internal/base-list/createCollectionConnectable.d.ts +3 -2
  190. package/build/types/observable/internal/base-list/createCollectionConnectable.d.ts.map +1 -1
  191. package/build/types/observable/internal/base-list/removeDuplicates.d.ts +1 -1
  192. package/build/types/observable/internal/base-list/removeDuplicates.d.ts.map +1 -1
  193. package/build/types/observable/internal/createInitEntry.d.ts +3 -0
  194. package/build/types/observable/internal/createInitEntry.d.ts.map +1 -0
  195. package/build/types/observable/internal/links/LinksHelper.d.ts +3 -1
  196. package/build/types/observable/internal/links/LinksHelper.d.ts.map +1 -1
  197. package/build/types/observable/internal/links/SpecificLinkQuery.d.ts +3 -1
  198. package/build/types/observable/internal/links/SpecificLinkQuery.d.ts.map +1 -1
  199. package/build/types/observable/internal/list/ListQuery.d.ts +3 -1
  200. package/build/types/observable/internal/list/ListQuery.d.ts.map +1 -1
  201. package/build/types/observable/internal/list/ListsHelper.d.ts +3 -1
  202. package/build/types/observable/internal/list/ListsHelper.d.ts.map +1 -1
  203. package/build/types/observable/internal/object/ObjectQuery.d.ts +3 -1
  204. package/build/types/observable/internal/object/ObjectQuery.d.ts.map +1 -1
  205. package/build/types/observable/internal/object/ObjectsHelper.d.ts.map +1 -1
  206. package/build/types/observable/internal/sorting/SortingStrategy.d.ts +1 -1
  207. package/build/types/observable/internal/sorting/SortingStrategy.d.ts.map +1 -1
  208. package/build/types/observable/internal/testUtils.d.ts.map +1 -1
  209. package/package.json +9 -9
  210. package/build/cjs/chunk-ELAA4C2C.cjs.map +0 -1
  211. package/build/cjs/chunk-KCMGIMVC.cjs.map +0 -1
@@ -0,0 +1,55 @@
1
+ /*
2
+ * Copyright 2025 Palantir Technologies, Inc. All rights reserved.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ import { BehaviorSubject } from "rxjs";
18
+ import { createInitEntry } from "./createInitEntry.js";
19
+ export class Subjects {
20
+ #layers;
21
+
22
+ // we can use a regular Map here because the refCounting will
23
+ // handle cleanup.
24
+ #cacheKeyToSubject = new WeakMap();
25
+ constructor({
26
+ logger,
27
+ layers
28
+ }) {
29
+ this.logger = logger;
30
+ this.#layers = layers;
31
+ }
32
+ peek = cacheKey => {
33
+ return this.#cacheKeyToSubject.get(cacheKey);
34
+ };
35
+ get = cacheKey => {
36
+ let subject = this.#cacheKeyToSubject.get(cacheKey);
37
+ if (!subject) {
38
+ const initialValue = this.#layers.top.get(cacheKey) ?? createInitEntry(cacheKey);
39
+ subject = new BehaviorSubject({
40
+ ...initialValue,
41
+ isOptimistic: initialValue.value !== this.#layers.truth.get(cacheKey)?.value
42
+ });
43
+ this.#cacheKeyToSubject.set(cacheKey, subject);
44
+ }
45
+ return subject;
46
+ };
47
+ delete = cacheKey => {
48
+ const subject = this.peek(cacheKey);
49
+ if (subject) {
50
+ subject.complete();
51
+ this.#cacheKeyToSubject.delete(cacheKey);
52
+ }
53
+ };
54
+ }
55
+ //# sourceMappingURL=Subjects.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Subjects.js","names":["BehaviorSubject","createInitEntry","Subjects","layers","cacheKeyToSubject","WeakMap","constructor","logger","peek","cacheKey","get","subject","initialValue","top","isOptimistic","value","truth","set","delete","complete"],"sources":["Subjects.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Logger } from \"@osdk/api\";\nimport { BehaviorSubject } from \"rxjs\";\nimport { createInitEntry } from \"./createInitEntry.js\";\nimport type { KnownCacheKey } from \"./KnownCacheKey.js\";\nimport type { Entry } from \"./Layer.js\";\nimport { type Layers } from \"./Layers.js\";\nimport type { SubjectPayload } from \"./SubjectPayload.js\";\n\nexport class Subjects {\n #layers: Layers;\n\n // we can use a regular Map here because the refCounting will\n // handle cleanup.\n #cacheKeyToSubject = new WeakMap<\n KnownCacheKey,\n BehaviorSubject<SubjectPayload<any>>\n >();\n\n logger?: Logger;\n\n constructor({ logger, layers }: { logger?: Logger; layers: Layers }) {\n this.logger = logger;\n this.#layers = layers;\n }\n\n peek = <KEY extends KnownCacheKey>(\n cacheKey: KEY,\n ):\n | BehaviorSubject<SubjectPayload<KEY>>\n | undefined =>\n {\n return this.#cacheKeyToSubject.get(cacheKey);\n };\n\n get = <KEY extends KnownCacheKey>(\n cacheKey: KEY,\n ): BehaviorSubject<SubjectPayload<KEY>> => {\n let subject = this.#cacheKeyToSubject.get(cacheKey);\n if (!subject) {\n const initialValue: Entry<KEY> = this.#layers.top.get(cacheKey)\n ?? createInitEntry(cacheKey);\n\n subject = new BehaviorSubject({\n ...initialValue,\n isOptimistic:\n initialValue.value !== this.#layers.truth.get(cacheKey)?.value,\n });\n this.#cacheKeyToSubject.set(cacheKey, subject);\n }\n\n return subject;\n };\n\n delete = <KEY extends KnownCacheKey>(\n cacheKey: KEY,\n ): void => {\n const subject = this.peek(cacheKey);\n if (subject) {\n subject.complete();\n this.#cacheKeyToSubject.delete(cacheKey);\n }\n };\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA,SAASA,eAAe,QAAQ,MAAM;AACtC,SAASC,eAAe,QAAQ,sBAAsB;AAMtD,OAAO,MAAMC,QAAQ,CAAC;EACpB,CAACC,MAAM;;EAEP;EACA;EACA,CAACC,iBAAiB,GAAG,IAAIC,OAAO,CAG9B,CAAC;EAIHC,WAAWA,CAAC;IAAEC,MAAM;IAAEJ;EAA4C,CAAC,EAAE;IACnE,IAAI,CAACI,MAAM,GAAGA,MAAM;IACpB,IAAI,CAAC,CAACJ,MAAM,GAAGA,MAAM;EACvB;EAEAK,IAAI,GACFC,QAAa,IAIf;IACE,OAAO,IAAI,CAAC,CAACL,iBAAiB,CAACM,GAAG,CAACD,QAAQ,CAAC;EAC9C,CAAC;EAEDC,GAAG,GACDD,QAAa,IAC4B;IACzC,IAAIE,OAAO,GAAG,IAAI,CAAC,CAACP,iBAAiB,CAACM,GAAG,CAACD,QAAQ,CAAC;IACnD,IAAI,CAACE,OAAO,EAAE;MACZ,MAAMC,YAAwB,GAAG,IAAI,CAAC,CAACT,MAAM,CAACU,GAAG,CAACH,GAAG,CAACD,QAAQ,CAAC,IAC1DR,eAAe,CAACQ,QAAQ,CAAC;MAE9BE,OAAO,GAAG,IAAIX,eAAe,CAAC;QAC5B,GAAGY,YAAY;QACfE,YAAY,EACVF,YAAY,CAACG,KAAK,KAAK,IAAI,CAAC,CAACZ,MAAM,CAACa,KAAK,CAACN,GAAG,CAACD,QAAQ,CAAC,EAAEM;MAC7D,CAAC,CAAC;MACF,IAAI,CAAC,CAACX,iBAAiB,CAACa,GAAG,CAACR,QAAQ,EAAEE,OAAO,CAAC;IAChD;IAEA,OAAOA,OAAO;EAChB,CAAC;EAEDO,MAAM,GACJT,QAAa,IACJ;IACT,MAAME,OAAO,GAAG,IAAI,CAACH,IAAI,CAACC,QAAQ,CAAC;IACnC,IAAIE,OAAO,EAAE;MACXA,OAAO,CAACQ,QAAQ,CAAC,CAAC;MAClB,IAAI,CAAC,CAACf,iBAAiB,CAACc,MAAM,CAACT,QAAQ,CAAC;IAC1C;EACF,CAAC;AACH","ignoreList":[]}
@@ -86,8 +86,8 @@ export class ActionApplication {
86
86
  objectType,
87
87
  primaryKey
88
88
  } of deletedObjects ?? []) {
89
- const cacheKey = this.store.getCacheKey("object", objectType, primaryKey);
90
- this.store.peekQuery(cacheKey)?.deleteFromStore("loaded",
89
+ const cacheKey = this.store.cacheKeys.get("object", objectType, primaryKey);
90
+ this.store.queries.peek(cacheKey)?.deleteFromStore("loaded",
91
91
  // this is probably not the best value to use
92
92
  batch);
93
93
  }
@@ -1 +1 @@
1
- {"version":3,"file":"ActionApplication.js","names":["runOptimisticJob","ACTION_DELAY","process","env","NODE_ENV","ActionApplication","constructor","store","applyAction","action","args","optimisticUpdate","logger","child","methodName","removeOptimisticResult","Array","isArray","debug","results","client","batchApplyAction","$returnEdits","invalidateActionEditResponse","actionResults","delay","default","#invalidateActionEditResponse","deletedObjects","modifiedObjects","addedObjects","editedObjectTypes","type","changes","promisesToWait","list","obj","push","invalidateObject","objectType","primaryKey","batch","cacheKey","getCacheKey","peekQuery","deleteFromStore","Promise","all","apiName","invalidateObjectType"],"sources":["ActionApplication.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n ActionDefinition,\n ActionEditResponse,\n ActionReturnTypeForOptions,\n} from \"@osdk/api\";\nimport type { ActionSignatureFromDef } from \"../../../actions/applyAction.js\";\nimport { type Changes } from \"../Changes.js\";\nimport type { ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport type { Store } from \"../Store.js\";\nimport { runOptimisticJob } from \"./OptimisticJob.js\";\n\nconst ACTION_DELAY = process.env.NODE_ENV === \"production\" ? 0 : 1000;\n\nexport class ActionApplication {\n constructor(private store: Store) {}\n\n applyAction: <Q extends ActionDefinition<any>>(\n action: Q,\n args:\n | Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]\n | Array<Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]>,\n opts?: Store.ApplyActionOptions,\n ) => Promise<ActionEditResponse> = async (\n action,\n args,\n { optimisticUpdate } = {},\n ) => {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.store.logger?.child({ methodName: \"applyAction\" })\n : this.store.logger;\n const removeOptimisticResult = runOptimisticJob(\n this.store,\n optimisticUpdate,\n );\n\n return await (async () => {\n try {\n if (Array.isArray(args)) {\n if (process.env.NODE_ENV !== \"production\") {\n logger?.debug(\"applying action to multiple args\", args);\n }\n\n const results: ActionReturnTypeForOptions<{ $returnEdits: true }> =\n await this.store\n .client(action).batchApplyAction(\n args,\n { $returnEdits: true },\n );\n\n await this.#invalidateActionEditResponse(results);\n\n return results;\n }\n\n // The types for client get confused when we dynamically applyAction so we\n // have to deal with the `any` here and force cast it to what it should be.\n // TODO: Update the types so this doesn't happen!\n\n const actionResults: ActionEditResponse = await this.store.client(\n action,\n ).applyAction(args as any, { $returnEdits: true });\n\n if (process.env.NODE_ENV !== \"production\") {\n if (ACTION_DELAY > 0) {\n logger?.debug(\"action done, pausing\", actionResults);\n const delay = (await import(\"delay\")).default;\n await delay(ACTION_DELAY);\n logger?.debug(\"action done, pausing done\");\n }\n }\n await this.#invalidateActionEditResponse(actionResults);\n return actionResults;\n } finally {\n if (process.env.NODE_ENV !== \"production\") {\n logger?.debug(\n \"optimistic action complete; remove the results\",\n );\n }\n // make sure this happens even if the action fails\n await removeOptimisticResult();\n }\n })();\n };\n\n #invalidateActionEditResponse = async (\n { deletedObjects, modifiedObjects, addedObjects, editedObjectTypes, type }:\n ActionEditResponse,\n ): Promise<void> => {\n let changes: Changes | undefined;\n if (type === \"edits\") {\n const promisesToWait: Promise<any>[] = [];\n\n for (const list of [deletedObjects, modifiedObjects, addedObjects]) {\n for (const obj of list ?? []) {\n promisesToWait.push(\n this.store.invalidateObject(obj.objectType, obj.primaryKey),\n );\n }\n }\n\n this.store.batch({}, (batch) => {\n for (const { objectType, primaryKey } of deletedObjects ?? []) {\n const cacheKey = this.store.getCacheKey<ObjectCacheKey>(\n \"object\",\n objectType,\n primaryKey,\n );\n this.store.peekQuery(cacheKey)?.deleteFromStore(\n \"loaded\", // this is probably not the best value to use\n batch,\n );\n }\n });\n await Promise.all(promisesToWait);\n } else {\n for (const apiName of editedObjectTypes) {\n await this.store.invalidateObjectType(apiName as string, changes);\n }\n }\n };\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"ActionApplication.js","names":["runOptimisticJob","ACTION_DELAY","process","env","NODE_ENV","ActionApplication","constructor","store","applyAction","action","args","optimisticUpdate","logger","child","methodName","removeOptimisticResult","Array","isArray","debug","results","client","batchApplyAction","$returnEdits","invalidateActionEditResponse","actionResults","delay","default","#invalidateActionEditResponse","deletedObjects","modifiedObjects","addedObjects","editedObjectTypes","type","changes","promisesToWait","list","obj","push","invalidateObject","objectType","primaryKey","batch","cacheKey","cacheKeys","get","queries","peek","deleteFromStore","Promise","all","apiName","invalidateObjectType"],"sources":["ActionApplication.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n ActionDefinition,\n ActionEditResponse,\n ActionReturnTypeForOptions,\n} from \"@osdk/api\";\nimport type { ActionSignatureFromDef } from \"../../../actions/applyAction.js\";\nimport { type Changes } from \"../Changes.js\";\nimport type { ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport type { Store } from \"../Store.js\";\nimport { runOptimisticJob } from \"./OptimisticJob.js\";\n\nconst ACTION_DELAY = process.env.NODE_ENV === \"production\" ? 0 : 1000;\n\nexport class ActionApplication {\n constructor(private store: Store) {}\n\n applyAction: <Q extends ActionDefinition<any>>(\n action: Q,\n args:\n | Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]\n | Array<Parameters<ActionSignatureFromDef<Q>[\"applyAction\"]>[0]>,\n opts?: Store.ApplyActionOptions,\n ) => Promise<ActionEditResponse> = async (\n action,\n args,\n { optimisticUpdate } = {},\n ) => {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.store.logger?.child({ methodName: \"applyAction\" })\n : this.store.logger;\n const removeOptimisticResult = runOptimisticJob(\n this.store,\n optimisticUpdate,\n );\n\n return await (async () => {\n try {\n if (Array.isArray(args)) {\n if (process.env.NODE_ENV !== \"production\") {\n logger?.debug(\"applying action to multiple args\", args);\n }\n\n const results: ActionReturnTypeForOptions<{ $returnEdits: true }> =\n await this.store\n .client(action).batchApplyAction(\n args,\n { $returnEdits: true },\n );\n\n await this.#invalidateActionEditResponse(results);\n\n return results;\n }\n\n // The types for client get confused when we dynamically applyAction so we\n // have to deal with the `any` here and force cast it to what it should be.\n // TODO: Update the types so this doesn't happen!\n\n const actionResults: ActionEditResponse = await this.store.client(\n action,\n ).applyAction(args as any, { $returnEdits: true });\n\n if (process.env.NODE_ENV !== \"production\") {\n if (ACTION_DELAY > 0) {\n logger?.debug(\"action done, pausing\", actionResults);\n const delay = (await import(\"delay\")).default;\n await delay(ACTION_DELAY);\n logger?.debug(\"action done, pausing done\");\n }\n }\n await this.#invalidateActionEditResponse(actionResults);\n return actionResults;\n } finally {\n if (process.env.NODE_ENV !== \"production\") {\n logger?.debug(\n \"optimistic action complete; remove the results\",\n );\n }\n // make sure this happens even if the action fails\n await removeOptimisticResult();\n }\n })();\n };\n\n #invalidateActionEditResponse = async (\n { deletedObjects, modifiedObjects, addedObjects, editedObjectTypes, type }:\n ActionEditResponse,\n ): Promise<void> => {\n let changes: Changes | undefined;\n if (type === \"edits\") {\n const promisesToWait: Promise<any>[] = [];\n\n for (const list of [deletedObjects, modifiedObjects, addedObjects]) {\n for (const obj of list ?? []) {\n promisesToWait.push(\n this.store.invalidateObject(obj.objectType, obj.primaryKey),\n );\n }\n }\n\n this.store.batch({}, (batch) => {\n for (const { objectType, primaryKey } of deletedObjects ?? []) {\n const cacheKey = this.store.cacheKeys.get<ObjectCacheKey>(\n \"object\",\n objectType,\n primaryKey,\n );\n this.store.queries.peek(cacheKey)?.deleteFromStore(\n \"loaded\", // this is probably not the best value to use\n batch,\n );\n }\n });\n await Promise.all(promisesToWait);\n } else {\n for (const apiName of editedObjectTypes) {\n await this.store.invalidateObjectType(apiName as string, changes);\n }\n }\n };\n}\n"],"mappings":"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","ignoreList":[]}
@@ -102,7 +102,7 @@ export function runOptimisticJob(store, optimisticUpdate) {
102
102
  return optimisticApplicationDone.then(
103
103
  // we don't want to leak the result
104
104
  () => undefined).finally(() => {
105
- store.removeLayer(optimisticId);
105
+ store.layers.remove(optimisticId);
106
106
  });
107
107
  };
108
108
  }
@@ -1 +1 @@
1
- {"version":3,"file":"OptimisticJob.js","names":["additionalContext","createOptimisticId","OptimisticJob","result","constructor","store","optimisticId","updatedObjects","addedObjectPromises","deletedObjects","getResult","addedObjects","Promise","allSettled","batchResult","batch","obj","status","objects","getQuery","apiName","value","$objectType","pk","$primaryKey","writeToStore","deleteFromStore","changes","context","updateObject","push","createObject","type","properties","create","client","objectFactory2","$apiName","undefined","then","objs","deleteObject","runOptimisticJob","optimisticUpdate","resolve","job","optimisticApplicationDone","finally","removeLayer"],"sources":["OptimisticJob.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { additionalContext } from \"../../../Client.js\";\nimport type { ObjectHolder } from \"../../../object/convertWireToOsdkObjects/ObjectHolder.js\";\nimport type { OptimisticBuilder } from \"../../OptimisticBuilder.js\";\nimport { type Changes } from \"../Changes.js\";\nimport { createOptimisticId, type OptimisticId } from \"../OptimisticId.js\";\nimport type { Store } from \"../Store.js\";\n\nexport class OptimisticJob {\n context: OptimisticBuilder;\n getResult: () => Promise<Changes>;\n #result!: Promise<Changes>;\n\n constructor(store: Store, optimisticId: OptimisticId) {\n const updatedObjects: Array<\n ObjectHolder\n > = [];\n\n // due to potentially needing to fetch the object metadata,\n // the creation of objects needs to be async. In practice, the\n // metadata is cached.\n const addedObjectPromises: Array<\n Promise<ObjectHolder>\n > = [];\n\n const deletedObjects: Array<ObjectHolder> = [];\n\n // TODO, this code needs to be refactored. its weird right now\n // but the contract for `runOptimisticJob` is good.\n\n // todo memoize this\n this.getResult = () => {\n return this.#result ??= (async () => {\n const addedObjects = await Promise.allSettled(\n addedObjectPromises,\n );\n\n const { batchResult } = store.batch({ optimisticId }, (batch) => {\n for (const obj of addedObjects) {\n if (obj.status === \"fulfilled\") {\n store.objects.getQuery({\n apiName: obj.value.$objectType,\n pk: obj.value.$primaryKey,\n }).writeToStore(obj.value, \"loading\", batch);\n } else {\n // TODO FIXME\n throw obj;\n }\n }\n\n for (const obj of updatedObjects) {\n store.objects.getQuery({\n apiName: obj.$objectType,\n pk: obj.$primaryKey,\n }).writeToStore(obj, \"loading\", batch);\n }\n\n for (const obj of deletedObjects) {\n store.objects.getQuery({\n apiName: obj.$objectType,\n pk: obj.$primaryKey,\n }).deleteFromStore(\"loading\", batch);\n }\n });\n\n return batchResult.changes;\n })();\n };\n\n this.context = {\n updateObject(value) {\n updatedObjects.push(value as unknown as ObjectHolder<typeof value>);\n return this;\n },\n createObject(type, pk, properties) {\n const create = store.client[additionalContext].objectFactory2(\n store.client[additionalContext],\n [{\n $primaryKey: pk,\n $apiName: type.apiName,\n $objectType: type.apiName,\n ...properties,\n }],\n undefined,\n {},\n ).then(objs => {\n return objs[0];\n });\n\n addedObjectPromises.push(create);\n return this;\n },\n deleteObject(value) {\n deletedObjects.push(value as unknown as ObjectHolder<typeof value>);\n return this;\n },\n };\n }\n}\n\nexport function runOptimisticJob(\n store: Store,\n optimisticUpdate: undefined | ((ctx: OptimisticBuilder) => void),\n): () => Promise<void> {\n if (!optimisticUpdate) {\n return () => Promise.resolve();\n }\n\n const optimisticId = createOptimisticId();\n const job = new OptimisticJob(store, optimisticId);\n optimisticUpdate(job.context);\n const optimisticApplicationDone = job.getResult();\n\n return () => {\n return optimisticApplicationDone.then(\n // we don't want to leak the result\n () => undefined,\n ).finally(() => {\n store.removeLayer(optimisticId);\n });\n };\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"OptimisticJob.js","names":["additionalContext","createOptimisticId","OptimisticJob","result","constructor","store","optimisticId","updatedObjects","addedObjectPromises","deletedObjects","getResult","addedObjects","Promise","allSettled","batchResult","batch","obj","status","objects","getQuery","apiName","value","$objectType","pk","$primaryKey","writeToStore","deleteFromStore","changes","context","updateObject","push","createObject","type","properties","create","client","objectFactory2","$apiName","undefined","then","objs","deleteObject","runOptimisticJob","optimisticUpdate","resolve","job","optimisticApplicationDone","finally","layers","remove"],"sources":["OptimisticJob.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { additionalContext } from \"../../../Client.js\";\nimport type { ObjectHolder } from \"../../../object/convertWireToOsdkObjects/ObjectHolder.js\";\nimport type { OptimisticBuilder } from \"../../OptimisticBuilder.js\";\nimport { type Changes } from \"../Changes.js\";\nimport { createOptimisticId, type OptimisticId } from \"../OptimisticId.js\";\nimport type { Store } from \"../Store.js\";\n\nexport class OptimisticJob {\n context: OptimisticBuilder;\n getResult: () => Promise<Changes>;\n #result!: Promise<Changes>;\n\n constructor(store: Store, optimisticId: OptimisticId) {\n const updatedObjects: Array<\n ObjectHolder\n > = [];\n\n // due to potentially needing to fetch the object metadata,\n // the creation of objects needs to be async. In practice, the\n // metadata is cached.\n const addedObjectPromises: Array<\n Promise<ObjectHolder>\n > = [];\n\n const deletedObjects: Array<ObjectHolder> = [];\n\n // TODO, this code needs to be refactored. its weird right now\n // but the contract for `runOptimisticJob` is good.\n\n // todo memoize this\n this.getResult = () => {\n return this.#result ??= (async () => {\n const addedObjects = await Promise.allSettled(\n addedObjectPromises,\n );\n\n const { batchResult } = store.batch({ optimisticId }, (batch) => {\n for (const obj of addedObjects) {\n if (obj.status === \"fulfilled\") {\n store.objects.getQuery({\n apiName: obj.value.$objectType,\n pk: obj.value.$primaryKey,\n }).writeToStore(obj.value, \"loading\", batch);\n } else {\n // TODO FIXME\n throw obj;\n }\n }\n\n for (const obj of updatedObjects) {\n store.objects.getQuery({\n apiName: obj.$objectType,\n pk: obj.$primaryKey,\n }).writeToStore(obj, \"loading\", batch);\n }\n\n for (const obj of deletedObjects) {\n store.objects.getQuery({\n apiName: obj.$objectType,\n pk: obj.$primaryKey,\n }).deleteFromStore(\"loading\", batch);\n }\n });\n\n return batchResult.changes;\n })();\n };\n\n this.context = {\n updateObject(value) {\n updatedObjects.push(value as unknown as ObjectHolder<typeof value>);\n return this;\n },\n createObject(type, pk, properties) {\n const create = store.client[additionalContext].objectFactory2(\n store.client[additionalContext],\n [{\n $primaryKey: pk,\n $apiName: type.apiName,\n $objectType: type.apiName,\n ...properties,\n }],\n undefined,\n {},\n ).then(objs => {\n return objs[0];\n });\n\n addedObjectPromises.push(create);\n return this;\n },\n deleteObject(value) {\n deletedObjects.push(value as unknown as ObjectHolder<typeof value>);\n return this;\n },\n };\n }\n}\n\nexport function runOptimisticJob(\n store: Store,\n optimisticUpdate: undefined | ((ctx: OptimisticBuilder) => void),\n): () => Promise<void> {\n if (!optimisticUpdate) {\n return () => Promise.resolve();\n }\n\n const optimisticId = createOptimisticId();\n const job = new OptimisticJob(store, optimisticId);\n optimisticUpdate(job.context);\n const optimisticApplicationDone = job.getResult();\n\n return () => {\n return optimisticApplicationDone.then(\n // we don't want to leak the result\n () => undefined,\n ).finally(() => {\n store.layers.remove(optimisticId);\n });\n };\n}\n"],"mappings":"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","ignoreList":[]}
@@ -60,10 +60,9 @@ export class BaseListQuery extends Query {
60
60
  */
61
61
  _updateList(items, status, batch, append = false) {
62
62
  if (process.env.NODE_ENV !== "production") {
63
- const logger = process.env.NODE_ENV !== "production" ? this.logger?.child({
63
+ this.logger?.child({
64
64
  methodName: "updateList"
65
- }) : this.logger;
66
- logger?.debug(`{status: ${status}, append: ${append}}`, JSON.stringify(items, null, 2));
65
+ }).debug(`{status: ${status}, append: ${append}}`, JSON.stringify(items, null, 2));
67
66
  }
68
67
  let objectCacheKeys;
69
68
  if (items.length === 0) {
@@ -144,11 +143,11 @@ export class BaseListQuery extends Query {
144
143
  // N.B. the store keeps the cache keys around for a bit so we don't
145
144
  // need to worry about them being GC'd before we re-retain them
146
145
  for (const objectCacheKey of existingList?.value?.data ?? []) {
147
- this.store.release(objectCacheKey);
146
+ this.store.cacheKeys.release(objectCacheKey);
148
147
  }
149
148
  }
150
149
  for (const objectCacheKey of objectCacheKeys) {
151
- this.store.retain(objectCacheKey);
150
+ this.store.cacheKeys.retain(objectCacheKey);
152
151
  }
153
152
  }
154
153
  if (append) {
@@ -157,13 +156,11 @@ export class BaseListQuery extends Query {
157
156
  return objectCacheKeys;
158
157
  }
159
158
  _dispose() {
160
- // eslint-disable-next-line no-console
161
- console.log("DISPOSE LIST QUERY");
162
159
  this.store.batch({}, batch => {
163
160
  const entry = batch.read(this.cacheKey);
164
161
  if (entry) {
165
162
  for (const objectCacheKey of entry.value?.data ?? []) {
166
- this.store.release(objectCacheKey);
163
+ this.store.cacheKeys.release(objectCacheKey);
167
164
  }
168
165
  }
169
166
  });
@@ -196,7 +193,7 @@ export class BaseListQuery extends Query {
196
193
  * @returns A connectable observable of the collection's payload type
197
194
  */
198
195
  _createConnectable(subject) {
199
- return createCollectionConnectable(subject, this.store, params => this.createPayload(params));
196
+ return createCollectionConnectable(subject, this.store.subjects, params => this.createPayload(params));
200
197
  }
201
198
 
202
199
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"BaseListQuery.js","names":["deepEqual","DEBUG_ONLY__cacheKeysToString","isObjectInstance","Query","NoOpSortingStrategy","createCollectionConnectable","removeDuplicates","BaseListQuery","sortingStrategy","_updateList","items","status","batch","append","process","env","NODE_ENV","logger","child","methodName","debug","JSON","stringify","objectCacheKeys","length","store","objects","storeOsdkInstances","retainReleaseAppend","_sortCacheKeys","writeToStore","data","entry","read","cacheKey","value","write","ret","registerCacheChanges","#retainReleaseAppend","existingList","optimisticWrite","objectCacheKey","release","retain","_dispose","console","log","createPayload","params","resolvedList","resolvedData","isOptimistic","fetchMore","hasMore","nextPageToken","lastUpdated","_createConnectable","subject","_preFetch","undefined","pendingPageFetch","pendingFetch","Promise","res","resolve","setStatus","fetchPageAndUpdate","abortController","signal","then","finally","minResultsToLoad","_fetchAndStore","count","aborted","result","fetchPageData","retVal","finalStatus","error","handleFetchError","_error","_status","sortCacheKeys","updateCollection","options"],"sources":["BaseListQuery.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Osdk, PageResult } from \"@osdk/api\";\nimport deepEqual from \"fast-deep-equal\";\nimport type { Connectable, Observable } from \"rxjs\";\nimport type {\n CommonObserveOptions,\n Status,\n} from \"../../ObservableClient/common.js\";\nimport { type CacheKey, DEBUG_ONLY__cacheKeysToString } from \"../CacheKey.js\";\nimport { isObjectInstance } from \"../isObjectInstance.js\";\nimport type { Entry } from \"../Layer.js\";\nimport { type ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport { Query } from \"../Query.js\";\nimport type { SortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport { NoOpSortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport type { BatchContext, SubjectPayload } from \"../Store.js\";\nimport type {\n CollectionConnectableParams,\n CollectionStorageData,\n} from \"./BaseCollectionQuery.js\";\nimport { createCollectionConnectable } from \"./createCollectionConnectable.js\";\nimport { removeDuplicates } from \"./removeDuplicates.js\";\n\n/**\n * Base class for collection-based queries (lists and links)\n * Provides common functionality for working with collections of objects\n */\nexport abstract class BaseListQuery<\n KEY extends CacheKey<any, CollectionStorageData, any, any>,\n PAYLOAD,\n O extends CommonObserveOptions,\n> extends Query<KEY, PAYLOAD, O> {\n /**\n * The sorting strategy to use for this collection\n * @protected\n */\n protected sortingStrategy: SortingStrategy = new NoOpSortingStrategy();\n\n // Collection-specific behavior is implemented by subclasses\n /**\n * Token for the next page of results\n * @protected\n */\n protected nextPageToken?: string;\n\n /**\n * Promise tracking an in-progress page fetch\n * @protected\n */\n protected pendingPageFetch?: Promise<void>;\n\n //\n // Shared Implementations\n //\n\n /**\n * Standard method to update a list of objects\n * Handles common list update patterns for both ListQuery and SpecificLinkQuery\n *\n * @param items Objects or cache keys to add to the list\n * @param status Status to set for the list\n * @param batch Batch context to use\n * @param append Whether to append to the existing list or replace it\n * @returns The updated entry\n */\n public _updateList<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n status: Status,\n batch: BatchContext,\n append: boolean = false,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"updateList\" })\n : this.logger;\n\n logger?.debug(\n `{status: ${status}, append: ${append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n objectCacheKeys = this.#retainReleaseAppend(batch, append, objectCacheKeys);\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n return this.writeToStore({ data: objectCacheKeys }, status, batch);\n }\n\n /**\n * Common implementation for writing to store for collection-based queries\n * @param data The collection data to write to the store\n * @param status The status to set\n * @param batch The batch context\n */\n writeToStore(\n data: CollectionStorageData,\n status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n const entry = batch.read(this.cacheKey);\n\n if (entry && deepEqual(data, entry.value)) {\n // Check if both data AND status are the same\n if (entry.status === status) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal and status unchanged (${status}), skipping update`,\n );\n }\n // Return the existing entry without writing to avoid unnecessary notifications\n return entry;\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal, just updating status from ${entry.status} to ${status}`,\n );\n }\n // Keep the same value but update status and lastUpdated\n return batch.write(this.cacheKey, entry.value, status);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `{status: ${status}},`,\n DEBUG_ONLY__cacheKeysToString(data.data),\n );\n }\n\n const ret = batch.write(this.cacheKey, data, status);\n this.registerCacheChanges(batch);\n return ret;\n }\n\n /**\n * Register changes to the cache based on the specific collection type\n * Implemented by subclasses to handle specific change registration\n */\n protected abstract registerCacheChanges(batch: BatchContext): void;\n\n /**\n * Common method for managing object reference counting and appending results\n * Used by collection queries when updating object references\n *\n * @param batch The batch context to use\n * @param append Whether to append to existing objects or replace them\n * @param objectCacheKeys Array of object cache keys to process\n * @returns The final array of object cache keys after retain/release/append\n */\n #retainReleaseAppend(\n batch: BatchContext,\n append: boolean,\n objectCacheKeys: ObjectCacheKey[],\n ): ObjectCacheKey[] {\n const existingList = batch.read(this.cacheKey);\n\n // whether its append or update we need to retain all the new objects\n if (!batch.optimisticWrite) {\n if (!append) {\n // we need to release all the old objects\n // N.B. the store keeps the cache keys around for a bit so we don't\n // need to worry about them being GC'd before we re-retain them\n for (const objectCacheKey of existingList?.value?.data ?? []) {\n this.store.release(objectCacheKey);\n }\n }\n\n for (const objectCacheKey of objectCacheKeys) {\n this.store.retain(objectCacheKey);\n }\n }\n\n if (append) {\n objectCacheKeys = [\n ...existingList?.value?.data ?? [],\n ...objectCacheKeys,\n ];\n }\n return objectCacheKeys;\n }\n\n _dispose(): void {\n // eslint-disable-next-line no-console\n console.log(\"DISPOSE LIST QUERY\");\n this.store.batch({}, (batch) => {\n const entry = batch.read(this.cacheKey);\n if (entry) {\n for (const objectCacheKey of entry.value?.data ?? []) {\n this.store.release(objectCacheKey);\n }\n }\n });\n }\n\n /**\n * Creates a payload from collection parameters\n * Default implementation that covers common fields for all collection types\n * Subclasses may override to add type-specific fields if needed\n *\n * @param params Common collection parameters\n * @returns A typed payload for the specific collection type\n */\n protected createPayload(\n params: CollectionConnectableParams,\n ): PAYLOAD {\n return {\n resolvedList: params.resolvedData,\n isOptimistic: params.isOptimistic,\n fetchMore: this.fetchMore,\n hasMore: this.nextPageToken != null,\n status: params.status,\n lastUpdated: params.lastUpdated,\n } as unknown as PAYLOAD; // Type assertion needed since we don't know exact subtype\n }\n\n /**\n * Creates a connectable observable for this collection\n * Common implementation shared by all collection types\n *\n * @param subject The subject to connect to\n * @returns A connectable observable of the collection's payload type\n */\n protected _createConnectable(\n subject: Observable<SubjectPayload<KEY>>,\n ): Connectable<PAYLOAD> {\n return createCollectionConnectable<KEY, PAYLOAD>(\n subject,\n this.store,\n (params) => this.createPayload(params),\n );\n }\n\n /**\n * @override Reset pagination state before a fetch\n */\n protected _preFetch(): void {\n this.nextPageToken = undefined;\n super._preFetch();\n }\n\n /**\n * Common fetchMore implementation for pagination\n * Handles pending request management and loading states\n */\n fetchMore = (): Promise<void> => {\n if (this.pendingPageFetch) {\n return this.pendingPageFetch;\n }\n\n if (this.pendingFetch) {\n this.pendingPageFetch = new Promise(async (res) => {\n await this.pendingFetch;\n res(this.fetchMore());\n });\n return this.pendingPageFetch;\n }\n\n if (this.nextPageToken == null) {\n return Promise.resolve(undefined);\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loading\", batch);\n });\n\n this.pendingFetch = this.fetchPageAndUpdate(\n \"loaded\",\n this.abortController?.signal,\n ).then(() => void 0).finally(() => {\n this.pendingPageFetch = undefined;\n });\n return this.pendingFetch;\n };\n\n /**\n * Minimum number of results to load initially\n * May be overridden by subclasses for specific collection types\n * @protected\n */\n protected minResultsToLoad: number = 0;\n\n /**\n * Common _fetchAndStore implementation for pagination\n * Uses fetchPageAndUpdate to load the initial set of data\n * Will load multiple pages if necessary to reach minResultsToLoad\n */\n protected async _fetchAndStore(): Promise<void> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"_fetchAndStore\" }).debug(\n \"fetching pages\",\n );\n }\n\n // Keep fetching pages until we have the minimum number of results or no more pages\n while (true) {\n const entry = await this.fetchPageAndUpdate(\n \"loading\",\n this.abortController?.signal,\n );\n\n if (!entry) {\n // we were aborted\n return;\n }\n\n // Check if we have enough results or no more pages\n const count = entry.value?.data.length || 0;\n if (count >= this.minResultsToLoad || this.nextPageToken == null) {\n break;\n }\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loaded\", batch);\n });\n\n return Promise.resolve();\n }\n\n /**\n * Template method for fetching a page of data and updating the store\n * Provides common error handling and abort signal checking\n *\n * @param status The status to set for the entry\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the updated entry or undefined if aborted\n */\n protected async fetchPageAndUpdate(\n status: Status,\n signal: AbortSignal | undefined,\n ): Promise<Entry<KEY> | undefined> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).debug(\n `Fetching data with status: ${status}`,\n );\n }\n\n // Early abort check\n if (signal?.aborted) {\n return undefined;\n }\n\n try {\n // Call the subclass-specific implementation to fetch data\n const result = await this.fetchPageData(signal);\n\n // Check for abort again after fetch\n if (signal?.aborted) {\n return undefined;\n }\n\n // Store the fetched data using batch operations\n const { retVal } = this.store.batch({}, (batch) => {\n const append = this.nextPageToken != null;\n const finalStatus = result.nextPageToken ? status : \"loaded\";\n\n return this._updateList(\n this.store.objects.storeOsdkInstances(result.data, batch),\n finalStatus,\n batch,\n append,\n );\n });\n\n return retVal;\n } catch (error: unknown) {\n // Log any errors that occur\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).error(\n \"Error fetching data\",\n error,\n );\n }\n\n // For unexpected errors, write error status if not aborted\n if (!signal?.aborted) {\n const { retVal } = this.store.batch({}, (batch) => {\n return this.handleFetchError(error, status, batch);\n });\n return retVal;\n }\n\n // If aborted, just return undefined\n return undefined;\n }\n }\n\n /**\n * Abstract method that subclasses implement for their specific data fetching logic\n *\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the fetched data\n */\n protected abstract fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>>;\n\n /**\n * Handle fetch errors by setting appropriate error state\n * Default implementation that subclasses can override\n *\n * @param error The error that occurred\n * @param status The intended status if successful\n * @param batch The batch context to use\n * @returns The updated entry with error status\n */\n protected handleFetchError(\n _error: unknown,\n _status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n // Default implementation writes an empty list with error status\n // Most subclasses should be able to use this\n return this.writeToStore({ data: [] }, \"error\", batch);\n }\n\n /**\n * Sort the collection items using the configured sorting strategy\n * @param objectCacheKeys - The cache keys to sort\n * @param batch - The batch context\n * @returns Sorted array of cache keys\n */\n protected _sortCacheKeys(\n objectCacheKeys: ObjectCacheKey[],\n batch: BatchContext,\n ): ObjectCacheKey[] {\n return this.sortingStrategy.sortCacheKeys(objectCacheKeys, batch);\n }\n\n /**\n * Unified method for updating collection data in the store\n * Handles storing, sorting, deduplication, and reference counting\n *\n * @param items - Either object cache keys or object instances to update\n * @param options - Configuration options for the update\n * @param batch - The batch context to use\n * @returns The updated entry\n */\n protected updateCollection<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n options: {\n append?: boolean;\n status: Status;\n },\n batch: BatchContext,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"updateCollection\" })\n : this.logger;\n\n logger?.debug(\n `{status: ${options.status}, append: ${options.append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n // Step 1: Convert items to object cache keys if needed\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n // Step 2: Handle retain/release/append logic\n objectCacheKeys = this.#retainReleaseAppend(\n batch,\n options.append ?? false,\n objectCacheKeys,\n );\n\n // Step 3: Sort using the configured sorting strategy\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n\n // Step 4: Remove duplicates\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n // Step 5: Write to store\n return this.writeToStore({ data: objectCacheKeys }, options.status, batch);\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"BaseListQuery.js","names":["deepEqual","DEBUG_ONLY__cacheKeysToString","isObjectInstance","Query","NoOpSortingStrategy","createCollectionConnectable","removeDuplicates","BaseListQuery","sortingStrategy","_updateList","items","status","batch","append","process","env","NODE_ENV","logger","child","methodName","debug","JSON","stringify","objectCacheKeys","length","store","objects","storeOsdkInstances","retainReleaseAppend","_sortCacheKeys","writeToStore","data","entry","read","cacheKey","value","write","ret","registerCacheChanges","#retainReleaseAppend","existingList","optimisticWrite","objectCacheKey","cacheKeys","release","retain","_dispose","createPayload","params","resolvedList","resolvedData","isOptimistic","fetchMore","hasMore","nextPageToken","lastUpdated","_createConnectable","subject","subjects","_preFetch","undefined","pendingPageFetch","pendingFetch","Promise","res","resolve","setStatus","fetchPageAndUpdate","abortController","signal","then","finally","minResultsToLoad","_fetchAndStore","count","aborted","result","fetchPageData","retVal","finalStatus","error","handleFetchError","_error","_status","sortCacheKeys","updateCollection","options"],"sources":["BaseListQuery.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Osdk, PageResult } from \"@osdk/api\";\nimport deepEqual from \"fast-deep-equal\";\nimport type { Connectable, Observable } from \"rxjs\";\nimport type {\n CommonObserveOptions,\n Status,\n} from \"../../ObservableClient/common.js\";\nimport type { BatchContext } from \"../BatchContext.js\";\nimport { type CacheKey, DEBUG_ONLY__cacheKeysToString } from \"../CacheKey.js\";\nimport { isObjectInstance } from \"../isObjectInstance.js\";\nimport type { Entry } from \"../Layer.js\";\nimport { type ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport { Query } from \"../Query.js\";\nimport type { SortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport { NoOpSortingStrategy } from \"../sorting/SortingStrategy.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type {\n CollectionConnectableParams,\n CollectionStorageData,\n} from \"./BaseCollectionQuery.js\";\nimport { createCollectionConnectable } from \"./createCollectionConnectable.js\";\nimport { removeDuplicates } from \"./removeDuplicates.js\";\n\n/**\n * Base class for collection-based queries (lists and links)\n * Provides common functionality for working with collections of objects\n */\nexport abstract class BaseListQuery<\n KEY extends CacheKey<any, CollectionStorageData, any, any>,\n PAYLOAD,\n O extends CommonObserveOptions,\n> extends Query<KEY, PAYLOAD, O> {\n /**\n * The sorting strategy to use for this collection\n * @protected\n */\n protected sortingStrategy: SortingStrategy = new NoOpSortingStrategy();\n\n // Collection-specific behavior is implemented by subclasses\n /**\n * Token for the next page of results\n * @protected\n */\n protected nextPageToken?: string;\n\n /**\n * Promise tracking an in-progress page fetch\n * @protected\n */\n protected pendingPageFetch?: Promise<void>;\n\n //\n // Shared Implementations\n //\n\n /**\n * Standard method to update a list of objects\n * Handles common list update patterns for both ListQuery and SpecificLinkQuery\n *\n * @param items Objects or cache keys to add to the list\n * @param status Status to set for the list\n * @param batch Batch context to use\n * @param append Whether to append to the existing list or replace it\n * @returns The updated entry\n */\n public _updateList<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n status: Status,\n batch: BatchContext,\n append: boolean = false,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger\n ?.child({ methodName: \"updateList\" })\n .debug(\n `{status: ${status}, append: ${append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n objectCacheKeys = this.#retainReleaseAppend(batch, append, objectCacheKeys);\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n return this.writeToStore({ data: objectCacheKeys }, status, batch);\n }\n\n /**\n * Common implementation for writing to store for collection-based queries\n * @param data The collection data to write to the store\n * @param status The status to set\n * @param batch The batch context\n */\n writeToStore(\n data: CollectionStorageData,\n status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n const entry = batch.read(this.cacheKey);\n\n if (entry && deepEqual(data, entry.value)) {\n // Check if both data AND status are the same\n if (entry.status === status) {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal and status unchanged (${status}), skipping update`,\n );\n }\n // Return the existing entry without writing to avoid unnecessary notifications\n return entry;\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `Collection data was deep equal, just updating status from ${entry.status} to ${status}`,\n );\n }\n // Keep the same value but update status and lastUpdated\n return batch.write(this.cacheKey, entry.value, status);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"writeToStore\" }).debug(\n `{status: ${status}},`,\n DEBUG_ONLY__cacheKeysToString(data.data),\n );\n }\n\n const ret = batch.write(this.cacheKey, data, status);\n this.registerCacheChanges(batch);\n return ret;\n }\n\n /**\n * Register changes to the cache based on the specific collection type\n * Implemented by subclasses to handle specific change registration\n */\n protected abstract registerCacheChanges(batch: BatchContext): void;\n\n /**\n * Common method for managing object reference counting and appending results\n * Used by collection queries when updating object references\n *\n * @param batch The batch context to use\n * @param append Whether to append to existing objects or replace them\n * @param objectCacheKeys Array of object cache keys to process\n * @returns The final array of object cache keys after retain/release/append\n */\n #retainReleaseAppend(\n batch: BatchContext,\n append: boolean,\n objectCacheKeys: ObjectCacheKey[],\n ): ObjectCacheKey[] {\n const existingList = batch.read(this.cacheKey);\n\n // whether its append or update we need to retain all the new objects\n if (!batch.optimisticWrite) {\n if (!append) {\n // we need to release all the old objects\n // N.B. the store keeps the cache keys around for a bit so we don't\n // need to worry about them being GC'd before we re-retain them\n for (const objectCacheKey of existingList?.value?.data ?? []) {\n this.store.cacheKeys.release(objectCacheKey);\n }\n }\n\n for (const objectCacheKey of objectCacheKeys) {\n this.store.cacheKeys.retain(objectCacheKey);\n }\n }\n\n if (append) {\n objectCacheKeys = [\n ...existingList?.value?.data ?? [],\n ...objectCacheKeys,\n ];\n }\n return objectCacheKeys;\n }\n\n _dispose(): void {\n this.store.batch({}, (batch) => {\n const entry = batch.read(this.cacheKey);\n if (entry) {\n for (const objectCacheKey of entry.value?.data ?? []) {\n this.store.cacheKeys.release(objectCacheKey);\n }\n }\n });\n }\n\n /**\n * Creates a payload from collection parameters\n * Default implementation that covers common fields for all collection types\n * Subclasses may override to add type-specific fields if needed\n *\n * @param params Common collection parameters\n * @returns A typed payload for the specific collection type\n */\n protected createPayload(\n params: CollectionConnectableParams,\n ): PAYLOAD {\n return {\n resolvedList: params.resolvedData,\n isOptimistic: params.isOptimistic,\n fetchMore: this.fetchMore,\n hasMore: this.nextPageToken != null,\n status: params.status,\n lastUpdated: params.lastUpdated,\n } as unknown as PAYLOAD; // Type assertion needed since we don't know exact subtype\n }\n\n /**\n * Creates a connectable observable for this collection\n * Common implementation shared by all collection types\n *\n * @param subject The subject to connect to\n * @returns A connectable observable of the collection's payload type\n */\n protected _createConnectable(\n subject: Observable<SubjectPayload<KEY>>,\n ): Connectable<PAYLOAD> {\n return createCollectionConnectable<KEY, PAYLOAD>(\n subject,\n this.store.subjects,\n (params) => this.createPayload(params),\n );\n }\n\n /**\n * @override Reset pagination state before a fetch\n */\n protected _preFetch(): void {\n this.nextPageToken = undefined;\n super._preFetch();\n }\n\n /**\n * Common fetchMore implementation for pagination\n * Handles pending request management and loading states\n */\n fetchMore = (): Promise<void> => {\n if (this.pendingPageFetch) {\n return this.pendingPageFetch;\n }\n\n if (this.pendingFetch) {\n this.pendingPageFetch = new Promise(async (res) => {\n await this.pendingFetch;\n res(this.fetchMore());\n });\n return this.pendingPageFetch;\n }\n\n if (this.nextPageToken == null) {\n return Promise.resolve(undefined);\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loading\", batch);\n });\n\n this.pendingFetch = this.fetchPageAndUpdate(\n \"loaded\",\n this.abortController?.signal,\n ).then(() => void 0).finally(() => {\n this.pendingPageFetch = undefined;\n });\n return this.pendingFetch;\n };\n\n /**\n * Minimum number of results to load initially\n * May be overridden by subclasses for specific collection types\n * @protected\n */\n protected minResultsToLoad: number = 0;\n\n /**\n * Common _fetchAndStore implementation for pagination\n * Uses fetchPageAndUpdate to load the initial set of data\n * Will load multiple pages if necessary to reach minResultsToLoad\n */\n protected async _fetchAndStore(): Promise<void> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"_fetchAndStore\" }).debug(\n \"fetching pages\",\n );\n }\n\n // Keep fetching pages until we have the minimum number of results or no more pages\n while (true) {\n const entry = await this.fetchPageAndUpdate(\n \"loading\",\n this.abortController?.signal,\n );\n\n if (!entry) {\n // we were aborted\n return;\n }\n\n // Check if we have enough results or no more pages\n const count = entry.value?.data.length || 0;\n if (count >= this.minResultsToLoad || this.nextPageToken == null) {\n break;\n }\n }\n\n this.store.batch({}, (batch) => {\n this.setStatus(\"loaded\", batch);\n });\n\n return Promise.resolve();\n }\n\n /**\n * Template method for fetching a page of data and updating the store\n * Provides common error handling and abort signal checking\n *\n * @param status The status to set for the entry\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the updated entry or undefined if aborted\n */\n protected async fetchPageAndUpdate(\n status: Status,\n signal: AbortSignal | undefined,\n ): Promise<Entry<KEY> | undefined> {\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).debug(\n `Fetching data with status: ${status}`,\n );\n }\n\n // Early abort check\n if (signal?.aborted) {\n return undefined;\n }\n\n try {\n // Call the subclass-specific implementation to fetch data\n const result = await this.fetchPageData(signal);\n\n // Check for abort again after fetch\n if (signal?.aborted) {\n return undefined;\n }\n\n // Store the fetched data using batch operations\n const { retVal } = this.store.batch({}, (batch) => {\n const append = this.nextPageToken != null;\n const finalStatus = result.nextPageToken ? status : \"loaded\";\n\n return this._updateList(\n this.store.objects.storeOsdkInstances(result.data, batch),\n finalStatus,\n batch,\n append,\n );\n });\n\n return retVal;\n } catch (error: unknown) {\n // Log any errors that occur\n if (process.env.NODE_ENV !== \"production\") {\n this.logger?.child({ methodName: \"fetchPageAndUpdate\" }).error(\n \"Error fetching data\",\n error,\n );\n }\n\n // For unexpected errors, write error status if not aborted\n if (!signal?.aborted) {\n const { retVal } = this.store.batch({}, (batch) => {\n return this.handleFetchError(error, status, batch);\n });\n return retVal;\n }\n\n // If aborted, just return undefined\n return undefined;\n }\n }\n\n /**\n * Abstract method that subclasses implement for their specific data fetching logic\n *\n * @param signal Optional AbortSignal for cancellation\n * @returns A promise that resolves to the fetched data\n */\n protected abstract fetchPageData(\n signal: AbortSignal | undefined,\n ): Promise<PageResult<Osdk.Instance<any>>>;\n\n /**\n * Handle fetch errors by setting appropriate error state\n * Default implementation that subclasses can override\n *\n * @param error The error that occurred\n * @param status The intended status if successful\n * @param batch The batch context to use\n * @returns The updated entry with error status\n */\n protected handleFetchError(\n _error: unknown,\n _status: Status,\n batch: BatchContext,\n ): Entry<KEY> {\n // Default implementation writes an empty list with error status\n // Most subclasses should be able to use this\n return this.writeToStore({ data: [] }, \"error\", batch);\n }\n\n /**\n * Sort the collection items using the configured sorting strategy\n * @param objectCacheKeys - The cache keys to sort\n * @param batch - The batch context\n * @returns Sorted array of cache keys\n */\n protected _sortCacheKeys(\n objectCacheKeys: ObjectCacheKey[],\n batch: BatchContext,\n ): ObjectCacheKey[] {\n return this.sortingStrategy.sortCacheKeys(objectCacheKeys, batch);\n }\n\n /**\n * Unified method for updating collection data in the store\n * Handles storing, sorting, deduplication, and reference counting\n *\n * @param items - Either object cache keys or object instances to update\n * @param options - Configuration options for the update\n * @param batch - The batch context to use\n * @returns The updated entry\n */\n protected updateCollection<T extends ObjectCacheKey | Osdk.Instance<any>>(\n items: T[],\n options: {\n append?: boolean;\n status: Status;\n },\n batch: BatchContext,\n ): Entry<KEY> {\n if (process.env.NODE_ENV !== \"production\") {\n const logger = process.env.NODE_ENV !== \"production\"\n ? this.logger?.child({ methodName: \"updateCollection\" })\n : this.logger;\n\n logger?.debug(\n `{status: ${options.status}, append: ${options.append}}`,\n JSON.stringify(items, null, 2),\n );\n }\n\n // Step 1: Convert items to object cache keys if needed\n let objectCacheKeys: ObjectCacheKey[];\n\n if (items.length === 0) {\n objectCacheKeys = [];\n } else if (isObjectInstance(items[0])) {\n // Items are object instances, need to store them first\n objectCacheKeys = this.store.objects.storeOsdkInstances(\n items as Array<Osdk.Instance<any>>,\n batch,\n );\n } else {\n // Items are already cache keys\n objectCacheKeys = items as ObjectCacheKey[];\n }\n\n // Step 2: Handle retain/release/append logic\n objectCacheKeys = this.#retainReleaseAppend(\n batch,\n options.append ?? false,\n objectCacheKeys,\n );\n\n // Step 3: Sort using the configured sorting strategy\n objectCacheKeys = this._sortCacheKeys(objectCacheKeys, batch);\n\n // Step 4: Remove duplicates\n objectCacheKeys = removeDuplicates(objectCacheKeys, batch);\n\n // Step 5: Write to store\n return this.writeToStore({ data: objectCacheKeys }, options.status, batch);\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -28,9 +28,9 @@ import { asapScheduler, combineLatest, connectable, distinctUntilChanged, map, o
28
28
  * @param createPayload A function that creates the payload from common parameters
29
29
  * @returns A connectable observable of the payload type
30
30
  */
31
- export function createCollectionConnectable(subject, store, createPayload) {
31
+ export function createCollectionConnectable(subject, subjects, createPayload) {
32
32
  return connectable(subject.pipe(switchMap(listEntry => {
33
- const resolvedData = listEntry?.value?.data == null || listEntry.value.data.length === 0 ? of([]) : combineLatest(listEntry.value.data.map(cacheKey => store.getSubject(cacheKey).pipe(map(objectEntry => objectEntry?.value), distinctUntilChanged())));
33
+ const resolvedData = listEntry?.value?.data == null || listEntry.value.data.length === 0 ? of([]) : combineLatest(listEntry.value.data.map(cacheKey => subjects.get(cacheKey).pipe(map(objectEntry => objectEntry?.value), distinctUntilChanged())));
34
34
  return scheduled(combineLatest({
35
35
  resolvedData,
36
36
  isOptimistic: of(listEntry.isOptimistic),
@@ -1 +1 @@
1
- {"version":3,"file":"createCollectionConnectable.js","names":["asapScheduler","combineLatest","connectable","distinctUntilChanged","map","of","ReplaySubject","scheduled","switchMap","createCollectionConnectable","subject","store","createPayload","pipe","listEntry","resolvedData","value","data","length","cacheKey","getSubject","objectEntry","isOptimistic","status","lastUpdated","params","Array","isArray","resetOnDisconnect","connector"],"sources":["createCollectionConnectable.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n asapScheduler,\n combineLatest,\n type Connectable,\n connectable,\n distinctUntilChanged,\n map,\n type Observable,\n of,\n ReplaySubject,\n scheduled,\n switchMap,\n} from \"rxjs\";\nimport type { Status } from \"../../ObservableClient/common.js\";\nimport type { CacheKey } from \"../CacheKey.js\";\nimport type { ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport type { Store, SubjectPayload } from \"../Store.js\";\n\n/**\n * Common parameters available for constructing a collection payload\n */\ninterface CollectionConnectableParams {\n /**\n * Array of resolved objects\n */\n resolvedData: any[];\n\n /**\n * Whether the data is from an optimistic update\n */\n isOptimistic: boolean;\n\n /**\n * Current loading status\n */\n status: Status;\n\n /**\n * Timestamp of the last update\n */\n lastUpdated: number;\n}\n\n/**\n * Creates a connectable observable for a collection of objects\n *\n * @param subject The subject to connect to\n * @param store The store to use for resolving objects\n * @param createPayload A function that creates the payload from common parameters\n * @returns A connectable observable of the payload type\n */\nexport function createCollectionConnectable<\n K extends CacheKey<any, any, any, any>,\n P,\n>(\n subject: Observable<SubjectPayload<K>>,\n store: Store,\n createPayload: (params: CollectionConnectableParams) => P,\n): Connectable<P> {\n return connectable<P>(\n subject.pipe(\n switchMap(listEntry => {\n const resolvedData = listEntry?.value?.data == null\n || listEntry.value.data.length === 0\n ? of([])\n : combineLatest(\n listEntry.value.data.map((cacheKey: ObjectCacheKey) =>\n store.getSubject(cacheKey).pipe(\n map(objectEntry => objectEntry?.value!),\n distinctUntilChanged(),\n )\n ),\n );\n\n return scheduled(\n combineLatest({\n resolvedData,\n isOptimistic: of(listEntry.isOptimistic),\n status: of(listEntry.status),\n lastUpdated: of(listEntry.lastUpdated),\n }).pipe(\n map(params =>\n createPayload({\n resolvedData: Array.isArray(params.resolvedData)\n ? params.resolvedData\n : [],\n isOptimistic: params.isOptimistic,\n status: params.status,\n lastUpdated: params.lastUpdated,\n })\n ),\n ),\n asapScheduler,\n );\n }),\n ),\n {\n resetOnDisconnect: false,\n connector: () => new ReplaySubject(1),\n },\n );\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SACEA,aAAa,EACbC,aAAa,EAEbC,WAAW,EACXC,oBAAoB,EACpBC,GAAG,EAEHC,EAAE,EACFC,aAAa,EACbC,SAAS,EACTC,SAAS,QACJ,MAAM;;AAMb;AACA;AACA;;AAuBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,2BAA2BA,CAIzCC,OAAsC,EACtCC,KAAY,EACZC,aAAyD,EACzC;EAChB,OAAOV,WAAW,CAChBQ,OAAO,CAACG,IAAI,CACVL,SAAS,CAACM,SAAS,IAAI;IACrB,MAAMC,YAAY,GAAGD,SAAS,EAAEE,KAAK,EAAEC,IAAI,IAAI,IAAI,IAC5CH,SAAS,CAACE,KAAK,CAACC,IAAI,CAACC,MAAM,KAAK,CAAC,GACpCb,EAAE,CAAC,EAAE,CAAC,GACNJ,aAAa,CACba,SAAS,CAACE,KAAK,CAACC,IAAI,CAACb,GAAG,CAAEe,QAAwB,IAChDR,KAAK,CAACS,UAAU,CAACD,QAAQ,CAAC,CAACN,IAAI,CAC7BT,GAAG,CAACiB,WAAW,IAAIA,WAAW,EAAEL,KAAM,CAAC,EACvCb,oBAAoB,CAAC,CACvB,CACF,CACF,CAAC;IAEH,OAAOI,SAAS,CACdN,aAAa,CAAC;MACZc,YAAY;MACZO,YAAY,EAAEjB,EAAE,CAACS,SAAS,CAACQ,YAAY,CAAC;MACxCC,MAAM,EAAElB,EAAE,CAACS,SAAS,CAACS,MAAM,CAAC;MAC5BC,WAAW,EAAEnB,EAAE,CAACS,SAAS,CAACU,WAAW;IACvC,CAAC,CAAC,CAACX,IAAI,CACLT,GAAG,CAACqB,MAAM,IACRb,aAAa,CAAC;MACZG,YAAY,EAAEW,KAAK,CAACC,OAAO,CAACF,MAAM,CAACV,YAAY,CAAC,GAC5CU,MAAM,CAACV,YAAY,GACnB,EAAE;MACNO,YAAY,EAAEG,MAAM,CAACH,YAAY;MACjCC,MAAM,EAAEE,MAAM,CAACF,MAAM;MACrBC,WAAW,EAAEC,MAAM,CAACD;IACtB,CAAC,CACH,CACF,CAAC,EACDxB,aACF,CAAC;EACH,CAAC,CACH,CAAC,EACD;IACE4B,iBAAiB,EAAE,KAAK;IACxBC,SAAS,EAAEA,CAAA,KAAM,IAAIvB,aAAa,CAAC,CAAC;EACtC,CACF,CAAC;AACH","ignoreList":[]}
1
+ {"version":3,"file":"createCollectionConnectable.js","names":["asapScheduler","combineLatest","connectable","distinctUntilChanged","map","of","ReplaySubject","scheduled","switchMap","createCollectionConnectable","subject","subjects","createPayload","pipe","listEntry","resolvedData","value","data","length","cacheKey","get","objectEntry","isOptimistic","status","lastUpdated","params","Array","isArray","resetOnDisconnect","connector"],"sources":["createCollectionConnectable.ts"],"sourcesContent":["/*\n * Copyright 2025 Palantir Technologies, Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n asapScheduler,\n combineLatest,\n type Connectable,\n connectable,\n distinctUntilChanged,\n map,\n type Observable,\n of,\n ReplaySubject,\n scheduled,\n switchMap,\n} from \"rxjs\";\nimport type { Status } from \"../../ObservableClient/common.js\";\nimport type { CacheKey } from \"../CacheKey.js\";\nimport type { ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type { Subjects } from \"../Subjects.js\";\n\n/**\n * Common parameters available for constructing a collection payload\n */\ninterface CollectionConnectableParams {\n /**\n * Array of resolved objects\n */\n resolvedData: any[];\n\n /**\n * Whether the data is from an optimistic update\n */\n isOptimistic: boolean;\n\n /**\n * Current loading status\n */\n status: Status;\n\n /**\n * Timestamp of the last update\n */\n lastUpdated: number;\n}\n\n/**\n * Creates a connectable observable for a collection of objects\n *\n * @param subject The subject to connect to\n * @param store The store to use for resolving objects\n * @param createPayload A function that creates the payload from common parameters\n * @returns A connectable observable of the payload type\n */\nexport function createCollectionConnectable<\n K extends CacheKey<any, any, any, any>,\n P,\n>(\n subject: Observable<SubjectPayload<K>>,\n subjects: Subjects,\n createPayload: (params: CollectionConnectableParams) => P,\n): Connectable<P> {\n return connectable<P>(\n subject.pipe(\n switchMap(listEntry => {\n const resolvedData = listEntry?.value?.data == null\n || listEntry.value.data.length === 0\n ? of([])\n : combineLatest(\n listEntry.value.data.map((cacheKey: ObjectCacheKey) =>\n subjects.get(cacheKey).pipe(\n map(objectEntry => objectEntry?.value!),\n distinctUntilChanged(),\n )\n ),\n );\n\n return scheduled(\n combineLatest({\n resolvedData,\n isOptimistic: of(listEntry.isOptimistic),\n status: of(listEntry.status),\n lastUpdated: of(listEntry.lastUpdated),\n }).pipe(\n map(params =>\n createPayload({\n resolvedData: Array.isArray(params.resolvedData)\n ? params.resolvedData\n : [],\n isOptimistic: params.isOptimistic,\n status: params.status,\n lastUpdated: params.lastUpdated,\n })\n ),\n ),\n asapScheduler,\n );\n }),\n ),\n {\n resetOnDisconnect: false,\n connector: () => new ReplaySubject(1),\n },\n );\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SACEA,aAAa,EACbC,aAAa,EAEbC,WAAW,EACXC,oBAAoB,EACpBC,GAAG,EAEHC,EAAE,EACFC,aAAa,EACbC,SAAS,EACTC,SAAS,QACJ,MAAM;;AAOb;AACA;AACA;;AAuBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,2BAA2BA,CAIzCC,OAAsC,EACtCC,QAAkB,EAClBC,aAAyD,EACzC;EAChB,OAAOV,WAAW,CAChBQ,OAAO,CAACG,IAAI,CACVL,SAAS,CAACM,SAAS,IAAI;IACrB,MAAMC,YAAY,GAAGD,SAAS,EAAEE,KAAK,EAAEC,IAAI,IAAI,IAAI,IAC5CH,SAAS,CAACE,KAAK,CAACC,IAAI,CAACC,MAAM,KAAK,CAAC,GACpCb,EAAE,CAAC,EAAE,CAAC,GACNJ,aAAa,CACba,SAAS,CAACE,KAAK,CAACC,IAAI,CAACb,GAAG,CAAEe,QAAwB,IAChDR,QAAQ,CAACS,GAAG,CAACD,QAAQ,CAAC,CAACN,IAAI,CACzBT,GAAG,CAACiB,WAAW,IAAIA,WAAW,EAAEL,KAAM,CAAC,EACvCb,oBAAoB,CAAC,CACvB,CACF,CACF,CAAC;IAEH,OAAOI,SAAS,CACdN,aAAa,CAAC;MACZc,YAAY;MACZO,YAAY,EAAEjB,EAAE,CAACS,SAAS,CAACQ,YAAY,CAAC;MACxCC,MAAM,EAAElB,EAAE,CAACS,SAAS,CAACS,MAAM,CAAC;MAC5BC,WAAW,EAAEnB,EAAE,CAACS,SAAS,CAACU,WAAW;IACvC,CAAC,CAAC,CAACX,IAAI,CACLT,GAAG,CAACqB,MAAM,IACRb,aAAa,CAAC;MACZG,YAAY,EAAEW,KAAK,CAACC,OAAO,CAACF,MAAM,CAACV,YAAY,CAAC,GAC5CU,MAAM,CAACV,YAAY,GACnB,EAAE;MACNO,YAAY,EAAEG,MAAM,CAACH,YAAY;MACjCC,MAAM,EAAEE,MAAM,CAACF,MAAM;MACrBC,WAAW,EAAEC,MAAM,CAACD;IACtB,CAAC,CACH,CACF,CAAC,EACDxB,aACF,CAAC;EACH,CAAC,CACH,CAAC,EACD;IACE4B,iBAAiB,EAAE,KAAK;IACxBC,SAAS,EAAEA,CAAA,KAAM,IAAIvB,aAAa,CAAC,CAAC;EACtC,CACF,CAAC;AACH","ignoreList":[]}
@@ -47,17 +47,15 @@ const mockEmployee3 = {
47
47
  fullName: "Bob Johnson"
48
48
  };
49
49
  describe("createCollectionConnectable", () => {
50
- let mockStore;
50
+ let mockSubjects;
51
51
  let createPayload;
52
52
  let mockListCacheKey;
53
53
  beforeEach(() => {
54
54
  const {
55
55
  client
56
56
  } = createClientMockHelper();
57
-
58
- // Mock the store with minimal required methods
59
- mockStore = {
60
- getSubject: vi.fn()
57
+ mockSubjects = {
58
+ get: vi.fn()
61
59
  };
62
60
 
63
61
  // Mock cache key for list
@@ -100,7 +98,7 @@ describe("createCollectionConnectable", () => {
100
98
  const subject = new BehaviorSubject(subjectPayload);
101
99
 
102
100
  // Mock store.getSubject to return object observables
103
- vi.mocked(mockStore.getSubject).mockImplementation(cacheKey => {
101
+ vi.mocked(mockSubjects.get).mockImplementation(cacheKey => {
104
102
  if (cacheKey === objectKey1) {
105
103
  return new BehaviorSubject({
106
104
  cacheKey: objectKey1,
@@ -121,7 +119,7 @@ describe("createCollectionConnectable", () => {
121
119
  }
122
120
  return new BehaviorSubject(undefined);
123
121
  });
124
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
122
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
125
123
 
126
124
  // Connect and subscribe
127
125
  const subscription = connectable.connect();
@@ -151,7 +149,7 @@ describe("createCollectionConnectable", () => {
151
149
  isOptimistic: false
152
150
  };
153
151
  const subject = new BehaviorSubject(subjectPayload);
154
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
152
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
155
153
  const subscription = connectable.connect();
156
154
  const observer = mockObserver();
157
155
  connectable.subscribe(observer);
@@ -175,7 +173,7 @@ describe("createCollectionConnectable", () => {
175
173
  isOptimistic: false
176
174
  };
177
175
  const subject = new BehaviorSubject(subjectPayload);
178
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
176
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
179
177
  const subscription = connectable.connect();
180
178
  const observer = mockObserver();
181
179
  connectable.subscribe(observer);
@@ -205,14 +203,14 @@ describe("createCollectionConnectable", () => {
205
203
  isOptimistic: true // This is an optimistic update
206
204
  };
207
205
  const subject = new BehaviorSubject(subjectPayload);
208
- vi.mocked(mockStore.getSubject).mockReturnValue(new BehaviorSubject({
206
+ vi.mocked(mockSubjects.get).mockReturnValue(new BehaviorSubject({
209
207
  cacheKey: objectKey1,
210
208
  value: mockEmployee1,
211
209
  status: "loaded",
212
210
  lastUpdated: Date.now(),
213
211
  isOptimistic: false
214
212
  }));
215
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
213
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
216
214
  const subscription = connectable.connect();
217
215
  const observer = mockObserver();
218
216
  connectable.subscribe(observer);
@@ -243,14 +241,14 @@ describe("createCollectionConnectable", () => {
243
241
  isOptimistic: false
244
242
  };
245
243
  const subject = new BehaviorSubject(basePayload);
246
- vi.mocked(mockStore.getSubject).mockReturnValue(new BehaviorSubject({
244
+ vi.mocked(mockSubjects.get).mockReturnValue(new BehaviorSubject({
247
245
  cacheKey: objectKey1,
248
246
  value: mockEmployee1,
249
247
  status: "loaded",
250
248
  lastUpdated: Date.now(),
251
249
  isOptimistic: false
252
250
  }));
253
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
251
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
254
252
  const subscription = connectable.connect();
255
253
  const observer = mockObserver();
256
254
  connectable.subscribe(observer);
@@ -307,7 +305,7 @@ describe("createCollectionConnectable", () => {
307
305
  const subject = new BehaviorSubject(subjectPayload);
308
306
 
309
307
  // Mock store.getSubject for all three objects
310
- vi.mocked(mockStore.getSubject).mockImplementation(cacheKey => {
308
+ vi.mocked(mockSubjects.get).mockImplementation(cacheKey => {
311
309
  if (cacheKey === objectKey1) {
312
310
  return new BehaviorSubject({
313
311
  cacheKey: objectKey1,
@@ -337,7 +335,7 @@ describe("createCollectionConnectable", () => {
337
335
  }
338
336
  return new BehaviorSubject(undefined);
339
337
  });
340
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
338
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
341
339
  const subscription = connectable.connect();
342
340
  const observer = mockObserver();
343
341
  connectable.subscribe(observer);
@@ -371,7 +369,7 @@ describe("createCollectionConnectable", () => {
371
369
  isOptimistic: false
372
370
  };
373
371
  const subject = new BehaviorSubject(initialPayload);
374
- vi.mocked(mockStore.getSubject).mockImplementation(cacheKey => {
372
+ vi.mocked(mockSubjects.get).mockImplementation(cacheKey => {
375
373
  if (cacheKey === objectKey1) {
376
374
  return new BehaviorSubject({
377
375
  cacheKey: objectKey1,
@@ -392,7 +390,7 @@ describe("createCollectionConnectable", () => {
392
390
  }
393
391
  return new BehaviorSubject(undefined);
394
392
  });
395
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
393
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
396
394
  const subscription = connectable.connect();
397
395
  const observer = mockObserver();
398
396
  connectable.subscribe(observer);
@@ -439,14 +437,14 @@ describe("createCollectionConnectable", () => {
439
437
  isOptimistic: false
440
438
  };
441
439
  const subject = new BehaviorSubject(subjectPayload);
442
- vi.mocked(mockStore.getSubject).mockReturnValue(new BehaviorSubject({
440
+ vi.mocked(mockSubjects.get).mockReturnValue(new BehaviorSubject({
443
441
  cacheKey: objectKey1,
444
442
  value: mockEmployee1,
445
443
  status: "loaded",
446
444
  lastUpdated: Date.now(),
447
445
  isOptimistic: false
448
446
  }));
449
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
447
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
450
448
  const subscription = connectable.connect();
451
449
  const observer1 = mockObserver();
452
450
  const observer2 = mockObserver();
@@ -481,14 +479,14 @@ describe("createCollectionConnectable", () => {
481
479
  isOptimistic: false
482
480
  };
483
481
  const subject = new BehaviorSubject(subjectPayload);
484
- vi.mocked(mockStore.getSubject).mockReturnValue(new BehaviorSubject({
482
+ vi.mocked(mockSubjects.get).mockReturnValue(new BehaviorSubject({
485
483
  cacheKey: objectKey1,
486
484
  value: mockEmployee1,
487
485
  status: "loaded",
488
486
  lastUpdated: Date.now(),
489
487
  isOptimistic: false
490
488
  }));
491
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
489
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
492
490
  const subscription = connectable.connect();
493
491
  const observer1 = mockObserver();
494
492
 
@@ -532,7 +530,7 @@ describe("createCollectionConnectable", () => {
532
530
  const subject = new BehaviorSubject(subjectPayload);
533
531
 
534
532
  // Mock store.getSubject to return undefined entry - this creates an object with undefined value
535
- vi.mocked(mockStore.getSubject).mockReturnValue(new BehaviorSubject({
533
+ vi.mocked(mockSubjects.get).mockReturnValue(new BehaviorSubject({
536
534
  cacheKey: objectKey1,
537
535
  value: undefined,
538
536
  // This is the key - undefined value
@@ -540,7 +538,7 @@ describe("createCollectionConnectable", () => {
540
538
  lastUpdated: Date.now(),
541
539
  isOptimistic: false
542
540
  }));
543
- const connectable = actualCreateCollectionConnectable(subject, mockStore, createPayload);
541
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, createPayload);
544
542
  const subscription = connectable.connect();
545
543
  const observer = mockObserver();
546
544
  connectable.subscribe(observer);
@@ -570,7 +568,7 @@ describe("createCollectionConnectable", () => {
570
568
  isOptimistic: false
571
569
  };
572
570
  const subject = new BehaviorSubject(subjectPayload);
573
- vi.mocked(mockStore.getSubject).mockReturnValue(new BehaviorSubject({
571
+ vi.mocked(mockSubjects.get).mockReturnValue(new BehaviorSubject({
574
572
  cacheKey: objectKey1,
575
573
  value: mockEmployee1,
576
574
  status: "loaded",
@@ -582,7 +580,7 @@ describe("createCollectionConnectable", () => {
582
580
  const errorThrowingCreatePayload = vi.fn(() => {
583
581
  throw new Error("Test error in createPayload");
584
582
  });
585
- const connectable = actualCreateCollectionConnectable(subject, mockStore, errorThrowingCreatePayload);
583
+ const connectable = actualCreateCollectionConnectable(subject, mockSubjects, errorThrowingCreatePayload);
586
584
  const subscription = connectable.connect();
587
585
  const observer = mockObserver();
588
586
  connectable.subscribe(observer);