provider.tsx 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import type { FC } from 'react'
  2. import { createContext, useCallback, useEffect, useRef } from 'react'
  3. import { createDatasetsDetailStore } from './store'
  4. import type { CommonNodeType, Node } from '../types'
  5. import { BlockEnum } from '../types'
  6. import type { KnowledgeRetrievalNodeType } from '../nodes/knowledge-retrieval/types'
  7. import { fetchDatasets } from '@/service/datasets'
  8. type DatasetsDetailStoreApi = ReturnType<typeof createDatasetsDetailStore>
  9. type DatasetsDetailContextType = DatasetsDetailStoreApi | undefined
  10. export const DatasetsDetailContext = createContext<DatasetsDetailContextType>(undefined)
  11. type DatasetsDetailProviderProps = {
  12. nodes: Node[]
  13. children: React.ReactNode
  14. }
  15. const DatasetsDetailProvider: FC<DatasetsDetailProviderProps> = ({
  16. nodes,
  17. children,
  18. }) => {
  19. const storeRef = useRef<DatasetsDetailStoreApi>()
  20. if (!storeRef.current)
  21. storeRef.current = createDatasetsDetailStore()
  22. const updateDatasetsDetail = useCallback(async (datasetIds: string[]) => {
  23. const { data: datasetsDetail } = await fetchDatasets({ url: '/datasets', params: { page: 1, ids: datasetIds } })
  24. if (datasetsDetail && datasetsDetail.length > 0)
  25. storeRef.current!.getState().updateDatasetsDetail(datasetsDetail)
  26. }, [])
  27. useEffect(() => {
  28. if (!storeRef.current) return
  29. const knowledgeRetrievalNodes = nodes.filter(node => node.data.type === BlockEnum.KnowledgeRetrieval)
  30. const allDatasetIds = knowledgeRetrievalNodes.reduce<string[]>((acc, node) => {
  31. return Array.from(new Set([...acc, ...(node.data as CommonNodeType<KnowledgeRetrievalNodeType>).dataset_ids]))
  32. }, [])
  33. if (allDatasetIds.length === 0) return
  34. updateDatasetsDetail(allDatasetIds)
  35. // eslint-disable-next-line react-hooks/exhaustive-deps
  36. }, [])
  37. return (
  38. <DatasetsDetailContext.Provider value={storeRef.current!}>
  39. {children}
  40. </DatasetsDetailContext.Provider>
  41. )
  42. }
  43. export default DatasetsDetailProvider