feat: introduce trigger functionality (#27644)
Signed-off-by: lyzno1 <yuanyouhuilyz@gmail.com> Co-authored-by: Stream <Stream_2@qq.com> Co-authored-by: lyzno1 <92089059+lyzno1@users.noreply.github.com> Co-authored-by: zhsama <torvalds@linux.do> Co-authored-by: Harry <xh001x@hotmail.com> Co-authored-by: lyzno1 <yuanyouhuilyz@gmail.com> Co-authored-by: yessenia <yessenia.contact@gmail.com> Co-authored-by: hjlarry <hjlarry@163.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: WTW0313 <twwu@dify.ai> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
This commit is contained in:
26
web/app/components/workflow/utils/workflow-entry.ts
Normal file
26
web/app/components/workflow/utils/workflow-entry.ts
Normal file
@@ -0,0 +1,26 @@
|
||||
import { BlockEnum, type Node, isTriggerNode } from '../types'
|
||||
|
||||
/**
|
||||
* Get the workflow entry node
|
||||
* Priority: trigger nodes > start node
|
||||
*/
|
||||
export function getWorkflowEntryNode(nodes: Node[]): Node | undefined {
|
||||
const triggerNode = nodes.find(node => isTriggerNode(node.data.type))
|
||||
if (triggerNode) return triggerNode
|
||||
|
||||
return nodes.find(node => node.data.type === BlockEnum.Start)
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if a node type is a workflow entry node
|
||||
*/
|
||||
export function isWorkflowEntryNode(nodeType: BlockEnum): boolean {
|
||||
return nodeType === BlockEnum.Start || isTriggerNode(nodeType)
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if workflow is in trigger mode
|
||||
*/
|
||||
export function isTriggerWorkflow(nodes: Node[]): boolean {
|
||||
return nodes.some(node => isTriggerNode(node.data.type))
|
||||
}
|
||||
Reference in New Issue
Block a user