Skip to content

fix(vueNodes): decrease default size of reroute nodes#8734

Open
christian-byrne wants to merge 4 commits intomainfrom
fix/vue-nodes/reroute-default-size
Open

fix(vueNodes): decrease default size of reroute nodes#8734
christian-byrne wants to merge 4 commits intomainfrom
fix/vue-nodes/reroute-default-size

Conversation

@christian-byrne
Copy link
Contributor

@christian-byrne christian-byrne commented Feb 8, 2026

Summary

Remove the 225px minimum width constraint from reroute nodes so they render at their intended ~75×26px size.

Changes

  • What: Reroute nodes now bypass the min-w-[225px] CSS constraint and bottom padding applied to regular nodes. resizable: false is set on the RerouteNode constructor to hide the resize handle. An isRerouteNode computed in LGraphNode.vue gates these behaviors by checking nodeData.type === "Reroute".

Review Focus

Fixes #4704

Screenshots (if applicable)

Reroute nodes now render at ~75px wide instead of being forced to 225px minimum.

┆Issue is synchronized with this Notion page by Unito

@github-actions
Copy link

github-actions bot commented Feb 8, 2026

🎨 Storybook Build Status

Build completed successfully!

⏰ Completed at: 02/14/2026, 03:00:58 AM UTC

🔗 Links


🎉 Your Storybook is ready for review!

@github-actions
Copy link

github-actions bot commented Feb 8, 2026

Playwright: ❌ 523 passed, 3 failed · 1 flaky

❌ Failed Tests

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

@coderabbitai
Copy link
Contributor

coderabbitai bot commented Feb 8, 2026

Note

Reviews paused

It looks like this branch is under active development. To avoid overwhelming you with review comments due to an influx of new commits, CodeRabbit has automatically paused this review. You can configure this behavior by changing the reviews.auto_review.auto_pause_after_reviewed_commits setting.

Use the following commands to manage reviews:

  • @coderabbitai resume to resume automatic reviews.
  • @coderabbitai review to trigger a single review.

Use the checkboxes below for quick actions:

  • ▶️ Resume reviews
  • 🔍 Trigger review
📝 Walkthrough

Walkthrough

Disables UI resizing for reroute nodes, tightens their computed size, exempts them from default min-width/min-height and certain padding in the Vue renderer, and adds unit and E2E tests verifying smaller sizing and absence of resize handles.

Changes

Cohort / File(s) Summary
Reroute Node Core
src/extensions/core/rerouteNode.ts
Sets this.resizable = false in the RerouteNode constructor and adjusts computeSize height logic (uses 50 instead of 75 when showOutputText is true).
Vue Node Render / Styling
src/renderer/extensions/vueNodes/components/LGraphNode.vue
Adds isRerouteNode computed flag; conditionally omits min-w/min-h and certain padding for reroute nodes; separates rendering branches so reroute nodes render slots/body differently and avoid guard rails applied to regular nodes.
Component Unit Tests
src/renderer/extensions/vueNodes/components/LGraphNode.test.ts
Adds mockRerouteNodeData and tests asserting reroute nodes bypass min-size constraints and do not render a resize handle while regular nodes do.
End-to-End Test
browser_tests/tests/vueNodes/rerouteNodeSize.spec.ts
New Playwright/Vue E2E test that loads a workflow with a reroute node, locates the reroute via the page graph model, asserts bounding box dimensions, and checks absence of resize affordances.

Estimated code review effort

🎯 3 (Moderate) | ⏱️ ~20 minutes

Poem

🐰 I nudged a tiny reroute, quick and neat,
A dot that hops where wire and shadows meet.
Small and spry, I weave the thread,
No handles cling, just room to tread.
A rabbit's cheer for lighter feet.

