@osdk/react-devtools 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (443) hide show
  1. package/CHANGELOG.md +79 -0
  2. package/build/esm/DevToolsContext.js +19 -0
  3. package/build/esm/DevToolsContext.js.map +1 -0
  4. package/build/esm/components/ActionMetrics.js +89 -0
  5. package/build/esm/components/ActionMetrics.js.map +1 -0
  6. package/build/esm/components/BubbleChart.js +175 -0
  7. package/build/esm/components/BubbleChart.js.map +1 -0
  8. package/build/esm/components/BubbleChart.module.scss.js +6 -0
  9. package/build/esm/components/CacheInspectorTab.js +291 -0
  10. package/build/esm/components/CacheInspectorTab.js.map +1 -0
  11. package/build/esm/components/CacheInspectorTab.module.scss.js +39 -0
  12. package/build/esm/components/CacheMetrics.js +55 -0
  13. package/build/esm/components/CacheMetrics.js.map +1 -0
  14. package/build/esm/components/ComponentCard.js +124 -0
  15. package/build/esm/components/ComponentCard.js.map +1 -0
  16. package/build/esm/components/ComponentCard.module.scss.js +31 -0
  17. package/build/esm/components/ComputeTab.js +175 -0
  18. package/build/esm/components/ComputeTab.js.map +1 -0
  19. package/build/esm/components/CopyableCodeBlock.js +49 -0
  20. package/build/esm/components/CopyableCodeBlock.js.map +1 -0
  21. package/build/esm/components/CopyableCodeBlock.module.scss.js +10 -0
  22. package/build/esm/components/DebuggingTab.js +342 -0
  23. package/build/esm/components/DebuggingTab.js.map +1 -0
  24. package/build/esm/components/DebuggingTab.module.scss.js +18 -0
  25. package/build/esm/components/HookRow.js +180 -0
  26. package/build/esm/components/HookRow.js.map +1 -0
  27. package/build/esm/components/HookRow.module.scss.js +16 -0
  28. package/build/esm/components/ImprovementsTab.js +138 -0
  29. package/build/esm/components/ImprovementsTab.js.map +1 -0
  30. package/build/esm/components/ImprovementsTab.module.scss.js +30 -0
  31. package/build/esm/components/InspectorSelectionHeader.js +65 -0
  32. package/build/esm/components/InspectorSelectionHeader.js.map +1 -0
  33. package/build/esm/components/InterceptTab.js +862 -0
  34. package/build/esm/components/InterceptTab.js.map +1 -0
  35. package/build/esm/components/InterceptTab.module.scss.js +49 -0
  36. package/build/esm/components/IssueCard.js +115 -0
  37. package/build/esm/components/IssueCard.js.map +1 -0
  38. package/build/esm/components/IssueCard.module.scss.js +24 -0
  39. package/build/esm/components/LogEntryCard.js +94 -0
  40. package/build/esm/components/LogEntryCard.js.map +1 -0
  41. package/build/esm/components/LogEntryCard.module.scss.js +19 -0
  42. package/build/esm/components/MockEditor.js +316 -0
  43. package/build/esm/components/MockEditor.js.map +1 -0
  44. package/build/esm/components/MonitorErrorBoundary.js +64 -0
  45. package/build/esm/components/MonitorErrorBoundary.js.map +1 -0
  46. package/build/esm/components/MonitorErrorBoundary.module.scss.js +9 -0
  47. package/build/esm/components/MonitoringPanel.js +434 -0
  48. package/build/esm/components/MonitoringPanel.js.map +1 -0
  49. package/build/esm/components/MonitoringPanel.module.scss.js +81 -0
  50. package/build/esm/components/ObjectLoadingMetrics.js +60 -0
  51. package/build/esm/components/ObjectLoadingMetrics.js.map +1 -0
  52. package/build/esm/components/OsdkAppErrorBoundary.js +68 -0
  53. package/build/esm/components/OsdkAppErrorBoundary.js.map +1 -0
  54. package/build/esm/components/OsdkDevTools.js +40 -0
  55. package/build/esm/components/OsdkDevTools.js.map +1 -0
  56. package/build/esm/components/OverrideEditor.js +197 -0
  57. package/build/esm/components/OverrideEditor.js.map +1 -0
  58. package/build/esm/components/PerformanceTab.js +297 -0
  59. package/build/esm/components/PerformanceTab.js.map +1 -0
  60. package/build/esm/components/PrimitiveSelectionPanel.js +220 -0
  61. package/build/esm/components/PrimitiveSelectionPanel.js.map +1 -0
  62. package/build/esm/components/PrimitiveSelectionPanel.module.scss.js +26 -0
  63. package/build/esm/components/issueTypes.js +2 -0
  64. package/build/esm/components/issueTypes.js.map +1 -0
  65. package/build/esm/components/resolveComponentName.js +57 -0
  66. package/build/esm/components/resolveComponentName.js.map +1 -0
  67. package/build/esm/components/testHelpers.js +312 -0
  68. package/build/esm/components/testHelpers.js.map +1 -0
  69. package/build/esm/css.d.ts +20 -0
  70. package/build/esm/fiber/DegradationNotice.js +193 -0
  71. package/build/esm/fiber/DegradationNotice.js.map +1 -0
  72. package/build/esm/fiber/DevtoolsHook.js +252 -0
  73. package/build/esm/fiber/DevtoolsHook.js.map +1 -0
  74. package/build/esm/fiber/FiberAccess.js +65 -0
  75. package/build/esm/fiber/FiberAccess.js.map +1 -0
  76. package/build/esm/fiber/FiberInspection.js +140 -0
  77. package/build/esm/fiber/FiberInspection.js.map +1 -0
  78. package/build/esm/fiber/FiberTags.js +52 -0
  79. package/build/esm/fiber/FiberTags.js.map +1 -0
  80. package/build/esm/fiber/HookStateInspector.js +254 -0
  81. package/build/esm/fiber/HookStateInspector.js.map +1 -0
  82. package/build/esm/fiber/SafeFiberOperation.js +35 -0
  83. package/build/esm/fiber/SafeFiberOperation.js.map +1 -0
  84. package/build/esm/fiber/capabilities.js +180 -0
  85. package/build/esm/fiber/capabilities.js.map +1 -0
  86. package/build/esm/fiber/traverseFiber.js +129 -0
  87. package/build/esm/fiber/traverseFiber.js.map +1 -0
  88. package/build/esm/fiber/types.js +2 -0
  89. package/build/esm/fiber/types.js.map +1 -0
  90. package/build/esm/fiber/validation.js +155 -0
  91. package/build/esm/fiber/validation.js.map +1 -0
  92. package/build/esm/hooks/createPollingStore.js +81 -0
  93. package/build/esm/hooks/createPollingStore.js.map +1 -0
  94. package/build/esm/hooks/useActiveComponents.js +27 -0
  95. package/build/esm/hooks/useActiveComponents.js.map +1 -0
  96. package/build/esm/hooks/useComponentRegistry.js +25 -0
  97. package/build/esm/hooks/useComponentRegistry.js.map +1 -0
  98. package/build/esm/hooks/useComputeSelectors.js +43 -0
  99. package/build/esm/hooks/useComputeSelectors.js.map +1 -0
  100. package/build/esm/hooks/useConsoleLogs.js +46 -0
  101. package/build/esm/hooks/useConsoleLogs.js.map +1 -0
  102. package/build/esm/hooks/useInspectorSelection.js +93 -0
  103. package/build/esm/hooks/useInspectorSelection.js.map +1 -0
  104. package/build/esm/hooks/useMetrics.js +23 -0
  105. package/build/esm/hooks/useMetrics.js.map +1 -0
  106. package/build/esm/hooks/usePersistedState.js +89 -0
  107. package/build/esm/hooks/usePersistedState.js.map +1 -0
  108. package/build/esm/hooks/useRecommendations.js +123 -0
  109. package/build/esm/hooks/useRecommendations.js.map +1 -0
  110. package/build/esm/hooks/useSharedTick.js +49 -0
  111. package/build/esm/hooks/useSharedTick.js.map +1 -0
  112. package/build/esm/hooks/useTimeElapsed.js +51 -0
  113. package/build/esm/hooks/useTimeElapsed.js.map +1 -0
  114. package/build/esm/hooks/useTrackerSubscription.js +97 -0
  115. package/build/esm/hooks/useTrackerSubscription.js.map +1 -0
  116. package/build/esm/hooks/useUnusedFieldAnalysis.js +99 -0
  117. package/build/esm/hooks/useUnusedFieldAnalysis.js.map +1 -0
  118. package/build/esm/index.js +31 -0
  119. package/build/esm/index.js.map +1 -0
  120. package/build/esm/inspector/ClickToInspectSystem.js +228 -0
  121. package/build/esm/inspector/ClickToInspectSystem.js.map +1 -0
  122. package/build/esm/inspector/components/ComponentLabel.js +175 -0
  123. package/build/esm/inspector/components/ComponentLabel.js.map +1 -0
  124. package/build/esm/inspector/components/ComponentLabel.module.scss.js +12 -0
  125. package/build/esm/inspector/components/InspectorBanner.js +79 -0
  126. package/build/esm/inspector/components/InspectorBanner.js.map +1 -0
  127. package/build/esm/inspector/components/InspectorOverlay.js +149 -0
  128. package/build/esm/inspector/components/InspectorOverlay.js.map +1 -0
  129. package/build/esm/inspector/components/SelectionHighlight.js +74 -0
  130. package/build/esm/inspector/components/SelectionHighlight.js.map +1 -0
  131. package/build/esm/inspector/createClickToInspect.js +21 -0
  132. package/build/esm/inspector/createClickToInspect.js.map +1 -0
  133. package/build/esm/inspector/hooks/useAnimatedBounds.js +167 -0
  134. package/build/esm/inspector/hooks/useAnimatedBounds.js.map +1 -0
  135. package/build/esm/inspector/index.js +40 -0
  136. package/build/esm/inspector/index.js.map +1 -0
  137. package/build/esm/inspector/inspectorController.js +328 -0
  138. package/build/esm/inspector/inspectorController.js.map +1 -0
  139. package/build/esm/inspector/types.js +2 -0
  140. package/build/esm/inspector/types.js.map +1 -0
  141. package/build/esm/inspector/utils/elementBounds.js +72 -0
  142. package/build/esm/inspector/utils/elementBounds.js.map +1 -0
  143. package/build/esm/inspector/utils/interpolation.js +26 -0
  144. package/build/esm/inspector/utils/interpolation.js.map +1 -0
  145. package/build/esm/inspector/utils/labelPositioning.js +62 -0
  146. package/build/esm/inspector/utils/labelPositioning.js.map +1 -0
  147. package/build/esm/mocking/MockCacheKeyGenerator.js +109 -0
  148. package/build/esm/mocking/MockCacheKeyGenerator.js.map +1 -0
  149. package/build/esm/mocking/MockManager.js +281 -0
  150. package/build/esm/mocking/MockManager.js.map +1 -0
  151. package/build/esm/prototyping/PrototypeOverrideStore.js +66 -0
  152. package/build/esm/prototyping/PrototypeOverrideStore.js.map +1 -0
  153. package/build/esm/prototyping/index.js +18 -0
  154. package/build/esm/prototyping/index.js.map +1 -0
  155. package/build/esm/public/vite.js +19 -0
  156. package/build/esm/public/vite.js.map +1 -0
  157. package/build/esm/register.js +41 -0
  158. package/build/esm/register.js.map +1 -0
  159. package/build/esm/scss.d.ts +20 -0
  160. package/build/esm/store/ComputeStore.js +269 -0
  161. package/build/esm/store/ComputeStore.js.map +1 -0
  162. package/build/esm/store/ConsoleLogStore.js +289 -0
  163. package/build/esm/store/ConsoleLogStore.js.map +1 -0
  164. package/build/esm/store/MetricsStore.js +428 -0
  165. package/build/esm/store/MetricsStore.js.map +1 -0
  166. package/build/esm/store/MonitorStore.js +288 -0
  167. package/build/esm/store/MonitorStore.js.map +1 -0
  168. package/build/esm/store/SubscribableStore.js +38 -0
  169. package/build/esm/store/SubscribableStore.js.map +1 -0
  170. package/build/esm/store/WindowErrorStore.js +195 -0
  171. package/build/esm/store/WindowErrorStore.js.map +1 -0
  172. package/build/esm/styles.css +19441 -0
  173. package/build/esm/styles.js +31 -0
  174. package/build/esm/styles.js.map +1 -0
  175. package/build/esm/types/compute.js +2 -0
  176. package/build/esm/types/compute.js.map +1 -0
  177. package/build/esm/types/emissions.js +2 -0
  178. package/build/esm/types/emissions.js.map +1 -0
  179. package/build/esm/types/index.js +23 -0
  180. package/build/esm/types/index.js.map +1 -0
  181. package/build/esm/utils/ActionLifecycleTracker.js +178 -0
  182. package/build/esm/utils/ActionLifecycleTracker.js.map +1 -0
  183. package/build/esm/utils/CacheEfficiencyAnalyzer.js +198 -0
  184. package/build/esm/utils/CacheEfficiencyAnalyzer.js.map +1 -0
  185. package/build/esm/utils/CircularBuffer.js +96 -0
  186. package/build/esm/utils/CircularBuffer.js.map +1 -0
  187. package/build/esm/utils/ComponentContextCapture.js +215 -0
  188. package/build/esm/utils/ComponentContextCapture.js.map +1 -0
  189. package/build/esm/utils/ComponentPrimitiveDiscovery.js +173 -0
  190. package/build/esm/utils/ComponentPrimitiveDiscovery.js.map +1 -0
  191. package/build/esm/utils/ComponentQueryRegistry.js +340 -0
  192. package/build/esm/utils/ComponentQueryRegistry.js.map +1 -0
  193. package/build/esm/utils/ComputeMonitor.js +199 -0
  194. package/build/esm/utils/ComputeMonitor.js.map +1 -0
  195. package/build/esm/utils/EventTimeline.js +130 -0
  196. package/build/esm/utils/EventTimeline.js.map +1 -0
  197. package/build/esm/utils/LinkTraversalTracker.js +116 -0
  198. package/build/esm/utils/LinkTraversalTracker.js.map +1 -0
  199. package/build/esm/utils/MockDataGenerator.js +473 -0
  200. package/build/esm/utils/MockDataGenerator.js.map +1 -0
  201. package/build/esm/utils/ObservableClientMonitor.js +768 -0
  202. package/build/esm/utils/ObservableClientMonitor.js.map +1 -0
  203. package/build/esm/utils/PerformanceRecommendationEngine.js +185 -0
  204. package/build/esm/utils/PerformanceRecommendationEngine.js.map +1 -0
  205. package/build/esm/utils/PropertyAccessTracker.js +238 -0
  206. package/build/esm/utils/PropertyAccessTracker.js.map +1 -0
  207. package/build/esm/utils/RecommendationMatcher.js +53 -0
  208. package/build/esm/utils/RecommendationMatcher.js.map +1 -0
  209. package/build/esm/utils/SubscriptionTracker.js +132 -0
  210. package/build/esm/utils/SubscriptionTracker.js.map +1 -0
  211. package/build/esm/utils/UnusedFieldAnalyzer.js +186 -0
  212. package/build/esm/utils/UnusedFieldAnalyzer.js.map +1 -0
  213. package/build/esm/utils/WaterfallDetector.js +200 -0
  214. package/build/esm/utils/WaterfallDetector.js.map +1 -0
  215. package/build/esm/utils/computePayload.js +37 -0
  216. package/build/esm/utils/computePayload.js.map +1 -0
  217. package/build/esm/utils/computeRequest.js +29 -0
  218. package/build/esm/utils/computeRequest.js.map +1 -0
  219. package/build/esm/utils/format.js +69 -0
  220. package/build/esm/utils/format.js.map +1 -0
  221. package/build/esm/utils/logger.js +31 -0
  222. package/build/esm/utils/logger.js.map +1 -0
  223. package/build/esm/vite/constants.js +18 -0
  224. package/build/esm/vite/constants.js.map +1 -0
  225. package/build/esm/vite/hookInstaller.js +99 -0
  226. package/build/esm/vite/hookInstaller.js.map +1 -0
  227. package/build/esm/vite/index.js +77 -0
  228. package/build/esm/vite/index.js.map +1 -0
  229. package/build/types/DevToolsContext.d.ts +3 -0
  230. package/build/types/DevToolsContext.d.ts.map +1 -0
  231. package/build/types/components/ActionMetrics.d.ts +6 -0
  232. package/build/types/components/ActionMetrics.d.ts.map +1 -0
  233. package/build/types/components/BubbleChart.d.ts +10 -0
  234. package/build/types/components/BubbleChart.d.ts.map +1 -0
  235. package/build/types/components/CacheInspectorTab.d.ts +6 -0
  236. package/build/types/components/CacheInspectorTab.d.ts.map +1 -0
  237. package/build/types/components/CacheMetrics.d.ts +6 -0
  238. package/build/types/components/CacheMetrics.d.ts.map +1 -0
  239. package/build/types/components/ComponentCard.d.ts +13 -0
  240. package/build/types/components/ComponentCard.d.ts.map +1 -0
  241. package/build/types/components/ComputeTab.d.ts +6 -0
  242. package/build/types/components/ComputeTab.d.ts.map +1 -0
  243. package/build/types/components/CopyableCodeBlock.d.ts +7 -0
  244. package/build/types/components/CopyableCodeBlock.d.ts.map +1 -0
  245. package/build/types/components/DebuggingTab.d.ts +6 -0
  246. package/build/types/components/DebuggingTab.d.ts.map +1 -0
  247. package/build/types/components/HookRow.d.ts +9 -0
  248. package/build/types/components/HookRow.d.ts.map +1 -0
  249. package/build/types/components/ImprovementsTab.d.ts +7 -0
  250. package/build/types/components/ImprovementsTab.d.ts.map +1 -0
  251. package/build/types/components/InspectorSelectionHeader.d.ts +12 -0
  252. package/build/types/components/InspectorSelectionHeader.d.ts.map +1 -0
  253. package/build/types/components/InterceptTab.d.ts +126 -0
  254. package/build/types/components/InterceptTab.d.ts.map +1 -0
  255. package/build/types/components/IssueCard.d.ts +8 -0
  256. package/build/types/components/IssueCard.d.ts.map +1 -0
  257. package/build/types/components/LogEntryCard.d.ts +7 -0
  258. package/build/types/components/LogEntryCard.d.ts.map +1 -0
  259. package/build/types/components/MockEditor.d.ts +58 -0
  260. package/build/types/components/MockEditor.d.ts.map +1 -0
  261. package/build/types/components/MonitorErrorBoundary.d.ts +16 -0
  262. package/build/types/components/MonitorErrorBoundary.d.ts.map +1 -0
  263. package/build/types/components/MonitoringPanel.d.ts +8 -0
  264. package/build/types/components/MonitoringPanel.d.ts.map +1 -0
  265. package/build/types/components/ObjectLoadingMetrics.d.ts +7 -0
  266. package/build/types/components/ObjectLoadingMetrics.d.ts.map +1 -0
  267. package/build/types/components/OsdkAppErrorBoundary.d.ts +18 -0
  268. package/build/types/components/OsdkAppErrorBoundary.d.ts.map +1 -0
  269. package/build/types/components/OsdkDevTools.d.ts +2 -0
  270. package/build/types/components/OsdkDevTools.d.ts.map +1 -0
  271. package/build/types/components/OverrideEditor.d.ts +26 -0
  272. package/build/types/components/OverrideEditor.d.ts.map +1 -0
  273. package/build/types/components/PerformanceTab.d.ts +8 -0
  274. package/build/types/components/PerformanceTab.d.ts.map +1 -0
  275. package/build/types/components/PrimitiveSelectionPanel.d.ts +28 -0
  276. package/build/types/components/PrimitiveSelectionPanel.d.ts.map +1 -0
  277. package/build/types/components/issueTypes.d.ts +16 -0
  278. package/build/types/components/issueTypes.d.ts.map +1 -0
  279. package/build/types/components/resolveComponentName.d.ts +3 -0
  280. package/build/types/components/resolveComponentName.d.ts.map +1 -0
  281. package/build/types/components/testHelpers.d.ts +2 -0
  282. package/build/types/components/testHelpers.d.ts.map +1 -0
  283. package/build/types/css.d.d.ts +4 -0
  284. package/build/types/css.d.d.ts.map +1 -0
  285. package/build/types/fiber/DegradationNotice.d.ts +8 -0
  286. package/build/types/fiber/DegradationNotice.d.ts.map +1 -0
  287. package/build/types/fiber/DevtoolsHook.d.ts +7 -0
  288. package/build/types/fiber/DevtoolsHook.d.ts.map +1 -0
  289. package/build/types/fiber/FiberAccess.d.ts +2 -0
  290. package/build/types/fiber/FiberAccess.d.ts.map +1 -0
  291. package/build/types/fiber/FiberInspection.d.ts +6 -0
  292. package/build/types/fiber/FiberInspection.d.ts.map +1 -0
  293. package/build/types/fiber/FiberTags.d.ts +33 -0
  294. package/build/types/fiber/FiberTags.d.ts.map +1 -0
  295. package/build/types/fiber/HookStateInspector.d.ts +45 -0
  296. package/build/types/fiber/HookStateInspector.d.ts.map +1 -0
  297. package/build/types/fiber/SafeFiberOperation.d.ts +7 -0
  298. package/build/types/fiber/SafeFiberOperation.d.ts.map +1 -0
  299. package/build/types/fiber/capabilities.d.ts +38 -0
  300. package/build/types/fiber/capabilities.d.ts.map +1 -0
  301. package/build/types/fiber/traverseFiber.d.ts +5 -0
  302. package/build/types/fiber/traverseFiber.d.ts.map +1 -0
  303. package/build/types/fiber/types.d.ts +87 -0
  304. package/build/types/fiber/types.d.ts.map +1 -0
  305. package/build/types/fiber/validation.d.ts +10 -0
  306. package/build/types/fiber/validation.d.ts.map +1 -0
  307. package/build/types/hooks/createPollingStore.d.ts +5 -0
  308. package/build/types/hooks/createPollingStore.d.ts.map +1 -0
  309. package/build/types/hooks/useActiveComponents.d.ts +3 -0
  310. package/build/types/hooks/useActiveComponents.d.ts.map +1 -0
  311. package/build/types/hooks/useComponentRegistry.d.ts +3 -0
  312. package/build/types/hooks/useComponentRegistry.d.ts.map +1 -0
  313. package/build/types/hooks/useComputeSelectors.d.ts +7 -0
  314. package/build/types/hooks/useComputeSelectors.d.ts.map +1 -0
  315. package/build/types/hooks/useConsoleLogs.d.ts +7 -0
  316. package/build/types/hooks/useConsoleLogs.d.ts.map +1 -0
  317. package/build/types/hooks/useInspectorSelection.d.ts +9 -0
  318. package/build/types/hooks/useInspectorSelection.d.ts.map +1 -0
  319. package/build/types/hooks/useMetrics.d.ts +3 -0
  320. package/build/types/hooks/useMetrics.d.ts.map +1 -0
  321. package/build/types/hooks/usePersistedState.d.ts +1 -0
  322. package/build/types/hooks/usePersistedState.d.ts.map +1 -0
  323. package/build/types/hooks/useRecommendations.d.ts +10 -0
  324. package/build/types/hooks/useRecommendations.d.ts.map +1 -0
  325. package/build/types/hooks/useSharedTick.d.ts +1 -0
  326. package/build/types/hooks/useSharedTick.d.ts.map +1 -0
  327. package/build/types/hooks/useTimeElapsed.d.ts +1 -0
  328. package/build/types/hooks/useTimeElapsed.d.ts.map +1 -0
  329. package/build/types/hooks/useTrackerSubscription.d.ts +16 -0
  330. package/build/types/hooks/useTrackerSubscription.d.ts.map +1 -0
  331. package/build/types/hooks/useUnusedFieldAnalysis.d.ts +8 -0
  332. package/build/types/hooks/useUnusedFieldAnalysis.d.ts.map +1 -0
  333. package/build/types/index.d.ts +21 -0
  334. package/build/types/index.d.ts.map +1 -0
  335. package/build/types/inspector/ClickToInspectSystem.d.ts +40 -0
  336. package/build/types/inspector/ClickToInspectSystem.d.ts.map +1 -0
  337. package/build/types/inspector/components/ComponentLabel.d.ts +3 -0
  338. package/build/types/inspector/components/ComponentLabel.d.ts.map +1 -0
  339. package/build/types/inspector/components/InspectorBanner.d.ts +5 -0
  340. package/build/types/inspector/components/InspectorBanner.d.ts.map +1 -0
  341. package/build/types/inspector/components/InspectorOverlay.d.ts +3 -0
  342. package/build/types/inspector/components/InspectorOverlay.d.ts.map +1 -0
  343. package/build/types/inspector/components/SelectionHighlight.d.ts +3 -0
  344. package/build/types/inspector/components/SelectionHighlight.d.ts.map +1 -0
  345. package/build/types/inspector/createClickToInspect.d.ts +3 -0
  346. package/build/types/inspector/createClickToInspect.d.ts.map +1 -0
  347. package/build/types/inspector/hooks/useAnimatedBounds.d.ts +2 -0
  348. package/build/types/inspector/hooks/useAnimatedBounds.d.ts.map +1 -0
  349. package/build/types/inspector/index.d.ts +13 -0
  350. package/build/types/inspector/index.d.ts.map +1 -0
  351. package/build/types/inspector/inspectorController.d.ts +2 -0
  352. package/build/types/inspector/inspectorController.d.ts.map +1 -0
  353. package/build/types/inspector/types.d.ts +94 -0
  354. package/build/types/inspector/types.d.ts.map +1 -0
  355. package/build/types/inspector/utils/elementBounds.d.ts +3 -0
  356. package/build/types/inspector/utils/elementBounds.d.ts.map +1 -0
  357. package/build/types/inspector/utils/interpolation.d.ts +7 -0
  358. package/build/types/inspector/utils/interpolation.d.ts.map +1 -0
  359. package/build/types/inspector/utils/labelPositioning.d.ts +3 -0
  360. package/build/types/inspector/utils/labelPositioning.d.ts.map +1 -0
  361. package/build/types/mocking/MockCacheKeyGenerator.d.ts +41 -0
  362. package/build/types/mocking/MockCacheKeyGenerator.d.ts.map +1 -0
  363. package/build/types/mocking/MockManager.d.ts +103 -0
  364. package/build/types/mocking/MockManager.d.ts.map +1 -0
  365. package/build/types/prototyping/PrototypeOverrideStore.d.ts +33 -0
  366. package/build/types/prototyping/PrototypeOverrideStore.d.ts.map +1 -0
  367. package/build/types/prototyping/index.d.ts +1 -0
  368. package/build/types/prototyping/index.d.ts.map +1 -0
  369. package/build/types/public/vite.d.ts +2 -0
  370. package/build/types/public/vite.d.ts.map +1 -0
  371. package/build/types/register.d.ts +1 -0
  372. package/build/types/register.d.ts.map +1 -0
  373. package/build/types/scss.d.d.ts +6 -0
  374. package/build/types/scss.d.d.ts.map +1 -0
  375. package/build/types/store/ComputeStore.d.ts +47 -0
  376. package/build/types/store/ComputeStore.d.ts.map +1 -0
  377. package/build/types/store/ConsoleLogStore.d.ts +29 -0
  378. package/build/types/store/ConsoleLogStore.d.ts.map +1 -0
  379. package/build/types/store/MetricsStore.d.ts +42 -0
  380. package/build/types/store/MetricsStore.d.ts.map +1 -0
  381. package/build/types/store/MonitorStore.d.ts +86 -0
  382. package/build/types/store/MonitorStore.d.ts.map +1 -0
  383. package/build/types/store/SubscribableStore.d.ts +6 -0
  384. package/build/types/store/SubscribableStore.d.ts.map +1 -0
  385. package/build/types/store/WindowErrorStore.d.ts +32 -0
  386. package/build/types/store/WindowErrorStore.d.ts.map +1 -0
  387. package/build/types/styles.d.ts +1 -0
  388. package/build/types/styles.d.ts.map +1 -0
  389. package/build/types/types/compute.d.ts +73 -0
  390. package/build/types/types/compute.d.ts.map +1 -0
  391. package/build/types/types/emissions.d.ts +24 -0
  392. package/build/types/types/emissions.d.ts.map +1 -0
  393. package/build/types/types/index.d.ts +143 -0
  394. package/build/types/types/index.d.ts.map +1 -0
  395. package/build/types/utils/ActionLifecycleTracker.d.ts +39 -0
  396. package/build/types/utils/ActionLifecycleTracker.d.ts.map +1 -0
  397. package/build/types/utils/CacheEfficiencyAnalyzer.d.ts +45 -0
  398. package/build/types/utils/CacheEfficiencyAnalyzer.d.ts.map +1 -0
  399. package/build/types/utils/CircularBuffer.d.ts +18 -0
  400. package/build/types/utils/CircularBuffer.d.ts.map +1 -0
  401. package/build/types/utils/ComponentContextCapture.d.ts +29 -0
  402. package/build/types/utils/ComponentContextCapture.d.ts.map +1 -0
  403. package/build/types/utils/ComponentPrimitiveDiscovery.d.ts +62 -0
  404. package/build/types/utils/ComponentPrimitiveDiscovery.d.ts.map +1 -0
  405. package/build/types/utils/ComponentQueryRegistry.d.ts +91 -0
  406. package/build/types/utils/ComponentQueryRegistry.d.ts.map +1 -0
  407. package/build/types/utils/ComputeMonitor.d.ts +14 -0
  408. package/build/types/utils/ComputeMonitor.d.ts.map +1 -0
  409. package/build/types/utils/EventTimeline.d.ts +102 -0
  410. package/build/types/utils/EventTimeline.d.ts.map +1 -0
  411. package/build/types/utils/LinkTraversalTracker.d.ts +43 -0
  412. package/build/types/utils/LinkTraversalTracker.d.ts.map +1 -0
  413. package/build/types/utils/MockDataGenerator.d.ts +23 -0
  414. package/build/types/utils/MockDataGenerator.d.ts.map +1 -0
  415. package/build/types/utils/ObservableClientMonitor.d.ts +62 -0
  416. package/build/types/utils/ObservableClientMonitor.d.ts.map +1 -0
  417. package/build/types/utils/PerformanceRecommendationEngine.d.ts +67 -0
  418. package/build/types/utils/PerformanceRecommendationEngine.d.ts.map +1 -0
  419. package/build/types/utils/PropertyAccessTracker.d.ts +50 -0
  420. package/build/types/utils/PropertyAccessTracker.d.ts.map +1 -0
  421. package/build/types/utils/RecommendationMatcher.d.ts +5 -0
  422. package/build/types/utils/RecommendationMatcher.d.ts.map +1 -0
  423. package/build/types/utils/SubscriptionTracker.d.ts +17 -0
  424. package/build/types/utils/SubscriptionTracker.d.ts.map +1 -0
  425. package/build/types/utils/UnusedFieldAnalyzer.d.ts +46 -0
  426. package/build/types/utils/UnusedFieldAnalyzer.d.ts.map +1 -0
  427. package/build/types/utils/WaterfallDetector.d.ts +28 -0
  428. package/build/types/utils/WaterfallDetector.d.ts.map +1 -0
  429. package/build/types/utils/computePayload.d.ts +3 -0
  430. package/build/types/utils/computePayload.d.ts.map +1 -0
  431. package/build/types/utils/computeRequest.d.ts +20 -0
  432. package/build/types/utils/computeRequest.d.ts.map +1 -0
  433. package/build/types/utils/format.d.ts +5 -0
  434. package/build/types/utils/format.d.ts.map +1 -0
  435. package/build/types/utils/logger.d.ts +2 -0
  436. package/build/types/utils/logger.d.ts.map +1 -0
  437. package/build/types/vite/constants.d.ts +1 -0
  438. package/build/types/vite/constants.d.ts.map +1 -0
  439. package/build/types/vite/hookInstaller.d.ts +1 -0
  440. package/build/types/vite/hookInstaller.d.ts.map +1 -0
  441. package/build/types/vite/index.d.ts +20 -0
  442. package/build/types/vite/index.d.ts.map +1 -0
  443. package/package.json +114 -0
