@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.
- package/CHANGELOG.md +79 -0
- package/build/esm/DevToolsContext.js +19 -0
- package/build/esm/DevToolsContext.js.map +1 -0
- package/build/esm/components/ActionMetrics.js +89 -0
- package/build/esm/components/ActionMetrics.js.map +1 -0
- package/build/esm/components/BubbleChart.js +175 -0
- package/build/esm/components/BubbleChart.js.map +1 -0
- package/build/esm/components/BubbleChart.module.scss.js +6 -0
- package/build/esm/components/CacheInspectorTab.js +291 -0
- package/build/esm/components/CacheInspectorTab.js.map +1 -0
- package/build/esm/components/CacheInspectorTab.module.scss.js +39 -0
- package/build/esm/components/CacheMetrics.js +55 -0
- package/build/esm/components/CacheMetrics.js.map +1 -0
- package/build/esm/components/ComponentCard.js +124 -0
- package/build/esm/components/ComponentCard.js.map +1 -0
- package/build/esm/components/ComponentCard.module.scss.js +31 -0
- package/build/esm/components/ComputeTab.js +175 -0
- package/build/esm/components/ComputeTab.js.map +1 -0
- package/build/esm/components/CopyableCodeBlock.js +49 -0
- package/build/esm/components/CopyableCodeBlock.js.map +1 -0
- package/build/esm/components/CopyableCodeBlock.module.scss.js +10 -0
- package/build/esm/components/DebuggingTab.js +342 -0
- package/build/esm/components/DebuggingTab.js.map +1 -0
- package/build/esm/components/DebuggingTab.module.scss.js +18 -0
- package/build/esm/components/HookRow.js +180 -0
- package/build/esm/components/HookRow.js.map +1 -0
- package/build/esm/components/HookRow.module.scss.js +16 -0
- package/build/esm/components/ImprovementsTab.js +138 -0
- package/build/esm/components/ImprovementsTab.js.map +1 -0
- package/build/esm/components/ImprovementsTab.module.scss.js +30 -0
- package/build/esm/components/InspectorSelectionHeader.js +65 -0
- package/build/esm/components/InspectorSelectionHeader.js.map +1 -0
- package/build/esm/components/InterceptTab.js +862 -0
- package/build/esm/components/InterceptTab.js.map +1 -0
- package/build/esm/components/InterceptTab.module.scss.js +49 -0
- package/build/esm/components/IssueCard.js +115 -0
- package/build/esm/components/IssueCard.js.map +1 -0
- package/build/esm/components/IssueCard.module.scss.js +24 -0
- package/build/esm/components/LogEntryCard.js +94 -0
- package/build/esm/components/LogEntryCard.js.map +1 -0
- package/build/esm/components/LogEntryCard.module.scss.js +19 -0
- package/build/esm/components/MockEditor.js +316 -0
- package/build/esm/components/MockEditor.js.map +1 -0
- package/build/esm/components/MonitorErrorBoundary.js +64 -0
- package/build/esm/components/MonitorErrorBoundary.js.map +1 -0
- package/build/esm/components/MonitorErrorBoundary.module.scss.js +9 -0
- package/build/esm/components/MonitoringPanel.js +434 -0
- package/build/esm/components/MonitoringPanel.js.map +1 -0
- package/build/esm/components/MonitoringPanel.module.scss.js +81 -0
- package/build/esm/components/ObjectLoadingMetrics.js +60 -0
- package/build/esm/components/ObjectLoadingMetrics.js.map +1 -0
- package/build/esm/components/OsdkAppErrorBoundary.js +68 -0
- package/build/esm/components/OsdkAppErrorBoundary.js.map +1 -0
- package/build/esm/components/OsdkDevTools.js +40 -0
- package/build/esm/components/OsdkDevTools.js.map +1 -0
- package/build/esm/components/OverrideEditor.js +197 -0
- package/build/esm/components/OverrideEditor.js.map +1 -0
- package/build/esm/components/PerformanceTab.js +297 -0
- package/build/esm/components/PerformanceTab.js.map +1 -0
- package/build/esm/components/PrimitiveSelectionPanel.js +220 -0
- package/build/esm/components/PrimitiveSelectionPanel.js.map +1 -0
- package/build/esm/components/PrimitiveSelectionPanel.module.scss.js +26 -0
- package/build/esm/components/issueTypes.js +2 -0
- package/build/esm/components/issueTypes.js.map +1 -0
- package/build/esm/components/resolveComponentName.js +57 -0
- package/build/esm/components/resolveComponentName.js.map +1 -0
- package/build/esm/components/testHelpers.js +312 -0
- package/build/esm/components/testHelpers.js.map +1 -0
- package/build/esm/css.d.ts +20 -0
- package/build/esm/fiber/DegradationNotice.js +193 -0
- package/build/esm/fiber/DegradationNotice.js.map +1 -0
- package/build/esm/fiber/DevtoolsHook.js +252 -0
- package/build/esm/fiber/DevtoolsHook.js.map +1 -0
- package/build/esm/fiber/FiberAccess.js +65 -0
- package/build/esm/fiber/FiberAccess.js.map +1 -0
- package/build/esm/fiber/FiberInspection.js +140 -0
- package/build/esm/fiber/FiberInspection.js.map +1 -0
- package/build/esm/fiber/FiberTags.js +52 -0
- package/build/esm/fiber/FiberTags.js.map +1 -0
- package/build/esm/fiber/HookStateInspector.js +254 -0
- package/build/esm/fiber/HookStateInspector.js.map +1 -0
- package/build/esm/fiber/SafeFiberOperation.js +35 -0
- package/build/esm/fiber/SafeFiberOperation.js.map +1 -0
- package/build/esm/fiber/capabilities.js +180 -0
- package/build/esm/fiber/capabilities.js.map +1 -0
- package/build/esm/fiber/traverseFiber.js +129 -0
- package/build/esm/fiber/traverseFiber.js.map +1 -0
- package/build/esm/fiber/types.js +2 -0
- package/build/esm/fiber/types.js.map +1 -0
- package/build/esm/fiber/validation.js +155 -0
- package/build/esm/fiber/validation.js.map +1 -0
- package/build/esm/hooks/createPollingStore.js +81 -0
- package/build/esm/hooks/createPollingStore.js.map +1 -0
- package/build/esm/hooks/useActiveComponents.js +27 -0
- package/build/esm/hooks/useActiveComponents.js.map +1 -0
- package/build/esm/hooks/useComponentRegistry.js +25 -0
- package/build/esm/hooks/useComponentRegistry.js.map +1 -0
- package/build/esm/hooks/useComputeSelectors.js +43 -0
- package/build/esm/hooks/useComputeSelectors.js.map +1 -0
- package/build/esm/hooks/useConsoleLogs.js +46 -0
- package/build/esm/hooks/useConsoleLogs.js.map +1 -0
- package/build/esm/hooks/useInspectorSelection.js +93 -0
- package/build/esm/hooks/useInspectorSelection.js.map +1 -0
- package/build/esm/hooks/useMetrics.js +23 -0
- package/build/esm/hooks/useMetrics.js.map +1 -0
- package/build/esm/hooks/usePersistedState.js +89 -0
- package/build/esm/hooks/usePersistedState.js.map +1 -0
- package/build/esm/hooks/useRecommendations.js +123 -0
- package/build/esm/hooks/useRecommendations.js.map +1 -0
- package/build/esm/hooks/useSharedTick.js +49 -0
- package/build/esm/hooks/useSharedTick.js.map +1 -0
- package/build/esm/hooks/useTimeElapsed.js +51 -0
- package/build/esm/hooks/useTimeElapsed.js.map +1 -0
- package/build/esm/hooks/useTrackerSubscription.js +97 -0
- package/build/esm/hooks/useTrackerSubscription.js.map +1 -0
- package/build/esm/hooks/useUnusedFieldAnalysis.js +99 -0
- package/build/esm/hooks/useUnusedFieldAnalysis.js.map +1 -0
- package/build/esm/index.js +31 -0
- package/build/esm/index.js.map +1 -0
- package/build/esm/inspector/ClickToInspectSystem.js +228 -0
- package/build/esm/inspector/ClickToInspectSystem.js.map +1 -0
- package/build/esm/inspector/components/ComponentLabel.js +175 -0
- package/build/esm/inspector/components/ComponentLabel.js.map +1 -0
- package/build/esm/inspector/components/ComponentLabel.module.scss.js +12 -0
- package/build/esm/inspector/components/InspectorBanner.js +79 -0
- package/build/esm/inspector/components/InspectorBanner.js.map +1 -0
- package/build/esm/inspector/components/InspectorOverlay.js +149 -0
- package/build/esm/inspector/components/InspectorOverlay.js.map +1 -0
- package/build/esm/inspector/components/SelectionHighlight.js +74 -0
- package/build/esm/inspector/components/SelectionHighlight.js.map +1 -0
- package/build/esm/inspector/createClickToInspect.js +21 -0
- package/build/esm/inspector/createClickToInspect.js.map +1 -0
- package/build/esm/inspector/hooks/useAnimatedBounds.js +167 -0
- package/build/esm/inspector/hooks/useAnimatedBounds.js.map +1 -0
- package/build/esm/inspector/index.js +40 -0
- package/build/esm/inspector/index.js.map +1 -0
- package/build/esm/inspector/inspectorController.js +328 -0
- package/build/esm/inspector/inspectorController.js.map +1 -0
- package/build/esm/inspector/types.js +2 -0
- package/build/esm/inspector/types.js.map +1 -0
- package/build/esm/inspector/utils/elementBounds.js +72 -0
- package/build/esm/inspector/utils/elementBounds.js.map +1 -0
- package/build/esm/inspector/utils/interpolation.js +26 -0
- package/build/esm/inspector/utils/interpolation.js.map +1 -0
- package/build/esm/inspector/utils/labelPositioning.js +62 -0
- package/build/esm/inspector/utils/labelPositioning.js.map +1 -0
- package/build/esm/mocking/MockCacheKeyGenerator.js +109 -0
- package/build/esm/mocking/MockCacheKeyGenerator.js.map +1 -0
- package/build/esm/mocking/MockManager.js +281 -0
- package/build/esm/mocking/MockManager.js.map +1 -0
- package/build/esm/prototyping/PrototypeOverrideStore.js +66 -0
- package/build/esm/prototyping/PrototypeOverrideStore.js.map +1 -0
- package/build/esm/prototyping/index.js +18 -0
- package/build/esm/prototyping/index.js.map +1 -0
- package/build/esm/public/vite.js +19 -0
- package/build/esm/public/vite.js.map +1 -0
- package/build/esm/register.js +41 -0
- package/build/esm/register.js.map +1 -0
- package/build/esm/scss.d.ts +20 -0
- package/build/esm/store/ComputeStore.js +269 -0
- package/build/esm/store/ComputeStore.js.map +1 -0
- package/build/esm/store/ConsoleLogStore.js +289 -0
- package/build/esm/store/ConsoleLogStore.js.map +1 -0
- package/build/esm/store/MetricsStore.js +428 -0
- package/build/esm/store/MetricsStore.js.map +1 -0
- package/build/esm/store/MonitorStore.js +288 -0
- package/build/esm/store/MonitorStore.js.map +1 -0
- package/build/esm/store/SubscribableStore.js +38 -0
- package/build/esm/store/SubscribableStore.js.map +1 -0
- package/build/esm/store/WindowErrorStore.js +195 -0
- package/build/esm/store/WindowErrorStore.js.map +1 -0
- package/build/esm/styles.css +19441 -0
- package/build/esm/styles.js +31 -0
- package/build/esm/styles.js.map +1 -0
- package/build/esm/types/compute.js +2 -0
- package/build/esm/types/compute.js.map +1 -0
- package/build/esm/types/emissions.js +2 -0
- package/build/esm/types/emissions.js.map +1 -0
- package/build/esm/types/index.js +23 -0
- package/build/esm/types/index.js.map +1 -0
- package/build/esm/utils/ActionLifecycleTracker.js +178 -0
- package/build/esm/utils/ActionLifecycleTracker.js.map +1 -0
- package/build/esm/utils/CacheEfficiencyAnalyzer.js +198 -0
- package/build/esm/utils/CacheEfficiencyAnalyzer.js.map +1 -0
- package/build/esm/utils/CircularBuffer.js +96 -0
- package/build/esm/utils/CircularBuffer.js.map +1 -0
- package/build/esm/utils/ComponentContextCapture.js +215 -0
- package/build/esm/utils/ComponentContextCapture.js.map +1 -0
- package/build/esm/utils/ComponentPrimitiveDiscovery.js +173 -0
- package/build/esm/utils/ComponentPrimitiveDiscovery.js.map +1 -0
- package/build/esm/utils/ComponentQueryRegistry.js +340 -0
- package/build/esm/utils/ComponentQueryRegistry.js.map +1 -0
- package/build/esm/utils/ComputeMonitor.js +199 -0
- package/build/esm/utils/ComputeMonitor.js.map +1 -0
- package/build/esm/utils/EventTimeline.js +130 -0
- package/build/esm/utils/EventTimeline.js.map +1 -0
- package/build/esm/utils/LinkTraversalTracker.js +116 -0
- package/build/esm/utils/LinkTraversalTracker.js.map +1 -0
- package/build/esm/utils/MockDataGenerator.js +473 -0
- package/build/esm/utils/MockDataGenerator.js.map +1 -0
- package/build/esm/utils/ObservableClientMonitor.js +768 -0
- package/build/esm/utils/ObservableClientMonitor.js.map +1 -0
- package/build/esm/utils/PerformanceRecommendationEngine.js +185 -0
- package/build/esm/utils/PerformanceRecommendationEngine.js.map +1 -0
- package/build/esm/utils/PropertyAccessTracker.js +238 -0
- package/build/esm/utils/PropertyAccessTracker.js.map +1 -0
- package/build/esm/utils/RecommendationMatcher.js +53 -0
- package/build/esm/utils/RecommendationMatcher.js.map +1 -0
- package/build/esm/utils/SubscriptionTracker.js +132 -0
- package/build/esm/utils/SubscriptionTracker.js.map +1 -0
- package/build/esm/utils/UnusedFieldAnalyzer.js +186 -0
- package/build/esm/utils/UnusedFieldAnalyzer.js.map +1 -0
- package/build/esm/utils/WaterfallDetector.js +200 -0
- package/build/esm/utils/WaterfallDetector.js.map +1 -0
- package/build/esm/utils/computePayload.js +37 -0
- package/build/esm/utils/computePayload.js.map +1 -0
- package/build/esm/utils/computeRequest.js +29 -0
- package/build/esm/utils/computeRequest.js.map +1 -0
- package/build/esm/utils/format.js +69 -0
- package/build/esm/utils/format.js.map +1 -0
- package/build/esm/utils/logger.js +31 -0
- package/build/esm/utils/logger.js.map +1 -0
- package/build/esm/vite/constants.js +18 -0
- package/build/esm/vite/constants.js.map +1 -0
- package/build/esm/vite/hookInstaller.js +99 -0
- package/build/esm/vite/hookInstaller.js.map +1 -0
- package/build/esm/vite/index.js +77 -0
- package/build/esm/vite/index.js.map +1 -0
- package/build/types/DevToolsContext.d.ts +3 -0
- package/build/types/DevToolsContext.d.ts.map +1 -0
- package/build/types/components/ActionMetrics.d.ts +6 -0
- package/build/types/components/ActionMetrics.d.ts.map +1 -0
- package/build/types/components/BubbleChart.d.ts +10 -0
- package/build/types/components/BubbleChart.d.ts.map +1 -0
- package/build/types/components/CacheInspectorTab.d.ts +6 -0
- package/build/types/components/CacheInspectorTab.d.ts.map +1 -0
- package/build/types/components/CacheMetrics.d.ts +6 -0
- package/build/types/components/CacheMetrics.d.ts.map +1 -0
- package/build/types/components/ComponentCard.d.ts +13 -0
- package/build/types/components/ComponentCard.d.ts.map +1 -0
- package/build/types/components/ComputeTab.d.ts +6 -0
- package/build/types/components/ComputeTab.d.ts.map +1 -0
- package/build/types/components/CopyableCodeBlock.d.ts +7 -0
- package/build/types/components/CopyableCodeBlock.d.ts.map +1 -0
- package/build/types/components/DebuggingTab.d.ts +6 -0
- package/build/types/components/DebuggingTab.d.ts.map +1 -0
- package/build/types/components/HookRow.d.ts +9 -0
- package/build/types/components/HookRow.d.ts.map +1 -0
- package/build/types/components/ImprovementsTab.d.ts +7 -0
- package/build/types/components/ImprovementsTab.d.ts.map +1 -0
- package/build/types/components/InspectorSelectionHeader.d.ts +12 -0
- package/build/types/components/InspectorSelectionHeader.d.ts.map +1 -0
- package/build/types/components/InterceptTab.d.ts +126 -0
- package/build/types/components/InterceptTab.d.ts.map +1 -0
- package/build/types/components/IssueCard.d.ts +8 -0
- package/build/types/components/IssueCard.d.ts.map +1 -0
- package/build/types/components/LogEntryCard.d.ts +7 -0
- package/build/types/components/LogEntryCard.d.ts.map +1 -0
- package/build/types/components/MockEditor.d.ts +58 -0
- package/build/types/components/MockEditor.d.ts.map +1 -0
- package/build/types/components/MonitorErrorBoundary.d.ts +16 -0
- package/build/types/components/MonitorErrorBoundary.d.ts.map +1 -0
- package/build/types/components/MonitoringPanel.d.ts +8 -0
- package/build/types/components/MonitoringPanel.d.ts.map +1 -0
- package/build/types/components/ObjectLoadingMetrics.d.ts +7 -0
- package/build/types/components/ObjectLoadingMetrics.d.ts.map +1 -0
- package/build/types/components/OsdkAppErrorBoundary.d.ts +18 -0
- package/build/types/components/OsdkAppErrorBoundary.d.ts.map +1 -0
- package/build/types/components/OsdkDevTools.d.ts +2 -0
- package/build/types/components/OsdkDevTools.d.ts.map +1 -0
- package/build/types/components/OverrideEditor.d.ts +26 -0
- package/build/types/components/OverrideEditor.d.ts.map +1 -0
- package/build/types/components/PerformanceTab.d.ts +8 -0
- package/build/types/components/PerformanceTab.d.ts.map +1 -0
- package/build/types/components/PrimitiveSelectionPanel.d.ts +28 -0
- package/build/types/components/PrimitiveSelectionPanel.d.ts.map +1 -0
- package/build/types/components/issueTypes.d.ts +16 -0
- package/build/types/components/issueTypes.d.ts.map +1 -0
- package/build/types/components/resolveComponentName.d.ts +3 -0
- package/build/types/components/resolveComponentName.d.ts.map +1 -0
- package/build/types/components/testHelpers.d.ts +2 -0
- package/build/types/components/testHelpers.d.ts.map +1 -0
- package/build/types/css.d.d.ts +4 -0
- package/build/types/css.d.d.ts.map +1 -0
- package/build/types/fiber/DegradationNotice.d.ts +8 -0
- package/build/types/fiber/DegradationNotice.d.ts.map +1 -0
- package/build/types/fiber/DevtoolsHook.d.ts +7 -0
- package/build/types/fiber/DevtoolsHook.d.ts.map +1 -0
- package/build/types/fiber/FiberAccess.d.ts +2 -0
- package/build/types/fiber/FiberAccess.d.ts.map +1 -0
- package/build/types/fiber/FiberInspection.d.ts +6 -0
- package/build/types/fiber/FiberInspection.d.ts.map +1 -0
- package/build/types/fiber/FiberTags.d.ts +33 -0
- package/build/types/fiber/FiberTags.d.ts.map +1 -0
- package/build/types/fiber/HookStateInspector.d.ts +45 -0
- package/build/types/fiber/HookStateInspector.d.ts.map +1 -0
- package/build/types/fiber/SafeFiberOperation.d.ts +7 -0
- package/build/types/fiber/SafeFiberOperation.d.ts.map +1 -0
- package/build/types/fiber/capabilities.d.ts +38 -0
- package/build/types/fiber/capabilities.d.ts.map +1 -0
- package/build/types/fiber/traverseFiber.d.ts +5 -0
- package/build/types/fiber/traverseFiber.d.ts.map +1 -0
- package/build/types/fiber/types.d.ts +87 -0
- package/build/types/fiber/types.d.ts.map +1 -0
- package/build/types/fiber/validation.d.ts +10 -0
- package/build/types/fiber/validation.d.ts.map +1 -0
- package/build/types/hooks/createPollingStore.d.ts +5 -0
- package/build/types/hooks/createPollingStore.d.ts.map +1 -0
- package/build/types/hooks/useActiveComponents.d.ts +3 -0
- package/build/types/hooks/useActiveComponents.d.ts.map +1 -0
- package/build/types/hooks/useComponentRegistry.d.ts +3 -0
- package/build/types/hooks/useComponentRegistry.d.ts.map +1 -0
- package/build/types/hooks/useComputeSelectors.d.ts +7 -0
- package/build/types/hooks/useComputeSelectors.d.ts.map +1 -0
- package/build/types/hooks/useConsoleLogs.d.ts +7 -0
- package/build/types/hooks/useConsoleLogs.d.ts.map +1 -0
- package/build/types/hooks/useInspectorSelection.d.ts +9 -0
- package/build/types/hooks/useInspectorSelection.d.ts.map +1 -0
- package/build/types/hooks/useMetrics.d.ts +3 -0
- package/build/types/hooks/useMetrics.d.ts.map +1 -0
- package/build/types/hooks/usePersistedState.d.ts +1 -0
- package/build/types/hooks/usePersistedState.d.ts.map +1 -0
- package/build/types/hooks/useRecommendations.d.ts +10 -0
- package/build/types/hooks/useRecommendations.d.ts.map +1 -0
- package/build/types/hooks/useSharedTick.d.ts +1 -0
- package/build/types/hooks/useSharedTick.d.ts.map +1 -0
- package/build/types/hooks/useTimeElapsed.d.ts +1 -0
- package/build/types/hooks/useTimeElapsed.d.ts.map +1 -0
- package/build/types/hooks/useTrackerSubscription.d.ts +16 -0
- package/build/types/hooks/useTrackerSubscription.d.ts.map +1 -0
- package/build/types/hooks/useUnusedFieldAnalysis.d.ts +8 -0
- package/build/types/hooks/useUnusedFieldAnalysis.d.ts.map +1 -0
- package/build/types/index.d.ts +21 -0
- package/build/types/index.d.ts.map +1 -0
- package/build/types/inspector/ClickToInspectSystem.d.ts +40 -0
- package/build/types/inspector/ClickToInspectSystem.d.ts.map +1 -0
- package/build/types/inspector/components/ComponentLabel.d.ts +3 -0
- package/build/types/inspector/components/ComponentLabel.d.ts.map +1 -0
- package/build/types/inspector/components/InspectorBanner.d.ts +5 -0
- package/build/types/inspector/components/InspectorBanner.d.ts.map +1 -0
- package/build/types/inspector/components/InspectorOverlay.d.ts +3 -0
- package/build/types/inspector/components/InspectorOverlay.d.ts.map +1 -0
- package/build/types/inspector/components/SelectionHighlight.d.ts +3 -0
- package/build/types/inspector/components/SelectionHighlight.d.ts.map +1 -0
- package/build/types/inspector/createClickToInspect.d.ts +3 -0
- package/build/types/inspector/createClickToInspect.d.ts.map +1 -0
- package/build/types/inspector/hooks/useAnimatedBounds.d.ts +2 -0
- package/build/types/inspector/hooks/useAnimatedBounds.d.ts.map +1 -0
- package/build/types/inspector/index.d.ts +13 -0
- package/build/types/inspector/index.d.ts.map +1 -0
- package/build/types/inspector/inspectorController.d.ts +2 -0
- package/build/types/inspector/inspectorController.d.ts.map +1 -0
- package/build/types/inspector/types.d.ts +94 -0
- package/build/types/inspector/types.d.ts.map +1 -0
- package/build/types/inspector/utils/elementBounds.d.ts +3 -0
- package/build/types/inspector/utils/elementBounds.d.ts.map +1 -0
- package/build/types/inspector/utils/interpolation.d.ts +7 -0
- package/build/types/inspector/utils/interpolation.d.ts.map +1 -0
- package/build/types/inspector/utils/labelPositioning.d.ts +3 -0
- package/build/types/inspector/utils/labelPositioning.d.ts.map +1 -0
- package/build/types/mocking/MockCacheKeyGenerator.d.ts +41 -0
- package/build/types/mocking/MockCacheKeyGenerator.d.ts.map +1 -0
- package/build/types/mocking/MockManager.d.ts +103 -0
- package/build/types/mocking/MockManager.d.ts.map +1 -0
- package/build/types/prototyping/PrototypeOverrideStore.d.ts +33 -0
- package/build/types/prototyping/PrototypeOverrideStore.d.ts.map +1 -0
- package/build/types/prototyping/index.d.ts +1 -0
- package/build/types/prototyping/index.d.ts.map +1 -0
- package/build/types/public/vite.d.ts +2 -0
- package/build/types/public/vite.d.ts.map +1 -0
- package/build/types/register.d.ts +1 -0
- package/build/types/register.d.ts.map +1 -0
- package/build/types/scss.d.d.ts +6 -0
- package/build/types/scss.d.d.ts.map +1 -0
- package/build/types/store/ComputeStore.d.ts +47 -0
- package/build/types/store/ComputeStore.d.ts.map +1 -0
- package/build/types/store/ConsoleLogStore.d.ts +29 -0
- package/build/types/store/ConsoleLogStore.d.ts.map +1 -0
- package/build/types/store/MetricsStore.d.ts +42 -0
- package/build/types/store/MetricsStore.d.ts.map +1 -0
- package/build/types/store/MonitorStore.d.ts +86 -0
- package/build/types/store/MonitorStore.d.ts.map +1 -0
- package/build/types/store/SubscribableStore.d.ts +6 -0
- package/build/types/store/SubscribableStore.d.ts.map +1 -0
- package/build/types/store/WindowErrorStore.d.ts +32 -0
- package/build/types/store/WindowErrorStore.d.ts.map +1 -0
- package/build/types/styles.d.ts +1 -0
- package/build/types/styles.d.ts.map +1 -0
- package/build/types/types/compute.d.ts +73 -0
- package/build/types/types/compute.d.ts.map +1 -0
- package/build/types/types/emissions.d.ts +24 -0
- package/build/types/types/emissions.d.ts.map +1 -0
- package/build/types/types/index.d.ts +143 -0
- package/build/types/types/index.d.ts.map +1 -0
- package/build/types/utils/ActionLifecycleTracker.d.ts +39 -0
- package/build/types/utils/ActionLifecycleTracker.d.ts.map +1 -0
- package/build/types/utils/CacheEfficiencyAnalyzer.d.ts +45 -0
- package/build/types/utils/CacheEfficiencyAnalyzer.d.ts.map +1 -0
- package/build/types/utils/CircularBuffer.d.ts +18 -0
- package/build/types/utils/CircularBuffer.d.ts.map +1 -0
- package/build/types/utils/ComponentContextCapture.d.ts +29 -0
- package/build/types/utils/ComponentContextCapture.d.ts.map +1 -0
- package/build/types/utils/ComponentPrimitiveDiscovery.d.ts +62 -0
- package/build/types/utils/ComponentPrimitiveDiscovery.d.ts.map +1 -0
- package/build/types/utils/ComponentQueryRegistry.d.ts +91 -0
- package/build/types/utils/ComponentQueryRegistry.d.ts.map +1 -0
- package/build/types/utils/ComputeMonitor.d.ts +14 -0
- package/build/types/utils/ComputeMonitor.d.ts.map +1 -0
- package/build/types/utils/EventTimeline.d.ts +102 -0
- package/build/types/utils/EventTimeline.d.ts.map +1 -0
- package/build/types/utils/LinkTraversalTracker.d.ts +43 -0
- package/build/types/utils/LinkTraversalTracker.d.ts.map +1 -0
- package/build/types/utils/MockDataGenerator.d.ts +23 -0
- package/build/types/utils/MockDataGenerator.d.ts.map +1 -0
- package/build/types/utils/ObservableClientMonitor.d.ts +62 -0
- package/build/types/utils/ObservableClientMonitor.d.ts.map +1 -0
- package/build/types/utils/PerformanceRecommendationEngine.d.ts +67 -0
- package/build/types/utils/PerformanceRecommendationEngine.d.ts.map +1 -0
- package/build/types/utils/PropertyAccessTracker.d.ts +50 -0
- package/build/types/utils/PropertyAccessTracker.d.ts.map +1 -0
- package/build/types/utils/RecommendationMatcher.d.ts +5 -0
- package/build/types/utils/RecommendationMatcher.d.ts.map +1 -0
- package/build/types/utils/SubscriptionTracker.d.ts +17 -0
- package/build/types/utils/SubscriptionTracker.d.ts.map +1 -0
- package/build/types/utils/UnusedFieldAnalyzer.d.ts +46 -0
- package/build/types/utils/UnusedFieldAnalyzer.d.ts.map +1 -0
- package/build/types/utils/WaterfallDetector.d.ts +28 -0
- package/build/types/utils/WaterfallDetector.d.ts.map +1 -0
- package/build/types/utils/computePayload.d.ts +3 -0
- package/build/types/utils/computePayload.d.ts.map +1 -0
- package/build/types/utils/computeRequest.d.ts +20 -0
- package/build/types/utils/computeRequest.d.ts.map +1 -0
- package/build/types/utils/format.d.ts +5 -0
- package/build/types/utils/format.d.ts.map +1 -0
- package/build/types/utils/logger.d.ts +2 -0
- package/build/types/utils/logger.d.ts.map +1 -0
- package/build/types/vite/constants.d.ts +1 -0
- package/build/types/vite/constants.d.ts.map +1 -0
- package/build/types/vite/hookInstaller.d.ts +1 -0
- package/build/types/vite/hookInstaller.d.ts.map +1 -0
- package/build/types/vite/index.d.ts +20 -0
- package/build/types/vite/index.d.ts.map +1 -0
- 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":[]}
|