Skip to content

feat: add proxyWidgetSelector support to SubgraphNode#10840

Open
jtydhr88 wants to merge 1 commit intomainfrom
proxy-widget-selector
Open

feat: add proxyWidgetSelector support to SubgraphNode#10840
jtydhr88 wants to merge 1 commit intomainfrom
proxy-widget-selector

Conversation

@jtydhr88
Copy link
Copy Markdown
Collaborator

@jtydhr88 jtydhr88 commented Apr 3, 2026

Summary

Need BE changes for blueprints Comfy-Org/ComfyUI#13275

Allow subgraph nodes to conditionally show/hide groups of promoted widgets via a combo dropdown selector. Configured through the proxyWidgetSelector property in node properties.

Screenshots (if applicable)

before
569451279-a1483a27-6a61-4e65-833f-2f537c0d8d47

after
https://github.com/user-attachments/assets/18e11041-7ef3-47cb-9617-b00a252ba3cb

┆Issue is synchronized with this Notion page by Unito

@jtydhr88 jtydhr88 requested a review from a team April 3, 2026 22:52
@dosubot dosubot bot added the size:M This PR changes 30-99 lines, ignoring generated files. label Apr 3, 2026
@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 3, 2026

🎭 Playwright: ✅ 939 passed, 0 failed · 3 flaky

📊 Browser Reports
  • chromium: View Report (✅ 925 / ❌ 0 / ⚠️ 3 / ⏭️ 1)
  • chromium-2x: View Report (✅ 2 / ❌ 0 / ⚠️ 0 / ⏭️ 0)
  • chromium-0.5x: View Report (✅ 1 / ❌ 0 / ⚠️ 0 / ⏭️ 0)
  • mobile-chrome: View Report (✅ 11 / ❌ 0 / ⚠️ 0 / ⏭️ 0)

@coderabbitai
Copy link
Copy Markdown
Contributor

coderabbitai bot commented Apr 3, 2026

📝 Walkthrough

Walkthrough

The changes introduce selector-driven widget filtering to subgraph nodes. A new ProxyWidgetSelector interface defines selector configuration, the widget mapping system propagates values options, and SubgraphNode implements selector widget initialization and dynamic filtering based on selector state.

Changes

Cohort / File(s) Summary
Widget Options Enhancement
src/composables/graph/useGraphNodeManager.ts
Added values property to SafeWidgetData.options type and updated widget mapping to propagate widget.options.values during extraction.
Selector Schema Definition
src/core/schemas/promotionSchema.ts
Introduced exported ProxyWidgetSelector interface defining selector structure with name, selected value, and option labels with optional widget mappings.
Selector Widget Implementation
src/lib/litegraph/src/subgraph/SubgraphNode.ts
Implemented selector-driven widget filtering via new _selectorWidget field, overridden widgets getter, and _initSelectorWidget() initialization method integrated into node lifecycle.

Sequence Diagram

sequenceDiagram
    actor User
    participant SubgraphNode
    participant SelectorWidget
    participant PromotedViews
    participant Canvas
    
    Note over SubgraphNode: Node Initialization
    SubgraphNode->>SubgraphNode: _internalConfigureAfterSlots()
    SubgraphNode->>SelectorWidget: _initSelectorWidget()<br/>(from proxyWidgetSelector config)
    SelectorWidget->>SubgraphNode: Register selection callback
    SubgraphNode->>Canvas: Mark dirty (initial setup)
    
    Note over User,Canvas: User Interaction
    User->>SelectorWidget: Select widget option
    SelectorWidget->>SubgraphNode: Callback triggered
    SubgraphNode->>SubgraphNode: Update selector.selected
    SubgraphNode->>SubgraphNode: Invalidate promoted views cache
    SubgraphNode->>SubgraphNode: Recompute widgets getter<br/>(filter by selection)
    SubgraphNode->>SubgraphNode: Recompute node size
    SubgraphNode->>Canvas: Mark dirty
    Canvas->>PromotedViews: Re-render filtered widgets
Loading

Estimated code review effort

🎯 3 (Moderate) | ⏱️ ~25 minutes

Poem

🐰 A selector widget takes the stage,
Filtering views on every page,
Promoted widgets dance and play,
Choosing options, finding their way,
Canvas glows with fresh new light! ✨


Important

Pre-merge checks failed

Please resolve all errors before merging. Addressing warnings is optional.

❌ Failed checks (3 warnings, 1 inconclusive)

Check name Status Explanation Resolution
Docstring Coverage ⚠️ Warning Docstring coverage is 0.00% which is insufficient. The required threshold is 80.00%. Write docstrings for the functions missing them to satisfy the coverage threshold.
Adr Compliance For Entity/Litegraph Changes ⚠️ Warning PR violates ADR 0003 by directly mutating spatial state via setSize() and setDirtyCanvas() without command pattern, and violates ADR 0008 by dynamically overriding node.widgets without migration guidance for extension ecosystem. Refactor widget callback to dispatch commands per ADR 0003 instead of direct mutations, and add migration documentation for the node.widgets property change affecting 40+ custom node repositories.
Description check ⚠️ Warning The PR description lacks the required structure from the template, missing key sections like 'What', 'Review Focus', and proper formatting. Restructure the description to follow the template: add a 'Changes' section with 'What' and any breaking changes/dependencies, and include a 'Review Focus' section explaining critical design decisions.
End-To-End Regression Coverage For Fixes ❓ Inconclusive Custom check requires verification of bug-fix language in commit subjects, but commit subjects are not provided in the review context and shell commands are prohibited. Provide commit subjects from the PR to complete the evaluation of condition 1 regarding bug-fix language.
✅ Passed checks (1 passed)
Check name Status Explanation
Title check ✅ Passed The title accurately and concisely summarizes the main feature being added: proxyWidgetSelector support to SubgraphNode, which aligns with all file changes.
✨ Finishing Touches
📝 Generate docstrings
  • Create stacked PR
  • Commit on current branch
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch proxy-widget-selector

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 3, 2026

🎨 Storybook: ✅ Built — View Storybook

Details

⏰ Completed at: 04/03/2026, 10:54:12 PM UTC

Links

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 3, 2026

📦 Bundle: 5.11 MB gzip 🔴 +539 B

Details

Summary

  • Raw size: 23.5 MB baseline 23.5 MB — 🔴 +1.71 kB
  • Gzip: 5.11 MB baseline 5.11 MB — 🔴 +539 B
  • Brotli: 3.95 MB baseline 3.95 MB — 🔴 +372 B
  • Bundles: 250 current • 250 baseline • 114 added / 114 removed

Category Glance
Data & Services 🔴 +1.71 kB (2.97 MB) · Vendor & Third-Party ⚪ 0 B (9.8 MB) · Other ⚪ 0 B (8.44 MB) · Graph Workspace ⚪ 0 B (1.2 MB) · Panels & Settings ⚪ 0 B (484 kB) · Utilities & Hooks ⚪ 0 B (338 kB) · + 5 more

App Entry Points — 22.3 kB (baseline 22.3 kB) • ⚪ 0 B

Main entry bundles and manifests

File Before After Δ Raw Δ Gzip Δ Brotli
assets/index-BQFKGOSV.js (removed) 22.3 kB 🟢 -22.3 kB 🟢 -7.95 kB 🟢 -6.79 kB
assets/index-D0S4ZkFg.js (new) 22.3 kB 🔴 +22.3 kB 🔴 +7.95 kB 🔴 +6.79 kB

Status: 1 added / 1 removed

Graph Workspace — 1.2 MB (baseline 1.2 MB) • ⚪ 0 B

Graph editor runtime, canvas, workflow orchestration

File Before After Δ Raw Δ Gzip Δ Brotli
assets/GraphView-bx-hdsfD.js (new) 1.2 MB 🔴 +1.2 MB 🔴 +256 kB 🔴 +193 kB
assets/GraphView-uvJNeKIB.js (removed) 1.2 MB 🟢 -1.2 MB 🟢 -256 kB 🟢 -193 kB

Status: 1 added / 1 removed

Views & Navigation — 76.6 kB (baseline 76.6 kB) • ⚪ 0 B

Top-level views, pages, and routed surfaces

File Before After Δ Raw Δ Gzip Δ Brotli
assets/CloudSurveyView-Nvkioq5D.js (new) 15.7 kB 🔴 +15.7 kB 🔴 +3.4 kB 🔴 +2.9 kB
assets/CloudSurveyView-YXF21fMV.js (removed) 15.7 kB 🟢 -15.7 kB 🟢 -3.4 kB 🟢 -2.89 kB
assets/CloudLoginView-Bvfv4aDf.js (new) 12 kB 🔴 +12 kB 🔴 +3.36 kB 🔴 +2.96 kB
assets/CloudLoginView-DeVpiw6j.js (removed) 12 kB 🟢 -12 kB 🟢 -3.36 kB 🟢 -2.96 kB
assets/CloudSignupView-CF2j63R0.js (removed) 9.78 kB 🟢 -9.78 kB 🟢 -2.86 kB 🟢 -2.5 kB
assets/CloudSignupView-IsCjhj-g.js (new) 9.78 kB 🔴 +9.78 kB 🔴 +2.85 kB 🔴 +2.5 kB
assets/UserCheckView-BrHBwKcf.js (new) 9.04 kB 🔴 +9.04 kB 🔴 +2.33 kB 🔴 +2.03 kB
assets/UserCheckView-C42KLgWV.js (removed) 9.04 kB 🟢 -9.04 kB 🟢 -2.33 kB 🟢 -2.03 kB
assets/CloudLayoutView-BzG-_nMo.js (new) 7.54 kB 🔴 +7.54 kB 🔴 +2.36 kB 🔴 +2.04 kB
assets/CloudLayoutView-DgNsFpvL.js (removed) 7.54 kB 🟢 -7.54 kB 🟢 -2.36 kB 🟢 -2.06 kB
assets/CloudForgotPasswordView-D_9Mg0wX.js (new) 5.94 kB 🔴 +5.94 kB 🔴 +2.09 kB 🔴 +1.84 kB
assets/CloudForgotPasswordView-D8x84dfQ.js (removed) 5.94 kB 🟢 -5.94 kB 🟢 -2.09 kB 🟢 -1.83 kB
assets/CloudAuthTimeoutView-DFnwyJDv.js (removed) 5.31 kB 🟢 -5.31 kB 🟢 -1.93 kB 🟢 -1.68 kB
assets/CloudAuthTimeoutView-N5vBlWGf.js (new) 5.31 kB 🔴 +5.31 kB 🔴 +1.93 kB 🔴 +1.7 kB
assets/CloudSubscriptionRedirectView-CTowKKrp.js (new) 5.08 kB 🔴 +5.08 kB 🔴 +1.91 kB 🔴 +1.69 kB
assets/CloudSubscriptionRedirectView-DTdLEAPn.js (removed) 5.08 kB 🟢 -5.08 kB 🟢 -1.91 kB 🟢 -1.69 kB
assets/UserSelectView-BDBdkhno.js (removed) 4.71 kB 🟢 -4.71 kB 🟢 -1.74 kB 🟢 -1.54 kB
assets/UserSelectView-DCqp8g5S.js (new) 4.71 kB 🔴 +4.71 kB 🔴 +1.74 kB 🔴 +1.54 kB

Status: 9 added / 9 removed / 2 unchanged

Panels & Settings — 484 kB (baseline 484 kB) • ⚪ 0 B

Configuration panels, inspectors, and settings screens

