@osdk/client 2.6.0-beta.2 → 2.6.0-beta.4

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 (267) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/build/browser/derivedProperties/createWithPropertiesObjectSet.js +2 -1
  3. package/build/browser/derivedProperties/createWithPropertiesObjectSet.js.map +1 -1
  4. package/build/browser/index.js.map +1 -1
  5. package/build/browser/internal/conversions/extractNamespace.js +22 -0
  6. package/build/browser/internal/conversions/extractNamespace.js.map +1 -0
  7. package/build/browser/internal/conversions/fullyQualifyPropName.js +26 -0
  8. package/build/browser/internal/conversions/fullyQualifyPropName.js.map +1 -0
  9. package/build/browser/internal/conversions/makeGeoFilterBbox.js +41 -0
  10. package/build/browser/internal/conversions/makeGeoFilterBbox.js.map +1 -0
  11. package/build/browser/internal/conversions/makeGeoFilterIntersects.js +29 -0
  12. package/build/browser/internal/conversions/makeGeoFilterIntersects.js.map +1 -0
  13. package/build/browser/internal/conversions/makeGeoFilterPolygon.js +30 -0
  14. package/build/browser/internal/conversions/makeGeoFilterPolygon.js.map +1 -0
  15. package/build/browser/internal/conversions/makeGeoFilterWithin.js +48 -0
  16. package/build/browser/internal/conversions/makeGeoFilterWithin.js.map +1 -0
  17. package/build/browser/internal/conversions/modernToLegacyWhereClause.js +30 -99
  18. package/build/browser/internal/conversions/modernToLegacyWhereClause.js.map +1 -1
  19. package/build/browser/internal/conversions/modernToLegacyWhereClause.test.js +139 -0
  20. package/build/browser/internal/conversions/modernToLegacyWhereClause.test.js.map +1 -1
  21. package/build/browser/object/convertWireToOsdkObjects/createOsdkInterface.js +1 -1
  22. package/build/browser/object/convertWireToOsdkObjects/createOsdkInterface.js.map +1 -1
  23. package/build/browser/object/fetchPage.js +1 -1
  24. package/build/browser/object/fetchPage.js.map +1 -1
  25. package/build/browser/object/formatting/applyPropertyFormatter.js +7 -1
  26. package/build/browser/object/formatting/applyPropertyFormatter.js.map +1 -1
  27. package/build/browser/object/formatting/applyPropertyFormatter.test.js +305 -2
  28. package/build/browser/object/formatting/applyPropertyFormatter.test.js.map +1 -1
  29. package/build/browser/object/formatting/formatDateTime.js +158 -0
  30. package/build/browser/object/formatting/formatDateTime.js.map +1 -0
  31. package/build/browser/objectSet/ObjectSetListenerWebsocket.js +17 -0
  32. package/build/browser/objectSet/ObjectSetListenerWebsocket.js.map +1 -1
  33. package/build/browser/observable/ObservableClient.js.map +1 -1
  34. package/build/browser/observable/internal/BulkObjectLoader.js +12 -4
  35. package/build/browser/observable/internal/BulkObjectLoader.js.map +1 -1
  36. package/build/browser/observable/internal/BulkObjectLoader.test.js +48 -0
  37. package/build/browser/observable/internal/BulkObjectLoader.test.js.map +1 -1
  38. package/build/browser/observable/internal/CacheKeys.js +9 -3
  39. package/build/browser/observable/internal/CacheKeys.js.map +1 -1
  40. package/build/browser/observable/internal/Canonicalizer.js +51 -0
  41. package/build/browser/observable/internal/Canonicalizer.js.map +1 -0
  42. package/build/browser/observable/internal/ObservableClientImpl.js.map +1 -1
  43. package/build/browser/observable/internal/OrderByCanonicalizer.js +1 -4
  44. package/build/browser/observable/internal/OrderByCanonicalizer.js.map +1 -1
  45. package/build/browser/observable/internal/RdpCanonicalizer.js +66 -0
  46. package/build/browser/observable/internal/RdpCanonicalizer.js.map +1 -0
  47. package/build/browser/observable/internal/RdpCanonicalizer.test.js +68 -0
  48. package/build/browser/observable/internal/RdpCanonicalizer.test.js.map +1 -0
  49. package/build/browser/observable/internal/SimpleWhereClause.js.map +1 -1
  50. package/build/browser/observable/internal/Store.js +160 -6
  51. package/build/browser/observable/internal/Store.js.map +1 -1
  52. package/build/browser/observable/internal/WhereClauseCanonicalizer.js +1 -1
  53. package/build/browser/observable/internal/WhereClauseCanonicalizer.js.map +1 -1
  54. package/build/browser/observable/internal/actions/ActionApplication.js +1 -1
  55. package/build/browser/observable/internal/actions/ActionApplication.js.map +1 -1
  56. package/build/browser/observable/internal/actions/OptimisticJob.js +3 -3
  57. package/build/browser/observable/internal/actions/OptimisticJob.js.map +1 -1
  58. package/build/browser/observable/internal/base-list/BaseListQuery.js +12 -3
  59. package/build/browser/observable/internal/base-list/BaseListQuery.js.map +1 -1
  60. package/build/browser/observable/internal/base-list/createCollectionConnectable.js +0 -5
  61. package/build/browser/observable/internal/base-list/createCollectionConnectable.js.map +1 -1
  62. package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js +26 -13
  63. package/build/browser/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -1
  64. package/build/browser/observable/internal/evaluateFilter.js +61 -0
  65. package/build/browser/observable/internal/evaluateFilter.js.map +1 -0
  66. package/build/browser/observable/internal/links/SpecificLinkCacheKey.js +33 -1
  67. package/build/browser/observable/internal/links/SpecificLinkCacheKey.js.map +1 -1
  68. package/build/browser/observable/internal/list/InterfaceListQuery.js +8 -3
  69. package/build/browser/observable/internal/list/InterfaceListQuery.js.map +1 -1
  70. package/build/browser/observable/internal/list/ListCacheKey.js +22 -1
  71. package/build/browser/observable/internal/list/ListCacheKey.js.map +1 -1
  72. package/build/browser/observable/internal/list/ListQuery.js +19 -13
  73. package/build/browser/observable/internal/list/ListQuery.js.map +1 -1
  74. package/build/browser/observable/internal/list/ListsHelper.js +12 -8
  75. package/build/browser/observable/internal/list/ListsHelper.js.map +1 -1
  76. package/build/browser/observable/internal/list/ObjectListQuery.js +10 -1
  77. package/build/browser/observable/internal/list/ObjectListQuery.js.map +1 -1
  78. package/build/browser/observable/internal/object/ObjectCacheKey.js +20 -1
  79. package/build/browser/observable/internal/object/ObjectCacheKey.js.map +1 -1
  80. package/build/browser/observable/internal/object/ObjectCacheKeyRegistry.js +126 -0
  81. package/build/browser/observable/internal/object/ObjectCacheKeyRegistry.js.map +1 -0
  82. package/build/browser/observable/internal/object/ObjectCacheKeyRegistry.test.js +173 -0
  83. package/build/browser/observable/internal/object/ObjectCacheKeyRegistry.test.js.map +1 -0
  84. package/build/browser/observable/internal/object/ObjectQuery.js +10 -58
  85. package/build/browser/observable/internal/object/ObjectQuery.js.map +1 -1
  86. package/build/browser/observable/internal/object/ObjectsHelper.js +65 -5
  87. package/build/browser/observable/internal/object/ObjectsHelper.js.map +1 -1
  88. package/build/browser/observable/internal/objectMatchesWhereClause.js +3 -37
  89. package/build/browser/observable/internal/objectMatchesWhereClause.js.map +1 -1
  90. package/build/browser/observable/internal/testUtils.js +3 -2
  91. package/build/browser/observable/internal/testUtils.js.map +1 -1
  92. package/build/browser/observable/internal/utils/rdpFieldOperations.js +83 -0
  93. package/build/browser/observable/internal/utils/rdpFieldOperations.js.map +1 -0
  94. package/build/browser/util/UserAgent.js +2 -2
  95. package/build/cjs/{chunk-X7WMWKLM.cjs → chunk-7567LSZD.cjs} +192 -55
  96. package/build/cjs/chunk-7567LSZD.cjs.map +1 -0
  97. package/build/cjs/{chunk-6L3MX4LH.cjs → chunk-VNLY3YOJ.cjs} +241 -196
  98. package/build/cjs/chunk-VNLY3YOJ.cjs.map +1 -0
  99. package/build/cjs/index.cjs +8 -8
  100. package/build/cjs/index.d.cts +1 -1
  101. package/build/cjs/public/internal.cjs +8 -8
  102. package/build/cjs/public/unstable-do-not-use.cjs +633 -208
  103. package/build/cjs/public/unstable-do-not-use.cjs.map +1 -1
  104. package/build/cjs/public/unstable-do-not-use.d.cts +6 -5
  105. package/build/esm/derivedProperties/createWithPropertiesObjectSet.js +2 -1
  106. package/build/esm/derivedProperties/createWithPropertiesObjectSet.js.map +1 -1
  107. package/build/esm/index.js.map +1 -1
  108. package/build/esm/internal/conversions/extractNamespace.js +22 -0
  109. package/build/esm/internal/conversions/extractNamespace.js.map +1 -0
  110. package/build/esm/internal/conversions/fullyQualifyPropName.js +26 -0
  111. package/build/esm/internal/conversions/fullyQualifyPropName.js.map +1 -0
  112. package/build/esm/internal/conversions/makeGeoFilterBbox.js +41 -0
  113. package/build/esm/internal/conversions/makeGeoFilterBbox.js.map +1 -0
  114. package/build/esm/internal/conversions/makeGeoFilterIntersects.js +29 -0
  115. package/build/esm/internal/conversions/makeGeoFilterIntersects.js.map +1 -0
  116. package/build/esm/internal/conversions/makeGeoFilterPolygon.js +30 -0
  117. package/build/esm/internal/conversions/makeGeoFilterPolygon.js.map +1 -0
  118. package/build/esm/internal/conversions/makeGeoFilterWithin.js +48 -0
  119. package/build/esm/internal/conversions/makeGeoFilterWithin.js.map +1 -0
  120. package/build/esm/internal/conversions/modernToLegacyWhereClause.js +30 -99
  121. package/build/esm/internal/conversions/modernToLegacyWhereClause.js.map +1 -1
  122. package/build/esm/internal/conversions/modernToLegacyWhereClause.test.js +139 -0
  123. package/build/esm/internal/conversions/modernToLegacyWhereClause.test.js.map +1 -1
  124. package/build/esm/object/convertWireToOsdkObjects/createOsdkInterface.js +1 -1
  125. package/build/esm/object/convertWireToOsdkObjects/createOsdkInterface.js.map +1 -1
  126. package/build/esm/object/fetchPage.js +1 -1
  127. package/build/esm/object/fetchPage.js.map +1 -1
  128. package/build/esm/object/formatting/applyPropertyFormatter.js +7 -1
  129. package/build/esm/object/formatting/applyPropertyFormatter.js.map +1 -1
  130. package/build/esm/object/formatting/applyPropertyFormatter.test.js +305 -2
  131. package/build/esm/object/formatting/applyPropertyFormatter.test.js.map +1 -1
  132. package/build/esm/object/formatting/formatDateTime.js +158 -0
  133. package/build/esm/object/formatting/formatDateTime.js.map +1 -0
  134. package/build/esm/objectSet/ObjectSetListenerWebsocket.js +17 -0
  135. package/build/esm/objectSet/ObjectSetListenerWebsocket.js.map +1 -1
  136. package/build/esm/observable/ObservableClient.js.map +1 -1
  137. package/build/esm/observable/internal/BulkObjectLoader.js +12 -4
  138. package/build/esm/observable/internal/BulkObjectLoader.js.map +1 -1
  139. package/build/esm/observable/internal/BulkObjectLoader.test.js +48 -0
  140. package/build/esm/observable/internal/BulkObjectLoader.test.js.map +1 -1
  141. package/build/esm/observable/internal/CacheKeys.js +9 -3
  142. package/build/esm/observable/internal/CacheKeys.js.map +1 -1
  143. package/build/esm/observable/internal/Canonicalizer.js +51 -0
  144. package/build/esm/observable/internal/Canonicalizer.js.map +1 -0
  145. package/build/esm/observable/internal/ObservableClientImpl.js.map +1 -1
  146. package/build/esm/observable/internal/OrderByCanonicalizer.js +1 -4
  147. package/build/esm/observable/internal/OrderByCanonicalizer.js.map +1 -1
  148. package/build/esm/observable/internal/RdpCanonicalizer.js +66 -0
  149. package/build/esm/observable/internal/RdpCanonicalizer.js.map +1 -0
  150. package/build/esm/observable/internal/RdpCanonicalizer.test.js +68 -0
  151. package/build/esm/observable/internal/RdpCanonicalizer.test.js.map +1 -0
  152. package/build/esm/observable/internal/SimpleWhereClause.js.map +1 -1
  153. package/build/esm/observable/internal/Store.js +160 -6
  154. package/build/esm/observable/internal/Store.js.map +1 -1
  155. package/build/esm/observable/internal/WhereClauseCanonicalizer.js +1 -1
  156. package/build/esm/observable/internal/WhereClauseCanonicalizer.js.map +1 -1
  157. package/build/esm/observable/internal/actions/ActionApplication.js +1 -1
  158. package/build/esm/observable/internal/actions/ActionApplication.js.map +1 -1
  159. package/build/esm/observable/internal/actions/OptimisticJob.js +3 -3
  160. package/build/esm/observable/internal/actions/OptimisticJob.js.map +1 -1
  161. package/build/esm/observable/internal/base-list/BaseListQuery.js +12 -3
  162. package/build/esm/observable/internal/base-list/BaseListQuery.js.map +1 -1
  163. package/build/esm/observable/internal/base-list/createCollectionConnectable.js +0 -5
  164. package/build/esm/observable/internal/base-list/createCollectionConnectable.js.map +1 -1
  165. package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js +26 -13
  166. package/build/esm/observable/internal/base-list/createCollectionConnectable.test.js.map +1 -1
  167. package/build/esm/observable/internal/evaluateFilter.js +61 -0
  168. package/build/esm/observable/internal/evaluateFilter.js.map +1 -0
  169. package/build/esm/observable/internal/links/SpecificLinkCacheKey.js +33 -1
  170. package/build/esm/observable/internal/links/SpecificLinkCacheKey.js.map +1 -1
  171. package/build/esm/observable/internal/list/InterfaceListQuery.js +8 -3
  172. package/build/esm/observable/internal/list/InterfaceListQuery.js.map +1 -1
  173. package/build/esm/observable/internal/list/ListCacheKey.js +22 -1
  174. package/build/esm/observable/internal/list/ListCacheKey.js.map +1 -1
  175. package/build/esm/observable/internal/list/ListQuery.js +19 -13
  176. package/build/esm/observable/internal/list/ListQuery.js.map +1 -1
  177. package/build/esm/observable/internal/list/ListsHelper.js +12 -8
  178. package/build/esm/observable/internal/list/ListsHelper.js.map +1 -1
  179. package/build/esm/observable/internal/list/ObjectListQuery.js +10 -1
  180. package/build/esm/observable/internal/list/ObjectListQuery.js.map +1 -1
  181. package/build/esm/observable/internal/object/ObjectCacheKey.js +20 -1
  182. package/build/esm/observable/internal/object/ObjectCacheKey.js.map +1 -1
  183. package/build/esm/observable/internal/object/ObjectCacheKeyRegistry.js +126 -0
  184. package/build/esm/observable/internal/object/ObjectCacheKeyRegistry.js.map +1 -0
  185. package/build/esm/observable/internal/object/ObjectCacheKeyRegistry.test.js +173 -0
  186. package/build/esm/observable/internal/object/ObjectCacheKeyRegistry.test.js.map +1 -0
  187. package/build/esm/observable/internal/object/ObjectQuery.js +10 -58
  188. package/build/esm/observable/internal/object/ObjectQuery.js.map +1 -1
  189. package/build/esm/observable/internal/object/ObjectsHelper.js +65 -5
  190. package/build/esm/observable/internal/object/ObjectsHelper.js.map +1 -1
  191. package/build/esm/observable/internal/objectMatchesWhereClause.js +3 -37
  192. package/build/esm/observable/internal/objectMatchesWhereClause.js.map +1 -1
  193. package/build/esm/observable/internal/testUtils.js +3 -2
  194. package/build/esm/observable/internal/testUtils.js.map +1 -1
  195. package/build/esm/observable/internal/utils/rdpFieldOperations.js +83 -0
  196. package/build/esm/observable/internal/utils/rdpFieldOperations.js.map +1 -0
  197. package/build/esm/util/UserAgent.js +2 -2
  198. package/build/types/index.d.ts +1 -1
  199. package/build/types/index.d.ts.map +1 -1
  200. package/build/types/internal/conversions/extractNamespace.d.ts +1 -0
  201. package/build/types/internal/conversions/extractNamespace.d.ts.map +1 -0
  202. package/build/types/internal/conversions/fullyQualifyPropName.d.ts +2 -0
  203. package/build/types/internal/conversions/fullyQualifyPropName.d.ts.map +1 -0
  204. package/build/types/internal/conversions/makeGeoFilterBbox.d.ts +3 -0
  205. package/build/types/internal/conversions/makeGeoFilterBbox.d.ts.map +1 -0
  206. package/build/types/internal/conversions/makeGeoFilterIntersects.d.ts +3 -0
  207. package/build/types/internal/conversions/makeGeoFilterIntersects.d.ts.map +1 -0
  208. package/build/types/internal/conversions/makeGeoFilterPolygon.d.ts +3 -0
  209. package/build/types/internal/conversions/makeGeoFilterPolygon.d.ts.map +1 -0
  210. package/build/types/internal/conversions/makeGeoFilterWithin.d.ts +3 -0
  211. package/build/types/internal/conversions/makeGeoFilterWithin.d.ts.map +1 -0
  212. package/build/types/internal/conversions/modernToLegacyWhereClause.d.ts +1 -1
  213. package/build/types/internal/conversions/modernToLegacyWhereClause.d.ts.map +1 -1
  214. package/build/types/object/formatting/applyPropertyFormatter.d.ts.map +1 -1
  215. package/build/types/object/formatting/formatDateTime.d.ts +6 -0
  216. package/build/types/object/formatting/formatDateTime.d.ts.map +1 -0
  217. package/build/types/observable/ObservableClient.d.ts +15 -5
  218. package/build/types/observable/ObservableClient.d.ts.map +1 -1
  219. package/build/types/observable/internal/BulkObjectLoader.d.ts.map +1 -1
  220. package/build/types/observable/internal/CacheKeys.d.ts.map +1 -1
  221. package/build/types/observable/internal/Canonicalizer.d.ts +37 -0
  222. package/build/types/observable/internal/Canonicalizer.d.ts.map +1 -0
  223. package/build/types/observable/internal/OrderByCanonicalizer.d.ts.map +1 -1
  224. package/build/types/observable/internal/RdpCanonicalizer.d.ts +8 -0
  225. package/build/types/observable/internal/RdpCanonicalizer.d.ts.map +1 -0
  226. package/build/types/observable/internal/RdpCanonicalizer.test.d.ts +1 -0
  227. package/build/types/observable/internal/RdpCanonicalizer.test.d.ts.map +1 -0
  228. package/build/types/observable/internal/SimpleWhereClause.d.ts +6 -2
  229. package/build/types/observable/internal/SimpleWhereClause.d.ts.map +1 -1
  230. package/build/types/observable/internal/Store.d.ts +4 -0
  231. package/build/types/observable/internal/Store.d.ts.map +1 -1
  232. package/build/types/observable/internal/WhereClauseCanonicalizer.d.ts +5 -2
  233. package/build/types/observable/internal/WhereClauseCanonicalizer.d.ts.map +1 -1
  234. package/build/types/observable/internal/actions/ActionApplication.d.ts.map +1 -1
  235. package/build/types/observable/internal/base-list/BaseListQuery.d.ts +6 -0
  236. package/build/types/observable/internal/base-list/BaseListQuery.d.ts.map +1 -1
  237. package/build/types/observable/internal/base-list/createCollectionConnectable.d.ts +1 -23
  238. package/build/types/observable/internal/base-list/createCollectionConnectable.d.ts.map +1 -1
  239. package/build/types/observable/internal/evaluateFilter.d.ts +6 -0
  240. package/build/types/observable/internal/evaluateFilter.d.ts.map +1 -0
  241. package/build/types/observable/internal/links/SpecificLinkCacheKey.d.ts +5 -0
  242. package/build/types/observable/internal/links/SpecificLinkCacheKey.d.ts.map +1 -1
  243. package/build/types/observable/internal/list/InterfaceListQuery.d.ts.map +1 -1
  244. package/build/types/observable/internal/list/ListCacheKey.d.ts +7 -1
  245. package/build/types/observable/internal/list/ListCacheKey.d.ts.map +1 -1
  246. package/build/types/observable/internal/list/ListQuery.d.ts +7 -7
  247. package/build/types/observable/internal/list/ListQuery.d.ts.map +1 -1
  248. package/build/types/observable/internal/list/ListsHelper.d.ts +3 -1
  249. package/build/types/observable/internal/list/ListsHelper.d.ts.map +1 -1
  250. package/build/types/observable/internal/list/ObjectListQuery.d.ts.map +1 -1
  251. package/build/types/observable/internal/object/ObjectCacheKey.d.ts +6 -1
  252. package/build/types/observable/internal/object/ObjectCacheKey.d.ts.map +1 -1
  253. package/build/types/observable/internal/object/ObjectCacheKeyRegistry.d.ts +60 -0
  254. package/build/types/observable/internal/object/ObjectCacheKeyRegistry.d.ts.map +1 -0
  255. package/build/types/observable/internal/object/ObjectCacheKeyRegistry.test.d.ts +1 -0
  256. package/build/types/observable/internal/object/ObjectCacheKeyRegistry.test.d.ts.map +1 -0
  257. package/build/types/observable/internal/object/ObjectQuery.d.ts +1 -1
  258. package/build/types/observable/internal/object/ObjectQuery.d.ts.map +1 -1
  259. package/build/types/observable/internal/object/ObjectsHelper.d.ts +15 -1
  260. package/build/types/observable/internal/object/ObjectsHelper.d.ts.map +1 -1
  261. package/build/types/observable/internal/objectMatchesWhereClause.d.ts.map +1 -1
  262. package/build/types/observable/internal/testUtils.d.ts.map +1 -1
  263. package/build/types/observable/internal/utils/rdpFieldOperations.d.ts +5 -0
  264. package/build/types/observable/internal/utils/rdpFieldOperations.d.ts.map +1 -0
  265. package/package.json +9 -9
  266. package/build/cjs/chunk-6L3MX4LH.cjs.map +0 -1
  267. package/build/cjs/chunk-X7WMWKLM.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"WhereClauseCanonicalizer.js","names":["Trie","deepEqual","invariant","WhereClauseCanonicalizer","cache","WeakMap","trie","existingOptions","Map","canonicalize","where","has","get","keysSet","Set","calculatedCanon","toCanon","cacheKey","lookupArray","Array","from","sort","lookupEntry","options","set","canon","find","ref","deref","push","WeakRef","#toCanon","process","env","NODE_ENV","isArray","$and","Object","keys","length","fromEntries","entries","a","b","localeCompare","map","k","v","add","x"],"sources":["WhereClauseCanonicalizer.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 { ObjectOrInterfaceDefinition, WhereClause } from \"@osdk/api\";\nimport { Trie } from \"@wry/trie\";\nimport deepEqual from \"fast-deep-equal\";\nimport invariant from \"tiny-invariant\";\nimport type { Canonical } from \"./Canonical.js\";\nimport type { SimpleWhereClause } from \"./SimpleWhereClause.js\";\n\nexport class WhereClauseCanonicalizer {\n /**\n * This is a shortcut cache for any WhereClause's that we have\n * seen and already canonicalized. The theory behind this\n * is that well behaving React applications will either `useMemo`\n * their where clause, or store it in state or pass it through as\n * props such that we are likely to get the same WhereClause\n * object multiple times and we can skip unnecessary work.\n */\n #cache = new WeakMap<\n WhereClause<any> | SimpleWhereClause,\n Canonical<SimpleWhereClause>\n >();\n\n /**\n * This is a trie that stores the sorted collapsed keys of a where clause to\n * the cache key for canonicalized options. In theory this keeps the number of\n * deepEqual comparisons down to a minimum but its probably overkill.\n */\n #trie = new Trie<object>();\n\n /**\n * This is a cache from the cacheKey provided by `this.#trie` to the potential\n * canonicalized options.\n */\n #existingOptions: Map<object, {\n options: WeakRef<Canonical<SimpleWhereClause>>[];\n }> = new Map();\n\n public canonicalize<T extends ObjectOrInterfaceDefinition>(\n where: WhereClause<T> | SimpleWhereClause,\n ): Canonical<SimpleWhereClause> {\n // fastest shortcut\n if (this.#cache.has(where)) {\n return this.#cache.get(where)!;\n }\n\n const keysSet = new Set<string>();\n const calculatedCanon = this.#toCanon(where, keysSet);\n const cacheKey = this.#trie.lookupArray(Array.from(keysSet).sort());\n const lookupEntry = this.#existingOptions.get(cacheKey)\n ?? { options: [] as WeakRef<Canonical<SimpleWhereClause>>[] };\n this.#existingOptions.set(cacheKey, lookupEntry);\n\n const canon =\n lookupEntry.options.find((ref) => deepEqual(ref.deref(), calculatedCanon))\n ?.deref()\n ?? calculatedCanon;\n\n if (canon === calculatedCanon) {\n // This means no existing options were found\n lookupEntry.options.push(new WeakRef(canon));\n }\n\n this.#cache.set(where, canon);\n return canon;\n }\n\n #toCanon = <T extends ObjectOrInterfaceDefinition>(\n where: WhereClause<T> | SimpleWhereClause,\n set: Set<string> = new Set<string>(),\n ): Canonical<SimpleWhereClause> => {\n if (\"$and\" in where) {\n if (process.env.NODE_ENV !== \"production\") {\n invariant(Array.isArray(where.$and), \"expected $and to be an array\");\n invariant(\n Object.keys(where).length === 1,\n \"expected only $and to be present\",\n );\n }\n if ((where as { $and: SimpleWhereClause[] }).$and.length === 0) {\n // empty $and is a no-op\n return {} as Canonical<SimpleWhereClause>;\n }\n if ((where as { $and: SimpleWhereClause[] }).$and.length === 1) {\n return this.#toCanon(\n (where as { $and: SimpleWhereClause[] }).$and[0],\n set,\n );\n }\n }\n // This is incomplete for all the cases possible but it gets us started\n\n return Object.fromEntries(\n Object.entries(where)\n .sort(([a], [b]) => a.localeCompare(b))\n .map(([k, v]) => {\n set.add(k);\n if (k === \"$and\" || k === \"$or\") {\n return [k, (v as Array<any>).map(x => this.#toCanon(x, set))];\n }\n if (k !== \"$not\" && typeof v === \"object\" && \"$eq\" in v) {\n return [k, v[\"$eq\"]];\n }\n return [k, v];\n }),\n ) as Canonical<SimpleWhereClause>;\n };\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"WhereClauseCanonicalizer.js","names":["Trie","deepEqual","invariant","WhereClauseCanonicalizer","cache","WeakMap","trie","existingOptions","Map","canonicalize","where","has","get","keysSet","Set","calculatedCanon","toCanon","cacheKey","lookupArray","Array","from","sort","lookupEntry","options","set","canon","find","ref","deref","push","WeakRef","#toCanon","process","env","NODE_ENV","isArray","$and","Object","keys","length","fromEntries","entries","a","b","localeCompare","map","k","v","add","x"],"sources":["WhereClauseCanonicalizer.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 ObjectOrInterfaceDefinition,\n SimplePropertyDef,\n WhereClause,\n} from \"@osdk/api\";\nimport { Trie } from \"@wry/trie\";\nimport deepEqual from \"fast-deep-equal\";\nimport invariant from \"tiny-invariant\";\nimport type { Canonical } from \"./Canonical.js\";\nimport type { SimpleWhereClause } from \"./SimpleWhereClause.js\";\n\nexport class WhereClauseCanonicalizer {\n /**\n * This is a shortcut cache for any WhereClause's that we have\n * seen and already canonicalized. The theory behind this\n * is that well behaving React applications will either `useMemo`\n * their where clause, or store it in state or pass it through as\n * props such that we are likely to get the same WhereClause\n * object multiple times and we can skip unnecessary work.\n */\n #cache = new WeakMap<\n | WhereClause<\n ObjectOrInterfaceDefinition,\n Record<string, SimplePropertyDef>\n >\n | SimpleWhereClause,\n Canonical<SimpleWhereClause>\n >();\n\n /**\n * This is a trie that stores the sorted collapsed keys of a where clause to\n * the cache key for canonicalized options. In theory this keeps the number of\n * deepEqual comparisons down to a minimum but its probably overkill.\n */\n #trie = new Trie<object>();\n\n /**\n * This is a cache from the cacheKey provided by `this.#trie` to the potential\n * canonicalized options.\n */\n #existingOptions: Map<object, {\n options: WeakRef<Canonical<SimpleWhereClause>>[];\n }> = new Map();\n\n public canonicalize<\n T extends ObjectOrInterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n where: WhereClause<T, RDPs> | SimpleWhereClause,\n ): Canonical<SimpleWhereClause> {\n // fastest shortcut\n if (this.#cache.has(where)) {\n return this.#cache.get(where)!;\n }\n\n const keysSet = new Set<string>();\n const calculatedCanon = this.#toCanon(where, keysSet);\n const cacheKey = this.#trie.lookupArray(Array.from(keysSet).sort());\n const lookupEntry = this.#existingOptions.get(cacheKey)\n ?? { options: [] as WeakRef<Canonical<SimpleWhereClause>>[] };\n this.#existingOptions.set(cacheKey, lookupEntry);\n\n const canon =\n lookupEntry.options.find((ref) => deepEqual(ref.deref(), calculatedCanon))\n ?.deref()\n ?? calculatedCanon;\n\n if (canon === calculatedCanon) {\n // This means no existing options were found\n lookupEntry.options.push(new WeakRef(canon));\n }\n\n this.#cache.set(where, canon);\n return canon;\n }\n\n #toCanon = <\n T extends ObjectOrInterfaceDefinition,\n RDPs extends Record<string, SimplePropertyDef> = {},\n >(\n where: WhereClause<T, RDPs> | SimpleWhereClause,\n set: Set<string> = new Set<string>(),\n ): Canonical<SimpleWhereClause> => {\n if (\"$and\" in where) {\n if (process.env.NODE_ENV !== \"production\") {\n invariant(Array.isArray(where.$and), \"expected $and to be an array\");\n invariant(\n Object.keys(where).length === 1,\n \"expected only $and to be present\",\n );\n }\n if ((where as { $and: SimpleWhereClause[] }).$and.length === 0) {\n // empty $and is a no-op\n return {} as Canonical<SimpleWhereClause>;\n }\n if ((where as { $and: SimpleWhereClause[] }).$and.length === 1) {\n return this.#toCanon(\n (where as { $and: SimpleWhereClause[] }).$and[0],\n set,\n );\n }\n }\n // This is incomplete for all the cases possible but it gets us started\n\n return Object.fromEntries(\n Object.entries(where)\n .sort(([a], [b]) => a.localeCompare(b))\n .map(([k, v]) => {\n set.add(k);\n if (k === \"$and\" || k === \"$or\") {\n return [k, (v as Array<any>).map(x => this.#toCanon(x, set))];\n }\n if (\n k !== \"$not\" && typeof v === \"object\" && v != null && \"$eq\" in v\n ) {\n return [k, v[\"$eq\"]];\n }\n return [k, v];\n }),\n ) as Canonical<SimpleWhereClause>;\n };\n}\n"],"mappings":"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","ignoreList":[]}
@@ -86,7 +86,7 @@ export class ActionApplication {
86
86
  objectType,
87
87
  primaryKey
88
88
  } of deletedObjects ?? []) {
89
- const cacheKey = this.store.cacheKeys.get("object", objectType, primaryKey);
89
+ const cacheKey = this.store.cacheKeys.get("object", objectType, primaryKey, /* rdpConfig */undefined);
90
90
  this.store.queries.peek(cacheKey)?.deleteFromStore("loaded",
91
91
  // this is probably not the best value to use
92
92
  batch);
@@ -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","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":[]}
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","undefined","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 /* rdpConfig */ undefined,\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":[]}
@@ -44,7 +44,7 @@ export class OptimisticJob {
44
44
  store.objects.getQuery({
45
45
  apiName: obj.value.$objectType,
46
46
  pk: obj.value.$primaryKey
47
- }).writeToStore(obj.value, "loading", batch);
47
+ }, undefined).writeToStore(obj.value, "loading", batch);
48
48
  } else {
49
49
  // TODO FIXME
50
50
  throw obj;
@@ -54,13 +54,13 @@ export class OptimisticJob {
54
54
  store.objects.getQuery({
55
55
  apiName: obj.$objectType,
56
56
  pk: obj.$primaryKey
57
- }).writeToStore(obj, "loading", batch);
57
+ }, undefined).writeToStore(obj, "loading", batch);
58
58
  }
