mirror of
https://github.com/langgenius/dify.git
synced 2026-03-26 16:50:14 +08:00
Frontend: - Migrate deprecated imports: modal→dialog, toast→ui/toast, tooltip→tooltip-plus, portal-to-follow-elem→portal-to-follow-elem-plus, select→ui/select, confirm→alert-dialog - Replace next/* with @/next/* wrapper modules - Convert TypeScript enums to const objects (erasable-syntax-only) - Replace all `any` types with `unknown` or specific types in workflow types - Fix unused vars, react-hooks-extra, react-refresh/only-export-components - Extract InteractionMode to separate module, tool-block commands to commands.ts Backend: - Fix pyrefly errors: type narrowing, null guards, getattr patterns - Remove unused TYPE_CHECKING imports in LLM node - Add ignore_imports entries to .importlinter for dify_graph boundary violations Made-with: Cursor
65 lines
2.4 KiB
TypeScript
65 lines
2.4 KiB
TypeScript
import type { WorkflowDataUpdater } from '@/app/components/workflow/types'
|
|
import { useCallback } from 'react'
|
|
import { useWorkflowUpdate } from '@/app/components/workflow/hooks'
|
|
import { useWorkflowStore } from '@/app/components/workflow/store'
|
|
import { fetchWorkflowDraft } from '@/service/workflow'
|
|
|
|
export const useWorkflowRefreshDraft = () => {
|
|
const workflowStore = useWorkflowStore()
|
|
const { handleUpdateWorkflowCanvas } = useWorkflowUpdate()
|
|
|
|
const handleRefreshWorkflowDraft = useCallback((notUpdateCanvas?: boolean) => {
|
|
const {
|
|
appId,
|
|
setSyncWorkflowDraftHash,
|
|
setIsSyncingWorkflowDraft,
|
|
setEnvironmentVariables,
|
|
setEnvSecrets,
|
|
setConversationVariables,
|
|
setIsWorkflowDataLoaded,
|
|
isWorkflowDataLoaded,
|
|
debouncedSyncWorkflowDraft,
|
|
} = workflowStore.getState()
|
|
|
|
const { cancel } = debouncedSyncWorkflowDraft
|
|
if (typeof cancel === 'function')
|
|
cancel()
|
|
|
|
const wasLoaded = isWorkflowDataLoaded
|
|
if (wasLoaded)
|
|
setIsWorkflowDataLoaded(false)
|
|
setIsSyncingWorkflowDraft(true)
|
|
fetchWorkflowDraft(`/apps/${appId}/workflows/draft`)
|
|
.then((response) => {
|
|
// Ensure we have a valid workflow structure with viewport
|
|
if (!notUpdateCanvas) {
|
|
const workflowData: WorkflowDataUpdater = {
|
|
nodes: response.graph?.nodes || [],
|
|
edges: response.graph?.edges || [],
|
|
viewport: response.graph?.viewport || { x: 0, y: 0, zoom: 1 },
|
|
}
|
|
handleUpdateWorkflowCanvas(workflowData)
|
|
}
|
|
setSyncWorkflowDraftHash(response.hash)
|
|
setEnvSecrets((response.environment_variables || []).filter(env => env.value_type === 'secret').reduce((acc, env) => {
|
|
acc[env.id] = typeof env.value === 'string' ? env.value : JSON.stringify(env.value)
|
|
return acc
|
|
}, {} as Record<string, string>))
|
|
setEnvironmentVariables(response.environment_variables?.map(env => env.value_type === 'secret' ? { ...env, value: '[__HIDDEN__]' } : env) || [])
|
|
setConversationVariables(response.conversation_variables || [])
|
|
setIsWorkflowDataLoaded(true)
|
|
})
|
|
.catch(() => {
|
|
if (wasLoaded)
|
|
setIsWorkflowDataLoaded(true)
|
|
})
|
|
.finally(() => {
|
|
setIsSyncingWorkflowDraft(false)
|
|
})
|
|
}, [handleUpdateWorkflowCanvas, workflowStore])
|
|
|
|
return {
|
|
handleRefreshWorkflowDraft,
|
|
}
|
|
}
|