🚥 Pre-merge checks | ✅ 5
✅ Passed checks (5 passed)
Check name Status Explanation
Title check ✅ Passed The title accurately describes the main change: reducing the default size of reroute nodes in Vue components.
Description check ✅ Passed The description covers all required template sections with clear explanations of what changed, breaking changes (none), and review focus points.
Linked Issues check ✅ Passed The PR implements the core requirement from issue #4704: making reroute nodes smaller by removing the 225px minimum width constraint and adjusting sizing to render at ~75×26px.
Out of Scope Changes check ✅ Passed All changes are directly related to reducing reroute node size: sizing adjustments, resizable property, CSS constraints, and comprehensive tests covering the new behavior.
Docstring Coverage ✅ Passed No functions found in the changed files to evaluate docstring coverage. Skipping docstring coverage check.

✏️ Tip: You can configure your own custom pre-merge checks in the settings.

✨ Finishing touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Post copyable unit tests in a comment
  • Commit unit tests in branch fix/vue-nodes/reroute-default-size

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

@github-actions
Copy link

github-actions bot commented Feb 8, 2026

Bundle Size Report

Summary

  • Raw size: 19.8 MB baseline 19.8 MB — 🔴 +400 B
  • Gzip: 4.24 MB baseline 4.24 MB — 🔴 +105 B
  • Brotli: 3.29 MB baseline 3.29 MB — 🟢 -53 B
  • Bundles: 230 current • 230 baseline • 2 added / 2 removed

Category Glance
Graph Workspace 🔴 +400 B (880 kB) · Vendor & Third-Party ⚪ 0 B (8.69 MB) · Other ⚪ 0 B (7.31 MB) · Data & Services ⚪ 0 B (2.15 MB) · Panels & Settings ⚪ 0 B (427 kB) · Utilities & Hooks ⚪ 0 B (237 kB) · + 5 more

Per-category breakdown
App Entry Points — 21.7 kB (baseline 21.7 kB) • ⚪ 0 B

Main entry bundles and manifests

File Before After Δ Raw Δ Gzip Δ Brotli
assets/index-B-4uiC3g.js (removed) 21.7 kB 🟢 -21.7 kB 🟢 -7.02 kB 🟢 -6.1 kB
assets/index-BDsnUJEv.js (new) 21.7 kB 🔴 +21.7 kB 🔴 +7.03 kB 🔴 +6.1 kB

Status: 1 added / 1 removed

Graph Workspace — 880 kB (baseline 879 kB) • 🔴 +400 B

Graph editor runtime, canvas, workflow orchestration

File Before After Δ Raw Δ Gzip Δ Brotli
assets/GraphView-E5F9335W.js (new) 880 kB 🔴 +880 kB 🔴 +190 kB 🔴 +144 kB
assets/GraphView-HoeLwPCL.js (removed) 879 kB 🟢 -879 kB 🟢 -190 kB 🟢 -144 kB

Status: 1 added / 1 removed

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

Top-level views, pages, and routed surfaces

File Before After Δ Raw Δ Gzip Δ Brotli
assets/CloudAuthTimeoutView-BNXUuLR9.js 4.96 kB 4.96 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudForgotPasswordView-CqbjZlSZ.js 5.61 kB 5.61 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudLayoutView-D4uKhBJy.js 6.48 kB 6.48 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudLoginView-BPYfz2sO.js 10.1 kB 10.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudSignupView-bgXlp5B9.js 7.46 kB 7.46 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudSorryContactSupportView-CnbSE1aL.js 1.02 kB 1.02 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudSubscriptionRedirectView-uUkSW1Gm.js 4.76 kB 4.76 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudSurveyView-CBqtF8kn.js 15.4 kB 15.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/layout-BN-ntRG8.js 296 B 296 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/UserCheckView-rsW2C4uJ.js 8.38 kB 8.38 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/UserSelectView-SHW8t_Tu.js 4.46 kB 4.46 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
Panels & Settings — 427 kB (baseline 427 kB) • ⚪ 0 B

Configuration panels, inspectors, and settings screens

File Before After Δ Raw Δ Gzip Δ Brotli
assets/AboutPanel-rxUgzD8Q.js 8.49 kB 8.49 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/cloudRemoteConfig-C5w8qMm4.js 1.49 kB 1.49 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/config-CepyQFhC.js 996 B 996 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ExtensionPanel-D8-2ApDh.js 9.43 kB 9.43 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/KeybindingPanel-BpppPVaj.js 12.4 kB 12.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/LegacyCreditsPanel-LG8q37G-.js 20.7 kB 20.7 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/refreshRemoteConfig-DjjXNcoP.js 1.14 kB 1.14 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SecretsPanel-CoaeQO2w.js 21.5 kB 21.5 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ServerConfigPanel-SL8H6x6E.js 6.5 kB 6.5 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-8z66fa9o.js 29.2 kB 29.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-B_EruZyQ.js 27.1 kB 27.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-BPuOKZZg.js 23.9 kB 23.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-C5NycgSh.js 31.6 kB 31.6 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-CF6cmuWq.js 37.6 kB 37.6 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-CMSM0-YP.js 28.1 kB 28.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-Djbh331J.js 29.8 kB 29.8 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-emoCO0AT.js 27.3 kB 27.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-H0rWARzj.js 23.3 kB 23.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-HiOqkizv.js 28 kB 28 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/settings-ohqijv3i.js 33.3 kB 33.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscriptionPanel-_53aybBI.js 18.7 kB 18.7 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/UserPanel-ChyW243S.js 6.21 kB 6.21 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
User & Accounts — 16.1 kB (baseline 16.1 kB) • ⚪ 0 B

Authentication, profile, and account management bundles

File Before After Δ Raw Δ Gzip Δ Brotli
assets/auth-D0b3BgID.js 317 B 317 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/auth-DDlx1Uue.js 3.4 kB 3.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/firebaseAuthStore-BrKFmNVr.js 837 B 837 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/PasswordFields-CdUdjtQy.js 4.51 kB 4.51 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SignUpForm-Cv6_Z_Rl.js 3.01 kB 3.01 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/UpdatePasswordContent-B7fkOjTt.js 2.42 kB 2.42 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WorkspaceProfilePic-BQO-2kig.js 1.57 kB 1.57 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
Editors & Dialogs — 785 B (baseline 785 B) • ⚪ 0 B

Modals, dialogs, drawers, and in-app editors

File Before After Δ Raw Δ Gzip Δ Brotli
assets/useSubscriptionDialog-D5ZE7vem.js 785 B 785 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
UI Components — 36.6 kB (baseline 36.6 kB) • ⚪ 0 B

Reusable component library chunks

File Before After Δ Raw Δ Gzip Δ Brotli
assets/Button-BlbRDbqy.js 2.98 kB 2.98 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudBadge-hxJOdoys.js 1.24 kB 1.24 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/cloudFeedbackTopbarButton-Dr7tNoMU.js 1.64 kB 1.64 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ComfyQueueButton-C0jx-z49.js 7.17 kB 7.17 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ComfyQueueButton-CulQtv99.js 842 B 842 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscribeButton-DRlV7y4y.js 2.35 kB 2.35 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/TopbarBadge-Ds7IqP5Z.js 7.45 kB 7.45 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/UserAvatar-DrH_EiZZ.js 1.17 kB 1.17 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useTerminalTabs-TrW1IJVS.js 9.89 kB 9.89 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetButton-DgRwIURU.js 1.84 kB 1.84 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
Data & Services — 2.15 MB (baseline 2.15 MB) • ⚪ 0 B

Stores, services, APIs, and repositories

File Before After Δ Raw Δ Gzip Δ Brotli
assets/api-DM91a_D4.js 646 kB 646 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/audioService-CiJfvQl6.js 1.73 kB 1.73 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/bootstrapStore-0NlPdXUg.js 2.08 kB 2.08 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/dialogService-BSoJCSOQ.js 774 B 774 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/dialogService-COfXCPpi.js 1.38 MB 1.38 MB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/dialogStore-D5Kfd1UD.js 4.1 kB 4.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/keybindingService-DH4NGyRQ.js 6.57 kB 6.57 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/load3dService-iSJtmA8J.js 91 kB 91 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/releaseStore-CuhRqYgf.js 809 B 809 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/releaseStore-rjBD-H_l.js 7.96 kB 7.96 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/serverConfigStore-CRmy-NJp.js 2.32 kB 2.32 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/systemStatsStore-Bw5QI-Qx.js 12.2 kB 12.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/userStore-grr_5GFG.js 1.85 kB 1.85 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/workflowDraftStore-Dq2TFDJb.js 785 B 785 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
Utilities & Hooks — 237 kB (baseline 237 kB) • ⚪ 0 B

Helpers, composables, and utility bundles

File Before After Δ Raw Δ Gzip Δ Brotli
assets/_plugin-vue_export-helper-CY4XIWDa.js 315 B 315 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/audioUtils-dbUQQNNt.js 858 B 858 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/colorUtil-BiqWg6CN.js 7 kB 7 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/envUtil-BHmbpOtd.js 466 B 466 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/markdownRendererUtil-DKmelI5u.js 1.56 kB 1.56 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SkeletonUtils-BputJAFn.js 133 B 133 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/subscriptionCheckoutUtil-QORpWLhD.js 2.53 kB 2.53 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useConflictDetection-BjmAcF_N.js 178 kB 178 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useCopyToClipboard-g_l_VTR-.js 1.57 kB 1.57 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useCurrentUser-DklJw2r7.js 771 B 771 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useErrorHandling-DYBD8ZZz.js 1.34 kB 1.34 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useExternalLink-BW7ksmwd.js 1.66 kB 1.66 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useFeatureFlags-CMv4I8Y-.js 3.32 kB 3.32 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useLoad3d-BBeaXtsO.js 14.6 kB 14.6 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useLoad3d-DKWmuida.js 908 B 908 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useLoad3dViewer-D1Okxrrk.js 14.1 kB 14.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useLoad3dViewer-vLk9iQi3.js 887 B 887 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useSubscriptionCredits-CCtRUKBY.js 2.75 kB 2.75 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useWorkspaceSwitch-CEHO3ye1.js 1.25 kB 1.25 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/useWorkspaceUI-JbOwee2I.js 3 kB 3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
Vendor & Third-Party — 8.69 MB (baseline 8.69 MB) • ⚪ 0 B

External libraries and shared vendor chunks

File Before After Δ Raw Δ Gzip Δ Brotli
assets/vendor-axios-C4mPrLmU.js 70.3 kB 70.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-chart-BxkFiWzp.js 399 kB 399 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-firebase-BvMr43CG.js 836 kB 836 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-i18n-BxsQv-KC.js 131 kB 131 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-markdown-uorjc_FY.js 102 kB 102 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-other-CON5ZIHM.js 1.52 MB 1.52 MB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-primevue-Bd8j9uVq.js 1.73 MB 1.73 MB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-reka-ui-B82zTENX.js 255 kB 255 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-sentry-SQwstEKc.js 182 kB 182 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-three-LBLOE6BD.js 1.8 MB 1.8 MB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-tiptap-Bi_34iZD.js 625 kB 625 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-vue-core-BjA-tjXK.js 311 kB 311 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-vueuse-DcEOrMQz.js 112 kB 112 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-xterm-Yc0APIKH.js 374 kB 374 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-yjs-CBmk8HiD.js 143 kB 143 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/vendor-zod-DcCUUPIi.js 109 kB 109 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
Other — 7.31 MB (baseline 7.31 MB) • ⚪ 0 B

Bundles that do not match a named category

File Before After Δ Raw Δ Gzip Δ Brotli
assets/AnimationControls-C2PN8K_8.js 4.61 kB 4.61 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ApiNodesSignInContent-DxP_ywVH.js 2.69 kB 2.69 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/AudioPreviewPlayer-D97fMUUj.js 10.9 kB 10.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/auto-BTnZwrs2.js 1.7 kB 1.7 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/BaseViewTemplate-D1Wkn_Pz.js 1.78 kB 1.78 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CancelSubscriptionDialogContent-GeP5waU2.js 4.85 kB 4.85 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/changeTracker-B63hrD1o.js 806 B 806 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/changeTracker-BkefQWMS.js 9.38 kB 9.38 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/cloudBadges-BpCZWrVj.js 1.42 kB 1.42 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CloudRunButtonWrapper-igqBGqFU.js 1.72 kB 1.72 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/cloudSessionCookie-SHoucsz1.js 3.15 kB 3.15 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/cloudSubscription-D28QMdQm.js 1.38 kB 1.38 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/comfy-logo-single-IINhk7dd.js 198 B 198 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ComfyOrgHeader-DAYiT6Xw.js 910 B 910 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-BA_pLDIO.js 14.7 kB 14.7 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-BhzDZEGT.js 15.7 kB 15.7 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-BNvNJ49l.js 15.8 kB 15.8 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-BrjHW_IV.js 18.4 kB 18.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-BuCfvdT4.js 17.1 kB 17.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-BumftKwc.js 15.8 kB 15.8 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-Cq5uT6l1.js 16.6 kB 16.6 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-CxH3xT8b.js 14.9 kB 14.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-D_Nd488H.js 16.3 kB 16.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-D1Ii1DEp.js 17.2 kB 17.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/commands-uLreJTDW.js 15.5 kB 15.5 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/constants-fZH7ZM7u.js 579 B 579 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/core-nQaG3Vpk.js 72.4 kB 72.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CreateWorkspaceDialogContent-DxUlD8XI.js 5.58 kB 5.58 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/CurrentUserPopoverWorkspace-MfGcK0Kn.js 19.9 kB 19.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/DeleteWorkspaceDialogContent-Bs910rhx.js 4.29 kB 4.29 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/EditWorkspaceDialogContent-CTPpLDlJ.js 5.38 kB 5.38 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/GlobalToast-Dj06SQmC.js 2.91 kB 2.91 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/graphHasMissingNodes-BiEpCA8i.js 761 B 761 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/groupNode-BLpM2ZMc.js 72.1 kB 72.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/i18n-D7oDc9A5.js 495 kB 495 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/i18n-Dkin6cXj.js 199 B 199 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ImportFailedNodeContent-CNb288kC.js 2.48 kB 2.48 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ImportFailedNodeFooter-D7x-tpBl.js 1.88 kB 1.88 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ImportFailedNodeHeader-LMkGR62F.js 1.08 kB 1.08 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/InviteMemberDialogContent-ydOwQRmo.js 7.44 kB 7.44 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/InviteMemberUpsellDialogContent-BIxjTlM1.js 3.88 kB 3.88 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/LazyImage-DR-0-yTy.js 12.3 kB 12.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/LeaveWorkspaceDialogContent-IP3vkBb7.js 4.12 kB 4.12 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Load3D-9USmHzbG.js 16.2 kB 16.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/load3d-Br0abtAN.js 14.8 kB 14.8 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Load3D-CoLNxwGR.js 1.12 kB 1.12 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Load3DConfiguration-iXV-ymbs.js 6.27 kB 6.27 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Load3DControls-CvE2PwbP.js 30.9 kB 30.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Load3dViewerContent-BcgyHe83.js 1.04 kB 1.04 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Load3dViewerContent-Ddl1nQW5.js 23.1 kB 23.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-B2rqO4ok.js 136 kB 136 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-B7zbjYoC.js 154 kB 154 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-Be3mUkOG.js 118 kB 118 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-BHvPYFxt.js 161 kB 161 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-CL3WdXR2.js 118 kB 118 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-CLfqZq3_.js 187 kB 187 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-CUXerpeP.js 133 kB 133 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-D8_6_IyP.js 134 kB 134 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-DiuZUyLe.js 167 kB 167 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-NSLXfI7X.js 138 kB 138 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/main-UlVmKY0W.js 141 kB 141 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Media3DTop-CHdzdEY0.js 1.82 kB 1.82 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MediaAudioTop-aTfN9fO4.js 1.43 kB 1.43 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MediaImageTop-DwcJSZ5v.js 1.75 kB 1.75 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MediaVideoTop-C7I_Nivi.js 2.23 kB 2.23 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MissingModelsWarning-CWR-sLUR.js 17.2 kB 17.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MissingNodesContent-CLJ4k1uj.js 6.18 kB 6.18 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MissingNodesFooter-ZcQw2OQN.js 6.75 kB 6.75 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/MissingNodesHeader-BAZcszup.js 1.09 kB 1.09 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nightlyBadges-CCyk4g8j.js 1.05 kB 1.05 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/NodeConflictDialogContent-BGCFmGCN.js 10.5 kB 10.5 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/NodeConflictFooter-UR8--yb_.js 2.37 kB 2.37 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/NodeConflictHeader-Dw3rwJjr.js 1.09 kB 1.09 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-3cab5KeM.js 415 kB 415 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-aLMm0gZm.js 362 kB 362 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-BkRL-oJ_.js 454 kB 454 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-BNE1oPUr.js 337 kB 337 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-BXPcnYpT.js 369 kB 369 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-CD0BvEYx.js 370 kB 370 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-CiYiQ6D5.js 416 kB 416 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-DcpehiUU.js 340 kB 340 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-DyWG6Iir.js 366 kB 366 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-hyXgxlxY.js 384 kB 384 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeDefs-TCrvxtjI.js 373 kB 373 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/nodeTemplates-95fa6GNi.js 9.35 kB 9.35 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/OBJLoader2WorkerModule-DTMpvldF.js 109 kB 109 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Preview3d-BbdiU-65.js 4.86 kB 4.86 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/previousFullPath-DEaITebJ.js 665 B 665 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/RemoveMemberDialogContent-8i_h0s0H.js 4.1 kB 4.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/RevokeInviteDialogContent-BVRDjfgR.js 4.01 kB 4.01 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/rolldown-runtime-DLICfi3-.js 1.97 kB 1.97 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/saveMesh-BiwvEQ0V.js 3.43 kB 3.43 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SelectValue-CdzHv1VF.js 8.94 kB 8.94 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SignInContent-Dv-mUDO7.js 19 kB 19 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/signInSchema-B_w46prb.js 1.53 kB 1.53 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/Slider-B-nteaB9.js 3.52 kB 3.52 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/src--CSlktKB.js 251 B 251 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscribeToRun-Bz7g8SAX.js 2.2 kB 2.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscriptionPanelContentWorkspace-CibhSHC_.js 979 B 979 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscriptionPanelContentWorkspace-CmZzJ9DU.js 21.6 kB 21.6 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscriptionRequiredDialogContent-byMbm_6B.js 26.2 kB 26.2 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/SubscriptionRequiredDialogContentWorkspace-CKqw5L6r.js 45.9 kB 45.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/telemetry-Db2yG1o2.js 226 B 226 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/types-DT3N7am7.js 204 B 204 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/ValueControlPopover-I8FlYoIn.js 4.97 kB 4.97 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/widget-BhHc6T04.js 445 B 445 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetBoundingBox-05_iDuzU.js 131 B 131 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetBoundingBox-JezhrbLj.js 3.91 kB 3.91 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetChart-B1i-QEjC.js 2.21 kB 2.21 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetColorPicker-BUNId5TS.js 2.9 kB 2.9 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetGalleria-DhRGcwZO.js 3.61 kB 3.61 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetImageCompare-CV8eZwv_.js 3.1 kB 3.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetImageCrop-CL-NTCjh.js 22.4 kB 22.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetInputNumber-BGrd1GYG.js 392 B 392 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetInputNumber-D75-HCal.js 15.8 kB 15.8 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetInputText-Ww-Tpbsi.js 1.86 kB 1.86 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetLayoutField-CLaC3IDH.js 1.95 kB 1.95 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetLegacy-Ce1W9RRq.js 794 B 794 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetMarkdown-CnTGrGUn.js 2.88 kB 2.88 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/widgetPropFilter-Cd0O5LPR.js 1.1 kB 1.1 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetRecordAudio-H3-VbbUl.js 17.4 kB 17.4 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetSelect-CQMk9AWE.js 57.8 kB 57.8 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetTextarea-bavVor9x.js 3.18 kB 3.18 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetToggleSwitch-CYFSDGXH.js 2.5 kB 2.5 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/widgetTypes-Cp8f93Pk.js 393 B 393 B ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WidgetWithControl-v_6nvlg8.js 7.08 kB 7.08 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B
assets/WorkspacePanelContent-BC_uj0cH.js 29.3 kB 29.3 kB ⚪ 0 B ⚪ 0 B ⚪ 0 B

@christian-byrne christian-byrne added the preview-cpu Creates a preview ephemeral environment for this PR (CPU only) label Feb 8, 2026
@christian-byrne christian-byrne force-pushed the fix/vue-nodes/reroute-default-size branch from 2e7d670 to 90bea80 Compare February 9, 2026 00:32
Copy link
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.

Actionable comments posted: 1

🤖 Fix all issues with AI agents
In `@browser_tests/tests/vueNodes/rerouteNodeSize.spec.ts`:
- Around line 68-69: The assertion is checking for zero resize handles but uses
.last(), which is misleading; update the locator usage by removing .last() so
that resizeHandle is obtained via
rerouteEl.locator('[role="button"][aria-label]') and then assert await
expect(resizeHandle).toHaveCount(0) (keep the existing selector fallback),
ensuring the test clearly asserts that no resize handle elements exist.
🧹 Nitpick comments (1)
browser_tests/tests/vueNodes/rerouteNodeSize.spec.ts (1)

16-20: Consider extracting the repeated reroute node lookup into a helper.

The logic to find the reroute node ID via page.evaluate is duplicated across all four tests. Extracting this into a helper function would reduce duplication and improve maintainability.

♻️ Suggested helper extraction
async function getRerouteNodeId(page: Page): Promise<string | null> {
  return page.evaluate(() => {
    const graph = window.app!.graph!
    const rerouteNode = graph.nodes.find((n) => n.type === 'Reroute')
    return rerouteNode ? String(rerouteNode.id) : null
  })
}

Then in each test:

const rerouteNodeId = await getRerouteNodeId(comfyPage.page)
expect(rerouteNodeId).not.toBeNull()

Also applies to: 33-41, 59-63, 75-79

@christian-byrne christian-byrne marked this pull request as ready for review February 9, 2026 02:34
@christian-byrne christian-byrne requested a review from a team as a code owner February 9, 2026 02:34
@dosubot dosubot bot added the size:L This PR changes 100-499 lines, ignoring generated files. label Feb 9, 2026
@pythongosssss
Copy link
Member

In litegraph mode the node is very hard to move as the clickable area for the slots takes up most of the node

@christian-byrne christian-byrne force-pushed the fix/vue-nodes/reroute-default-size branch 2 times, most recently from 93692fb to a88a5e6 Compare February 13, 2026 22:47
- Skip min-w-[225px] and min-h constraints for reroute nodes in Vue
- Render bare NodeSlots without body wrapper for compact layout
- Hide footer Button and resize handles for reroute nodes
- All changes are Vue-only; no modifications to shared litegraph code
- Add screenshot baseline test for visual regression

Fixes #4704

Amp-Thread-ID: https://ampcode.com/threads/T-019c5893-c9d2-77cb-9e90-a9a0631220db
@christian-byrne christian-byrne force-pushed the fix/vue-nodes/reroute-default-size branch from a88a5e6 to 9925d27 Compare February 14, 2026 00:50
@christian-byrne
Copy link
Contributor Author

I simplified it

Screenshot from 2026-02-13 16-46-37 Screenshot from 2026-02-13 16-46-46

@christian-byrne
Copy link
Contributor Author

Test here: https://pr-2369.testenvs.comfy.org/

actions-user and others added 3 commits February 14, 2026 00:52
Reroute nodes without min-h caused ResizeObserver to measure a tiny
DOM height. After removeNodeTitleHeight subtracted 30px the stored
height became 0, making the node invisible when switching to litegraph
mode. Use h-(--node-height) so the DOM height always matches
computeSize() after the title-height normalization.

Amp-Thread-ID: https://ampcode.com/threads/T-019c59fb-447e-7191-ba36-b85f723346e1
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

preview-cpu Creates a preview ephemeral environment for this PR (CPU only) size:L This PR changes 100-499 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Please make reroutes smaller

3 participants