59
59
  for (const obj of deletedObjects) {
60
60
  store.objects.getQuery({
61
61
  apiName: obj.$objectType,
62
62
  pk: obj.$primaryKey
63
- }).deleteFromStore("loading", batch);
63
+ }, undefined).deleteFromStore("loading", batch);
64
64
  }
65
65
  });
66
66
  return batchResult.changes;
@@ -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","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":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,iBAAiB,QAAQ,oBAAoB;AAItD,SAASC,kBAAkB,QAA2B,oBAAoB;AAG1E,OAAO,MAAMC,aAAa,CAAC;EAGzB,CAACC,MAAM;EAEPC,WAAWA,CAACC,KAAY,EAAEC,YAA0B,EAAE;IACpD,MAAMC,cAEL,GAAG,EAAE;;IAEN;IACA;IACA;IACA,MAAMC,mBAEL,GAAG,EAAE;IAEN,MAAMC,cAAmC,GAAG,EAAE;;IAE9C;IACA;;IAEA;IACA,IAAI,CAACC,SAAS,GAAG,MAAM;MACrB,OAAO,IAAI,CAAC,CAACP,MAAM,KAAK,CAAC,YAAY;QACnC,MAAMQ,YAAY,GAAG,MAAMC,OAAO,CAACC,UAAU,CAC3CL,mBACF,CAAC;QAED,MAAM;UAAEM;QAAY,CAAC,GAAGT,KAAK,CAACU,KAAK,CAAC;UAAET;QAAa,CAAC,EAAGS,KAAK,IAAK;UAC/D,KAAK,MAAMC,GAAG,IAAIL,YAAY,EAAE;YAC9B,IAAIK,GAAG,CAACC,MAAM,KAAK,WAAW,EAAE;cAC9BZ,KAAK,CAACa,OAAO,CAACC,QAAQ,CAAC;gBACrBC,OAAO,EAAEJ,GAAG,CAACK,KAAK,CAACC,WAAW;gBAC9BC,EAAE,EAAEP,GAAG,CAACK,KAAK,CAACG;cAChB,CAAC,CAAC,CAACC,YAAY,CAACT,GAAG,CAACK,KAAK,EAAE,SAAS,EAAEN,KAAK,CAAC;YAC9C,CAAC,MAAM;cACL;cACA,MAAMC,GAAG;YACX;UACF;UAEA,KAAK,MAAMA,GAAG,IAAIT,cAAc,EAAE;YAChCF,KAAK,CAACa,OAAO,CAACC,QAAQ,CAAC;cACrBC,OAAO,EAAEJ,GAAG,CAACM,WAAW;cACxBC,EAAE,EAAEP,GAAG,CAACQ;YACV,CAAC,CAAC,CAACC,YAAY,CAACT,GAAG,EAAE,SAAS,EAAED,KAAK,CAAC;UACxC;UAEA,KAAK,MAAMC,GAAG,IAAIP,cAAc,EAAE;YAChCJ,KAAK,CAACa,OAAO,CAACC,QAAQ,CAAC;cACrBC,OAAO,EAAEJ,GAAG,CAACM,WAAW;cACxBC,EAAE,EAAEP,GAAG,CAACQ;YACV,CAAC,CAAC,CAACE,eAAe,CAAC,SAAS,EAAEX,KAAK,CAAC;UACtC;QACF,CAAC,CAAC;QAEF,OAAOD,WAAW,CAACa,OAAO;MAC5B,CAAC,EAAE,CAAC;IACN,CAAC;IAED,IAAI,CAACC,OAAO,GAAG;MACbC,YAAYA,CAACR,KAAK,EAAE;QAClBd,cAAc,CAACuB,IAAI,CAACT,KAA8C,CAAC;QACnE,OAAO,IAAI;MACb,CAAC;MACDU,YAAYA,CAACC,IAAI,EAAET,EAAE,EAAEU,UAAU,EAAE;QACjC,MAAMC,MAAM,GAAG7B,KAAK,CAAC8B,MAAM,CAACnC,iBAAiB,CAAC,CAACoC,cAAc,CAC3D/B,KAAK,CAAC8B,MAAM,CAACnC,iBAAiB,CAAC,EAC/B,CAAC;UACCwB,WAAW,EAAED,EAAE;UACfc,QAAQ,EAAEL,IAAI,CAACZ,OAAO;UACtBE,WAAW,EAAEU,IAAI,CAACZ,OAAO;UACzB,GAAGa;QACL,CAAC,CAAC,EACFK,SAAS,EACT,CAAC,CACH,CAAC,CAACC,IAAI,CAACC,IAAI,IAAI;UACb,OAAOA,IAAI,CAAC,CAAC,CAAC;QAChB,CAAC,CAAC;QAEFhC,mBAAmB,CAACsB,IAAI,CAACI,MAAM,CAAC;QAChC,OAAO,IAAI;MACb,CAAC;MACDO,YAAYA,CAACpB,KAAK,EAAE;QAClBZ,cAAc,CAACqB,IAAI,CAACT,KAA8C,CAAC;QACnE,OAAO,IAAI;MACb;IACF,CAAC;EACH;AACF;AAEA,OAAO,SAASqB,gBAAgBA,CAC9BrC,KAAY,EACZsC,gBAAgE,EAC3C;EACrB,IAAI,CAACA,gBAAgB,EAAE;IACrB,OAAO,MAAM/B,OAAO,CAACgC,OAAO,CAAC,CAAC;EAChC;EAEA,MAAMtC,YAAY,GAAGL,kBAAkB,CAAC,CAAC;EACzC,MAAM4C,GAAG,GAAG,IAAI3C,aAAa,CAACG,KAAK,EAAEC,YAAY,CAAC;EAClDqC,gBAAgB,CAACE,GAAG,CAACjB,OAAO,CAAC;EAC7B,MAAMkB,yBAAyB,GAAGD,GAAG,CAACnC,SAAS,CAAC,CAAC;EAEjD,OAAO,MAAM;IACX,OAAOoC,yBAAyB,CAACP,IAAI;IACnC;IACA,MAAMD,SACR,CAAC,CAACS,OAAO,CAAC,MAAM;MACd1C,KAAK,CAAC2C,MAAM,CAACC,MAAM,CAAC3C,YAAY,CAAC;IACnC,CAAC,CAAC;EACJ,CAAC;AACH","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","undefined","writeToStore","deleteFromStore","changes","context","updateObject","push","createObject","type","properties","create","client","objectFactory2","$apiName","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 }, undefined).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 }, undefined).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 }, undefined).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":[]}
@@ -17,6 +17,7 @@
17
17
  import deepEqual from "fast-deep-equal";
