| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import type { | 
					
						
							|  |  |  |   FC, | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   ReactNode, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | } from 'react' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   cloneElement, | 
					
						
							|  |  |  |   memo, | 
					
						
							|  |  |  |   useCallback, | 
					
						
							|  |  |  | } from 'react' | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   RiCloseLine, | 
					
						
							|  |  |  |   RiPlayLargeLine, | 
					
						
							|  |  |  | } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  | import { useShallow } from 'zustand/react/shallow' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import NextStep from './components/next-step' | 
					
						
							|  |  |  | import PanelOperator from './components/panel-operator' | 
					
						
							| 
									
										
										
										
											2024-05-30 14:24:53 +08:00
										 |  |  | import HelpLink from './components/help-link' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   DescriptionInput, | 
					
						
							|  |  |  |   TitleInput, | 
					
						
							|  |  |  | } from './components/title-description-input' | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  | import ErrorHandleOnPanel from './components/error-handle/error-handle-on-panel' | 
					
						
							| 
									
										
										
										
											2024-12-20 15:44:37 +08:00
										 |  |  | import RetryOnPanel from './components/retry/retry-on-panel' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { useResizePanel } from './hooks/use-resize-panel' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import cn from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import BlockIcon from '@/app/components/workflow/block-icon' | 
					
						
							| 
									
										
										
										
											2024-12-20 15:44:37 +08:00
										 |  |  | import Split from '@/app/components/workflow/nodes/_base/components/split' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							| 
									
										
										
										
											2024-06-26 08:37:12 +02:00
										 |  |  |   WorkflowHistoryEvent, | 
					
						
							| 
									
										
										
										
											2024-06-05 14:00:47 +08:00
										 |  |  |   useAvailableBlocks, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   useNodeDataUpdate, | 
					
						
							|  |  |  |   useNodesInteractions, | 
					
						
							|  |  |  |   useNodesReadOnly, | 
					
						
							|  |  |  |   useNodesSyncDraft, | 
					
						
							|  |  |  |   useToolIcon, | 
					
						
							| 
									
										
										
										
											2024-04-26 14:23:13 +08:00
										 |  |  |   useWorkflow, | 
					
						
							| 
									
										
										
										
											2024-06-26 08:37:12 +02:00
										 |  |  |   useWorkflowHistory, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | } from '@/app/components/workflow/hooks' | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   canRunBySingle, | 
					
						
							|  |  |  |   hasErrorHandleNode, | 
					
						
							| 
									
										
										
										
											2024-12-20 15:44:37 +08:00
										 |  |  |   hasRetryNode, | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  | } from '@/app/components/workflow/utils' | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import type { Node } from '@/app/components/workflow/types' | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  | import { useStore as useAppStore } from '@/app/components/app/store' | 
					
						
							| 
									
										
										
										
											2024-06-25 16:41:49 +08:00
										 |  |  | import { useStore } from '@/app/components/workflow/store' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | type BasePanelProps = { | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   children: ReactNode | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | } & Node | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const BasePanel: FC<BasePanelProps> = ({ | 
					
						
							|  |  |  |   id, | 
					
						
							|  |  |  |   data, | 
					
						
							|  |  |  |   children, | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   const { showMessageLogModal } = useAppStore(useShallow(state => ({ | 
					
						
							|  |  |  |     showMessageLogModal: state.showMessageLogModal, | 
					
						
							|  |  |  |   }))) | 
					
						
							| 
									
										
										
										
											2024-06-25 16:41:49 +08:00
										 |  |  |   const showSingleRunPanel = useStore(s => s.showSingleRunPanel) | 
					
						
							| 
									
										
										
										
											2025-03-05 17:41:15 +08:00
										 |  |  |   const panelWidth = localStorage.getItem('workflow-node-panel-width') ? Number.parseFloat(localStorage.getItem('workflow-node-panel-width')!) : 420 | 
					
						
							| 
									
										
										
										
											2024-04-26 14:23:13 +08:00
										 |  |  |   const { | 
					
						
							|  |  |  |     setPanelWidth, | 
					
						
							|  |  |  |   } = useWorkflow() | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const { handleNodeSelect } = useNodesInteractions() | 
					
						
							|  |  |  |   const { handleSyncWorkflowDraft } = useNodesSyncDraft() | 
					
						
							|  |  |  |   const { nodesReadOnly } = useNodesReadOnly() | 
					
						
							| 
									
										
										
										
											2025-04-24 16:29:58 +08:00
										 |  |  |   const { availableNextBlocks } = useAvailableBlocks(data.type, data.isInIteration || data.isInLoop) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const toolIcon = useToolIcon(data) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-26 14:23:13 +08:00
										 |  |  |   const handleResize = useCallback((width: number) => { | 
					
						
							|  |  |  |     setPanelWidth(width) | 
					
						
							|  |  |  |   }, [setPanelWidth]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const { | 
					
						
							|  |  |  |     triggerRef, | 
					
						
							|  |  |  |     containerRef, | 
					
						
							|  |  |  |   } = useResizePanel({ | 
					
						
							|  |  |  |     direction: 'horizontal', | 
					
						
							|  |  |  |     triggerDirection: 'left', | 
					
						
							|  |  |  |     minWidth: 420, | 
					
						
							|  |  |  |     maxWidth: 720, | 
					
						
							| 
									
										
										
										
											2024-04-26 14:23:13 +08:00
										 |  |  |     onResize: handleResize, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-26 08:37:12 +02:00
										 |  |  |   const { saveStateToHistory } = useWorkflowHistory() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const { | 
					
						
							|  |  |  |     handleNodeDataUpdate, | 
					
						
							|  |  |  |     handleNodeDataUpdateWithSyncDraft, | 
					
						
							|  |  |  |   } = useNodeDataUpdate() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleTitleBlur = useCallback((title: string) => { | 
					
						
							|  |  |  |     handleNodeDataUpdateWithSyncDraft({ id, data: { title } }) | 
					
						
							| 
									
										
										
										
											2024-06-26 08:37:12 +02:00
										 |  |  |     saveStateToHistory(WorkflowHistoryEvent.NodeTitleChange) | 
					
						
							|  |  |  |   }, [handleNodeDataUpdateWithSyncDraft, id, saveStateToHistory]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const handleDescriptionChange = useCallback((desc: string) => { | 
					
						
							|  |  |  |     handleNodeDataUpdateWithSyncDraft({ id, data: { desc } }) | 
					
						
							| 
									
										
										
										
											2024-06-26 08:37:12 +02:00
										 |  |  |     saveStateToHistory(WorkflowHistoryEvent.NodeDescriptionChange) | 
					
						
							|  |  |  |   }, [handleNodeDataUpdateWithSyncDraft, id, saveStateToHistory]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |     <div className={cn( | 
					
						
							|  |  |  |       'relative mr-2 h-full', | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       showMessageLogModal && '!absolute -top-[5px] right-[416px] z-0 !mr-0 w-[384px] overflow-hidden rounded-2xl border-[0.5px] border-components-panel-border shadow-lg transition-all', | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |     )}> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |       <div | 
					
						
							|  |  |  |         ref={triggerRef} | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |         className='absolute -left-2 top-1/2 h-6 w-3 -translate-y-1/2 cursor-col-resize resize-x'> | 
					
						
							|  |  |  |         <div className='h-6 w-1 rounded-sm bg-divider-regular'></div> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |       <div | 
					
						
							|  |  |  |         ref={containerRef} | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |         className={cn('h-full rounded-2xl border-[0.5px] border-components-panel-border bg-components-panel-bg shadow-lg', showSingleRunPanel ? 'overflow-hidden' : 'overflow-y-auto')} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         style={{ | 
					
						
							| 
									
										
										
										
											2024-04-26 14:23:13 +08:00
										 |  |  |           width: `${panelWidth}px`, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         }} | 
					
						
							|  |  |  |       > | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |         <div className='sticky top-0 z-10 border-b-[0.5px] border-divider-regular bg-components-panel-bg'> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |           <div className='flex items-center px-4 pb-1 pt-4'> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |             <BlockIcon | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               className='mr-1 shrink-0' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |               type={data.type} | 
					
						
							|  |  |  |               toolIcon={toolIcon} | 
					
						
							|  |  |  |               size='md' | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |             <TitleInput | 
					
						
							|  |  |  |               value={data.title || ''} | 
					
						
							|  |  |  |               onBlur={handleTitleBlur} | 
					
						
							|  |  |  |             /> | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |             <div className='flex shrink-0 items-center text-text-tertiary'> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |               { | 
					
						
							|  |  |  |                 canRunBySingle(data.type) && !nodesReadOnly && ( | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |                   <Tooltip | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                     popupContent={t('workflow.panel.runThisStep')} | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |                     popupClassName='mr-1' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                   > | 
					
						
							|  |  |  |                     <div | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |                       className='mr-1 flex h-6 w-6 cursor-pointer items-center justify-center rounded-md hover:bg-state-base-hover' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                       onClick={() => { | 
					
						
							|  |  |  |                         handleNodeDataUpdate({ id, data: { _isSingleRun: true } }) | 
					
						
							|  |  |  |                         handleSyncWorkflowDraft(true) | 
					
						
							|  |  |  |                       }} | 
					
						
							|  |  |  |                     > | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                       <RiPlayLargeLine className='h-4 w-4 text-text-tertiary' /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                     </div> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |                   </Tooltip> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 ) | 
					
						
							|  |  |  |               } | 
					
						
							| 
									
										
										
										
											2024-05-30 14:24:53 +08:00
										 |  |  |               <HelpLink nodeType={data.type} /> | 
					
						
							|  |  |  |               <PanelOperator id={id} data={data} showHelpLink={false} /> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               <div className='mx-3 h-3.5 w-[1px] bg-divider-regular' /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |               <div | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 className='flex h-6 w-6 cursor-pointer items-center justify-center' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 onClick={() => handleNodeSelect(id, true)} | 
					
						
							|  |  |  |               > | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 <RiCloseLine className='h-4 w-4 text-text-tertiary' /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |               </div> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |           <div className='p-2'> | 
					
						
							|  |  |  |             <DescriptionInput | 
					
						
							|  |  |  |               value={data.desc || ''} | 
					
						
							|  |  |  |               onChange={handleDescriptionChange} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  |         <div> | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |           {cloneElement(children as any, { id, data })} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-12-20 15:44:37 +08:00
										 |  |  |         <Split /> | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           hasRetryNode(data.type) && ( | 
					
						
							|  |  |  |             <RetryOnPanel | 
					
						
							|  |  |  |               id={id} | 
					
						
							|  |  |  |               data={data} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-12-11 14:21:38 +08:00
										 |  |  |         { | 
					
						
							|  |  |  |           hasErrorHandleNode(data.type) && ( | 
					
						
							|  |  |  |             <ErrorHandleOnPanel | 
					
						
							|  |  |  |               id={id} | 
					
						
							|  |  |  |               data={data} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-06-05 14:00:47 +08:00
										 |  |  |           !!availableNextBlocks.length && ( | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |             <div className='border-t-[0.5px] border-divider-regular p-4'> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               <div className='system-sm-semibold-uppercase mb-1 flex items-center text-text-secondary'> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 {t('workflow.panel.nextStep').toLocaleUpperCase()} | 
					
						
							|  |  |  |               </div> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               <div className='system-xs-regular mb-2 text-text-tertiary'> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 {t('workflow.panel.addNextStep')} | 
					
						
							|  |  |  |               </div> | 
					
						
							|  |  |  |               <NextStep selectedNode={{ id, data } as Node} /> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default memo(BasePanel) |