Files
dify/web/app/components/rag-pipeline/index.tsx
Novice 499d237b7e fix: pass all CI quality checks - ESLint, TypeScript, basedpyright, pyrefly, lint-imports
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
2026-03-24 10:54:58 +08:00

90 lines
2.4 KiB
TypeScript

import type { Features as FeaturesData } from '@/app/components/base/features/types'
import type { InjectWorkflowStoreSliceFn } from '@/app/components/workflow/store'
import { useMemo } from 'react'
import { FeaturesProvider } from '@/app/components/base/features'
import Loading from '@/app/components/base/loading'
import WorkflowWithDefaultContext from '@/app/components/workflow'
import {
WorkflowContextProvider,
} from '@/app/components/workflow/context'
import {
initialEdges,
initialNodes,
} from '@/app/components/workflow/utils'
import { useDatasetDetailContextWithSelector } from '@/context/dataset-detail'
import Conversion from './components/conversion'
import RagPipelineMain from './components/rag-pipeline-main'
import { usePipelineInit } from './hooks'
import { createRagPipelineSliceSlice } from './store'
import { processNodesWithoutDataSource } from './utils'
const RagPipeline = () => {
const {
data,
isLoading,
} = usePipelineInit()
const nodesData = useMemo(() => {
if (data)
return initialNodes(data.graph.nodes, data.graph.edges)
return []
}, [data])
const edgesData = useMemo(() => {
if (data)
return initialEdges(data.graph.edges, data.graph.nodes)
return []
}, [data])
const initialFeatures = useMemo(() => {
const features = data?.features || {}
return {
sandbox: features.sandbox || { enabled: false },
} as FeaturesData
}, [data?.features])
if (!data || isLoading) {
return (
<div className="relative flex h-full w-full items-center justify-center">
<Loading />
</div>
)
}
const {
nodes: processedNodes,
viewport,
} = processNodesWithoutDataSource(nodesData, data.graph.viewport)
return (
<WorkflowWithDefaultContext
edges={edgesData}
nodes={processedNodes}
>
<FeaturesProvider features={initialFeatures}>
<RagPipelineMain
edges={edgesData}
nodes={processedNodes}
viewport={viewport}
/>
</FeaturesProvider>
</WorkflowWithDefaultContext>
)
}
const RagPipelineWrapper = () => {
const pipelineId = useDatasetDetailContextWithSelector(s => s.dataset?.pipeline_id)
if (!pipelineId)
return <Conversion />
return (
<WorkflowContextProvider
injectWorkflowStoreSliceFn={createRagPipelineSliceSlice as InjectWorkflowStoreSliceFn}
>
<RagPipeline />
</WorkflowContextProvider>
)
}
export default RagPipelineWrapper