Commit b8447a3
refactor: modularize WorkflowBuilder component and improve UI/UX
BREAKING CHANGES:
- Split 2100+ line WorkflowBuilder.tsx into smaller, focused components
- Restructured workflow state management and business logic
Component Architecture:
- Created WorkflowHeader.tsx: Simplified header with navigation controls
- Created WorkflowTitleSection.tsx: Dedicated section for workflow name and status badge
- Created WorkflowFooter.tsx: Action buttons (test, save, delete, activate)
- Created TriggerPanel/: Modular trigger configuration components
- TriggerPanel.tsx: Main trigger configuration container
- TriggerSelect.tsx: Trigger type selector
- AppTrigger.tsx: App-based trigger configuration
- ScheduleTrigger.tsx: Schedule configuration UI
- Created StepsPanel.tsx: Complete workflow steps management
- Created RequestTriggerModal.tsx: Modal for requesting new app triggers
State Management:
- Extracted useWorkflowState.ts: Centralized state management
- Extracted useWorkflowActions.ts: Action handlers and business logic
- Extracted useWorkflowValidation.ts: Validation rules and tooltips
Utilities:
- Created types.ts: Centralized TypeScript interfaces and types
- Created utils/cronHelpers.ts: Cron expression generation and parsing
Bug Fixes:
- Fixed Gmail triggers not showing by passing selectedAppSlug to useAppTriggersQuery
- Fixed duplicate email signatures in Gmail drafts by updating librechat.yaml instructions
- Fixed TypeScript JSX errors by converting constants to functions
UI Improvements:
- Improved header layout with dedicated workflow title section
- Better visual hierarchy and spacing
- Mobile-responsive design throughout
- Centered workflow title with cleaner styling
- Added emoji prefix requirement for workflow names
Additional Changes:
- Updated Workflow.js tool to encourage emoji prefixes in workflow names
- Enhanced Gmail MCP instructions for better signature handling
- Maintained all existing functionality while improving maintainability
The refactoring reduces complexity, improves code organization, and makes
the WorkflowBuilder more maintainable while fixing critical bugs in the
trigger selection and email handling functionality.
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <[email protected]>1 parent f284214 commit b8447a3
File tree
18 files changed
+4500
-1771
lines changed- api
- app/clients/tools/structured
- server/services/Pipedream
- client/src
- components/SidePanel/WorkflowBuilder
- Steps
- Trigger
- utils
- hooks/Workflows
18 files changed
+4500
-1771
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
44 | 44 | | |
45 | 45 | | |
46 | 46 | | |
| 47 | + | |
| 48 | + | |
47 | 49 | | |
48 | 50 | | |
49 | 51 | | |
| |||
55 | 57 | | |
56 | 58 | | |
57 | 59 | | |
58 | | - | |
| 60 | + | |
59 | 61 | | |
60 | 62 | | |
61 | 63 | | |
| |||
75 | 77 | | |
76 | 78 | | |
77 | 79 | | |
78 | | - | |
| 80 | + | |
79 | 81 | | |
80 | 82 | | |
81 | 83 | | |
| |||
138 | 140 | | |
139 | 141 | | |
140 | 142 | | |
141 | | - | |
| 143 | + | |
142 | 144 | | |
143 | 145 | | |
144 | 146 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
751 | 751 | | |
752 | 752 | | |
753 | 753 | | |
754 | | - | |
| 754 | + | |
755 | 755 | | |
756 | 756 | | |
757 | 757 | | |
| |||
Lines changed: 133 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
0 commit comments