File Before After Δ Raw Δ Gzip Δ Brotli
assets/KeybindingPanel-nilwbBZ1.js (new) 46.6 kB 🔴 +46.6 kB 🔴 +9.52 kB 🔴 +8.49 kB
assets/KeybindingPanel-OOJsiP2n.js (removed) 46.6 kB 🟢 -46.6 kB 🟢 -9.52 kB 🟢 -8.47 kB
assets/SecretsPanel-B8cRxs8l.js (new) 22.4 kB 🔴 +22.4 kB 🔴 +5.42 kB 🔴 +4.77 kB
assets/SecretsPanel-DsFrzhEL.js (removed) 22.4 kB 🟢 -22.4 kB 🟢 -5.42 kB 🟢 -4.78 kB
assets/LegacyCreditsPanel-aXIp8JbE.js (new) 21.5 kB 🔴 +21.5 kB 🔴 +5.81 kB 🔴 +5.14 kB
assets/LegacyCreditsPanel-RU7odCVb.js (removed) 21.5 kB 🟢 -21.5 kB 🟢 -5.81 kB 🟢 -5.13 kB
assets/SubscriptionPanel-Bd3-KR2E.js (removed) 19.7 kB 🟢 -19.7 kB 🟢 -5.01 kB 🟢 -4.4 kB
assets/SubscriptionPanel-C1yW60H-.js (new) 19.7 kB 🔴 +19.7 kB 🔴 +5.01 kB 🔴 +4.42 kB
assets/AboutPanel-BnIyaGRT.js (new) 12 kB 🔴 +12 kB 🔴 +3.33 kB 🔴 +2.99 kB
assets/AboutPanel-CGui_hJV.js (removed) 12 kB 🟢 -12 kB 🟢 -3.33 kB 🟢 -2.98 kB
assets/ExtensionPanel-CXyupjGT.js (new) 9.78 kB 🔴 +9.78 kB 🔴 +2.82 kB 🔴 +2.52 kB
assets/ExtensionPanel-g6TGAGkG.js (removed) 9.78 kB 🟢 -9.78 kB 🟢 -2.82 kB 🟢 -2.51 kB
assets/ServerConfigPanel-Bo7bAkf1.js (new) 6.85 kB 🔴 +6.85 kB 🔴 +2.27 kB 🔴 +2.04 kB
assets/ServerConfigPanel-DY8jgiOW.js (removed) 6.85 kB 🟢 -6.85 kB 🟢 -2.27 kB 🟢 -2.03 kB
assets/UserPanel-DbNyx1FB.js (new) 6.56 kB 🔴 +6.56 kB 🔴 +2.15 kB 🔴 +1.88 kB
assets/UserPanel-ePxJEGZf.js (removed) 6.56 kB 🟢 -6.56 kB 🟢 -2.15 kB 🟢 -1.88 kB
assets/cloudRemoteConfig-BK93MxtA.js (removed) 1.85 kB 🟢 -1.85 kB 🟢 -903 B 🟢 -791 B
assets/cloudRemoteConfig-DJdWTQCp.js (new) 1.85 kB 🔴 +1.85 kB 🔴 +903 B 🔴 +777 B
assets/refreshRemoteConfig-3sXzzq4J.js (removed) 1.45 kB 🟢 -1.45 kB 🟢 -649 B 🟢 -548 B
assets/refreshRemoteConfig-DXmAP1nU.js (new) 1.45 kB 🔴 +1.45 kB 🔴 +650 B 🔴 +553 B

Status: 10 added / 10 removed / 12 unchanged

User & Accounts — 17.1 kB (baseline 17.1 kB) • ⚪ 0 B

Authentication, profile, and account management bundles

File Before After Δ Raw Δ Gzip Δ Brotli
assets/auth-BxV7Wgh_.js (new) 3.57 kB 🔴 +3.57 kB 🔴 +1.26 kB 🔴 +1.07 kB
assets/auth-Dhg1UQRU.js (removed) 3.57 kB 🟢 -3.57 kB 🟢 -1.26 kB 🟢 -1.07 kB
assets/SignUpForm-6L6I1yw_.js (new) 3.16 kB 🔴 +3.16 kB 🔴 +1.29 kB 🔴 +1.14 kB
assets/SignUpForm-Cj2NDE6B.js (removed) 3.16 kB 🟢 -3.16 kB 🟢 -1.29 kB 🟢 -1.15 kB
assets/UpdatePasswordContent-B5x7B0mt.js (removed) 2.66 kB 🟢 -2.66 kB 🟢 -1.19 kB 🟢 -1.07 kB
assets/UpdatePasswordContent-CMY7xXxz.js (new) 2.66 kB 🔴 +2.66 kB 🔴 +1.19 kB 🔴 +1.05 kB
assets/authStore-6nYcn94O.js (new) 989 B 🔴 +989 B 🔴 +484 B 🔴 +434 B
assets/authStore-B_NMw0CZ.js (removed) 989 B 🟢 -989 B 🟢 -484 B 🟢 -436 B
assets/auth-oyMq3yqm.js (removed) 348 B 🟢 -348 B 🟢 -218 B 🟢 -190 B
assets/auth-Pp6Ah0SU.js (new) 348 B 🔴 +348 B 🔴 +218 B 🔴 +190 B

Status: 5 added / 5 removed / 2 unchanged

Editors & Dialogs — 109 kB (baseline 109 kB) • ⚪ 0 B

Modals, dialogs, drawers, and in-app editors

File Before After Δ Raw Δ Gzip Δ Brotli
assets/useShareDialog-B5UFgBE7.js (new) 108 kB 🔴 +108 kB 🔴 +22.4 kB 🔴 +18.9 kB
assets/useShareDialog-BA_RlAHw.js (removed) 108 kB 🟢 -108 kB 🟢 -22.4 kB 🟢 -18.9 kB
assets/useSubscriptionDialog-BVRkHIzm.js (new) 969 B 🔴 +969 B 🔴 +475 B 🔴 +419 B
assets/useSubscriptionDialog-CMTg1gWK.js (removed) 969 B 🟢 -969 B 🟢 -475 B 🟢 -420 B

Status: 2 added / 2 removed

UI Components — 60.3 kB (baseline 60.3 kB) • ⚪ 0 B

Reusable component library chunks

File Before After Δ Raw Δ Gzip Δ Brotli
assets/ComfyQueueButton-E_ibLL72.js (new) 13.5 kB 🔴 +13.5 kB 🔴 +3.79 kB 🔴 +3.37 kB
assets/ComfyQueueButton-RB_aFpSE.js (removed) 13.5 kB 🟢 -13.5 kB 🟢 -3.79 kB 🟢 -3.37 kB
assets/useTerminalTabs-CKn8frPW.js (removed) 10.7 kB 🟢 -10.7 kB 🟢 -3.6 kB 🟢 -3.16 kB
assets/useTerminalTabs-PmVkKeDG.js (new) 10.7 kB 🔴 +10.7 kB 🔴 +3.6 kB 🔴 +3.17 kB
assets/SubscribeButton-Brf48D76.js (new) 2.42 kB 🔴 +2.42 kB 🔴 +1.04 kB 🔴 +915 B
assets/SubscribeButton-jWD2eDHw.js (removed) 2.42 kB 🟢 -2.42 kB 🟢 -1.05 kB 🟢 -914 B
assets/cloudFeedbackTopbarButton-D247WnGJ.js (removed) 1.66 kB 🟢 -1.66 kB 🟢 -844 B 🟢 -750 B
assets/cloudFeedbackTopbarButton-Vh6IzPVZ.js (new) 1.66 kB 🔴 +1.66 kB 🔴 +844 B 🔴 +751 B
assets/ComfyQueueButton-BuKppV-v.js (new) 1.03 kB 🔴 +1.03 kB 🔴 +490 B 🔴 +445 B
assets/ComfyQueueButton-CG4AMD2y.js (removed) 1.03 kB 🟢 -1.03 kB 🟢 -489 B 🟢 -442 B

Status: 5 added / 5 removed / 8 unchanged

Data & Services — 2.97 MB (baseline 2.97 MB) • 🔴 +1.71 kB

Stores, services, APIs, and repositories

File Before After Δ Raw Δ Gzip Δ Brotli
assets/dialogService-BtteYNXC.js (new) 1.94 MB 🔴 +1.94 MB 🔴 +445 kB 🔴 +338 kB
assets/dialogService-CaW4TQiA.js (removed) 1.94 MB 🟢 -1.94 MB 🟢 -445 kB 🟢 -338 kB
assets/api-C2QqC5UQ.js (new) 887 kB 🔴 +887 kB 🔴 +212 kB 🔴 +167 kB
assets/api-BzQeKjsg.js (removed) 885 kB 🟢 -885 kB 🟢 -211 kB 🟢 -167 kB
assets/load3dService-C9ZR-ISJ.js (removed) 92.5 kB 🟢 -92.5 kB 🟢 -19.7 kB 🟢 -16.9 kB
assets/load3dService-DTbH9vp1.js (new) 92.5 kB 🔴 +92.5 kB 🔴 +19.7 kB 🔴 +16.9 kB
assets/workflowShareService-CKcycI85.js (removed) 16.6 kB 🟢 -16.6 kB 🟢 -4.88 kB 🟢 -4.32 kB
assets/workflowShareService-D9XraaGI.js (new) 16.6 kB 🔴 +16.6 kB 🔴 +4.88 kB 🔴 +4.32 kB
assets/keybindingService-C__Yt75C.js (removed) 13.8 kB 🟢 -13.8 kB 🟢 -3.67 kB 🟢 -3.21 kB
assets/keybindingService-DPf5nBca.js (new) 13.8 kB 🔴 +13.8 kB 🔴 +3.67 kB 🔴 +3.21 kB
assets/releaseStore-B_8YuLcD.js (removed) 8.12 kB 🟢 -8.12 kB 🟢 -2.28 kB 🟢 -2 kB
assets/releaseStore-DoutHvJl.js (new) 8.12 kB 🔴 +8.12 kB 🔴 +2.28 kB 🔴 +2 kB
assets/userStore-BrNhxOWq.js (removed) 2.24 kB 🟢 -2.24 kB 🟢 -869 B 🟢 -766 B
assets/userStore-NhwYE0Ru.js (new) 2.24 kB 🔴 +2.24 kB 🔴 +870 B 🔴 +765 B
assets/audioService-BmWyGmOe.js (new) 1.8 kB 🔴 +1.8 kB 🔴 +877 B 🔴 +757 B
assets/audioService-CM5KuzAn.js (removed) 1.8 kB 🟢 -1.8 kB 🟢 -877 B 🟢 -758 B
assets/releaseStore-BLZ8d_Un.js (removed) 993 B 🟢 -993 B 🟢 -482 B 🟢 -430 B
assets/releaseStore-Dcq74RV0.js (new) 993 B 🔴 +993 B 🔴 +482 B 🔴 +431 B
assets/workflowDraftStore-BO40oXEh.js (removed) 969 B 🟢 -969 B 🟢 -473 B 🟢 -426 B
assets/workflowDraftStore-Dxvwvf3s.js (new) 969 B 🔴 +969 B 🔴 +475 B 🔴 +423 B
assets/dialogService-BfXO7CDv.js (new) 958 B 🔴 +958 B 🔴 +467 B 🔴 +419 B
assets/dialogService-DvQDJTAr.js (removed) 958 B 🟢 -958 B 🟢 -467 B 🟢 -417 B
assets/settingStore-CHAty-Ih.js (removed) 956 B 🟢 -956 B 🟢 -470 B 🟢 -419 B
assets/settingStore-JldTr9fz.js (new) 956 B 🔴 +956 B 🔴 +471 B 🔴 +414 B
assets/assetsStore-DOBjeWas.js (removed) 955 B 🟢 -955 B 🟢 -469 B 🟢 -421 B
assets/assetsStore-jePT35s-.js (new) 955 B 🔴 +955 B 🔴 +471 B 🔴 +416 B

Status: 13 added / 13 removed / 4 unchanged

Utilities & Hooks — 338 kB (baseline 338 kB) • ⚪ 0 B

Helpers, composables, and utility bundles

