dify/web/app/components/plugins/plugin-page/plugin-tasks/hooks.ts

48 lines
1.2 KiB
TypeScript
Raw Normal View History

2024-11-12 17:58:14 +08:00
import { useCallback } from 'react'
2024-11-11 18:17:44 +08:00
import { TaskStatus } from '@/app/components/plugins/types'
import type { PluginStatus } from '@/app/components/plugins/types'
2024-11-12 17:58:14 +08:00
import {
useMutationClearTaskPlugin,
usePluginTaskList,
} from '@/service/use-plugins'
2024-11-11 18:17:44 +08:00
export const usePluginTaskStatus = () => {
2024-11-12 17:58:14 +08:00
const {
pluginTasks,
} = usePluginTaskList()
const { mutate } = useMutationClearTaskPlugin()
const allPlugins = pluginTasks.map(task => task.plugins.map((plugin) => {
return {
...plugin,
taskId: task.id,
}
})).flat()
2024-11-11 18:17:44 +08:00
const errorPlugins: PluginStatus[] = []
const successPlugins: PluginStatus[] = []
const runningPlugins: PluginStatus[] = []
allPlugins.forEach((plugin) => {
if (plugin.status === TaskStatus.running)
runningPlugins.push(plugin)
if (plugin.status === TaskStatus.failed)
errorPlugins.push(plugin)
if (plugin.status === TaskStatus.success)
successPlugins.push(plugin)
})
2024-11-12 17:58:14 +08:00
const handleClearErrorPlugin = useCallback((taskId: string, pluginId: string) => {
mutate({
taskId,
pluginId,
})
}, [mutate])
2024-11-11 18:17:44 +08:00
return {
errorPlugins,
successPlugins,
runningPlugins,
totalPluginsLength: allPlugins.length,
2024-11-12 17:58:14 +08:00
handleClearErrorPlugin,
2024-11-11 18:17:44 +08:00
}
}