18
18
  import { DEBUG_ONLY__cacheKeysToString } from "../CacheKey.js";
19
19
  import { isObjectInstance } from "../isObjectInstance.js";
20
+ import { RDP_IDX } from "../list/ListCacheKey.js";
20
21
  import { Query } from "../Query.js";
21
22
  import { NoOpSortingStrategy } from "../sorting/SortingStrategy.js";
22
23
  import { createCollectionConnectable } from "./createCollectionConnectable.js";
@@ -33,6 +34,13 @@ export class BaseListQuery extends Query {
33
34
  */
34
35
  sortingStrategy = new NoOpSortingStrategy();
35
36
 
37
+ /**
38
+ * Get RDP configuration from the cache key
39
+ */
40
+ get rdpConfig() {
41
+ return this.cacheKey.otherKeys[RDP_IDX];
42
+ }
43
+
36
44
  // Collection-specific behavior is implemented by subclasses
37
45
  /**
38
46
  * Token for the next page of results
@@ -69,7 +77,7 @@ export class BaseListQuery extends Query {
69
77
  objectCacheKeys = [];
70
78
  } else if (isObjectInstance(items[0])) {
71
79
  // Items are object instances, need to store them first
72
- objectCacheKeys = this.store.objects.storeOsdkInstances(items, batch);
80
+ objectCacheKeys = this.store.objects.storeOsdkInstances(items, batch, this.rdpConfig);
73
81
  } else {
74
82
  // Items are already cache keys
75
83
  objectCacheKeys = items;
@@ -304,7 +312,8 @@ export class BaseListQuery extends Query {
304
312
  } = this.store.batch({}, batch => {
305
313
  const append = this.nextPageToken != null;
306
314
  const finalStatus = result.nextPageToken ? status : "loaded";
307
- return this._updateList(this.store.objects.storeOsdkInstances(result.data, batch), finalStatus, batch, append);
315
+ const objectKeys = this.store.objects.storeOsdkInstances(result.data, batch, this.rdpConfig);
316
+ return this._updateList(objectKeys, finalStatus, batch, append);
308
317
  });
309
318
  return retVal;
310
319
  } catch (error) {
@@ -387,7 +396,7 @@ export class BaseListQuery extends Query {
387
396
  objectCacheKeys = [];
388
397
  } else if (isObjectInstance(items[0])) {
389
398
  // Items are object instances, need to store them first
390
- objectCacheKeys = this.store.objects.storeOsdkInstances(items, batch);
399
+ objectCacheKeys = this.store.objects.storeOsdkInstances(items, batch, this.rdpConfig);
391
400
  } else {
392
401
  // Items are already cache keys
393
402
  objectCacheKeys = items;
@@ -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","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":[]}
1
+ {"version":3,"file":"BaseListQuery.js","names":["deepEqual","DEBUG_ONLY__cacheKeysToString","isObjectInstance","RDP_IDX","Query","NoOpSortingStrategy","createCollectionConnectable","removeDuplicates","BaseListQuery","sortingStrategy","rdpConfig","cacheKey","otherKeys","_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","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","objectKeys","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 type { Canonical } from \"../Canonical.js\";\nimport { isObjectInstance } from \"../isObjectInstance.js\";\nimport type { Entry } from \"../Layer.js\";\nimport { RDP_IDX } from \"../list/ListCacheKey.js\";\nimport { type ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport { Query } from \"../Query.js\";\nimport type { Rdp } from \"../RdpCanonicalizer.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 /**\n * Get RDP configuration from the cache key\n */\n public get rdpConfig(): Canonical<Rdp> | null {\n return this.cacheKey.otherKeys[RDP_IDX];\n }\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 this.rdpConfig,\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 const objectKeys = this.store.objects.storeOsdkInstances(\n result.data,\n batch,\n this.rdpConfig,\n );\n\n return this._updateList(\n objectKeys,\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 this.rdpConfig,\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":[]}
@@ -15,11 +15,6 @@
15
15
  */
16
16
 
17
17
  import { asapScheduler, combineLatest, connectable, distinctUntilChanged, map, of, ReplaySubject, scheduled, switchMap } from "rxjs";
18
-
19
- /**
20
- * Common parameters available for constructing a collection payload
21
- */
22
-
23
18
  /**
24
19
  * Creates a connectable observable for a collection of objects
25
20
  *
@@ -1 +1 @@
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":[]}
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 { CacheKey } from \"../CacheKey.js\";\nimport type { ObjectCacheKey } from \"../object/ObjectCacheKey.js\";\nimport type { SubjectPayload } from \"../SubjectPayload.js\";\nimport type { Subjects } from \"../Subjects.js\";\nimport type { CollectionConnectableParams } from \"./BaseCollectionQuery.js\";\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;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":[]}
@@ -78,11 +78,13 @@ describe("createCollectionConnectable", () => {
78
78
  // Mock object cache keys
79
79
  const objectKey1 = {
80
80
  type: "object",
81
- otherKeys: ["Employee", 1]
81
+ otherKeys: ["Employee", 1, undefined],
82
+ __cacheKey: {}
82
83
  };
83
84
  const objectKey2 = {
84
85
  type: "object",
85
- otherKeys: ["Employee", 2]
86
+ otherKeys: ["Employee", 2, undefined],
87
+ __cacheKey: {}
86
88
  };
87
89
 
88
90
  // Create subject payload with mock data
@@ -191,7 +193,8 @@ describe("createCollectionConnectable", () => {
191
193
  it("should propagate optimistic flag correctly", async () => {
192
194
  const objectKey1 = {
193
195
  type: "object",
194
- otherKeys: ["Employee", 1]
196
+ otherKeys: ["Employee", 1, undefined],
197
+ __cacheKey: {}
195
198
  };
196
199
  const subjectPayload = {
197
200
  cacheKey: mockListCacheKey,
@@ -229,7 +232,8 @@ describe("createCollectionConnectable", () => {
229
232
  it("should handle different status values", async () => {
230
233
  const objectKey1 = {
231
234
  type: "object",
232
- otherKeys: ["Employee", 1]
235
+ otherKeys: ["Employee", 1, undefined],
236
+ __cacheKey: {}
233
237
  };
234
238
  const basePayload = {
235
239
  cacheKey: mockListCacheKey,
@@ -283,15 +287,18 @@ describe("createCollectionConnectable", () => {
283
287
  it("should handle multiple objects in collection", async () => {
284
288
  const objectKey1 = {
285
289
  type: "object",
286
- otherKeys: ["Employee", 1]
290
+ otherKeys: ["Employee", 1, undefined],
291
+ __cacheKey: {}
287
292
  };
288
293
  const objectKey2 = {
289
294
  type: "object",
290
- otherKeys: ["Employee", 2]
295
+ otherKeys: ["Employee", 2, undefined],
296
+ __cacheKey: {}
291
297
  };
292
298
  const objectKey3 = {
293
299
  type: "object",
294
- otherKeys: ["Employee", 3]
300
+ otherKeys: ["Employee", 3, undefined],
301
+ __cacheKey: {}
295
302
  };
296
303
  const subjectPayload = {
297
304
  cacheKey: mockListCacheKey,
@@ -351,11 +358,13 @@ describe("createCollectionConnectable", () => {
351
358
  it("should handle objects being added/removed from collection", async () => {
352
359
  const objectKey1 = {
353
360
  type: "object",
354
- otherKeys: ["Employee", 1]
361
+ otherKeys: ["Employee", 1, undefined],
362
+ __cacheKey: {}
355
363
  };
356
364
  const objectKey2 = {
357
365
  type: "object",
358
- otherKeys: ["Employee", 2]
366
+ otherKeys: ["Employee", 2, undefined],
367
+ __cacheKey: {}
359
368
  };
360
369
 
361
370
  // Start with one object
@@ -425,7 +434,8 @@ describe("createCollectionConnectable", () => {
425
434
  it("should support multiple subscribers", async () => {
426
435
  const objectKey1 = {
427
436
  type: "object",
428
- otherKeys: ["Employee", 1]
437
+ otherKeys: ["Employee", 1, undefined],
438
+ __cacheKey: {}
429
439
  };
430
440
  const subjectPayload = {
431
441
  cacheKey: mockListCacheKey,
@@ -467,7 +477,8 @@ describe("createCollectionConnectable", () => {
467
477
  it("should use ReplaySubject behavior (last value replayed)", async () => {
468
478
  const objectKey1 = {
469
479
  type: "object",
470
- otherKeys: ["Employee", 1]
480
+ otherKeys: ["Employee", 1, undefined],
481
+ __cacheKey: {}
471
482
  };
472
483
  const subjectPayload = {
473
484
  cacheKey: mockListCacheKey,
@@ -516,7 +527,8 @@ describe("createCollectionConnectable", () => {
516
527
  it("should handle store.getSubject returning undefined object entry", async () => {
517
528
  const objectKey1 = {
518
529
  type: "object",
519
- otherKeys: ["Employee", 1]
530
+ otherKeys: ["Employee", 1, undefined],
531
+ __cacheKey: {}
520
532
  };
521
533
  const subjectPayload = {
522
534
  cacheKey: mockListCacheKey,
@@ -556,7 +568,8 @@ describe("createCollectionConnectable", () => {
556
568
  it("should handle createPayload function throwing errors", async () => {
557
569
  const objectKey1 = {
558
570
  type: "object",
559
- otherKeys: ["Employee", 1]
571
+ otherKeys: ["Employee", 1, undefined],
572
+ __cacheKey: {}
560
573
  };
561
574
  const subjectPayload = {
562
575
  cacheKey: mockListCacheKey,