File Before After Δ Raw Δ Gzip Δ Brotli
assets/useConflictDetection-CVtIDolT.js (removed) 232 kB 🟢 -232 kB 🟢 -51.3 kB 🟢 -41.7 kB
assets/useConflictDetection-DSwXVrpm.js (new) 232 kB 🔴 +232 kB 🔴 +51.3 kB 🔴 +41.8 kB
assets/useLoad3dViewer-BOS1zSJm.js (new) 18.7 kB 🔴 +18.7 kB 🔴 +4.44 kB 🔴 +3.87 kB
assets/useLoad3dViewer-CC1LaBue.js (removed) 18.7 kB 🟢 -18.7 kB 🟢 -4.44 kB 🟢 -3.88 kB
assets/useLoad3d-DveMLm4V.js (new) 15 kB 🔴 +15 kB 🔴 +3.79 kB 🔴 +3.38 kB
assets/useLoad3d-K5cZszIo.js (removed) 15 kB 🟢 -15 kB 🟢 -3.79 kB 🟢 -3.35 kB
assets/useFeatureFlags-Dg4tQjYw.js (new) 5.78 kB 🔴 +5.78 kB 🔴 +1.75 kB 🔴 +1.48 kB
assets/useFeatureFlags-DjYwCzEG.js (removed) 5.78 kB 🟢 -5.78 kB 🟢 -1.75 kB 🟢 -1.48 kB
assets/useCopyToClipboard-BdFO5ast.js (removed) 5.29 kB 🟢 -5.29 kB 🟢 -1.86 kB 🟢 -1.57 kB
assets/useCopyToClipboard-CI1haKQE.js (new) 5.29 kB 🔴 +5.29 kB 🔴 +1.86 kB 🔴 +1.57 kB
assets/useWorkspaceUI-Bgl5NYuC.js (removed) 3.34 kB 🟢 -3.34 kB 🟢 -979 B 🟢 -813 B
assets/useWorkspaceUI-DDY2gspM.js (new) 3.34 kB 🔴 +3.34 kB 🔴 +979 B 🔴 +812 B
assets/subscriptionCheckoutUtil-1BCtyJfV.js (removed) 2.97 kB 🟢 -2.97 kB 🟢 -1.31 kB 🟢 -1.14 kB
assets/subscriptionCheckoutUtil-C8ymr-V_.js (new) 2.97 kB 🔴 +2.97 kB 🔴 +1.31 kB 🔴 +1.14 kB
assets/assetPreviewUtil-EaQ588si.js (removed) 2.27 kB 🟢 -2.27 kB 🟢 -958 B 🟢 -832 B
assets/assetPreviewUtil-hxSeFN85.js (new) 2.27 kB 🔴 +2.27 kB 🔴 +960 B 🔴 +839 B
assets/useUpstreamValue-CH98pguo.js (removed) 2.08 kB 🟢 -2.08 kB 🟢 -805 B 🟢 -713 B
assets/useUpstreamValue-TZ9Jdfrl.js (new) 2.08 kB 🔴 +2.08 kB 🔴 +804 B 🔴 +713 B
assets/useLoad3d-B7q1omQe.js (removed) 1.13 kB 🟢 -1.13 kB 🟢 -540 B 🟢 -484 B
assets/useLoad3d-C1SD49v3.js (new) 1.13 kB 🔴 +1.13 kB 🔴 +540 B 🔴 +484 B
assets/useLoad3dViewer-DIUrsmaX.js (new) 1.07 kB 🔴 +1.07 kB 🔴 +507 B 🔴 +455 B
assets/useLoad3dViewer-DT9BBmYK.js (removed) 1.07 kB 🟢 -1.07 kB 🟢 -505 B 🟢 -455 B
assets/useCurrentUser-BZmQjFiX.js (removed) 955 B 🟢 -955 B 🟢 -470 B 🟢 -421 B
assets/useCurrentUser-DVVfUVeF.js (new) 955 B 🔴 +955 B 🔴 +469 B 🔴 +417 B
assets/useWorkspaceSwitch-BQGXp-ik.js (new) 747 B 🔴 +747 B 🔴 +385 B 🔴 +332 B
assets/useWorkspaceSwitch-CrmBR2te.js (removed) 747 B 🟢 -747 B 🟢 -384 B 🟢 -330 B

Status: 13 added / 13 removed / 13 unchanged

Vendor & Third-Party — 9.8 MB (baseline 9.8 MB) • ⚪ 0 B

External libraries and shared vendor chunks

Status: 16 unchanged

Other — 8.44 MB (baseline 8.44 MB) • ⚪ 0 B

Bundles that do not match a named category

File Before After Δ Raw Δ Gzip Δ Brotli
assets/core-C-px6R9k.js (new) 76.8 kB 🔴 +76.8 kB 🔴 +19.9 kB 🔴 +17 kB
assets/core-CmhufUOl.js (removed) 76.8 kB 🟢 -76.8 kB 🟢 -19.9 kB 🟢 -16.9 kB
assets/groupNode-B0jIwf82.js (new) 74 kB 🔴 +74 kB 🔴 +18.5 kB 🔴 +16.3 kB
assets/groupNode-CJUzZrFX.js (removed) 74 kB 🟢 -74 kB 🟢 -18.5 kB 🟢 -16.3 kB
assets/WidgetSelect-BmX1IdnY.js (removed) 64.6 kB 🟢 -64.6 kB 🟢 -14.1 kB 🟢 -12.2 kB
assets/WidgetSelect-DMBST8R8.js (new) 64.6 kB 🔴 +64.6 kB 🔴 +14.1 kB 🔴 +12.2 kB
assets/SubscriptionRequiredDialogContentWorkspace-BI1sMvEI.js (removed) 48.9 kB 🟢 -48.9 kB 🟢 -9.29 kB 🟢 -7.95 kB
assets/SubscriptionRequiredDialogContentWorkspace-BkxXaFQs.js (new) 48.9 kB 🔴 +48.9 kB 🔴 +9.29 kB 🔴 +7.97 kB
assets/WidgetPainter-CLhenAi_.js (new) 33.3 kB 🔴 +33.3 kB 🔴 +8.11 kB 🔴 +7.18 kB
assets/WidgetPainter-DpbzYR6N.js (removed) 33.3 kB 🟢 -33.3 kB 🟢 -8.12 kB 🟢 -7.19 kB
assets/Load3DControls-BBVEsNXD.js (new) 32.1 kB 🔴 +32.1 kB 🔴 +5.47 kB 🔴 +4.76 kB
assets/Load3DControls-BJ4G1OlM.js (removed) 32.1 kB 🟢 -32.1 kB 🟢 -5.47 kB 🟢 -4.76 kB
assets/WorkspacePanelContent-Ck1ms93R.js (new) 29.9 kB 🔴 +29.9 kB 🔴 +6.33 kB 🔴 +5.56 kB
assets/WorkspacePanelContent-jc_Je5qX.js (removed) 29.9 kB 🟢 -29.9 kB 🟢 -6.33 kB 🟢 -5.55 kB
assets/SubscriptionRequiredDialogContent-DkZ0URSs.js (new) 28.2 kB 🔴 +28.2 kB 🔴 +7.17 kB 🔴 +6.3 kB
assets/SubscriptionRequiredDialogContent-DLaMFntU.js (removed) 28.2 kB 🟢 -28.2 kB 🟢 -7.17 kB 🟢 -6.3 kB
assets/Load3dViewerContent-Baehqj-w.js (new) 24.5 kB 🔴 +24.5 kB 🔴 +5.33 kB 🔴 +4.63 kB
assets/Load3dViewerContent-DlcxV4NQ.js (removed) 24.5 kB 🟢 -24.5 kB 🟢 -5.33 kB 🟢 -4.64 kB
assets/WidgetImageCrop-4ehFuhTj.js (new) 23.3 kB 🔴 +23.3 kB 🔴 +5.83 kB 🔴 +5.13 kB
assets/WidgetImageCrop-CyeWwhwR.js (removed) 23.3 kB 🟢 -23.3 kB 🟢 -5.83 kB 🟢 -5.13 kB
assets/SubscriptionPanelContentWorkspace-2_diwwNP.js (new) 22.2 kB 🔴 +22.2 kB 🔴 +5.18 kB 🔴 +4.55 kB
assets/SubscriptionPanelContentWorkspace-BO-QsEEl.js (removed) 22.2 kB 🟢 -22.2 kB 🟢 -5.18 kB 🟢 -4.55 kB
assets/SignInContent-2crlqyio.js (removed) 20.4 kB 🟢 -20.4 kB 🟢 -5.29 kB 🟢 -4.64 kB
assets/SignInContent-Q_5Vv_rW.js (new) 20.4 kB 🔴 +20.4 kB 🔴 +5.3 kB 🔴 +4.63 kB
assets/CurrentUserPopoverWorkspace-BEBepHLV.js (new) 20.4 kB 🔴 +20.4 kB 🔴 +4.83 kB 🔴 +4.32 kB
assets/CurrentUserPopoverWorkspace-CUrxlqTi.js (removed) 20.4 kB 🟢 -20.4 kB 🟢 -4.83 kB 🟢 -4.33 kB
assets/WidgetInputNumber-C_ezCWbL.js (new) 19.1 kB 🔴 +19.1 kB 🔴 +4.84 kB 🔴 +4.3 kB
assets/WidgetInputNumber-CThSBFOy.js (removed) 19.1 kB 🟢 -19.1 kB 🟢 -4.84 kB 🟢 -4.3 kB
assets/WidgetRecordAudio-D_XMsgel.js (new) 18.1 kB 🔴 +18.1 kB 🔴 +5.18 kB 🔴 +4.64 kB
assets/WidgetRecordAudio-DbiOw4aS.js (removed) 18.1 kB 🟢 -18.1 kB 🟢 -5.18 kB 🟢 -4.64 kB
assets/Load3D-BFqZMi2l.js (new) 16.9 kB 🔴 +16.9 kB 🔴 +4.12 kB 🔴 +3.6 kB
assets/Load3D-DaoaT4Qg.js (removed) 16.9 kB 🟢 -16.9 kB 🟢 -4.12 kB 🟢 -3.59 kB
assets/load3d-B6VJdf5-.js (new) 15 kB 🔴 +15 kB 🔴 +4.32 kB 🔴 +3.73 kB
assets/load3d-DG7xgSgw.js (removed) 15 kB 🟢 -15 kB 🟢 -4.32 kB 🟢 -3.73 kB
assets/WaveAudioPlayer-B83V_FH0.js (new) 13.4 kB 🔴 +13.4 kB 🔴 +3.69 kB 🔴 +3.22 kB
assets/WaveAudioPlayer-CCKMo0Hj.js (removed) 13.4 kB 🟢 -13.4 kB 🟢 -3.69 kB 🟢 -3.22 kB
assets/WidgetCurve-CJKyPzZZ.js (removed) 12 kB 🟢 -12 kB 🟢 -3.85 kB 🟢 -3.48 kB
assets/WidgetCurve-ynWUD3vi.js (new) 12 kB 🔴 +12 kB 🔴 +3.85 kB 🔴 +3.49 kB
assets/TeamWorkspacesDialogContent-DqhLBzms.js (new) 11.1 kB 🔴 +11.1 kB 🔴 +3.33 kB 🔴 +2.97 kB
assets/TeamWorkspacesDialogContent-DvhvDNTi.js (removed) 11.1 kB 🟢 -11.1 kB 🟢 -3.33 kB 🟢 -2.98 kB
assets/nodeTemplates-_Zblgs5D.js (new) 9.58 kB 🔴 +9.58 kB 🔴 +3.37 kB 🔴 +2.97 kB
assets/nodeTemplates-DyFUneAJ.js (removed) 9.58 kB 🟢 -9.58 kB 🟢 -3.37 kB 🟢 -2.97 kB
assets/InviteMemberDialogContent-CfZJqkNW.js (removed) 7.77 kB 🟢 -7.77 kB 🟢 -2.45 kB 🟢 -2.15 kB
assets/InviteMemberDialogContent-pw2ykfSZ.js (new) 7.77 kB 🔴 +7.77 kB 🔴 +2.45 kB 🔴 +2.14 kB
assets/Load3DConfiguration-Caj3ePe_.js (removed) 6.6 kB 🟢 -6.6 kB 🟢 -2.04 kB 🟢 -1.78 kB
assets/Load3DConfiguration-DtFIPxGE.js (new) 6.6 kB 🔴 +6.6 kB 🔴 +2.04 kB 🔴 +1.78 kB
assets/onboardingCloudRoutes-BhW1qT0u.js (new) 6.53 kB 🔴 +6.53 kB 🔴 +2.04 kB 🔴 +1.77 kB
assets/onboardingCloudRoutes-C0BKfjJg.js (removed) 6.53 kB 🟢 -6.53 kB 🟢 -2.04 kB 🟢 -1.74 kB
assets/WidgetWithControl-ljzUJH-9.js (new) 5.99 kB 🔴 +5.99 kB 🔴 +2.39 kB 🔴 +2.13 kB
assets/WidgetWithControl-zQzZrRGA.js (removed) 5.99 kB 🟢 -5.99 kB 🟢 -2.38 kB 🟢 -2.11 kB
assets/CreateWorkspaceDialogContent-KOD56lHY.js (new) 5.95 kB 🔴 +5.95 kB 🔴 +2.15 kB 🔴 +1.87 kB
assets/CreateWorkspaceDialogContent-OncOa_4A.js (removed) 5.95 kB 🟢 -5.95 kB 🟢 -2.15 kB 🟢 -1.88 kB
assets/FreeTierDialogContent-BMIvx5cU.js (new) 5.82 kB 🔴 +5.82 kB 🔴 +2.04 kB 🔴 +1.81 kB
assets/FreeTierDialogContent-DxCZpQ0d.js (removed) 5.82 kB 🟢 -5.82 kB 🟢 -2.05 kB 🟢 -1.81 kB
assets/EditWorkspaceDialogContent-CPLoh2m6.js (new) 5.75 kB 🔴 +5.75 kB 🔴 +2.11 kB 🔴 +1.84 kB
assets/EditWorkspaceDialogContent-DBO9zu4Z.js (removed) 5.75 kB 🟢 -5.75 kB 🟢 -2.11 kB 🟢 -1.84 kB
assets/WidgetTextarea-CK3xy-Z3.js (new) 5.53 kB 🔴 +5.53 kB 🔴 +2.17 kB 🔴 +1.92 kB
assets/WidgetTextarea-wSbzdwB0.js (removed) 5.53 kB 🟢 -5.53 kB 🟢 -2.17 kB 🟢 -1.92 kB
assets/Preview3d-D-UgyCHA.js (new) 5.36 kB 🔴 +5.36 kB 🔴 +1.79 kB 🔴 +1.56 kB
assets/Preview3d-DTw058QB.js (removed) 5.36 kB 🟢 -5.36 kB 🟢 -1.79 kB 🟢 -1.56 kB
assets/ValueControlPopover-C-L2RzXq.js (removed) 5.33 kB 🟢 -5.33 kB 🟢 -1.93 kB 🟢 -1.73 kB
assets/ValueControlPopover-DEBcB3bM.js (new) 5.33 kB 🔴 +5.33 kB 🔴 +1.93 kB 🔴 +1.72 kB
assets/CancelSubscriptionDialogContent-BADzaAfq.js (new) 5.22 kB 🔴 +5.22 kB 🔴 +1.95 kB 🔴 +1.7 kB
assets/CancelSubscriptionDialogContent-Bp1UNeeG.js (removed) 5.22 kB 🟢 -5.22 kB 🟢 -1.95 kB 🟢 -1.7 kB
assets/DeleteWorkspaceDialogContent-DCJ84ssM.js (removed) 4.65 kB 🟢 -4.65 kB 🟢 -1.79 kB 🟢 -1.55 kB
assets/DeleteWorkspaceDialogContent-VbIii2TD.js (new) 4.65 kB 🔴 +4.65 kB 🔴 +1.79 kB 🔴 +1.55 kB
assets/LeaveWorkspaceDialogContent-CnokxVMy.js (new) 4.48 kB 🔴 +4.48 kB 🔴 +1.73 kB 🔴 +1.5 kB
assets/LeaveWorkspaceDialogContent-CZ8hRGcx.js (removed) 4.48 kB 🟢 -4.48 kB 🟢 -1.74 kB 🟢 -1.51 kB
assets/RemoveMemberDialogContent-BmcwhCXC.js (removed) 4.46 kB 🟢 -4.46 kB 🟢 -1.69 kB 🟢 -1.47 kB
assets/RemoveMemberDialogContent-Cr0nbZv-.js (new) 4.46 kB 🔴 +4.46 kB 🔴 +1.69 kB 🔴 +1.47 kB
assets/tierBenefits-CYjfq_7r.js (removed) 4.45 kB 🟢 -4.45 kB 🟢 -1.58 kB 🟢 -1.36 kB
assets/tierBenefits-Dnq_vqw6.js (new) 4.45 kB 🔴 +4.45 kB 🔴 +1.58 kB 🔴 +1.36 kB
assets/RevokeInviteDialogContent-1VE36NIF.js (removed) 4.37 kB 🟢 -4.37 kB 🟢 -1.7 kB 🟢 -1.48 kB
assets/RevokeInviteDialogContent-SG5hxNUH.js (new) 4.37 kB 🔴 +4.37 kB 🔴 +1.7 kB 🔴 +1.49 kB
assets/InviteMemberUpsellDialogContent-Bn97rBtB.js (removed) 4.27 kB 🟢 -4.27 kB 🟢 -1.56 kB 🟢 -1.37 kB
assets/InviteMemberUpsellDialogContent-sJoO4byl.js (new) 4.27 kB 🔴 +4.27 kB 🔴 +1.56 kB 🔴 +1.37 kB
assets/cloudSessionCookie-JUUJgAQZ.js (removed) 4.12 kB 🟢 -4.12 kB 🟢 -1.49 kB 🟢 -1.3 kB
assets/cloudSessionCookie-MYV1YFNv.js (new) 4.12 kB 🔴 +4.12 kB 🔴 +1.49 kB 🔴 +1.29 kB
assets/saveMesh-B7eGdhMy.js (new) 3.92 kB 🔴 +3.92 kB 🔴 +1.68 kB 🔴 +1.48 kB
assets/saveMesh-fK9AkNbt.js (removed) 3.92 kB 🟢 -3.92 kB 🟢 -1.68 kB 🟢 -1.48 kB
assets/Media3DTop-BcPUfJsz.js (removed) 3.85 kB 🟢 -3.85 kB 🟢 -1.62 kB 🟢 -1.43 kB
assets/Media3DTop-DfShVMjf.js (new) 3.85 kB 🔴 +3.85 kB 🔴 +1.62 kB 🔴 +1.42 kB
assets/GlobalToast-CbSoKBgM.js (new) 3.05 kB 🔴 +3.05 kB 🔴 +1.25 kB 🔴 +1.1 kB
assets/GlobalToast-L0qD3dTO.js (removed) 3.05 kB 🟢 -3.05 kB 🟢 -1.26 kB 🟢 -1.1 kB
assets/SubscribeToRun-DxxJhuBG.js (new) 2.13 kB 🔴 +2.13 kB 🔴 +983 B 🔴 +881 B
assets/SubscribeToRun-tWskb2oE.js (removed) 2.13 kB 🟢 -2.13 kB 🟢 -983 B 🟢 -880 B
assets/MediaAudioTop-CdRHP2Ul.js (new) 2.02 kB 🔴 +2.02 kB 🔴 +984 B 🔴 +837 B
assets/MediaAudioTop-DK0qHiik.js (removed) 2.02 kB 🟢 -2.02 kB 🟢 -983 B 🟢 -829 B
assets/CloudRunButtonWrapper-90Bm1cHz.js (new) 1.99 kB 🔴 +1.99 kB 🔴 +910 B 🔴 +808 B
assets/CloudRunButtonWrapper-wI670lOZ.js (removed) 1.99 kB 🟢 -1.99 kB 🟢 -908 B 🟢 -801 B
assets/graphHasMissingNodes-CKAEkpd4.js (new) 1.83 kB 🔴 +1.83 kB 🔴 +863 B 🔴 +756 B
assets/graphHasMissingNodes-Dum-aLUN.js (removed) 1.83 kB 🟢 -1.83 kB 🟢 -861 B 🟢 -750 B
assets/cloudBadges-DBKEkcMf.js (new) 1.77 kB 🔴 +1.77 kB 🔴 +891 B 🔴 +787 B
assets/cloudBadges-lz6UBuij.js (removed) 1.77 kB 🟢 -1.77 kB 🟢 -889 B 🟢 -792 B
assets/cloudSubscription-BNfs8Qnm.js (removed) 1.68 kB 🟢 -1.68 kB 🟢 -812 B 🟢 -710 B
assets/cloudSubscription-c0ef7qzm.js (new) 1.68 kB 🔴 +1.68 kB 🔴 +814 B 🔴 +710 B
assets/previousFullPath-BEVIYNi9.js (removed) 1.53 kB 🟢 -1.53 kB 🟢 -695 B 🟢 -601 B
assets/previousFullPath-VbblFeq7.js (new) 1.53 kB 🔴 +1.53 kB 🔴 +693 B 🔴 +599 B
assets/Load3D-DDxNqW-6.js (new) 1.34 kB 🔴 +1.34 kB 🔴 +615 B 🔴 +542 B
assets/Load3D-EtnbyXQT.js (removed) 1.34 kB 🟢 -1.34 kB 🟢 -612 B 🟢 -546 B
assets/nightlyBadges-BRaiJ3Am.js (removed) 1.29 kB 🟢 -1.29 kB 🟢 -657 B 🟢 -585 B
assets/nightlyBadges-CM852y05.js (new) 1.29 kB 🔴 +1.29 kB 🔴 +659 B 🔴 +586 B
assets/Load3dViewerContent-BIB6f1nt.js (new) 1.23 kB 🔴 +1.23 kB 🔴 +566 B 🔴 +502 B
assets/Load3dViewerContent-C53k28P3.js (removed) 1.23 kB 🟢 -1.23 kB 🟢 -564 B 🟢 -496 B
assets/SubscriptionPanelContentWorkspace-BRu3E9EU.js (new) 1.15 kB 🔴 +1.15 kB 🔴 +535 B 🔴 +466 B
assets/SubscriptionPanelContentWorkspace-DSw2csls.js (removed) 1.15 kB 🟢 -1.15 kB 🟢 -535 B 🟢 -467 B
assets/WidgetLegacy-CKHHvyxl.js (removed) 978 B 🟢 -978 B 🟢 -481 B 🟢 -427 B
assets/WidgetLegacy-wIVK2UNY.js (new) 978 B 🔴 +978 B 🔴 +480 B 🔴 +424 B
assets/changeTracker-B3TsF5bD.js (removed) 952 B 🟢 -952 B 🟢 -470 B 🟢 -418 B
assets/changeTracker-DlEFX9Pv.js (new) 952 B 🔴 +952 B 🔴 +469 B 🔴 +414 B

