| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { useCallback } from 'react' | 
					
						
							|  |  |  | import produce from 'immer' | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  | import { v4 as uuid4 } from 'uuid' | 
					
						
							| 
									
										
										
										
											2024-08-15 17:26:11 +08:00
										 |  |  | import { useUpdateNodeInternals } from 'reactflow' | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  | import type { | 
					
						
							|  |  |  |   Var, | 
					
						
							|  |  |  | } from '../../types' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { VarType } from '../../types' | 
					
						
							|  |  |  | import { LogicalOperator } from './types' | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  | import type { | 
					
						
							|  |  |  |   CaseItem, | 
					
						
							|  |  |  |   HandleAddCondition, | 
					
						
							|  |  |  |   HandleRemoveCondition, | 
					
						
							|  |  |  |   HandleUpdateCondition, | 
					
						
							|  |  |  |   HandleUpdateConditionLogicalOperator, | 
					
						
							|  |  |  |   IfElseNodeType, | 
					
						
							|  |  |  | } from './types' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   branchNameCorrect, | 
					
						
							|  |  |  |   getOperators, | 
					
						
							|  |  |  | } from './utils' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import useNodeCrud from '@/app/components/workflow/nodes/_base/hooks/use-node-crud' | 
					
						
							|  |  |  | import { | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   useEdgesInteractions, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   useNodesReadOnly, | 
					
						
							|  |  |  | } from '@/app/components/workflow/hooks' | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  | import useAvailableVarList from '@/app/components/workflow/nodes/_base/hooks/use-available-var-list' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | const useConfig = (id: string, payload: IfElseNodeType) => { | 
					
						
							| 
									
										
										
										
											2024-08-15 17:26:11 +08:00
										 |  |  |   const updateNodeInternals = useUpdateNodeInternals() | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const { nodesReadOnly: readOnly } = useNodesReadOnly() | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const { handleEdgeDeleteByDeleteBranch } = useEdgesInteractions() | 
					
						
							|  |  |  |   const { inputs, setInputs } = useNodeCrud<IfElseNodeType>(id, payload) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const filterVar = useCallback((varPayload: Var) => { | 
					
						
							|  |  |  |     return varPayload.type !== VarType.arrayFile | 
					
						
							|  |  |  |   }, []) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   const { | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |     availableVars, | 
					
						
							|  |  |  |     availableNodesWithParent, | 
					
						
							|  |  |  |   } = useAvailableVarList(id, { | 
					
						
							|  |  |  |     onlyLeafNodeVar: false, | 
					
						
							|  |  |  |     filterVar, | 
					
						
							|  |  |  |   }) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const filterNumberVar = useCallback((varPayload: Var) => { | 
					
						
							|  |  |  |     return varPayload.type === VarType.number | 
					
						
							|  |  |  |   }, []) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { | 
					
						
							|  |  |  |     availableVars: availableNumberVars, | 
					
						
							|  |  |  |     availableNodesWithParent: availableNumberNodesWithParent, | 
					
						
							|  |  |  |   } = useAvailableVarList(id, { | 
					
						
							|  |  |  |     onlyLeafNodeVar: false, | 
					
						
							|  |  |  |     filterVar: filterNumberVar, | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleAddCase = useCallback(() => { | 
					
						
							|  |  |  |     const newInputs = produce(inputs, () => { | 
					
						
							|  |  |  |       if (inputs.cases) { | 
					
						
							|  |  |  |         const case_id = uuid4() | 
					
						
							|  |  |  |         inputs.cases.push({ | 
					
						
							|  |  |  |           case_id, | 
					
						
							|  |  |  |           logical_operator: LogicalOperator.and, | 
					
						
							|  |  |  |           conditions: [], | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         if (inputs._targetBranches) { | 
					
						
							|  |  |  |           const elseCaseIndex = inputs._targetBranches.findIndex(branch => branch.id === 'false') | 
					
						
							|  |  |  |           if (elseCaseIndex > -1) { | 
					
						
							|  |  |  |             inputs._targetBranches = branchNameCorrect([ | 
					
						
							|  |  |  |               ...inputs._targetBranches.slice(0, elseCaseIndex), | 
					
						
							|  |  |  |               { | 
					
						
							|  |  |  |                 id: case_id, | 
					
						
							|  |  |  |                 name: '', | 
					
						
							|  |  |  |               }, | 
					
						
							|  |  |  |               ...inputs._targetBranches.slice(elseCaseIndex), | 
					
						
							|  |  |  |             ]) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     setInputs(newInputs) | 
					
						
							|  |  |  |   }, [inputs, setInputs]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleRemoveCase = useCallback((caseId: string) => { | 
					
						
							|  |  |  |     const newInputs = produce(inputs, (draft) => { | 
					
						
							|  |  |  |       draft.cases = draft.cases?.filter(item => item.case_id !== caseId) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (draft._targetBranches) | 
					
						
							|  |  |  |         draft._targetBranches = branchNameCorrect(draft._targetBranches.filter(branch => branch.id !== caseId)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       handleEdgeDeleteByDeleteBranch(id, caseId) | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     setInputs(newInputs) | 
					
						
							|  |  |  |   }, [inputs, setInputs, id, handleEdgeDeleteByDeleteBranch]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const handleSortCase = useCallback((newCases: (CaseItem & { id: string })[]) => { | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     const newInputs = produce(inputs, (draft) => { | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |       draft.cases = newCases.filter(Boolean).map(item => ({ | 
					
						
							|  |  |  |         id: item.id, | 
					
						
							|  |  |  |         case_id: item.case_id, | 
					
						
							|  |  |  |         logical_operator: item.logical_operator, | 
					
						
							|  |  |  |         conditions: item.conditions, | 
					
						
							|  |  |  |       })) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       draft._targetBranches = branchNameCorrect([ | 
					
						
							|  |  |  |         ...newCases.filter(Boolean).map(item => ({ id: item.case_id, name: '' })), | 
					
						
							|  |  |  |         { id: 'false', name: '' }, | 
					
						
							|  |  |  |       ]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     }) | 
					
						
							|  |  |  |     setInputs(newInputs) | 
					
						
							| 
									
										
										
										
											2024-08-15 17:26:11 +08:00
										 |  |  |     updateNodeInternals(id) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   }, [inputs, setInputs]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const handleAddCondition = useCallback<HandleAddCondition>((caseId, valueSelector, varItem) => { | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     const newInputs = produce(inputs, (draft) => { | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |       const targetCase = draft.cases?.find(item => item.case_id === caseId) | 
					
						
							|  |  |  |       if (targetCase) { | 
					
						
							|  |  |  |         targetCase.conditions.push({ | 
					
						
							|  |  |  |           id: uuid4(), | 
					
						
							|  |  |  |           varType: varItem.type, | 
					
						
							|  |  |  |           variable_selector: valueSelector, | 
					
						
							|  |  |  |           comparison_operator: getOperators(varItem.type)[0], | 
					
						
							|  |  |  |           value: '', | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     }) | 
					
						
							|  |  |  |     setInputs(newInputs) | 
					
						
							|  |  |  |   }, [inputs, setInputs]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const handleRemoveCondition = useCallback<HandleRemoveCondition>((caseId, conditionId) => { | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     const newInputs = produce(inputs, (draft) => { | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |       const targetCase = draft.cases?.find(item => item.case_id === caseId) | 
					
						
							|  |  |  |       if (targetCase) | 
					
						
							|  |  |  |         targetCase.conditions = targetCase.conditions.filter(item => item.id !== conditionId) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     }) | 
					
						
							|  |  |  |     setInputs(newInputs) | 
					
						
							|  |  |  |   }, [inputs, setInputs]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const handleUpdateCondition = useCallback<HandleUpdateCondition>((caseId, conditionId, newCondition) => { | 
					
						
							|  |  |  |     const newInputs = produce(inputs, (draft) => { | 
					
						
							|  |  |  |       const targetCase = draft.cases?.find(item => item.case_id === caseId) | 
					
						
							|  |  |  |       if (targetCase) { | 
					
						
							|  |  |  |         const targetCondition = targetCase.conditions.find(item => item.id === conditionId) | 
					
						
							|  |  |  |         if (targetCondition) | 
					
						
							|  |  |  |           Object.assign(targetCondition, newCondition) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     setInputs(newInputs) | 
					
						
							|  |  |  |   }, [inputs, setInputs]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |   const handleUpdateConditionLogicalOperator = useCallback<HandleUpdateConditionLogicalOperator>((caseId, value) => { | 
					
						
							|  |  |  |     const newInputs = produce(inputs, (draft) => { | 
					
						
							|  |  |  |       const targetCase = draft.cases?.find(item => item.case_id === caseId) | 
					
						
							|  |  |  |       if (targetCase) | 
					
						
							|  |  |  |         targetCase.logical_operator = value | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |     }) | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |     setInputs(newInputs) | 
					
						
							|  |  |  |   }, [inputs, setInputs]) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return { | 
					
						
							|  |  |  |     readOnly, | 
					
						
							|  |  |  |     inputs, | 
					
						
							|  |  |  |     filterVar, | 
					
						
							| 
									
										
										
										
											2024-07-10 18:20:13 +08:00
										 |  |  |     filterNumberVar, | 
					
						
							|  |  |  |     handleAddCase, | 
					
						
							|  |  |  |     handleRemoveCase, | 
					
						
							|  |  |  |     handleSortCase, | 
					
						
							|  |  |  |     handleAddCondition, | 
					
						
							|  |  |  |     handleRemoveCondition, | 
					
						
							|  |  |  |     handleUpdateCondition, | 
					
						
							|  |  |  |     handleUpdateConditionLogicalOperator, | 
					
						
							|  |  |  |     nodesOutputVars: availableVars, | 
					
						
							|  |  |  |     availableNodes: availableNodesWithParent, | 
					
						
							|  |  |  |     nodesOutputNumberVars: availableNumberVars, | 
					
						
							|  |  |  |     availableNumberNodes: availableNumberNodesWithParent, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default useConfig |