@@ -0,0 +1,291 @@
1
+ /*
2
+ * Copyright 2025 Palantir Technologies, Inc. All rights reserved.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ import { Button, ButtonGroup, Card, Collapse, Icon, InputGroup, Tag, Tooltip } from "@blueprintjs/core";
18
+ import React, { useMemo, useState } from "react";
19
+ import { createPollingStore } from "../hooks/createPollingStore.js";
20
+ import { formatBytes, formatRelativeTime } from "../utils/format.js";
21
+ import styles from "./CacheInspectorTab.module.scss.js";
22
+ import { CopyableCodeBlock } from "./CopyableCodeBlock.js";
23
+ function getTypeColor(type) {
24
+ switch (type) {
25
+ case "object":
26
+ return "primary";
27
+ case "list":
28
+ return "success";
29
+ case "link":
30
+ return "warning";
31
+ case "objectSet":
32
+ return "danger";
33
+ default:
34
+ return undefined;
35
+ }
36
+ }
37
+ function getStatusIcon(status) {
38
+ switch (status) {
39
+ case "loaded":
40
+ return "tick-circle";
41
+ case "loading":
42
+ return "refresh";
43
+ case "error":
44
+ return "error";
45
+ case "init":
46
+ return "time";
47
+ default:
48
+ return "help";
49
+ }
50
+ }
51
+ function getStatusColor(status) {
52
+ switch (status) {
53
+ case "loaded":
54
+ return "success";
55
+ case "loading":
56
+ return "primary";
57
+ case "error":
58
+ return "danger";
59
+ case "init":
60
+ return "none";
61
+ default:
62
+ return undefined;
63
+ }
64
+ }
65
+ const emptySnapshot = {
66
+ entries: [],
67
+ stats: {
68
+ totalEntries: 0,
69
+ totalSize: 0,
70
+ totalHits: 0
71
+ }
72
+ };
73
+ export const CacheInspectorTab = ({
74
+ monitorStore
75
+ }) => {
76
+ const [searchQuery, setSearchQuery] = useState("");
77
+ const [expandedKeys, setExpandedKeys] = useState(new Set());
78
+ const snapshotStore = React.useMemo(() => createPollingStore(async () => {
79
+ const entries = await monitorStore.loadCacheEntries();
80
+ const totalSize = entries.reduce((sum, e) => sum + e.metadata.size, 0);
81
+ const totalHits = entries.reduce((sum, e) => sum + (e.metadata.hitCount ?? 0), 0);
82
+ return {
83
+ entries,
84
+ stats: {
85
+ totalEntries: entries.length,
86
+ totalSize,
87
+ totalHits
88
+ }
89
+ };
90
+ }, 2000), [monitorStore]);
91
+ const polledSnapshot = React.useSyncExternalStore(snapshotStore.subscribe, snapshotStore.getSnapshot);
92
+ const snapshot = polledSnapshot ?? emptySnapshot;
93
+ const filteredEntries = useMemo(() => snapshot.entries.filter(entry => {
94
+ if (!searchQuery.trim()) {
95
+ return true;
96
+ }
97
+ const query = searchQuery.toLowerCase();
98
+ return entry.key.toLowerCase().includes(query) || entry.objectType.toLowerCase().includes(query) || entry.type.toLowerCase().includes(query);
99
+ }), [snapshot.entries, searchQuery]);
100
+ const toggleExpanded = key => {
101
+ const newSet = new Set(expandedKeys);
102
+ if (newSet.has(key)) {
103
+ newSet.delete(key);
104
+ } else {
105
+ newSet.add(key);
106
+ }
107
+ setExpandedKeys(newSet);
108
+ };
109
+ const [invalidateError, setInvalidateError] = useState(null);
110
+ const handleInvalidate = async entry => {
111
+ setInvalidateError(null);
112
+ try {
113
+ await monitorStore.invalidateCacheEntry(entry);
114
+ snapshotStore.forceRefresh();
115
+ } catch (error) {
116
+ setInvalidateError(error instanceof Error ? error : new Error(String(error)));
117
+ }
118
+ };
119
+ const handleClearAll = async () => {
120
+ if (confirm("Clear entire cache? This will force all queries to refetch.")) {
121
+ setInvalidateError(null);
122
+ try {
123
+ await monitorStore.clearCache();
124
+ snapshotStore.forceRefresh();
125
+ } catch (error) {
126
+ setInvalidateError(error instanceof Error ? error : new Error(String(error)));
127
+ }
128
+ }
129
+ };
130
+ return /*#__PURE__*/React.createElement("div", {
131
+ className: styles.cacheInspector
132
+ }, /*#__PURE__*/React.createElement("div", {
133
+ className: styles.toolbar
134
+ }, /*#__PURE__*/React.createElement("h3", {
135
+ className: styles.title
136
+ }, "Cache Inspector"), /*#__PURE__*/React.createElement("div", {
137
+ className: styles.stats
138
+ }, /*#__PURE__*/React.createElement("div", {
139
+ className: styles.stat
140
+ }, /*#__PURE__*/React.createElement("span", {
141
+ className: styles.statLabel
142
+ }, "Entries"), /*#__PURE__*/React.createElement("span", {
143
+ className: styles.statValue
144
+ }, snapshot.stats.totalEntries)), /*#__PURE__*/React.createElement("div", {
145
+ className: styles.stat
146
+ }, /*#__PURE__*/React.createElement("span", {
147
+ className: styles.statLabel
148
+ }, "Total Size"), /*#__PURE__*/React.createElement("span", {
149
+ className: styles.statValue
150
+ }, formatBytes(snapshot.stats.totalSize))), /*#__PURE__*/React.createElement("div", {
151
+ className: styles.stat
152
+ }, /*#__PURE__*/React.createElement("span", {
153
+ className: styles.statLabel
154
+ }, "Total Hits"), /*#__PURE__*/React.createElement("span", {
155
+ className: styles.statValue
156
+ }, snapshot.stats.totalHits)))), /*#__PURE__*/React.createElement("div", {
157
+ className: styles.toolbarActions
158
+ }, /*#__PURE__*/React.createElement("div", {
159
+ className: styles.search
160
+ }, /*#__PURE__*/React.createElement(InputGroup, {
161
+ leftIcon: "search",
162
+ placeholder: "Search cache entries...",
163
+ value: searchQuery,
164
+ onChange: e => setSearchQuery(e.target.value),
165
+ fill: true
166
+ })), /*#__PURE__*/React.createElement(ButtonGroup, null, /*#__PURE__*/React.createElement(Button, {
167
+ icon: "refresh",
168
+ onClick: () => snapshotStore.forceRefresh(),
169
+ size: "small"
170
+ }, "Refresh"), /*#__PURE__*/React.createElement(Button, {
171
+ icon: "trash",
172
+ intent: "danger",
173
+ onClick: () => void handleClearAll(),
174
+ size: "small"
175
+ }, "Clear All"))), invalidateError && /*#__PURE__*/React.createElement("div", {
176
+ className: styles.errorBanner
177
+ }, /*#__PURE__*/React.createElement(Icon, {
178
+ icon: "error",
179
+ intent: "danger"
180
+ }), /*#__PURE__*/React.createElement("span", null, invalidateError.message), /*#__PURE__*/React.createElement(Button, {
181
+ icon: "cross",
182
+ variant: "minimal",
183
+ size: "small",
184
+ onClick: () => {
185
+ setInvalidateError(null);
186
+ }
187
+ })), /*#__PURE__*/React.createElement("div", {
188
+ className: styles.content
189
+ }, polledSnapshot === undefined && /*#__PURE__*/React.createElement("div", {
190
+ className: styles.skeletonList
191
+ }, Array.from({
192
+ length: 5
193
+ }).map((_, i) => /*#__PURE__*/React.createElement("div", {
194
+ key: i,
195
+ className: styles.skeletonEntry
196
+ }, /*#__PURE__*/React.createElement("div", {
197
+ className: styles.skeletonTag
198
+ }), /*#__PURE__*/React.createElement("div", {
199
+ className: styles.skeletonText
200
+ }), /*#__PURE__*/React.createElement("div", {
201
+ className: styles.skeletonBadge
202
+ })))), filteredEntries.length === 0 && polledSnapshot !== undefined && /*#__PURE__*/React.createElement("div", {
203
+ className: styles.emptyState
204
+ }, /*#__PURE__*/React.createElement(Icon, {
205
+ icon: "database",
206
+ size: 28
207
+ }), /*#__PURE__*/React.createElement("div", {
208
+ className: styles.emptyTitle
209
+ }, snapshot.entries.length === 0 ? "No Cache Entries" : "No Matching Entries"), /*#__PURE__*/React.createElement("div", {
210
+ className: styles.emptyDescription
211
+ }, snapshot.entries.length === 0 ? "The cache is empty. Query some data to see cache entries." : "Try a different search term.")), filteredEntries.map((entry, index) => {
212
+ const isExpanded = expandedKeys.has(entry.key);
213
+ return /*#__PURE__*/React.createElement(Card, {
214
+ key: entry.key,
215
+ className: styles.entryCard,
216
+ style: {
217
+ "--entrance-index": index
218
+ }
219
+ }, /*#__PURE__*/React.createElement("div", {
220
+ className: styles.entryHeader,
221
+ onClick: () => toggleExpanded(entry.key)
222
+ }, /*#__PURE__*/React.createElement("div", {
223
+ className: styles.entryHeaderLeft
224
+ }, /*#__PURE__*/React.createElement(Icon, {
225
+ icon: isExpanded ? "chevron-down" : "chevron-right",
226
+ size: 14,
227
+ className: styles.expandIcon
228
+ }), /*#__PURE__*/React.createElement(Tag, {
229
+ minimal: true,
230
+ intent: getTypeColor(entry.type),
231
+ className: styles.typeTag
232
+ }, entry.type), /*#__PURE__*/React.createElement("span", {
233
+ className: styles.objectType
234
+ }, entry.objectType), entry.metadata.isOptimistic && /*#__PURE__*/React.createElement(Tooltip, {
235
+ content: "Has optimistic updates"
236
+ }, /*#__PURE__*/React.createElement(Tag, {
237
+ minimal: true,
238
+ intent: "warning",
239
+ icon: "time"
240
+ }, "Optimistic"))), /*#__PURE__*/React.createElement("div", {
241
+ className: styles.entryHeaderRight
242
+ }, /*#__PURE__*/React.createElement(Tooltip, {
243
+ content: `Status: ${entry.metadata.status}`
244
+ }, /*#__PURE__*/React.createElement(Tag, {
245
+ minimal: true,
246
+ intent: getStatusColor(entry.metadata.status),
247
+ icon: getStatusIcon(entry.metadata.status)
248
+ }, entry.metadata.status)), /*#__PURE__*/React.createElement(Tooltip, {
249
+ content: `Last updated: ${new Date(entry.metadata.timestamp).toLocaleString()}`
250
+ }, /*#__PURE__*/React.createElement("span", {
251
+ className: styles.age
252
+ }, formatRelativeTime(entry.metadata.timestamp))), /*#__PURE__*/React.createElement(Tooltip, {
253
+ content: `Cache entry size`
254
+ }, /*#__PURE__*/React.createElement("span", {
255
+ className: styles.size
256
+ }, formatBytes(entry.metadata.size))), /*#__PURE__*/React.createElement(Button, {
257
+ icon: "refresh",
258
+ variant: "minimal",
259
+ size: "small",
260
+ onClick: e => {
261
+ e.stopPropagation();
262
+ void handleInvalidate(entry);
263
+ }
264
+ }))), /*#__PURE__*/React.createElement(Collapse, {
265
+ isOpen: isExpanded
266
+ }, /*#__PURE__*/React.createElement("div", {
267
+ className: styles.entryBody
268
+ }, /*#__PURE__*/React.createElement("div", {
269
+ className: styles.section
270
+ }, /*#__PURE__*/React.createElement("h4", null, "Cache Key"), /*#__PURE__*/React.createElement(CopyableCodeBlock, {
271
+ className: styles.codeBlock
272
+ }, entry.key)), entry.type === "list" && (entry.where != null || entry.orderBy != null) && /*#__PURE__*/React.createElement("div", {
273
+ className: styles.section
274
+ }, /*#__PURE__*/React.createElement("h4", null, "Query Parameters"), /*#__PURE__*/React.createElement(CopyableCodeBlock, {
275
+ className: styles.codeBlock
276
+ }, JSON.stringify({
277
+ where: entry.where,
278
+ orderBy: entry.orderBy,
279
+ pageSize: entry.pageSize
280
+ }, null, 2))), entry.type === "link" && entry.linkName != null && /*#__PURE__*/React.createElement("div", {
281
+ className: styles.section
282
+ }, /*#__PURE__*/React.createElement("h4", null, "Link"), /*#__PURE__*/React.createElement(CopyableCodeBlock, {
283
+ className: styles.codeBlock
284
+ }, entry.linkName)), entry.data !== undefined && /*#__PURE__*/React.createElement("div", {
285
+ className: styles.section
286
+ }, /*#__PURE__*/React.createElement("h4", null, "Cached Data"), /*#__PURE__*/React.createElement(CopyableCodeBlock, {
287
+ className: styles.codeBlock
288
+ }, JSON.stringify(entry.data, null, 2))))));
289
+ })));
290
+ };
291
+ //# sourceMappingURL=CacheInspectorTab.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CacheInspectorTab.js","names":["Button","ButtonGroup","Card","Collapse","Icon","InputGroup","Tag","Tooltip","React","useMemo","useState","createPollingStore","formatBytes","formatRelativeTime","styles","CopyableCodeBlock","getTypeColor","type","undefined","getStatusIcon","status","getStatusColor","emptySnapshot","entries","stats","totalEntries","totalSize","totalHits","CacheInspectorTab","monitorStore","searchQuery","setSearchQuery","expandedKeys","setExpandedKeys","Set","snapshotStore","loadCacheEntries","reduce","sum","e","metadata","size","hitCount","length","polledSnapshot","useSyncExternalStore","subscribe","getSnapshot","snapshot","filteredEntries","filter","entry","trim","query","toLowerCase","key","includes","objectType","toggleExpanded","newSet","has","delete","add","invalidateError","setInvalidateError","handleInvalidate","invalidateCacheEntry","forceRefresh","error","Error","String","handleClearAll","confirm","clearCache","createElement","className","cacheInspector","toolbar","title","stat","statLabel","statValue","toolbarActions","search","leftIcon","placeholder","value","onChange","target","fill","icon","onClick","intent","errorBanner","message","variant","content","skeletonList","Array","from","map","_","i","skeletonEntry","skeletonTag","skeletonText","skeletonBadge","emptyState","emptyTitle","emptyDescription","index","isExpanded","entryCard","style","entryHeader","entryHeaderLeft","expandIcon","minimal","typeTag","isOptimistic","entryHeaderRight","Date","timestamp","toLocaleString","age","stopPropagation","isOpen","entryBody","section","codeBlock","where","orderBy","JSON","stringify","pageSize","linkName","data"],"sources":["CacheInspectorTab.tsx"],"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 Button,\n ButtonGroup,\n Card,\n Collapse,\n Icon,\n InputGroup,\n Tag,\n Tooltip,\n} from \"@blueprintjs/core\";\nimport type { CacheEntry } from \"@osdk/client/observable\";\nimport React, { useMemo, useState } from \"react\";\nimport { createPollingStore } from \"../hooks/createPollingStore.js\";\nimport type { MonitorStore } from \"../store/MonitorStore.js\";\nimport { formatBytes, formatRelativeTime } from \"../utils/format.js\";\nimport styles from \"./CacheInspectorTab.module.scss\";\nimport { CopyableCodeBlock } from \"./CopyableCodeBlock.js\";\n\nfunction getTypeColor(type: string) {\n switch (type) {\n case \"object\":\n return \"primary\";\n case \"list\":\n return \"success\";\n case \"link\":\n return \"warning\";\n case \"objectSet\":\n return \"danger\";\n default:\n return undefined;\n }\n}\n\nfunction getStatusIcon(status: string) {\n switch (status) {\n case \"loaded\":\n return \"tick-circle\";\n case \"loading\":\n return \"refresh\";\n case \"error\":\n return \"error\";\n case \"init\":\n return \"time\";\n default:\n return \"help\";\n }\n}\n\nfunction getStatusColor(status: string) {\n switch (status) {\n case \"loaded\":\n return \"success\";\n case \"loading\":\n return \"primary\";\n case \"error\":\n return \"danger\";\n case \"init\":\n return \"none\";\n default:\n return undefined;\n }\n}\n\nexport interface CacheInspectorTabProps {\n monitorStore: MonitorStore;\n}\n\ninterface CacheSnapshot {\n entries: CacheEntry[];\n stats: {\n totalEntries: number;\n totalSize: number;\n totalHits: number;\n };\n}\n\nconst emptySnapshot: CacheSnapshot = {\n entries: [],\n stats: { totalEntries: 0, totalSize: 0, totalHits: 0 },\n};\n\nexport const CacheInspectorTab: React.FC<CacheInspectorTabProps> = (\n { monitorStore },\n) => {\n const [searchQuery, setSearchQuery] = useState(\"\");\n const [expandedKeys, setExpandedKeys] = useState<Set<string>>(new Set());\n const snapshotStore = React.useMemo(\n () =>\n createPollingStore(async () => {\n const entries = await monitorStore.loadCacheEntries();\n const totalSize = entries.reduce(\n (sum: number, e: CacheEntry) => sum + e.metadata.size,\n 0,\n );\n const totalHits = entries.reduce(\n (sum: number, e: CacheEntry) => sum + (e.metadata.hitCount ?? 0),\n 0,\n );\n return {\n entries,\n stats: {\n totalEntries: entries.length,\n totalSize,\n totalHits,\n },\n };\n }, 2000),\n [monitorStore],\n );\n const polledSnapshot = React.useSyncExternalStore(\n snapshotStore.subscribe,\n snapshotStore.getSnapshot,\n );\n\n const snapshot: CacheSnapshot = polledSnapshot ?? emptySnapshot;\n\n const filteredEntries = useMemo(() =>\n snapshot.entries.filter(entry => {\n if (!searchQuery.trim()) {\n return true;\n }\n const query = searchQuery.toLowerCase();\n return (\n entry.key.toLowerCase().includes(query)\n || entry.objectType.toLowerCase().includes(query)\n || entry.type.toLowerCase().includes(query)\n );\n }), [snapshot.entries, searchQuery]);\n\n const toggleExpanded = (key: string) => {\n const newSet = new Set(expandedKeys);\n if (newSet.has(key)) {\n newSet.delete(key);\n } else {\n newSet.add(key);\n }\n setExpandedKeys(newSet);\n };\n\n const [invalidateError, setInvalidateError] = useState<Error | null>(null);\n\n const handleInvalidate = async (entry: CacheEntry) => {\n setInvalidateError(null);\n try {\n await monitorStore.invalidateCacheEntry(entry);\n snapshotStore.forceRefresh();\n } catch (error) {\n setInvalidateError(\n error instanceof Error ? error : new Error(String(error)),\n );\n }\n };\n\n const handleClearAll = async () => {\n if (\n confirm(\"Clear entire cache? This will force all queries to refetch.\")\n ) {\n setInvalidateError(null);\n try {\n await monitorStore.clearCache();\n snapshotStore.forceRefresh();\n } catch (error) {\n setInvalidateError(\n error instanceof Error ? error : new Error(String(error)),\n );\n }\n }\n };\n\n return (\n <div className={styles.cacheInspector}>\n <div className={styles.toolbar}>\n <h3 className={styles.title}>Cache Inspector</h3>\n\n <div className={styles.stats}>\n <div className={styles.stat}>\n <span className={styles.statLabel}>Entries</span>\n <span className={styles.statValue}>\n {snapshot.stats.totalEntries}\n </span>\n </div>\n\n <div className={styles.stat}>\n <span className={styles.statLabel}>Total Size</span>\n <span className={styles.statValue}>\n {formatBytes(snapshot.stats.totalSize)}\n </span>\n </div>\n\n <div className={styles.stat}>\n <span className={styles.statLabel}>Total Hits</span>\n <span className={styles.statValue}>{snapshot.stats.totalHits}</span>\n </div>\n </div>\n </div>\n\n <div className={styles.toolbarActions}>\n <div className={styles.search}>\n <InputGroup\n leftIcon=\"search\"\n placeholder=\"Search cache entries...\"\n value={searchQuery}\n onChange={(e) => setSearchQuery(e.target.value)}\n fill={true}\n />\n </div>\n\n <ButtonGroup>\n <Button\n icon=\"refresh\"\n onClick={() => snapshotStore.forceRefresh()}\n size=\"small\"\n >\n Refresh\n </Button>\n <Button\n icon=\"trash\"\n intent=\"danger\"\n onClick={() => void handleClearAll()}\n size=\"small\"\n >\n Clear All\n </Button>\n </ButtonGroup>\n </div>\n\n {invalidateError && (\n <div className={styles.errorBanner}>\n <Icon icon=\"error\" intent=\"danger\" />\n <span>{invalidateError.message}</span>\n <Button\n icon=\"cross\"\n variant=\"minimal\"\n size=\"small\"\n onClick={() => {\n setInvalidateError(null);\n }}\n />\n </div>\n )}\n\n <div className={styles.content}>\n {polledSnapshot === undefined && (\n <div className={styles.skeletonList}>\n {Array.from({ length: 5 }).map((_, i) => (\n <div key={i} className={styles.skeletonEntry}>\n <div className={styles.skeletonTag} />\n <div className={styles.skeletonText} />\n <div className={styles.skeletonBadge} />\n </div>\n ))}\n </div>\n )}\n\n {filteredEntries.length === 0 && polledSnapshot !== undefined && (\n <div className={styles.emptyState}>\n <Icon icon=\"database\" size={28} />\n <div className={styles.emptyTitle}>\n {snapshot.entries.length === 0\n ? \"No Cache Entries\"\n : \"No Matching Entries\"}\n </div>\n <div className={styles.emptyDescription}>\n {snapshot.entries.length === 0\n ? \"The cache is empty. Query some data to see cache entries.\"\n : \"Try a different search term.\"}\n </div>\n </div>\n )}\n\n {filteredEntries.map((entry, index) => {\n const isExpanded = expandedKeys.has(entry.key);\n return (\n <Card\n key={entry.key}\n className={styles.entryCard}\n style={{ \"--entrance-index\": index } as React.CSSProperties}\n >\n <div\n className={styles.entryHeader}\n onClick={() => toggleExpanded(entry.key)}\n >\n <div className={styles.entryHeaderLeft}>\n <Icon\n icon={isExpanded ? \"chevron-down\" : \"chevron-right\"}\n size={14}\n className={styles.expandIcon}\n />\n <Tag\n minimal={true}\n intent={getTypeColor(entry.type)}\n className={styles.typeTag}\n >\n {entry.type}\n </Tag>\n <span className={styles.objectType}>{entry.objectType}</span>\n {entry.metadata.isOptimistic && (\n <Tooltip content=\"Has optimistic updates\">\n <Tag minimal={true} intent=\"warning\" icon=\"time\">\n Optimistic\n </Tag>\n </Tooltip>\n )}\n </div>\n\n <div className={styles.entryHeaderRight}>\n <Tooltip content={`Status: ${entry.metadata.status}`}>\n <Tag\n minimal={true}\n intent={getStatusColor(entry.metadata.status)}\n icon={getStatusIcon(entry.metadata.status)}\n >\n {entry.metadata.status}\n </Tag>\n </Tooltip>\n <Tooltip\n content={`Last updated: ${\n new Date(entry.metadata.timestamp).toLocaleString()\n }`}\n >\n <span className={styles.age}>\n {formatRelativeTime(entry.metadata.timestamp)}\n </span>\n </Tooltip>\n <Tooltip content={`Cache entry size`}>\n <span className={styles.size}>\n {formatBytes(entry.metadata.size)}\n </span>\n </Tooltip>\n <Button\n icon=\"refresh\"\n variant=\"minimal\"\n size=\"small\"\n onClick={(e) => {\n e.stopPropagation();\n void handleInvalidate(entry);\n }}\n />\n </div>\n </div>\n\n <Collapse isOpen={isExpanded}>\n <div className={styles.entryBody}>\n <div className={styles.section}>\n <h4>Cache Key</h4>\n <CopyableCodeBlock className={styles.codeBlock}>\n {entry.key}\n </CopyableCodeBlock>\n </div>\n\n {entry.type === \"list\"\n && (entry.where != null || entry.orderBy != null) && (\n <div className={styles.section}>\n <h4>Query Parameters</h4>\n <CopyableCodeBlock className={styles.codeBlock}>\n {JSON.stringify(\n {\n where: entry.where,\n orderBy: entry.orderBy,\n pageSize: entry.pageSize,\n },\n null,\n 2,\n )}\n </CopyableCodeBlock>\n </div>\n )}\n\n {entry.type === \"link\" && entry.linkName != null && (\n <div className={styles.section}>\n <h4>Link</h4>\n <CopyableCodeBlock className={styles.codeBlock}>\n {entry.linkName}\n </CopyableCodeBlock>\n </div>\n )}\n\n {entry.data !== undefined && (\n <div className={styles.section}>\n <h4>Cached Data</h4>\n <CopyableCodeBlock className={styles.codeBlock}>\n {JSON.stringify(entry.data, null, 2)}\n </CopyableCodeBlock>\n </div>\n )}\n </div>\n </Collapse>\n </Card>\n );\n })}\n </div>\n </div>\n );\n};\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,39 @@
1
+ // AUTO-GENERATED by scripts/build-css.mjs. Do not edit by hand.
2
+ const styles = {
3
+ "cacheInspector": "CacheInspectorTab-module__cacheInspector___0pTFp4iE",
4
+ "toolbar": "CacheInspectorTab-module__toolbar___zGcbShwN",
5
+ "title": "CacheInspectorTab-module__title___3bcYim5b",
6
+ "stats": "CacheInspectorTab-module__stats___zjIkUbZ-",
7
+ "stat": "CacheInspectorTab-module__stat___N5shnit-",
8
+ "statLabel": "CacheInspectorTab-module__statLabel___QRj1olUh",
9
+ "statValue": "CacheInspectorTab-module__statValue___rKUZv6Ig",
10
+ "toolbarActions": "CacheInspectorTab-module__toolbarActions___4fhMzxCo",
11
+ "search": "CacheInspectorTab-module__search___963zrlxE",
12
+ "errorBanner": "CacheInspectorTab-module__errorBanner___sQ0cXPIy",
13
+ "content": "CacheInspectorTab-module__content___Sfk9-0ev",
14
+ "empty": "CacheInspectorTab-module__empty___eglE5xhh",
15
+ "entryCard": "CacheInspectorTab-module__entryCard___63Z-EsdU",
16
+ "dt-fade-up": "CacheInspectorTab-module__dt-fade-up___--iXhYKu",
17
+ "entryHeader": "CacheInspectorTab-module__entryHeader___-aCymZEs",
18
+ "entryHeaderLeft": "CacheInspectorTab-module__entryHeaderLeft___u3v9fniB",
19
+ "expandIcon": "CacheInspectorTab-module__expandIcon___55C3Sw1J",
20
+ "typeTag": "CacheInspectorTab-module__typeTag___p6D-09S1",
21
+ "objectType": "CacheInspectorTab-module__objectType___AhYHuO3-",
22
+ "entryHeaderRight": "CacheInspectorTab-module__entryHeaderRight___X-B6V3GW",
23
+ "age": "CacheInspectorTab-module__age___xXiWG-wZ",
24
+ "size": "CacheInspectorTab-module__size___lLjfu2mJ",
25
+ "entryBody": "CacheInspectorTab-module__entryBody___utmRh5bL",
26
+ "section": "CacheInspectorTab-module__section___ZoZ0TYcg",
27
+ "codeBlock": "CacheInspectorTab-module__codeBlock___ernkTy8t",
28
+ "callout": "CacheInspectorTab-module__callout___foEeQTsC",
29
+ "emptyState": "CacheInspectorTab-module__emptyState___HjYFi2jd",
30
+ "emptyTitle": "CacheInspectorTab-module__emptyTitle___SCvU7CKc",
31
+ "emptyDescription": "CacheInspectorTab-module__emptyDescription___sDVcthMS",
32
+ "skeletonList": "CacheInspectorTab-module__skeletonList___iH9w-cS5",
33
+ "skeletonEntry": "CacheInspectorTab-module__skeletonEntry___H615KpZc",
34
+ "skeletonTag": "CacheInspectorTab-module__skeletonTag___nFw9vTy8",
35
+ "dt-shimmer": "CacheInspectorTab-module__dt-shimmer___nasBcNkO",
36
+ "skeletonText": "CacheInspectorTab-module__skeletonText___9bDpA0d7",
37
+ "skeletonBadge": "CacheInspectorTab-module__skeletonBadge___22IU0H7P"
38
+ };
39
+ export default styles;
@@ -0,0 +1,55 @@
1
+ /*
2
+ * Copyright 2025 Palantir Technologies, Inc. All rights reserved.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ import classNames from "classnames";
18
+ import React from "react";
19
+ import { formatNumber, formatTime } from "../utils/format.js";
20
+ import styles from "./MonitoringPanel.module.scss.js";
21
+ const CACHE_HIT_EXCELLENT = 0.8;
22
+ const CACHE_HIT_GOOD = 0.5;
23
+ export const CacheMetrics = ({
24
+ metrics
25
+ }) => {
26
+ const totalObjects = metrics.aggregates.totalObjectsFromCache + metrics.aggregates.totalObjectsFromNetwork;
27
+ const objectBasedRate = totalObjects > 0 ? metrics.aggregates.totalObjectsFromCache / totalObjects : 0;
28
+ const rateClass = objectBasedRate >= CACHE_HIT_EXCELLENT ? styles.success : objectBasedRate >= CACHE_HIT_GOOD ? styles.warning : styles.danger;
29
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
30
+ className: styles.metric
31
+ }, /*#__PURE__*/React.createElement("span", {
32
+ className: styles.metricLabel
33
+ }, "Cache Hit Rate"), /*#__PURE__*/React.createElement("span", {
34
+ className: classNames(styles.metricValue, rateClass)
35
+ }, (objectBasedRate * 100).toFixed(0), "%"), /*#__PURE__*/React.createElement("span", {
36
+ className: styles.metricSubtext
37
+ }, formatNumber(metrics.aggregates.totalObjectsFromCache), " /", " ", formatNumber(totalObjects), " objects")), /*#__PURE__*/React.createElement("div", {
38
+ className: styles.metric
39
+ }, /*#__PURE__*/React.createElement("span", {
40
+ className: styles.metricLabel
41
+ }, "Cache Savings"), /*#__PURE__*/React.createElement("span", {
42
+ className: classNames(styles.metricValue, styles.success)
43
+ }, formatNumber(metrics.aggregates.cacheHits + metrics.aggregates.revalidations + metrics.aggregates.deduplications), " requests saved"), /*#__PURE__*/React.createElement("span", {
44
+ className: styles.metricSubtext
45
+ }, formatNumber(metrics.aggregates.deduplications), " deduped")), /*#__PURE__*/React.createElement("div", {
46
+ className: styles.metric
47
+ }, /*#__PURE__*/React.createElement("span", {
48
+ className: styles.metricLabel
49
+ }, "Avg Response"), /*#__PURE__*/React.createElement("span", {
50
+ className: styles.metricValue
51
+ }, formatTime(metrics.rates.averageResponseTime)), /*#__PURE__*/React.createElement("span", {
52
+ className: styles.metricSubtext
53
+ }, "Cache: ", formatTime(metrics.rates.averageCachedResponseTime))));
54
+ };
55
+ //# sourceMappingURL=CacheMetrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CacheMetrics.js","names":["classNames","React","formatNumber","formatTime","styles","CACHE_HIT_EXCELLENT","CACHE_HIT_GOOD","CacheMetrics","metrics","totalObjects","aggregates","totalObjectsFromCache","totalObjectsFromNetwork","objectBasedRate","rateClass","success","warning","danger","createElement","Fragment","className","metric","metricLabel","metricValue","toFixed","metricSubtext","cacheHits","revalidations","deduplications","rates","averageResponseTime","averageCachedResponseTime"],"sources":["CacheMetrics.tsx"],"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 classNames from \"classnames\";\nimport React from \"react\";\nimport type { MetricsSnapshot } from \"../types/index.js\";\nimport { formatNumber, formatTime } from \"../utils/format.js\";\nimport styles from \"./MonitoringPanel.module.scss\";\n\nconst CACHE_HIT_EXCELLENT = 0.8;\nconst CACHE_HIT_GOOD = 0.5;\n\nexport interface CacheMetricsProps {\n metrics: MetricsSnapshot;\n}\n\nexport const CacheMetrics: React.FC<CacheMetricsProps> = ({ metrics }) => {\n const totalObjects = metrics.aggregates.totalObjectsFromCache\n + metrics.aggregates.totalObjectsFromNetwork;\n const objectBasedRate = totalObjects > 0\n ? metrics.aggregates.totalObjectsFromCache / totalObjects\n : 0;\n const rateClass = objectBasedRate >= CACHE_HIT_EXCELLENT\n ? styles.success\n : objectBasedRate >= CACHE_HIT_GOOD\n ? styles.warning\n : styles.danger;\n\n return (\n <>\n <div className={styles.metric}>\n <span className={styles.metricLabel}>Cache Hit Rate</span>\n <span className={classNames(styles.metricValue, rateClass)}>\n {(objectBasedRate * 100).toFixed(0)}%\n </span>\n <span className={styles.metricSubtext}>\n {formatNumber(metrics.aggregates.totalObjectsFromCache)} /{\" \"}\n {formatNumber(totalObjects)} objects\n </span>\n </div>\n\n <div className={styles.metric}>\n <span className={styles.metricLabel}>Cache Savings</span>\n <span className={classNames(styles.metricValue, styles.success)}>\n {formatNumber(\n metrics.aggregates.cacheHits\n + metrics.aggregates.revalidations\n + metrics.aggregates.deduplications,\n )} requests saved\n </span>\n <span className={styles.metricSubtext}>\n {formatNumber(metrics.aggregates.deduplications)} deduped\n </span>\n </div>\n\n <div className={styles.metric}>\n <span className={styles.metricLabel}>Avg Response</span>\n <span className={styles.metricValue}>\n {formatTime(metrics.rates.averageResponseTime)}\n </span>\n <span className={styles.metricSubtext}>\n Cache: {formatTime(metrics.rates.averageCachedResponseTime)}\n </span>\n </div>\n </>\n );\n};\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,124 @@
1
+ /*
2
+ * Copyright 2025 Palantir Technologies, Inc. All rights reserved.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ import { Icon, Tag, Tooltip } from "@blueprintjs/core";
18
+ import classNames from "classnames";
19
+ import React, { useState } from "react";
20
+ import styles from "./ComponentCard.module.scss.js";
21
+ import { HookRow } from "./HookRow.js";
22
+ import { resolveComponentName } from "./resolveComponentName.js";
23
+ export const ComponentCard = ({
24
+ componentId,
25
+ bindings,
26
+ formatTime = ms => `${ms.toFixed(1)}ms`,
27
+ monitorStore,
28
+ style,
29
+ issues = []
30
+ }) => {
31
+ const [expanded, setExpanded] = useState(false);
32
+ if (bindings.length === 0) {
33
+ return null;
34
+ }
35
+ const componentName = resolveComponentName(bindings);
36
+ const totalRenders = bindings.reduce((sum, b) => sum + b.renderCount, 0);
37
+ const avgRenderDuration = bindings.reduce((sum, b) => sum + b.avgRenderDuration, 0) / bindings.length;
38
+ const hasWarnings = bindings.length > 10;
39
+ const errorCount = issues.filter(i => i.severity === "error").length;
40
+ const warningCount = issues.filter(i => i.severity === "warning").length;
41
+ const healthStatus = errorCount > 0 ? "error" : warningCount > 0 ? "warning" : "healthy";
42
+ return /*#__PURE__*/React.createElement("div", {
43
+ className: styles.componentCard,
44
+ style: style
45
+ }, /*#__PURE__*/React.createElement("div", {
46
+ className: styles.header,
47
+ onClick: () => setExpanded(!expanded)
48
+ }, /*#__PURE__*/React.createElement("div", {
49
+ className: styles.headerLeft
50
+ }, /*#__PURE__*/React.createElement(Icon, {
51
+ icon: expanded ? "chevron-down" : "chevron-right",
52
+ size: 14,
53
+ className: styles.expandIcon
54
+ }), /*#__PURE__*/React.createElement("span", {
55
+ className: classNames(styles.healthDot, styles[`health_${healthStatus}`])
56
+ }), /*#__PURE__*/React.createElement("span", {
57
+ className: styles.componentName
58
+ }, componentName)), /*#__PURE__*/React.createElement("div", {
59
+ className: styles.headerRight
60
+ }, hasWarnings && /*#__PURE__*/React.createElement(Tooltip, {
61
+ content: "This component has many hooks"
62
+ }, /*#__PURE__*/React.createElement(Tag, {
63
+ minimal: true,
64
+ intent: "warning",
65
+ className: styles.warningTag
66
+ }, /*#__PURE__*/React.createElement(Icon, {
67
+ icon: "warning-sign",
68
+ size: 10
69
+ }))), /*#__PURE__*/React.createElement(Tooltip, {
70
+ content: `${bindings.length} OSDK hooks`
71
+ }, /*#__PURE__*/React.createElement(Tag, {
72
+ minimal: true,
73
+ intent: "primary",
74
+ className: styles.hookCountTag
75
+ }, bindings.length)), issues.length > 0 && /*#__PURE__*/React.createElement(Tooltip, {
76
+ content: `${issues.length} issue${issues.length !== 1 ? "s" : ""}`
77
+ }, /*#__PURE__*/React.createElement(Tag, {
78
+ minimal: true,
79
+ intent: errorCount > 0 ? "danger" : "warning",
80
+ className: styles.issueCountTag
81
+ }, /*#__PURE__*/React.createElement(Icon, {
82
+ icon: "warning-sign",
83
+ size: 10
84
+ }), " ", issues.length)), issues.length === 0 && /*#__PURE__*/React.createElement("span", {
85
+ className: styles.healthyLabel
86
+ }, "healthy"), totalRenders > 0 && /*#__PURE__*/React.createElement(Tooltip, {
87
+ content: `${totalRenders} total renders`
88
+ }, /*#__PURE__*/React.createElement("div", {
89
+ className: styles.renderCount
90
+ }, /*#__PURE__*/React.createElement(Icon, {
91
+ icon: "refresh",
92
+ size: 10
93
+ }), /*#__PURE__*/React.createElement("span", null, totalRenders))), avgRenderDuration > 0 && /*#__PURE__*/React.createElement(Tooltip, {
94
+ content: `Average render time`
95
+ }, /*#__PURE__*/React.createElement("div", {
96
+ className: styles.avgDuration
97
+ }, /*#__PURE__*/React.createElement(Icon, {
98
+ icon: "time",
99
+ size: 10
100
+ }), /*#__PURE__*/React.createElement("span", null, formatTime(avgRenderDuration)))))), expanded && /*#__PURE__*/React.createElement("div", {
101
+ className: styles.body
102
+ }, /*#__PURE__*/React.createElement("div", {
103
+ className: styles.hooks
104
+ }, bindings.map((binding, index) => /*#__PURE__*/React.createElement(HookRow, {
105
+ key: `${binding.querySignature}-${index}`,
106
+ binding: binding,
107
+ formatTime: formatTime,
108
+ monitorStore: monitorStore
109
+ }))), issues.length > 0 && /*#__PURE__*/React.createElement("div", {
110
+ className: styles.inlineIssues
111
+ }, issues.map(issue => /*#__PURE__*/React.createElement("div", {
112
+ key: issue.id,
113
+ className: classNames(styles.inlineIssue, styles[`inlineIssue_${issue.severity}`])
114
+ }, /*#__PURE__*/React.createElement(Icon, {
115
+ icon: issue.severity === "error" ? "error" : issue.severity === "warning" ? "warning-sign" : "info-sign",
116
+ size: 12,
117
+ intent: issue.severity === "error" ? "danger" : issue.severity === "warning" ? "warning" : "primary"
118
+ }), /*#__PURE__*/React.createElement("span", {
119
+ className: styles.inlineIssueText
120
+ }, issue.title, issue.suggestion && /*#__PURE__*/React.createElement("span", {
121
+ className: styles.inlineIssueSuggestion
122
+ }, " \u2192 ", issue.suggestion)))))));
123
+ };
124
+ //# sourceMappingURL=ComponentCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ComponentCard.js","names":["Icon","Tag","Tooltip","classNames","React","useState","styles","HookRow","resolveComponentName","ComponentCard","componentId","bindings","formatTime","ms","toFixed","monitorStore","style","issues","expanded","setExpanded","length","componentName","totalRenders","reduce","sum","b","renderCount","avgRenderDuration","hasWarnings","errorCount","filter","i","severity","warningCount","healthStatus","createElement","className","componentCard","header","onClick","headerLeft","icon","size","expandIcon","healthDot","headerRight","content","minimal","intent","warningTag","hookCountTag","issueCountTag","healthyLabel","avgDuration","body","hooks","map","binding","index","key","querySignature","inlineIssues","issue","id","inlineIssue","inlineIssueText","title","suggestion","inlineIssueSuggestion"],"sources":["ComponentCard.tsx"],"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 { Icon, Tag, Tooltip } from \"@blueprintjs/core\";\nimport classNames from \"classnames\";\nimport React, { useState } from \"react\";\nimport type { MonitorStore } from \"../store/MonitorStore.js\";\nimport type { ComponentHookBinding } from \"../utils/ComponentQueryRegistry.js\";\nimport styles from \"./ComponentCard.module.scss\";\nimport { HookRow } from \"./HookRow.js\";\nimport type { Issue } from \"./issueTypes.js\";\nimport { resolveComponentName } from \"./resolveComponentName.js\";\n\nexport interface ComponentCardProps {\n componentId: string;\n bindings: ComponentHookBinding[];\n formatTime?: (ms: number) => string;\n monitorStore?: MonitorStore;\n style?: React.CSSProperties;\n issues?: Issue[];\n}\n\nexport const ComponentCard: React.FC<ComponentCardProps> = ({\n componentId,\n bindings,\n formatTime = (ms) => `${ms.toFixed(1)}ms`,\n monitorStore,\n style,\n issues = [],\n}) => {\n const [expanded, setExpanded] = useState(false);\n\n if (bindings.length === 0) {\n return null;\n }\n\n const componentName = resolveComponentName(bindings);\n\n const totalRenders = bindings.reduce((sum, b) => sum + b.renderCount, 0);\n const avgRenderDuration = bindings.reduce(\n (sum, b) => sum + b.avgRenderDuration,\n 0,\n ) / bindings.length;\n\n const hasWarnings = bindings.length > 10;\n\n const errorCount = issues.filter(i => i.severity === \"error\").length;\n const warningCount = issues.filter(i => i.severity === \"warning\").length;\n const healthStatus: \"healthy\" | \"warning\" | \"error\" = errorCount > 0\n ? \"error\"\n : warningCount > 0\n ? \"warning\"\n : \"healthy\";\n\n return (\n <div className={styles.componentCard} style={style}>\n <div\n className={styles.header}\n onClick={() => setExpanded(!expanded)}\n >\n <div className={styles.headerLeft}>\n <Icon\n icon={expanded ? \"chevron-down\" : \"chevron-right\"}\n size={14}\n className={styles.expandIcon}\n />\n <span\n className={classNames(\n styles.healthDot,\n styles[`health_${healthStatus}`],\n )}\n />\n <span className={styles.componentName}>{componentName}</span>\n </div>\n\n <div className={styles.headerRight}>\n {hasWarnings && (\n <Tooltip content=\"This component has many hooks\">\n <Tag minimal intent=\"warning\" className={styles.warningTag}>\n <Icon icon=\"warning-sign\" size={10} />\n </Tag>\n </Tooltip>\n )}\n <Tooltip content={`${bindings.length} OSDK hooks`}>\n <Tag minimal intent=\"primary\" className={styles.hookCountTag}>\n {bindings.length}\n </Tag>\n </Tooltip>\n {issues.length > 0 && (\n <Tooltip\n content={`${issues.length} issue${\n issues.length !== 1 ? \"s\" : \"\"\n }`}\n >\n <Tag\n minimal\n intent={errorCount > 0 ? \"danger\" : \"warning\"}\n className={styles.issueCountTag}\n >\n <Icon icon=\"warning-sign\" size={10} /> {issues.length}\n </Tag>\n </Tooltip>\n )}\n {issues.length === 0 && (\n <span className={styles.healthyLabel}>healthy</span>\n )}\n {totalRenders > 0 && (\n <Tooltip content={`${totalRenders} total renders`}>\n <div className={styles.renderCount}>\n <Icon icon=\"refresh\" size={10} />\n <span>{totalRenders}</span>\n </div>\n </Tooltip>\n )}\n {avgRenderDuration > 0 && (\n <Tooltip content={`Average render time`}>\n <div className={styles.avgDuration}>\n <Icon icon=\"time\" size={10} />\n <span>{formatTime(avgRenderDuration)}</span>\n </div>\n </Tooltip>\n )}\n </div>\n </div>\n\n {expanded && (\n <div className={styles.body}>\n <div className={styles.hooks}>\n {bindings.map((binding, index) => (\n <HookRow\n key={`${binding.querySignature}-${index}`}\n binding={binding}\n formatTime={formatTime}\n monitorStore={monitorStore}\n />\n ))}\n </div>\n {issues.length > 0 && (\n <div className={styles.inlineIssues}>\n {issues.map(issue => (\n <div\n key={issue.id}\n className={classNames(\n styles.inlineIssue,\n styles[`inlineIssue_${issue.severity}`],\n )}\n >\n <Icon\n icon={issue.severity === \"error\"\n ? \"error\"\n : issue.severity === \"warning\"\n ? \"warning-sign\"\n : \"info-sign\"}\n size={12}\n intent={issue.severity === \"error\"\n ? \"danger\"\n : issue.severity === \"warning\"\n ? \"warning\"\n : \"primary\"}\n />\n <span className={styles.inlineIssueText}>\n {issue.title}\n {issue.suggestion && (\n <span className={styles.inlineIssueSuggestion}>\n {\" \\u2192 \"}\n {issue.suggestion}\n </span>\n )}\n </span>\n </div>\n ))}\n </div>\n )}\n </div>\n )}\n </div>\n );\n};\n"],"mappings":"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","ignoreList":[]}