Status: 55 added / 55 removed / 79 unchanged

⚡ Performance Report

canvas-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 60.2 MB heap
canvas-mouse-sweep: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 56.1 MB heap
canvas-zoom-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 64.1 MB heap
dom-widget-clipping: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 47.0 MB heap
large-graph-idle: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 53.3 MB heap
large-graph-pan: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 67.4 MB heap
large-graph-zoom: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 59.3 MB heap
minimap-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 54.0 MB heap
subgraph-dom-widget-clipping: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 47.2 MB heap
subgraph-idle: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 60.1 MB heap
subgraph-mouse-sweep: · 60.0 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 52.5 MB heap
viewport-pan-sweep: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 72.4 MB heap
vue-large-graph-idle: · 58.1 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 152.2 MB heap
vue-large-graph-pan: · 58.1 avg FPS · 59.5 P5 FPS ✅ (target: ≥52) · 0ms TBT · 152.3 MB heap
workflow-execution: · 60.0 avg FPS · 59.9 P5 FPS ✅ (target: ≥52) · 0ms TBT · 46.9 MB heap

No regressions detected.

All metrics
Metric Baseline PR (median) Δ Sig
canvas-idle: avg frame time 17ms 17ms -0% z=-0.9
canvas-idle: p95 frame time 17ms 17ms +0%
canvas-idle: layout duration 0ms 0ms +0%
canvas-idle: style recalc duration 9ms 8ms -10% z=-2.7
canvas-idle: layout count 0 0 +0%
canvas-idle: style recalc count 11 11 +0% z=-0.3
canvas-idle: task duration 348ms 335ms -4% z=-1.9
canvas-idle: script duration 22ms 22ms -0% z=-1.5
canvas-idle: TBT 0ms 0ms +0%
canvas-idle: heap used 61.2 MB 60.2 MB -2%
canvas-idle: DOM nodes 21 21 +0% z=-1.2
canvas-idle: event listeners 6 6 +0% z=-1.2
canvas-mouse-sweep: avg frame time 17ms 17ms +0% z=-0.4
canvas-mouse-sweep: p95 frame time 17ms 17ms +0%
canvas-mouse-sweep: layout duration 4ms 3ms -4% z=-0.9
canvas-mouse-sweep: style recalc duration 43ms 39ms -9% z=-1.0
canvas-mouse-sweep: layout count 12 12 +0%
canvas-mouse-sweep: style recalc count 81 84 +4% z=2.3
canvas-mouse-sweep: task duration 983ms 915ms -7% z=0.9
canvas-mouse-sweep: script duration 137ms 126ms -8% z=-1.5
canvas-mouse-sweep: TBT 0ms 0ms +0%
canvas-mouse-sweep: heap used 56.3 MB 56.1 MB -0%
canvas-mouse-sweep: DOM nodes 65 67 +3% z=1.8
canvas-mouse-sweep: event listeners 6 6 +0% z=-0.6
canvas-zoom-sweep: avg frame time 17ms 17ms +0% z=0.5
canvas-zoom-sweep: p95 frame time 17ms 17ms -1%
canvas-zoom-sweep: layout duration 1ms 1ms +5% z=-0.4
canvas-zoom-sweep: style recalc duration 18ms 16ms -12% z=-2.3
canvas-zoom-sweep: layout count 6 6 +0%
canvas-zoom-sweep: style recalc count 32 30 -6% z=-2.8
canvas-zoom-sweep: task duration 310ms 288ms -7% z=-1.7
canvas-zoom-sweep: script duration 27ms 22ms -16% z=-1.6
canvas-zoom-sweep: TBT 0ms 0ms +0%
canvas-zoom-sweep: heap used 64.2 MB 64.1 MB -0%
canvas-zoom-sweep: DOM nodes 80 77 -4% z=-2.8
canvas-zoom-sweep: event listeners 19 19 +0% z=-0.9
dom-widget-clipping: avg frame time 17ms 17ms +0% z=0.1
dom-widget-clipping: p95 frame time 17ms 17ms +0%
dom-widget-clipping: layout duration 0ms 0ms +0%
dom-widget-clipping: style recalc duration 10ms 9ms -8% z=-1.3
dom-widget-clipping: layout count 0 0 +0%
dom-widget-clipping: style recalc count 13 13 +0% z=-0.2
dom-widget-clipping: task duration 354ms 321ms -9% z=-2.6
dom-widget-clipping: script duration 64ms 63ms -1% z=-1.4
dom-widget-clipping: TBT 0ms 0ms +0%
dom-widget-clipping: heap used 47.0 MB 47.0 MB -0%
dom-widget-clipping: DOM nodes 22 22 +0% z=-0.1
dom-widget-clipping: event listeners 2 2 +0% variance too high
large-graph-idle: avg frame time 17ms 17ms -0% z=-1.0
large-graph-idle: p95 frame time 17ms 17ms -0%
large-graph-idle: layout duration 0ms 0ms +0%
large-graph-idle: style recalc duration 10ms 9ms -8% z=-3.2
large-graph-idle: layout count 0 0 +0%
large-graph-idle: style recalc count 10 10 +0% z=-5.1
large-graph-idle: task duration 545ms 511ms -6% z=-0.6
large-graph-idle: script duration 101ms 94ms -7% z=-0.8
large-graph-idle: TBT 0ms 0ms +0%
large-graph-idle: heap used 52.8 MB 53.3 MB +1%
large-graph-idle: DOM nodes -255 -258 +1% z=-312.8
large-graph-idle: event listeners -123 -125 +2% z=-24.8
large-graph-pan: avg frame time 17ms 17ms +0% z=0.3
large-graph-pan: p95 frame time 17ms 17ms +0%
large-graph-pan: layout duration 0ms 0ms +0%
large-graph-pan: style recalc duration 16ms 16ms +1% z=-1.1
large-graph-pan: layout count 0 0 +0%
large-graph-pan: style recalc count 68 70 +3% z=0.7
large-graph-pan: task duration 1073ms 1012ms -6% z=-1.6
large-graph-pan: script duration 400ms 383ms -4% z=-1.3
large-graph-pan: TBT 0ms 0ms +0%
large-graph-pan: heap used 65.1 MB 67.4 MB +4%
large-graph-pan: DOM nodes -261 -259 -1% z=-168.5
large-graph-pan: event listeners -127 -125 -2% z=-156.9
large-graph-zoom: avg frame time 17ms 17ms +0%
large-graph-zoom: p95 frame time 17ms 17ms +1%
large-graph-zoom: layout duration 7ms 7ms -6%
large-graph-zoom: style recalc duration 16ms 15ms -6%
large-graph-zoom: layout count 60 60 +0%
large-graph-zoom: style recalc count 66 66 +0%
large-graph-zoom: task duration 1385ms 1238ms -11%
large-graph-zoom: script duration 518ms 472ms -9%
large-graph-zoom: TBT 0ms 0ms +0%
large-graph-zoom: heap used 61.0 MB 59.3 MB -3%
large-graph-zoom: DOM nodes -264 -264 +0%
large-graph-zoom: event listeners -123 -125 +2%
minimap-idle: avg frame time 17ms 17ms +0% z=0.1
minimap-idle: p95 frame time 17ms 17ms -1%
minimap-idle: layout duration 0ms 0ms +0%
minimap-idle: style recalc duration 9ms 10ms +5% z=0.1
minimap-idle: layout count 0 0 +0%
minimap-idle: style recalc count 9 11 +22% z=2.1
minimap-idle: task duration 536ms 505ms -6% z=-0.5
minimap-idle: script duration 97ms 91ms -5% z=-0.7
minimap-idle: TBT 0ms 0ms +0%
minimap-idle: heap used 53.9 MB 54.0 MB +0%
minimap-idle: DOM nodes -261 -259 -1% z=-203.4
minimap-idle: event listeners -127 -125 -2% z=-196.2
subgraph-dom-widget-clipping: avg frame time 17ms 17ms +0% z=0.1
subgraph-dom-widget-clipping: p95 frame time 17ms 17ms +0%
subgraph-dom-widget-clipping: layout duration 0ms 0ms +0%
subgraph-dom-widget-clipping: style recalc duration 14ms 12ms -15% z=-1.1
subgraph-dom-widget-clipping: layout count 0 0 +0%
subgraph-dom-widget-clipping: style recalc count 49 48 -2% z=0.1
subgraph-dom-widget-clipping: task duration 370ms 340ms -8% z=-2.1
subgraph-dom-widget-clipping: script duration 132ms 123ms -7% z=-0.9
subgraph-dom-widget-clipping: TBT 0ms 0ms +0%
subgraph-dom-widget-clipping: heap used 47.3 MB 47.2 MB -0%
subgraph-dom-widget-clipping: DOM nodes 23 22 -4% z=-0.2
subgraph-dom-widget-clipping: event listeners 8 8 +0% z=-1.4
subgraph-idle: avg frame time 17ms 17ms +0% z=0.4
subgraph-idle: p95 frame time 17ms 17ms +0%
subgraph-idle: layout duration 0ms 0ms +0%
subgraph-idle: style recalc duration 10ms 9ms -15% z=-1.8
subgraph-idle: layout count 0 0 +0%
subgraph-idle: style recalc count 11 11 +0% z=0.2
subgraph-idle: task duration 370ms 327ms -12% z=-1.4
subgraph-idle: script duration 18ms 18ms +1% z=-0.8
subgraph-idle: TBT 0ms 0ms +0%
subgraph-idle: heap used 60.1 MB 60.1 MB +0%
subgraph-idle: DOM nodes 22 22 +0% z=0.1
subgraph-idle: event listeners 6 6 +0% variance too high
subgraph-mouse-sweep: avg frame time 17ms 17ms -0% z=-0.5
subgraph-mouse-sweep: p95 frame time 17ms 17ms +1%
subgraph-mouse-sweep: layout duration 5ms 4ms -15% z=-1.8
subgraph-mouse-sweep: style recalc duration 48ms 44ms -9% z=0.4
subgraph-mouse-sweep: layout count 16 16 +0%
subgraph-mouse-sweep: style recalc count 85 83 -2% z=1.5
subgraph-mouse-sweep: task duration 910ms 860ms -5% z=1.4
subgraph-mouse-sweep: script duration 109ms 94ms -14% z=-1.1
subgraph-mouse-sweep: TBT 0ms 0ms +0%
subgraph-mouse-sweep: heap used 52.5 MB 52.5 MB -0%
subgraph-mouse-sweep: DOM nodes 73 72 -1% z=2.3
subgraph-mouse-sweep: event listeners 6 6 +0% variance too high
viewport-pan-sweep: avg frame time 17ms 17ms +0%
viewport-pan-sweep: p95 frame time 17ms 17ms +0%
viewport-pan-sweep: layout duration 0ms 0ms +0%
viewport-pan-sweep: style recalc duration 46ms 42ms -8%
viewport-pan-sweep: layout count 0 0 +0%
viewport-pan-sweep: style recalc count 252 251 -0%
viewport-pan-sweep: task duration 3713ms 3419ms -8%
viewport-pan-sweep: script duration 1263ms 1218ms -4%
viewport-pan-sweep: TBT 0ms 0ms +0%
viewport-pan-sweep: heap used 73.1 MB 72.4 MB -1%
viewport-pan-sweep: DOM nodes -254 -257 +1%
viewport-pan-sweep: event listeners -111 -111 +0%
vue-large-graph-idle: avg frame time 17ms 17ms +0%
vue-large-graph-idle: p95 frame time 17ms 17ms +0%
vue-large-graph-idle: layout duration 0ms 0ms +0%
vue-large-graph-idle: style recalc duration 0ms 0ms +0%
vue-large-graph-idle: layout count 0 0 +0%
vue-large-graph-idle: style recalc count 0 0 +0%
vue-large-graph-idle: task duration 12296ms 10680ms -13%
vue-large-graph-idle: script duration 626ms 526ms -16%
vue-large-graph-idle: TBT 0ms 0ms +0%
vue-large-graph-idle: heap used 158.3 MB 152.2 MB -4%
vue-large-graph-idle: DOM nodes -8331 -8331 +0%
vue-large-graph-idle: event listeners -16462 -16470 +0%
vue-large-graph-pan: avg frame time 17ms 17ms +0%
vue-large-graph-pan: p95 frame time 17ms 17ms +1%
vue-large-graph-pan: layout duration 0ms 0ms +0%
vue-large-graph-pan: style recalc duration 14ms 13ms -13%
vue-large-graph-pan: layout count 0 0 +0%
vue-large-graph-pan: style recalc count 70 67 -4%
vue-large-graph-pan: task duration 14487ms 13744ms -5%
vue-large-graph-pan: script duration 844ms 805ms -5%
vue-large-graph-pan: TBT 0ms 0ms +0%
vue-large-graph-pan: heap used 152.4 MB 152.3 MB -0%
vue-large-graph-pan: DOM nodes -8331 -8331 +0%
vue-large-graph-pan: event listeners -16460 -16458 -0%
workflow-execution: avg frame time 17ms 17ms -0% z=-0.4
workflow-execution: p95 frame time 17ms 17ms -1%
workflow-execution: layout duration 1ms 1ms -8% z=-2.0
workflow-execution: style recalc duration 24ms 22ms -7% z=-1.1
workflow-execution: layout count 5 5 +0% z=0.1
workflow-execution: style recalc count 16 17 +6% z=-0.4
workflow-execution: task duration 123ms 111ms -10% z=-1.1
workflow-execution: script duration 27ms 27ms +0% z=-0.5
workflow-execution: TBT 0ms 0ms +0%
workflow-execution: heap used 47.7 MB 46.9 MB -2%
workflow-execution: DOM nodes 156 158 +1% z=-0.4
workflow-execution: event listeners 71 71 +0% z=4.4
Historical variance (last 15 runs)
Metric μ σ CV
canvas-idle: avg frame time 17ms 0ms 0.0%
canvas-idle: layout duration 0ms 0ms 0.0%
canvas-idle: style recalc duration 11ms 1ms 8.2%
canvas-idle: layout count 0 0 0.0%
canvas-idle: style recalc count 11 1 5.0%
canvas-idle: task duration 395ms 31ms 7.9%
canvas-idle: script duration 25ms 2ms 8.8%
canvas-idle: TBT 0ms 0ms 0.0%
canvas-idle: DOM nodes 23 1 5.6%
canvas-idle: event listeners 12 5 40.9%
canvas-mouse-sweep: avg frame time 17ms 0ms 0.0%
canvas-mouse-sweep: layout duration 4ms 0ms 5.4%
canvas-mouse-sweep: style recalc duration 43ms 3ms 7.4%
canvas-mouse-sweep: layout count 12 0 0.0%
canvas-mouse-sweep: style recalc count 79 2 3.0%
canvas-mouse-sweep: task duration 865ms 58ms 6.7%
canvas-mouse-sweep: script duration 136ms 6ms 4.8%
canvas-mouse-sweep: TBT 0ms 0ms 0.0%
canvas-mouse-sweep: DOM nodes 62 3 4.2%
canvas-mouse-sweep: event listeners 8 4 49.4%
canvas-zoom-sweep: avg frame time 17ms 0ms 0.0%
canvas-zoom-sweep: layout duration 1ms 0ms 7.0%
canvas-zoom-sweep: style recalc duration 19ms 2ms 8.0%
canvas-zoom-sweep: layout count 6 0 0.0%
canvas-zoom-sweep: style recalc count 31 0 1.5%
canvas-zoom-sweep: task duration 327ms 23ms 7.1%
canvas-zoom-sweep: script duration 27ms 3ms 11.1%
canvas-zoom-sweep: TBT 0ms 0ms 0.0%
canvas-zoom-sweep: DOM nodes 79 1 1.0%
canvas-zoom-sweep: event listeners 24 5 21.8%
dom-widget-clipping: avg frame time 17ms 0ms 0.0%
dom-widget-clipping: layout duration 0ms 0ms 0.0%
dom-widget-clipping: style recalc duration 10ms 1ms 8.0%
dom-widget-clipping: layout count 0 0 0.0%
dom-widget-clipping: style recalc count 13 0 3.8%
dom-widget-clipping: task duration 365ms 16ms 4.5%
dom-widget-clipping: script duration 68ms 3ms 4.8%
dom-widget-clipping: TBT 0ms 0ms 0.0%
dom-widget-clipping: DOM nodes 22 1 6.4%
dom-widget-clipping: event listeners 8 6 81.2%
large-graph-idle: avg frame time 17ms 0ms 0.0%
large-graph-idle: layout duration 0ms 0ms 0.0%
large-graph-idle: style recalc duration 12ms 1ms 8.6%
large-graph-idle: layout count 0 0 0.0%
large-graph-idle: style recalc count 12 0 2.7%
large-graph-idle: task duration 542ms 54ms 10.0%
large-graph-idle: script duration 102ms 11ms 10.3%
large-graph-idle: TBT 0ms 0ms 0.0%
large-graph-idle: DOM nodes 25 1 3.7%
large-graph-idle: event listeners 26 6 23.2%
large-graph-pan: avg frame time 17ms 0ms 0.0%
large-graph-pan: layout duration 0ms 0ms 0.0%
large-graph-pan: style recalc duration 17ms 1ms 4.6%
large-graph-pan: layout count 0 0 0.0%
large-graph-pan: style recalc count 70 1 0.9%
large-graph-pan: task duration 1082ms 43ms 4.0%
large-graph-pan: script duration 408ms 20ms 4.8%
large-graph-pan: TBT 0ms 0ms 0.0%
large-graph-pan: DOM nodes 19 2 8.7%
large-graph-pan: event listeners 5 1 16.8%
minimap-idle: avg frame time 17ms 0ms 0.0%
minimap-idle: layout duration 0ms 0ms 0.0%
minimap-idle: style recalc duration 10ms 1ms 8.6%
minimap-idle: layout count 0 0 0.0%
minimap-idle: style recalc count 10 1 7.1%
minimap-idle: task duration 527ms 47ms 9.0%
minimap-idle: script duration 98ms 10ms 10.1%
minimap-idle: TBT 0ms 0ms 0.0%
minimap-idle: DOM nodes 19 1 7.1%
minimap-idle: event listeners 5 1 14.4%
subgraph-dom-widget-clipping: avg frame time 17ms 0ms 0.0%
subgraph-dom-widget-clipping: layout duration 0ms 0ms 0.0%
subgraph-dom-widget-clipping: style recalc duration 13ms 1ms 7.4%
subgraph-dom-widget-clipping: layout count 0 0 0.0%
subgraph-dom-widget-clipping: style recalc count 48 1 1.2%
subgraph-dom-widget-clipping: task duration 378ms 18ms 4.9%
subgraph-dom-widget-clipping: script duration 128ms 6ms 4.9%
subgraph-dom-widget-clipping: TBT 0ms 0ms 0.0%
subgraph-dom-widget-clipping: DOM nodes 22 1 5.0%
subgraph-dom-widget-clipping: event listeners 16 6 36.0%
subgraph-idle: avg frame time 17ms 0ms 0.0%
subgraph-idle: layout duration 0ms 0ms 0.0%
subgraph-idle: style recalc duration 10ms 1ms 7.5%
subgraph-idle: layout count 0 0 0.0%
subgraph-idle: style recalc count 11 1 6.0%
subgraph-idle: task duration 370ms 31ms 8.5%
subgraph-idle: script duration 20ms 3ms 13.2%
subgraph-idle: TBT 0ms 0ms 0.0%
subgraph-idle: DOM nodes 22 1 6.9%
subgraph-idle: event listeners 10 7 64.5%
subgraph-mouse-sweep: avg frame time 17ms 0ms 0.0%
subgraph-mouse-sweep: layout duration 5ms 0ms 6.8%
subgraph-mouse-sweep: style recalc duration 42ms 3ms 7.8%
subgraph-mouse-sweep: layout count 16 0 0.0%
subgraph-mouse-sweep: style recalc count 80 2 2.4%
subgraph-mouse-sweep: task duration 766ms 69ms 9.0%
subgraph-mouse-sweep: script duration 101ms 7ms 6.5%
subgraph-mouse-sweep: TBT 0ms 0ms 0.0%
subgraph-mouse-sweep: DOM nodes 67 2 3.3%
subgraph-mouse-sweep: event listeners 8 4 52.6%
workflow-execution: avg frame time 17ms 0ms 0.0%
workflow-execution: layout duration 2ms 0ms 9.4%
workflow-execution: style recalc duration 24ms 2ms 9.1%
workflow-execution: layout count 5 1 11.0%
workflow-execution: style recalc count 18 2 11.5%
workflow-execution: task duration 123ms 11ms 8.8%
workflow-execution: script duration 29ms 3ms 10.2%
workflow-execution: TBT 0ms 0ms 0.0%
workflow-execution: DOM nodes 161 7 4.4%
workflow-execution: event listeners 52 4 8.4%
Trend (last 15 commits on main)
Metric Trend Dir Latest
canvas-idle: avg frame time ▆▃▆▁▆▃▆█▆▆▄▃▃▄▃ ➡️ 17ms
canvas-idle: p95 frame time ➡️ NaNms
canvas-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-idle: style recalc duration ▇▇▆▆▃█▄▃▄▃▇▄▁▆▇ ➡️ 11ms
canvas-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
canvas-idle: style recalc count █▃▅▂▅▆▃▁▂▁▂▅▆▅▆ ➡️ 12
canvas-idle: task duration ▃▃▃▆▂▃▃▅▆▂█▃▁▃▃ ➡️ 391ms
canvas-idle: script duration ▄▃▅▇▂▅▃▆▇▅█▄▁▅▆ ➡️ 27ms
canvas-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-idle: heap used ➡️ NaN MB
canvas-idle: DOM nodes █▇▆▅▃▇▃▁▂▂▅▆▆▆▇ ➡️ 24
canvas-idle: event listeners ▅█▅▄▁▅▁▁▁▄▅▅▁▅▄ 📉 11
canvas-mouse-sweep: avg frame time ▆█▆▃▁▃▁▆▆▁▃▆▆▃▃ ➡️ 17ms
canvas-mouse-sweep: p95 frame time ➡️ NaNms
canvas-mouse-sweep: layout duration ▁▃▂▄▁▂▁▃▆▂█▇▆▄▃ ➡️ 4ms
canvas-mouse-sweep: style recalc duration ▄▄▂▄▁▂▃▃▅▄█▆▂▄▄ ➡️ 43ms
canvas-mouse-sweep: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 12
canvas-mouse-sweep: style recalc count █▅▄▃▂▂▁▄▄▅▆▅▂▇▄ ➡️ 79
canvas-mouse-sweep: task duration █▆▄▂▂▃▂▄▄▅█▆▁▆▄ ➡️ 868ms
canvas-mouse-sweep: script duration ▄▅▄▆▄▆▆▆▅▅█▆▁▅▆ ➡️ 139ms
canvas-mouse-sweep: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-mouse-sweep: heap used ➡️ NaN MB
canvas-mouse-sweep: DOM nodes █▅▃▃▁▂▂▃▂▄▆▅▃▅▅ ➡️ 64
canvas-mouse-sweep: event listeners █▁▁▁▁▁▇▁▁▁██▇▁█ 📈 13
canvas-zoom-sweep: avg frame time ▅▅█▄▅▁▁▁▅▁▁▅▄▅▁ ➡️ 17ms
canvas-zoom-sweep: p95 frame time ➡️ NaNms
canvas-zoom-sweep: layout duration ▆▅▅▄▁▁█▅▃▅▇▆▁▂▆ ➡️ 1ms
canvas-zoom-sweep: style recalc duration ▆▅▄▆▅▃█▆▇▅▇▄▁▃▅ ➡️ 20ms
canvas-zoom-sweep: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 6
canvas-zoom-sweep: style recalc count ▁▁▃▄▆▃▆█▄▄▆▁▆▁▆ ➡️ 32
canvas-zoom-sweep: task duration ▄▂▁▇▂▂▄▅▆▃█▄▁▁▅ ➡️ 338ms
canvas-zoom-sweep: script duration ▃▃▂▇▂▂▅▇▆▅█▄▁▂▆ ➡️ 30ms
canvas-zoom-sweep: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
canvas-zoom-sweep: heap used ➡️ NaN MB
canvas-zoom-sweep: DOM nodes ▄▃▁▅█▁▃▆▄▅▅▃▃▄▃ ➡️ 79
canvas-zoom-sweep: event listeners ▁▁▂▅█▂▁▅▁▅▅▄▁▅▁ ➡️ 19
dom-widget-clipping: avg frame time ▂▄▅▅▂▄█▇▅▇▇▅▅▁▇ ➡️ 17ms
dom-widget-clipping: p95 frame time ➡️ NaNms
dom-widget-clipping: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
dom-widget-clipping: style recalc duration ▆▆▂▆▄▃██▄▁▆▇▆▃▅ ➡️ 10ms
dom-widget-clipping: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
dom-widget-clipping: style recalc count ▇█▅█▅▄█▇▇▁▇▄▇▂▅ ➡️ 13
dom-widget-clipping: task duration ▃▃▁▅▄▃▅▆▅▂▇█▁▅▅ ➡️ 371ms
dom-widget-clipping: script duration ▅▄▄▆▆▅▇▇▆▃█▇▁▇▇ ➡️ 71ms
dom-widget-clipping: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
dom-widget-clipping: heap used ➡️ NaN MB
dom-widget-clipping: DOM nodes ▇▇▄▇▅▄█▇▅▁▅▄▇▃▄ ➡️ 21
dom-widget-clipping: event listeners ▅▅▅▅▁▅██▁▁▁▁█▁▁ 📉 2
large-graph-idle: avg frame time ▅▅▅▅▅▂▁▂▄▅▄▂▂▅█ ➡️ 17ms
large-graph-idle: p95 frame time ➡️ NaNms
large-graph-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-idle: style recalc duration ▅▅▅▆▄▅▃▄▅▅▆█▁▄▆ ➡️ 13ms
large-graph-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
large-graph-idle: style recalc count █▆█▃▃▁▃▆▃▆▆▃▆██ ➡️ 12
large-graph-idle: task duration ▂▃▂▆▂▃▃▇▅▃██▁▂▅ ➡️ 569ms
large-graph-idle: script duration ▄▅▄▆▄▅▅▇▆▅█▆▁▃▆ ➡️ 110ms
large-graph-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-idle: heap used ➡️ NaN MB
large-graph-idle: DOM nodes ▆█▅▂▅▃▁▂▃▅▅▆▂▆▅ ➡️ 25
large-graph-idle: event listeners ███▇██▄▁▄▇▇█▂█▇ ➡️ 29
large-graph-pan: avg frame time ▆▃▃▆█▃▁█▆▆▆▆█▁▆ ➡️ 17ms
large-graph-pan: p95 frame time ➡️ NaNms
large-graph-pan: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-pan: style recalc duration ▃▂▄▄▁▅▂▂▁▄▄█▃▁▂ ➡️ 17ms
large-graph-pan: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
large-graph-pan: style recalc count ▆▃█▂▃▂▂▂▁▇▅▃█▆▃ ➡️ 69
large-graph-pan: task duration ▄▃▄▆▄▄▄▆▄▄█▆▁▂▅ ➡️ 1100ms
large-graph-pan: script duration ▅▄▅▆▆▅▄▆▄▅█▄▁▄▅ ➡️ 413ms
large-graph-pan: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
large-graph-pan: heap used ➡️ NaN MB
large-graph-pan: DOM nodes ▅▃▆▂▄▁▃▁▁▅▁▂█▅▂ ➡️ 18
large-graph-pan: event listeners █▆█▁▁▆▁▁▃▆▁▃██▃ ➡️ 5
minimap-idle: avg frame time ▃▆▆▃█▁█▆▆▃▃▆█▆█ ➡️ 17ms
minimap-idle: p95 frame time ➡️ NaNms
minimap-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
minimap-idle: style recalc duration ▄█▁█▅▅█▅▅▃▅▁▁▄▆ ➡️ 10ms
minimap-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
minimap-idle: style recalc count ▃▅▂▄█▃▆▁▂▅▂▁▅▆▃ ➡️ 9
minimap-idle: task duration ▃▄▁▅▁▃▄▅▇▃█▅▁▁▅ ➡️ 547ms
minimap-idle: script duration ▄▆▃▇▃▅▆▆▇▅█▅▁▃▆ ➡️ 106ms
minimap-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
minimap-idle: heap used ➡️ NaN MB
minimap-idle: DOM nodes ▃▅▂▄█▃▆▁▂▅▂▁▅▆▃ ➡️ 19
minimap-idle: event listeners ▃▃▆▁▁▁▃▁▁▆▁▃█▆▁ ➡️ 4
subgraph-dom-widget-clipping: avg frame time ▅▄▄▄▄▄█▄▄▄▃▁▆▃▃ ➡️ 17ms
subgraph-dom-widget-clipping: p95 frame time ➡️ NaNms
subgraph-dom-widget-clipping: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-dom-widget-clipping: style recalc duration ▂▄▃▅▅▃▂▅▇▃▄█▁▄▆ ➡️ 14ms
subgraph-dom-widget-clipping: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
subgraph-dom-widget-clipping: style recalc count ▇█▆▃▆▃▁▆█▇▃▆▇█▅ ➡️ 48
subgraph-dom-widget-clipping: task duration ▂▃▃▆▅▅▂▅█▂▆█▁▂▇ ➡️ 398ms
subgraph-dom-widget-clipping: script duration ▃▃▃▄▅▅▂▄█▂▅▇▁▂▅ ➡️ 131ms
subgraph-dom-widget-clipping: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-dom-widget-clipping: heap used ➡️ NaN MB
subgraph-dom-widget-clipping: DOM nodes ▅▇▅▂▅▂▁▅▅▅▁▇▅█▄ ➡️ 22
subgraph-dom-widget-clipping: event listeners ▅▅▅▂▅▁▅██▁▁█▅█▅ 📈 16
subgraph-idle: avg frame time ▆▆█▁▆▃▆▆▆▃▆▁▃▆█ ➡️ 17ms
subgraph-idle: p95 frame time ➡️ NaNms
subgraph-idle: layout duration ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-idle: style recalc duration ▁▇▃▆▂▄▂▃▃▆▆▄▃▇█ ➡️ 12ms
subgraph-idle: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0
subgraph-idle: style recalc count ▃▆▃▃▂▅▁▂▁▆▃▃██▇ ➡️ 12
subgraph-idle: task duration ▁▃▁▇▁▁▃▆▅▂█▅▁▁▄ ➡️ 378ms
subgraph-idle: script duration ▁▃▂▇▁▂▃▇▆▂█▅▂▁▅ ➡️ 22ms
subgraph-idle: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-idle: heap used ➡️ NaN MB
subgraph-idle: DOM nodes ▃▅▃▂▁▄▁▂▁▅▃▂▇█▇ ➡️ 24
subgraph-idle: event listeners ▁▅▁▁▁▁▁▁▁▅▄▁███ 📈 21
subgraph-mouse-sweep: avg frame time ▅▄▁▃▃▄▆▄▆▃▃█▁▃▃ ➡️ 17ms
subgraph-mouse-sweep: p95 frame time ➡️ NaNms
subgraph-mouse-sweep: layout duration ▁▄▄▄▃▃▅▅▅▂█▇▂▃▆ ➡️ 5ms
subgraph-mouse-sweep: style recalc duration ▃▂▄▅▂▃▄▅█▃█▆▁▂▅ ➡️ 43ms
subgraph-mouse-sweep: layout count ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 16
subgraph-mouse-sweep: style recalc count ▅▂▅▅▁▄▃▅█▅▆▄▂▄▅ ➡️ 81
subgraph-mouse-sweep: task duration ▃▂▄▅▂▄▄▅▇▄█▆▁▃▅ ➡️ 785ms
subgraph-mouse-sweep: script duration ▄▅▄▇▅▅▆▇▆▅██▁▄▆ ➡️ 105ms
subgraph-mouse-sweep: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
subgraph-mouse-sweep: heap used ➡️ NaN MB
subgraph-mouse-sweep: DOM nodes ▅▁▄▅▁▄▃▃█▅▅▄▂▅▃ ➡️ 66
subgraph-mouse-sweep: event listeners ▇▁▂▇▁▂▂▂█▇▂▂▇▇▂ 📈 5
workflow-execution: avg frame time ▆▆▆▄▆▆▃▄▁▄█▆▅▄▆ ➡️ 17ms
workflow-execution: p95 frame time ➡️ NaNms
workflow-execution: layout duration ▁▆▁▃▂▄▃▂▃▃▅█▄▂▅ ➡️ 2ms
workflow-execution: style recalc duration ▃▇▅▇▁▅▆▇█▁██▂▄▆ ➡️ 25ms
workflow-execution: layout count ▁█▂▃▂▃▃▁▃▃▄▃▂▃▂ ➡️ 5
workflow-execution: style recalc count ▃█▅▇▁▄▅▆▅▅▅▅▄▄▂ ➡️ 15
workflow-execution: task duration ▂▅▄▅▁▄▆▆▆▁▇█▁▃▃ ➡️ 120ms
workflow-execution: script duration ▄▃▄▄▃▅▄▅▆▂▇█▁▃▄ ➡️ 29ms
workflow-execution: TBT ▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄ ➡️ 0ms
workflow-execution: heap used ➡️ NaN MB
workflow-execution: DOM nodes ▂█▃▆▁▄▃▅▃█▃▃▄▃▁ ➡️ 152
workflow-execution: event listeners ▅███▁▅███▁██▅█▅ ➡️ 49
Raw data
{
  "timestamp": "2026-04-03T23:04:39.535Z",
  "gitSha": "66678b6acf4e10cbf4e29a28d763113c64e52340",
  "branch": "proxy-widget-selector",
  "measurements": [
    {
      "name": "canvas-idle",
      "durationMs": 2037.8029999999967,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 8.396999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 334.812,
      "heapDeltaBytes": 21077396,
      "heapUsedBytes": 63829504,
      "domNodes": 21,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 24.009000000000004,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "canvas-idle",
      "durationMs": 2021.4280000000144,
      "styleRecalcs": 12,
      "styleRecalcDurationMs": 9.440999999999999,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 338.842,
      "heapDeltaBytes": -4667472,
      "heapUsedBytes": 44282448,
      "domNodes": 23,
      "jsHeapTotalBytes": 24641536,
      "scriptDurationMs": 21.996000000000002,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-idle",
      "durationMs": 2016.8270000000348,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 8.461000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 329.615,
      "heapDeltaBytes": 20342868,
      "heapUsedBytes": 63171056,
      "domNodes": 20,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 19.022000000000006,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 1997.163999999998,
      "styleRecalcs": 84,
      "styleRecalcDurationMs": 40.583,
      "layouts": 12,
      "layoutDurationMs": 3.4599999999999995,
      "taskDurationMs": 919.465,
      "heapDeltaBytes": 6999252,
      "heapUsedBytes": 58930880,
      "domNodes": 68,
      "jsHeapTotalBytes": 25690112,
      "scriptDurationMs": 126.14999999999998,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 1984.6000000000004,
      "styleRecalcs": 81,
      "styleRecalcDurationMs": 38.605000000000004,
      "layouts": 12,
      "layoutDurationMs": 3.1799999999999997,
      "taskDurationMs": 893.061,
      "heapDeltaBytes": 16347152,
      "heapUsedBytes": 58812688,
      "domNodes": 66,
      "jsHeapTotalBytes": 23592960,
      "scriptDurationMs": 124.38199999999999,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "canvas-mouse-sweep",
      "durationMs": 2010.3430000000344,
      "styleRecalcs": 84,
      "styleRecalcDurationMs": 39.484,
      "layouts": 12,
      "layoutDurationMs": 3.4290000000000003,
      "taskDurationMs": 915.3639999999999,
      "heapDeltaBytes": 16036992,
      "heapUsedBytes": 58846492,
      "domNodes": 67,
      "jsHeapTotalBytes": 23330816,
      "scriptDurationMs": 128.53,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1749.5620000000258,
      "styleRecalcs": 29,
      "styleRecalcDurationMs": 15.301,
      "layouts": 6,
      "layoutDurationMs": 0.6460000000000001,
      "taskDurationMs": 291.14,
      "heapDeltaBytes": 15450196,
      "heapUsedBytes": 67189348,
      "domNodes": 77,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 24.495,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1751.7090000000053,
      "styleRecalcs": 31,
      "styleRecalcDurationMs": 18.791,
      "layouts": 6,
      "layoutDurationMs": 0.5499999999999999,
      "taskDurationMs": 288.42,
      "heapDeltaBytes": 24688804,
      "heapUsedBytes": 67123576,
      "domNodes": 79,
      "jsHeapTotalBytes": 20447232,
      "scriptDurationMs": 22.236,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "canvas-zoom-sweep",
      "durationMs": 1748.5799999999472,
      "styleRecalcs": 30,
      "styleRecalcDurationMs": 15.642,
      "layouts": 6,
      "layoutDurationMs": 0.6229999999999999,
      "taskDurationMs": 280.498,
      "heapDeltaBytes": 24711096,
      "heapUsedBytes": 67498168,
      "domNodes": 77,
      "jsHeapTotalBytes": 20709376,
      "scriptDurationMs": 22.452000000000005,
      "eventListeners": 19,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 635.563000000019,
      "styleRecalcs": 13,
      "styleRecalcDurationMs": 9.144999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 393.78000000000003,
      "heapDeltaBytes": -2558912,
      "heapUsedBytes": 49283224,
      "domNodes": 22,
      "jsHeapTotalBytes": 16252928,
      "scriptDurationMs": 73.837,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 531.2270000000012,
      "styleRecalcs": 13,
      "styleRecalcDurationMs": 8.854,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 321.2200000000001,
      "heapDeltaBytes": 6210300,
      "heapUsedBytes": 49041032,
      "domNodes": 22,
      "jsHeapTotalBytes": 14155776,
      "scriptDurationMs": 62.910999999999994,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "dom-widget-clipping",
      "durationMs": 534.4929999999977,
      "styleRecalcs": 12,
      "styleRecalcDurationMs": 8.232999999999999,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 320.679,
      "heapDeltaBytes": 6463476,
      "heapUsedBytes": 49339064,
      "domNodes": 19,
      "jsHeapTotalBytes": 13631488,
      "scriptDurationMs": 63.38399999999999,
      "eventListeners": 2,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "large-graph-idle",
      "durationMs": 1999.1520000000094,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 9.968000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 518.965,
      "heapDeltaBytes": 15646592,
      "heapUsedBytes": 67135448,
      "domNodes": -256,
      "jsHeapTotalBytes": 14929920,
      "scriptDurationMs": 93.583,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2037.7269999999612,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 8.884,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 507.283,
      "heapDeltaBytes": 3242176,
      "heapUsedBytes": 55870368,
      "domNodes": -258,
      "jsHeapTotalBytes": 16969728,
      "scriptDurationMs": 89.861,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "large-graph-idle",
      "durationMs": 2044.3070000000034,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 8.846,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 511.17999999999995,
      "heapDeltaBytes": 5088744,
      "heapUsedBytes": 55861368,
      "domNodes": -259,
      "jsHeapTotalBytes": 16969728,
      "scriptDurationMs": 95.59700000000001,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2134.2940000000112,
      "styleRecalcs": 70,
      "styleRecalcDurationMs": 16.8,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1011.311,
      "heapDeltaBytes": 18157672,
      "heapUsedBytes": 70352568,
      "domNodes": -259,
      "jsHeapTotalBytes": 17698816,
      "scriptDurationMs": 392.484,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2115.4050000000097,
      "styleRecalcs": 68,
      "styleRecalcDurationMs": 14.432,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1012.264,
      "heapDeltaBytes": 17090328,
      "heapUsedBytes": 70665772,
      "domNodes": -262,
      "jsHeapTotalBytes": 19271680,
      "scriptDurationMs": 377.619,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.670000000000012,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-pan",
      "durationMs": 2133.560999999986,
      "styleRecalcs": 71,
      "styleRecalcDurationMs": 16.409999999999997,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 1021.0839999999998,
      "heapDeltaBytes": 21399272,
      "heapUsedBytes": 72888692,
      "domNodes": -257,
      "jsHeapTotalBytes": 17436672,
      "scriptDurationMs": 383.262,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3117.741999999993,
      "styleRecalcs": 64,
      "styleRecalcDurationMs": 13.744000000000003,
      "layouts": 60,
      "layoutDurationMs": 6.831,
      "taskDurationMs": 1237.952,
      "heapDeltaBytes": 6656504,
      "heapUsedBytes": 61517332,
      "domNodes": -264,
      "jsHeapTotalBytes": 17231872,
      "scriptDurationMs": 469.77399999999994,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3154.487999999958,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 16.502,
      "layouts": 60,
      "layoutDurationMs": 7.123000000000001,
      "taskDurationMs": 1237.2510000000002,
      "heapDeltaBytes": 7964168,
      "heapUsedBytes": 63778012,
      "domNodes": -261,
      "jsHeapTotalBytes": 16240640,
      "scriptDurationMs": 472.346,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "large-graph-zoom",
      "durationMs": 3147.809000000052,
      "styleRecalcs": 66,
      "styleRecalcDurationMs": 15.108,
      "layouts": 60,
      "layoutDurationMs": 6.819999999999999,
      "taskDurationMs": 1253.7069999999999,
      "heapDeltaBytes": 7451904,
      "heapUsedBytes": 62186812,
      "domNodes": -264,
      "jsHeapTotalBytes": 18018304,
      "scriptDurationMs": 483.257,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "minimap-idle",
      "durationMs": 2032.2570000000155,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 9.868000000000002,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 504.42999999999995,
      "heapDeltaBytes": 3949248,
      "heapUsedBytes": 56440284,
      "domNodes": -259,
      "jsHeapTotalBytes": 16445440,
      "scriptDurationMs": 91.39999999999999,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "minimap-idle",
      "durationMs": 2033.3969999999795,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 7.664000000000001,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 512.499,
      "heapDeltaBytes": 4270304,
      "heapUsedBytes": 57092812,
      "domNodes": -259,
      "jsHeapTotalBytes": 15921152,
      "scriptDurationMs": 95.15300000000002,
      "eventListeners": -125,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "minimap-idle",
      "durationMs": 2016.2780000000566,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 9.62,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 504.89099999999996,
      "heapDeltaBytes": 3287452,
      "heapUsedBytes": 56578968,
      "domNodes": -258,
      "jsHeapTotalBytes": 16445440,
      "scriptDurationMs": 90.787,
      "eventListeners": -127,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 525.779,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 11.699,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 339.916,
      "heapDeltaBytes": 6148208,
      "heapUsedBytes": 49278468,
      "domNodes": 22,
      "jsHeapTotalBytes": 13893632,
      "scriptDurationMs": 122.58300000000001,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 506.0940000000187,
      "styleRecalcs": 48,
      "styleRecalcDurationMs": 11.297,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 331.658,
      "heapDeltaBytes": 6074296,
      "heapUsedBytes": 50580620,
      "domNodes": 22,
      "jsHeapTotalBytes": 13893632,
      "scriptDurationMs": 116.697,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "subgraph-dom-widget-clipping",
      "durationMs": 578.6570000000211,
      "styleRecalcs": 49,
      "styleRecalcDurationMs": 11.689,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 351.371,
      "heapDeltaBytes": 6738512,
      "heapUsedBytes": 49528172,
      "domNodes": 22,
      "jsHeapTotalBytes": 12582912,
      "scriptDurationMs": 122.70900000000002,
      "eventListeners": 8,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999727
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2030.2050000000236,
      "styleRecalcs": 10,
      "styleRecalcDurationMs": 8.896999999999998,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 327.33299999999997,
      "heapDeltaBytes": 19883328,
      "heapUsedBytes": 63091804,
      "domNodes": 20,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 14.536,
      "eventListeners": 4,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "subgraph-idle",
      "durationMs": 2005.9160000000134,
      "styleRecalcs": 12,
      "styleRecalcDurationMs": 9.857999999999999,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 338.507,
      "heapDeltaBytes": 20001740,
      "heapUsedBytes": 62676800,
      "domNodes": 23,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 19.830000000000002,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "subgraph-idle",
      "durationMs": 1990.3759999999693,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 8.968,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 326.65299999999996,
      "heapDeltaBytes": 19933768,
      "heapUsedBytes": 63027188,
      "domNodes": 22,
      "jsHeapTotalBytes": 22806528,
      "scriptDurationMs": 18.061,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.699999999999818
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1963.6619999999994,
      "styleRecalcs": 83,
      "styleRecalcDurationMs": 43.881,
      "layouts": 16,
      "layoutDurationMs": 3.987,
      "taskDurationMs": 859.941,
      "heapDeltaBytes": 11910920,
      "heapUsedBytes": 55040744,
      "domNodes": 72,
      "jsHeapTotalBytes": 23068672,
      "scriptDurationMs": 97.748,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.800000000000182
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1676.0529999999676,
      "styleRecalcs": 76,
      "styleRecalcDurationMs": 36.111999999999995,
      "layouts": 16,
      "layoutDurationMs": 4.7059999999999995,
      "taskDurationMs": 622.392,
      "heapDeltaBytes": 12019796,
      "heapUsedBytes": 56307456,
      "domNodes": 62,
      "jsHeapTotalBytes": 23855104,
      "scriptDurationMs": 91.925,
      "eventListeners": 4,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333335,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "subgraph-mouse-sweep",
      "durationMs": 1972.171000000003,
      "styleRecalcs": 87,
      "styleRecalcDurationMs": 48.458,
      "layouts": 16,
      "layoutDurationMs": 4.119000000000001,
      "taskDurationMs": 896.405,
      "heapDeltaBytes": 11848460,
      "heapUsedBytes": 55059280,
      "domNodes": 73,
      "jsHeapTotalBytes": 22544384,
      "scriptDurationMs": 93.58500000000001,
      "eventListeners": 6,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8184.762000000006,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 42.287000000000006,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 3418.523,
      "heapDeltaBytes": 27694264,
      "heapUsedBytes": 78252080,
      "domNodes": -255,
      "jsHeapTotalBytes": 18485248,
      "scriptDurationMs": 1217.786,
      "eventListeners": -109,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8165.05699999999,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 42.102000000000004,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 3679.7329999999997,
      "heapDeltaBytes": 25139272,
      "heapUsedBytes": 75940564,
      "domNodes": -258,
      "jsHeapTotalBytes": 24776704,
      "scriptDurationMs": 1368.9520000000002,
      "eventListeners": -111,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.66333333333332,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "viewport-pan-sweep",
      "durationMs": 8144.426000000067,
      "styleRecalcs": 251,
      "styleRecalcDurationMs": 41.717000000000006,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 3378.5380000000005,
      "heapDeltaBytes": 24718636,
      "heapUsedBytes": 75587420,
      "domNodes": -257,
      "jsHeapTotalBytes": 18747392,
      "scriptDurationMs": 1187.2600000000002,
      "eventListeners": -111,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 10688.437000000022,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 10680.216,
      "heapDeltaBytes": -33980944,
      "heapUsedBytes": 163279804,
      "domNodes": -8331,
      "jsHeapTotalBytes": 23158784,
      "scriptDurationMs": 549.225,
      "eventListeners": -16466,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333358,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 10751.192000000003,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 10742.264000000001,
      "heapDeltaBytes": -31276680,
      "heapUsedBytes": 159591632,
      "domNodes": -8330,
      "jsHeapTotalBytes": 18178048,
      "scriptDurationMs": 526.297,
      "eventListeners": -16470,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "vue-large-graph-idle",
      "durationMs": 10587.341000000037,
      "styleRecalcs": 0,
      "styleRecalcDurationMs": 0,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 10574.504,
      "heapDeltaBytes": -27698280,
      "heapUsedBytes": 159473592,
      "domNodes": -8333,
      "jsHeapTotalBytes": 18178048,
      "scriptDurationMs": 524.51,
      "eventListeners": -16472,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.219999999999953,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 14059.285999999986,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 12.766,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 14036.945,
      "heapDeltaBytes": -34326556,
      "heapUsedBytes": 160377996,
      "domNodes": -8333,
      "jsHeapTotalBytes": -3141632,
      "scriptDurationMs": 804.732,
      "eventListeners": -16458,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.223333333333358,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 13655.123000000003,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 12.545,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 13635.347,
      "heapDeltaBytes": -53366084,
      "heapUsedBytes": 147866684,
      "domNodes": -8331,
      "jsHeapTotalBytes": 614400,
      "scriptDurationMs": 829.7159999999999,
      "eventListeners": -16490,
      "totalBlockingTimeMs": 49,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.799999999999272
    },
    {
      "name": "vue-large-graph-pan",
      "durationMs": 13763.344999999958,
      "styleRecalcs": 67,
      "styleRecalcDurationMs": 12.437000000000003,
      "layouts": 0,
      "layoutDurationMs": 0,
      "taskDurationMs": 13743.765,
      "heapDeltaBytes": -34098208,
      "heapUsedBytes": 159712328,
      "domNodes": -8331,
      "jsHeapTotalBytes": 90112,
      "scriptDurationMs": 802.0229999999999,
      "eventListeners": -16458,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 17.776666666666642,
      "p95FrameDurationMs": 16.700000000000728
    },
    {
      "name": "workflow-execution",
      "durationMs": 137.46000000003278,
      "styleRecalcs": 11,
      "styleRecalcDurationMs": 21.697000000000003,
      "layouts": 5,
      "layoutDurationMs": 1.5530000000000002,
      "taskDurationMs": 100.906,
      "heapDeltaBytes": 2946888,
      "heapUsedBytes": 46989320,
      "domNodes": 150,
      "jsHeapTotalBytes": 262144,
      "scriptDurationMs": 27.493999999999996,
      "eventListeners": 37,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.666666666666668,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "workflow-execution",
      "durationMs": 446.59200000000965,
      "styleRecalcs": 17,
      "styleRecalcDurationMs": 21.894999999999996,
      "layouts": 5,
      "layoutDurationMs": 1.2590000000000001,
      "taskDurationMs": 115.52999999999999,
      "heapDeltaBytes": 4497820,
      "heapUsedBytes": 49763448,
      "domNodes": 158,
      "jsHeapTotalBytes": 0,
      "scriptDurationMs": 27.740000000000002,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.700000000000273
    },
    {
      "name": "workflow-execution",
      "durationMs": 443.93800000000283,
      "styleRecalcs": 18,
      "styleRecalcDurationMs": 22.751,
      "layouts": 4,
      "layoutDurationMs": 1.017,
      "taskDurationMs": 110.72300000000001,
      "heapDeltaBytes": 4453488,
      "heapUsedBytes": 49154296,
      "domNodes": 158,
      "jsHeapTotalBytes": 0,
      "scriptDurationMs": 23.951,
      "eventListeners": 71,
      "totalBlockingTimeMs": 0,
      "frameDurationMs": 16.663333333333338,
      "p95FrameDurationMs": 16.700000000000273
    }
  ]
}

