mirror of
https://github.com/langgenius/dify.git
synced 2024-11-16 19:59:50 +08:00
7753ba2d37
Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Yeuoly <admin@srmxy.cn> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: StyleZhang <jasonapring2015@outlook.com> Co-authored-by: jyong <jyong@dify.ai> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: jyong <718720800@qq.com>
119 lines
3.6 KiB
TypeScript
119 lines
3.6 KiB
TypeScript
import { useCallback } from 'react'
|
|
import produce from 'immer'
|
|
import { useStoreApi } from 'reactflow'
|
|
import { useParams } from 'next/navigation'
|
|
import {
|
|
useStore,
|
|
useWorkflowStore,
|
|
} from '../store'
|
|
import { BlockEnum } from '../types'
|
|
import { useNodesReadOnly } from './use-workflow'
|
|
import { syncWorkflowDraft } from '@/service/workflow'
|
|
import { useFeaturesStore } from '@/app/components/base/features/hooks'
|
|
import { API_PREFIX } from '@/config'
|
|
|
|
export const useNodesSyncDraft = () => {
|
|
const store = useStoreApi()
|
|
const workflowStore = useWorkflowStore()
|
|
const featuresStore = useFeaturesStore()
|
|
const { getNodesReadOnly } = useNodesReadOnly()
|
|
const debouncedSyncWorkflowDraft = useStore(s => s.debouncedSyncWorkflowDraft)
|
|
const params = useParams()
|
|
|
|
const getPostParams = useCallback((appIdParams?: string) => {
|
|
const {
|
|
getNodes,
|
|
edges,
|
|
transform,
|
|
} = store.getState()
|
|
const [x, y, zoom] = transform
|
|
const appId = workflowStore.getState().appId
|
|
|
|
if (appId || appIdParams) {
|
|
const nodes = getNodes()
|
|
const hasStartNode = nodes.find(node => node.data.type === BlockEnum.Start)
|
|
|
|
if (!hasStartNode)
|
|
return
|
|
|
|
const features = featuresStore!.getState().features
|
|
const producedNodes = produce(nodes, (draft) => {
|
|
draft.forEach((node) => {
|
|
Object.keys(node.data).forEach((key) => {
|
|
if (key.startsWith('_'))
|
|
delete node.data[key]
|
|
})
|
|
})
|
|
})
|
|
const producedEdges = produce(edges, (draft) => {
|
|
draft.forEach((edge) => {
|
|
Object.keys(edge.data).forEach((key) => {
|
|
if (key.startsWith('_'))
|
|
delete edge.data[key]
|
|
})
|
|
})
|
|
})
|
|
return {
|
|
url: `/apps/${appId || appIdParams}/workflows/draft`,
|
|
params: {
|
|
graph: {
|
|
nodes: producedNodes,
|
|
edges: producedEdges,
|
|
viewport: {
|
|
x,
|
|
y,
|
|
zoom,
|
|
},
|
|
},
|
|
features: {
|
|
opening_statement: features.opening?.opening_statement || '',
|
|
suggested_questions: features.opening?.suggested_questions || [],
|
|
suggested_questions_after_answer: features.suggested,
|
|
text_to_speech: features.text2speech,
|
|
speech_to_text: features.speech2text,
|
|
retriever_resource: features.citation,
|
|
sensitive_word_avoidance: features.moderation,
|
|
file_upload: features.file,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
}, [store, featuresStore, workflowStore])
|
|
|
|
const syncWorkflowDraftWhenPageClose = useCallback(() => {
|
|
const postParams = getPostParams()
|
|
|
|
if (postParams) {
|
|
navigator.sendBeacon(
|
|
`${API_PREFIX}/apps/${params.appId}/workflows/draft?_token=${localStorage.getItem('console_token')}`,
|
|
JSON.stringify(postParams.params),
|
|
)
|
|
}
|
|
}, [getPostParams, params.appId])
|
|
|
|
const doSyncWorkflowDraft = useCallback(async (appId?: string) => {
|
|
const postParams = getPostParams(appId)
|
|
|
|
if (postParams) {
|
|
const res = await syncWorkflowDraft(postParams)
|
|
workflowStore.getState().setDraftUpdatedAt(res.updated_at)
|
|
}
|
|
}, [workflowStore, getPostParams])
|
|
|
|
const handleSyncWorkflowDraft = useCallback((sync?: boolean, appId?: string) => {
|
|
if (getNodesReadOnly())
|
|
return
|
|
|
|
if (sync)
|
|
doSyncWorkflowDraft(appId)
|
|
else
|
|
debouncedSyncWorkflowDraft(doSyncWorkflowDraft)
|
|
}, [debouncedSyncWorkflowDraft, doSyncWorkflowDraft, getNodesReadOnly])
|
|
|
|
return {
|
|
doSyncWorkflowDraft,
|
|
handleSyncWorkflowDraft,
|
|
syncWorkflowDraftWhenPageClose,
|
|
}
|
|
}
|