refactor(tool-input): subblock-first rendering, component extraction, bug fixes#3207
refactor(tool-input): subblock-first rendering, component extraction, bug fixes#3207waleedlatif1 merged 17 commits intostagingfrom
Conversation
…d dependsOn gating Replace 17+ individual SyncWrapper components with a single centralized ToolSubBlockRenderer that bridges the subblock store with StoredTool.params via synthetic store keys. This reduces ~1000 lines of duplicated wrapper code and ensures tool-input renders subblock components identically to the standalone SubBlock path. - Add ToolSubBlockRenderer with bidirectional store sync - Add basic/advanced mode toggle (ArrowLeftRight) using collaborative functions - Add dependsOn gating via useDependsOnGate (fields disable instead of hiding) - Add paramVisibility field to SubBlockConfig for tool-input visibility control - Pass canonicalModeOverrides through getSubBlocksForToolInput - Show (optional) label for non-user-only fields (LLM can inject at runtime) Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
…canonical toggle, extract components - Attach resolved paramVisibility to subblocks from getSubBlocksForToolInput - Add labelSuffix prop to SubBlock for "(optional)" badge on user-or-llm params - Fix folder selector missing for tools with canonicalParamId (e.g. Google Drive) - Fix canonical toggle not clickable by letting SubBlock handle dependsOn internally - Extract ParameterWithLabel, ToolSubBlockRenderer, ToolCredentialSelector to components/tools/ - Extract StoredTool interface to types.ts, selection helpers to utils.ts - Remove dead code (mcpError, refreshTools, oldParamIds, initialParams) - Strengthen typing: replace any with proper types on icon components and evaluateParameterCondition
|
The latest updates on your projects. Learn more about Vercel for GitHub. |
Greptile OverviewGreptile SummaryThis PR successfully refactors the tool-input system by replacing a ~440-line Key improvements:
Issues found:
Confidence Score: 4/5
Important Files Changed
Sequence DiagramsequenceDiagram
participant TI as ToolInput
participant TSR as ToolSubBlockRenderer
participant SB as SubBlock
participant Store as SubBlockStore
TI->>TSR: Render tool parameter<br/>(with subBlock config)
Note over TSR: Create synthetic ID:<br/>${subBlockId}-tool-${toolIndex}-${paramId}
TSR->>Store: useSubBlockValue(syntheticId)
Store-->>TSR: [storeValue, setStoreValue]
Note over TSR: Sync tool.params → store
TSR->>TSR: Parse JSON if object type<br/>(file-upload, table, etc.)
TSR->>Store: setStoreValue(parsed/string)
TSR->>SB: <SubBlock config={...} canonicalToggle={...}/>
Note over SB: Renders using native<br/>SubBlock components
SB->>Store: Updates store on user input
Store-->>TSR: storeValue changed
Note over TSR: Sync store → tool.params
TSR->>TSR: Stringify if object type
TSR->>TI: onParamChange(toolIndex, paramId, stringValue)
Last reviewed commit: a76e6e9 |
.../components/editor/components/sub-block/components/tool-input/components/tools/parameter.tsx
Outdated
Show resolved
Hide resolved
...ts/editor/components/sub-block/components/tool-input/components/tools/sub-block-renderer.tsx
Show resolved
Hide resolved
…evant in tool input, and removed unused param
|
@cursor review |
The SubBlock-first rendering path was hard-returning after rendering subblocks, so tool params without matching subblocks (like inputMapping for workflow tools) were never rendered. Now renders subblocks first, then any remaining displayParams not covered by subblocks via the legacy ParameterWithLabel fallback. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
After redeploying a child workflow via the stale badge, the workflow state cache was not invalidated, so WorkflowInputMapperInput kept showing stale input fields until page refresh. Now invalidates workflowKeys.state on deploy success. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
…tional) spacing - Set workflowId param to user-only in workflow_executor tool config so "Select Workflow" no longer shows "(optional)" indicator - Tighten (optional) label spacing with -ml-[3px] to counteract parent Label's gap-[6px], making it feel inline with the label text Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
Use items-baseline instead of items-center on Label flex containers so the smaller (optional) text aligns with the label text baseline rather than sitting slightly below it. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
Bump the expanded tool body container's top padding from 8px to 12px for more breathing room between the header bar and the first parameter. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
Revert container padding to py-[8px] (MCP tools were correct). Wrap SubBlock-first output in a div with pt-[4px] so only registry tools get extra breathing room from the container top. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
SubBlock's internal gap (10px between label and input) matched the between-parameter gap (10px), making them indistinguishable. Increase the between-parameter gap to 14px so consecutive parameters are visually distinct, matching the separation seen in ParameterWithLabel. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
|
@cursor review |
...ts/editor/components/sub-block/components/tool-input/components/tools/sub-block-renderer.tsx
Show resolved
Hide resolved
|
@cursor review |
...ts/editor/components/sub-block/components/tool-input/components/tools/sub-block-renderer.tsx
Outdated
Show resolved
Hide resolved
apps/sim/app/workspace/[workspaceId]/w/[workflowId]/workflow.tsx
Outdated
Show resolved
Hide resolved
.../components/editor/components/sub-block/components/tool-input/components/tools/parameter.tsx
Show resolved
Hide resolved
|
@greptile |
...ts/editor/components/sub-block/components/tool-input/components/tools/sub-block-renderer.tsx
Show resolved
Hide resolved
|
https://github.com/cursor review |
|
@cursor review |
There was a problem hiding this comment.
Cursor Bugbot has reviewed your changes and found 2 potential issues.
Bugbot Autofix is OFF. To automatically fix reported issues with Cloud Agents, enable Autofix in the Cursor dashboard.
Summary
ToolSubBlockRendererthat delegates to<SubBlock>for full rendering paritylabelSuffixprop on SubBlockcanonicalParamId(e.g. Google Drive list files)ParameterWithLabel,ToolSubBlockRenderer,ToolCredentialSelectortocomponents/tools/StoredTooltotypes.ts, selection helpers toutils.tsany)Type of Change
Testing
tsc --noEmit— zero errorsChecklist