Copy link
Copy Markdown
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🧹 Nitpick comments (1)
src/lib/litegraph/src/subgraph/SubgraphNode.ts (1)

354-361: Consider using setProperty for property mutation.

The callback directly mutates selector.selected. While this works because selector is a reference to this.properties.proxyWidgetSelector, using the node's property change mechanism would ensure consistency with the trigger system and undo/redo if applicable.

♻️ Optional: Use setProperty for consistency
       callback: (value: unknown) => {
-        selector.selected = String(value)
+        this.setProperty('proxyWidgetSelector', {
+          ...selector,
+          selected: String(value)
+        })
         this._selectorWidget!.value = String(value)
         this._invalidatePromotedViewsCache()
         const minSize = this.computeSize()
         this.setSize([this.size[0], minSize[1]])
         this.graph?.setDirtyCanvas(true, true)
       }
🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@src/lib/litegraph/src/subgraph/SubgraphNode.ts` around lines 354 - 361, The
callback currently mutates selector.selected directly (selector is
this.properties.proxyWidgetSelector); change it to use the node property API by
calling this.setProperty('proxyWidgetSelector', <new object with selected set to
String(value)>) instead of direct assignment, then update
this._selectorWidget!.value, call this._invalidatePromotedViewsCache(),
recompute size via this.computeSize(), call this.setSize([this.size[0],
minSize[1]]), and mark the graph dirty with this.graph?.setDirtyCanvas(true,
true) so property change hooks/undo-redo are honored.
🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.

Nitpick comments:
In `@src/lib/litegraph/src/subgraph/SubgraphNode.ts`:
- Around line 354-361: The callback currently mutates selector.selected directly
(selector is this.properties.proxyWidgetSelector); change it to use the node
property API by calling this.setProperty('proxyWidgetSelector', <new object with
selected set to String(value)>) instead of direct assignment, then update
this._selectorWidget!.value, call this._invalidatePromotedViewsCache(),
recompute size via this.computeSize(), call this.setSize([this.size[0],
minSize[1]]), and mark the graph dirty with this.graph?.setDirtyCanvas(true,
true) so property change hooks/undo-redo are honored.

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yaml

Review profile: CHILL

Plan: Pro

Run ID: 4d671434-2a8a-48cb-bdc8-03411ea61503

📥 Commits

Reviewing files that changed from the base of the PR and between 17d2870 and e154bba.

📒 Files selected for processing (3)
  • src/composables/graph/useGraphNodeManager.ts
  • src/core/schemas/promotionSchema.ts
  • src/lib/litegraph/src/subgraph/SubgraphNode.ts

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:M This PR changes 30-99 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants