- import { useCallback, useEffect } from 'react'
 - import type {
 -   FormOption,
 -   ModelProvider,
 - } from '@/app/components/header/account-setting/model-provider-page/declarations'
 - import { fetchModelProviderModelList } from '@/service/common'
 - import { fetchPluginInfoFromMarketPlace } from '@/service/plugins'
 - import type {
 -   DebugInfo as DebugInfoTypes,
 -   Dependency,
 -   GitHubItemAndMarketPlaceDependency,
 -   InstallPackageResponse,
 -   InstalledLatestVersionResponse,
 -   InstalledPluginListWithTotalResponse,
 -   PackageDependency,
 -   Plugin,
 -   PluginDeclaration,
 -   PluginDetail,
 -   PluginInfoFromMarketPlace,
 -   PluginTask,
 -   PluginType,
 -   PluginsFromMarketplaceByInfoResponse,
 -   PluginsFromMarketplaceResponse,
 -   ReferenceSetting,
 -   VersionInfo,
 -   VersionListResponse,
 -   uploadGitHubResponse,
 - } from '@/app/components/plugins/types'
 - import { TaskStatus } from '@/app/components/plugins/types'
 - import { PluginType as PluginTypeEnum } from '@/app/components/plugins/types'
 - import type {
 -   PluginsSearchParams,
 - } from '@/app/components/plugins/marketplace/types'
 - import { get, getMarketplace, post, postMarketplace } from './base'
 - import type { MutateOptions, QueryOptions } from '@tanstack/react-query'
 - import {
 -   useInfiniteQuery,
 -   useMutation,
 -   useQuery,
 -   useQueryClient,
 - } from '@tanstack/react-query'
 - import { useInvalidateAllBuiltInTools } from './use-tools'
 - import useReferenceSetting from '@/app/components/plugins/plugin-page/use-reference-setting'
 - import { uninstallPlugin } from '@/service/plugins'
 - import useRefreshPluginList from '@/app/components/plugins/install-plugin/hooks/use-refresh-plugin-list'
 - import { cloneDeep } from 'lodash-es'
 - 
 - const NAME_SPACE = 'plugins'
 - 
 - const useInstalledPluginListKey = [NAME_SPACE, 'installedPluginList']
 - export const useCheckInstalled = ({
 -   pluginIds,
 -   enabled,
 - }: {
 -   pluginIds: string[],
 -   enabled: boolean
 - }) => {
 -   return useQuery<{ plugins: PluginDetail[] }>({
 -     queryKey: [NAME_SPACE, 'checkInstalled', pluginIds],
 -     queryFn: () => post<{ plugins: PluginDetail[] }>('/workspaces/current/plugin/list/installations/ids', {
 -       body: {
 -         plugin_ids: pluginIds,
 -       },
 -     }),
 -     enabled,
 -     staleTime: 0, // always fresh
 -   })
 - }
 - 
 - export const useInstalledPluginList = (disable?: boolean, pageSize = 100) => {
 -   const fetchPlugins = async ({ pageParam = 1 }) => {
 -     const response = await get<InstalledPluginListWithTotalResponse>(
 -       `/workspaces/current/plugin/list?page=${pageParam}&page_size=${pageSize}`,
 -     )
 -     return response
 -   }
 - 
 -   const {
 -     data,
 -     error,
 -     fetchNextPage,
 -     hasNextPage,
 -     isFetchingNextPage,
 -     isLoading,
 -     isSuccess,
 -   } = useInfiniteQuery({
 -     enabled: !disable,
 -     queryKey: useInstalledPluginListKey,
 -     queryFn: fetchPlugins,
 -     getNextPageParam: (lastPage, pages) => {
 -       const totalItems = lastPage.total
 -       const currentPage = pages.length
 -       const itemsLoaded = currentPage * pageSize
 - 
 -       if (itemsLoaded >= totalItems)
 -         return
 - 
 -       return currentPage + 1
 -     },
 -     initialPageParam: 1,
 -   })
 - 
 -   const plugins = data?.pages.flatMap(page => page.plugins) ?? []
 -   const total = data?.pages[0].total ?? 0
 - 
 -   return {
 -     data: disable ? undefined : {
 -       plugins,
 -       total,
 -     },
 -     isLastPage: !hasNextPage,
 -     loadNextPage: () => {
 -       fetchNextPage()
 -     },
 -     isLoading,
 -     isFetching: isFetchingNextPage,
 -     error,
 -     isSuccess,
 -   }
 - }
 - 
 - export const useInstalledLatestVersion = (pluginIds: string[]) => {
 -   return useQuery<InstalledLatestVersionResponse>({
 -     queryKey: [NAME_SPACE, 'installedLatestVersion', pluginIds],
 -     queryFn: () => post<InstalledLatestVersionResponse>('/workspaces/current/plugin/list/latest-versions', {
 -       body: {
 -         plugin_ids: pluginIds,
 -       },
 -     }),
 -     enabled: !!pluginIds.length,
 -     initialData: pluginIds.length ? undefined : { versions: {} },
 -   })
 - }
 - 
 - export const useInvalidateInstalledPluginList = () => {
 -   const queryClient = useQueryClient()
 -   const invalidateAllBuiltInTools = useInvalidateAllBuiltInTools()
 -   return () => {
 -     queryClient.invalidateQueries(
 -       {
 -         queryKey: useInstalledPluginListKey,
 -       })
 -     invalidateAllBuiltInTools()
 -   }
 - }
 - 
 - export const useInstallPackageFromMarketPlace = (options?: MutateOptions<InstallPackageResponse, Error, string>) => {
 -   return useMutation({
 -     ...options,
 -     mutationFn: (uniqueIdentifier: string) => {
 -       return post<InstallPackageResponse>('/workspaces/current/plugin/install/marketplace', { body: { plugin_unique_identifiers: [uniqueIdentifier] } })
 -     },
 -   })
 - }
 - 
 - export const useUpdatePackageFromMarketPlace = (options?: MutateOptions<InstallPackageResponse, Error, object>) => {
 -   return useMutation({
 -     ...options,
 -     mutationFn: (body: object) => {
 -       return post<InstallPackageResponse>('/workspaces/current/plugin/upgrade/marketplace', {
 -         body,
 -       })
 -     },
 -   })
 - }
 - 
 - export const usePluginDeclarationFromMarketPlace = (pluginUniqueIdentifier: string) => {
 -   return useQuery({
 -     queryKey: [NAME_SPACE, 'pluginDeclaration', pluginUniqueIdentifier],
 -     queryFn: () => get<{ manifest: PluginDeclaration }>('/workspaces/current/plugin/marketplace/pkg', { params: { plugin_unique_identifier: pluginUniqueIdentifier } }),
 -     enabled: !!pluginUniqueIdentifier,
 -   })
 - }
 - 
 - export const useVersionListOfPlugin = (pluginID: string) => {
 -   return useQuery<{ data: VersionListResponse }>({
 -     enabled: !!pluginID,
 -     queryKey: [NAME_SPACE, 'versions', pluginID],
 -     queryFn: () => getMarketplace<{ data: VersionListResponse }>(`/plugins/${pluginID}/versions`, { params: { page: 1, page_size: 100 } }),
 -   })
 - }
 - export const useInvalidateVersionListOfPlugin = () => {
 -   const queryClient = useQueryClient()
 -   return (pluginID: string) => {
 -     queryClient.invalidateQueries({ queryKey: [NAME_SPACE, 'versions', pluginID] })
 -   }
 - }
 - 
 - export const useInstallPackageFromLocal = () => {
 -   return useMutation({
 -     mutationFn: (uniqueIdentifier: string) => {
 -       return post<InstallPackageResponse>('/workspaces/current/plugin/install/pkg', {
 -         body: { plugin_unique_identifiers: [uniqueIdentifier] },
 -       })
 -     },
 -   })
 - }
 - 
 - export const useInstallPackageFromGitHub = () => {
 -   return useMutation({
 -     mutationFn: ({ repoUrl, selectedVersion, selectedPackage, uniqueIdentifier }: {
 -       repoUrl: string
 -       selectedVersion: string
 -       selectedPackage: string
 -       uniqueIdentifier: string
 -     }) => {
 -       return post<InstallPackageResponse>('/workspaces/current/plugin/install/github', {
 -         body: {
 -           repo: repoUrl,
 -           version: selectedVersion,
 -           package: selectedPackage,
 -           plugin_unique_identifier: uniqueIdentifier,
 -         },
 -       })
 -     },
 -   })
 - }
 - 
 - export const useUploadGitHub = (payload: {
 -   repo: string
 -   version: string
 -   package: string
 - }) => {
 -   return useQuery({
 -     queryKey: [NAME_SPACE, 'uploadGitHub', payload],
 -     queryFn: () => post<uploadGitHubResponse>('/workspaces/current/plugin/upload/github', {
 -       body: payload,
 -     }),
 -     retry: 0,
 -   })
 - }
 - 
 - export const useInstallOrUpdate = ({
 -   onSuccess,
 - }: {
 -   onSuccess?: (res: { success: boolean }[]) => void
 - }) => {
 -   const { mutateAsync: updatePackageFromMarketPlace } = useUpdatePackageFromMarketPlace()
 - 
 -   return useMutation({
 -     mutationFn: (data: {
 -       payload: Dependency[],
 -       plugin: Plugin[],
 -       installedInfo: Record<string, VersionInfo>
 -     }) => {
 -       const { payload, plugin, installedInfo } = data
 - 
 -       return Promise.all(payload.map(async (item, i) => {
 -         try {
 -           const orgAndName = `${plugin[i]?.org || plugin[i]?.author}/${plugin[i]?.name}`
 -           const installedPayload = installedInfo[orgAndName]
 -           const isInstalled = !!installedPayload
 -           let uniqueIdentifier = ''
 - 
 -           if (item.type === 'github') {
 -             const data = item as GitHubItemAndMarketPlaceDependency
 -             // From local bundle don't have data.value.github_plugin_unique_identifier
 -             uniqueIdentifier = data.value.github_plugin_unique_identifier!
 -             if (!uniqueIdentifier) {
 -               const { unique_identifier } = await post<uploadGitHubResponse>('/workspaces/current/plugin/upload/github', {
 -                 body: {
 -                   repo: data.value.repo!,
 -                   version: data.value.release! || data.value.version!,
 -                   package: data.value.packages! || data.value.package!,
 -                 },
 -               })
 -               uniqueIdentifier = data.value.github_plugin_unique_identifier! || unique_identifier
 -               // has the same version, but not installed
 -               if (uniqueIdentifier === installedPayload?.uniqueIdentifier) {
 -                 return {
 -                   success: true,
 -                 }
 -               }
 -             }
 -             if (!isInstalled) {
 -               await post<InstallPackageResponse>('/workspaces/current/plugin/install/github', {
 -                 body: {
 -                   repo: data.value.repo!,
 -                   version: data.value.release! || data.value.version!,
 -                   package: data.value.packages! || data.value.package!,
 -                   plugin_unique_identifier: uniqueIdentifier,
 -                 },
 -               })
 -             }
 -           }
 -           if (item.type === 'marketplace') {
 -             const data = item as GitHubItemAndMarketPlaceDependency
 -             uniqueIdentifier = data.value.marketplace_plugin_unique_identifier! || plugin[i]?.plugin_id
 -             if (uniqueIdentifier === installedPayload?.uniqueIdentifier) {
 -               return {
 -                 success: true,
 -               }
 -             }
 -             if (!isInstalled) {
 -               await post<InstallPackageResponse>('/workspaces/current/plugin/install/marketplace', {
 -                 body: {
 -                   plugin_unique_identifiers: [uniqueIdentifier],
 -                 },
 -               })
 -             }
 -           }
 -           if (item.type === 'package') {
 -             const data = item as PackageDependency
 -             uniqueIdentifier = data.value.unique_identifier
 -             if (uniqueIdentifier === installedPayload?.uniqueIdentifier) {
 -               return {
 -                 success: true,
 -               }
 -             }
 -             if (!isInstalled) {
 -               await post<InstallPackageResponse>('/workspaces/current/plugin/install/pkg', {
 -                 body: {
 -                   plugin_unique_identifiers: [uniqueIdentifier],
 -                 },
 -               })
 -             }
 -           }
 -           if (isInstalled) {
 -             if (item.type === 'package') {
 -               await uninstallPlugin(installedPayload.installedId)
 -               await post<InstallPackageResponse>('/workspaces/current/plugin/install/pkg', {
 -                 body: {
 -                   plugin_unique_identifiers: [uniqueIdentifier],
 -                 },
 -               })
 -             }
 -             else {
 -               await updatePackageFromMarketPlace({
 -                 original_plugin_unique_identifier: installedPayload?.uniqueIdentifier,
 -                 new_plugin_unique_identifier: uniqueIdentifier,
 -               })
 -             }
 -           }
 -           return ({ success: true })
 -         }
 -         // eslint-disable-next-line unused-imports/no-unused-vars
 -         catch (e) {
 -           return Promise.resolve({ success: false })
 -         }
 -       }))
 -     },
 -     onSuccess,
 -   })
 - }
 - 
 - export const useDebugKey = () => {
 -   return useQuery({
 -     queryKey: [NAME_SPACE, 'debugKey'],
 -     queryFn: () => get<DebugInfoTypes>('/workspaces/current/plugin/debugging-key'),
 -   })
 - }
 - 
 - const useReferenceSettingKey = [NAME_SPACE, 'referenceSettings']
 - export const useReferenceSettings = () => {
 -   return useQuery({
 -     queryKey: useReferenceSettingKey,
 -     queryFn: () => get<ReferenceSetting>('/workspaces/current/plugin/preferences/fetch'),
 -   })
 - }
 - 
 - export const useInvalidateReferenceSettings = () => {
 -   const queryClient = useQueryClient()
 -   return () => {
 -     queryClient.invalidateQueries(
 -       {
 -         queryKey: useReferenceSettingKey,
 -       })
 -   }
 - }
 - 
 - export const useMutationReferenceSettings = ({
 -   onSuccess,
 - }: {
 -   onSuccess?: () => void
 - }) => {
 -   return useMutation({
 -     mutationFn: (payload: ReferenceSetting) => {
 -       return post('/workspaces/current/plugin/preferences/change', { body: payload })
 -     },
 -     onSuccess,
 -   })
 - }
 - 
 - export const useRemoveAutoUpgrade = () => {
 -   return useMutation({
 -     mutationFn: (payload: { plugin_id: string }) => {
 -       return post('/workspaces/current/plugin/preferences/autoupgrade/exclude', { body: payload })
 -     },
 -   })
 - }
 - 
 - export const useMutationPluginsFromMarketplace = () => {
 -   return useMutation({
 -     mutationFn: (pluginsSearchParams: PluginsSearchParams) => {
 -       const {
 -         query,
 -         sortBy,
 -         sortOrder,
 -         category,
 -         tags,
 -         exclude,
 -         type,
 -         page = 1,
 -         pageSize = 40,
 -       } = pluginsSearchParams
 -       const pluginOrBundle = type === 'bundle' ? 'bundles' : 'plugins'
 -       return postMarketplace<{ data: PluginsFromMarketplaceResponse }>(`/${pluginOrBundle}/search/advanced`, {
 -         body: {
 -           page,
 -           page_size: pageSize,
 -           query,
 -           sort_by: sortBy,
 -           sort_order: sortOrder,
 -           category: category !== 'all' ? category : '',
 -           tags,
 -           exclude,
 -           type,
 -         },
 -       })
 -     },
 -   })
 - }
 - 
 - export const useFetchPluginsInMarketPlaceByIds = (unique_identifiers: string[], options?: QueryOptions<{ data: PluginsFromMarketplaceResponse }>) => {
 -   return useQuery({
 -     ...options,
 -     queryKey: [NAME_SPACE, 'fetchPluginsInMarketPlaceByIds', unique_identifiers],
 -     queryFn: () => postMarketplace<{ data: PluginsFromMarketplaceResponse }>('/plugins/identifier/batch', {
 -       body: {
 -         unique_identifiers,
 -       },
 -     }),
 -     enabled: unique_identifiers?.filter(i => !!i).length > 0,
 -     retry: 0,
 -   })
 - }
 - 
 - export const useFetchPluginListOrBundleList = (pluginsSearchParams: PluginsSearchParams) => {
 -   return useQuery({
 -     queryKey: [NAME_SPACE, 'fetchPluginListOrBundleList', pluginsSearchParams],
 -     queryFn: () => {
 -       const {
 -         query,
 -         sortBy,
 -         sortOrder,
 -         category,
 -         tags,
 -         exclude,
 -         type,
 -         page = 1,
 -         pageSize = 40,
 -       } = pluginsSearchParams
 -       const pluginOrBundle = type === 'bundle' ? 'bundles' : 'plugins'
 -       return postMarketplace<{ data: PluginsFromMarketplaceResponse }>(`/${pluginOrBundle}/search/advanced`, {
 -         body: {
 -           page,
 -           page_size: pageSize,
 -           query,
 -           sort_by: sortBy,
 -           sort_order: sortOrder,
 -           category: category !== 'all' ? category : '',
 -           tags,
 -           exclude,
 -           type,
 -         },
 -       })
 -     },
 -   })
 - }
 - 
 - export const useFetchPluginsInMarketPlaceByInfo = (infos: Record<string, any>[]) => {
 -   return useQuery({
 -     queryKey: [NAME_SPACE, 'fetchPluginsInMarketPlaceByInfo', infos],
 -     queryFn: () => postMarketplace<{ data: PluginsFromMarketplaceByInfoResponse }>('/plugins/versions/batch', {
 -       body: {
 -         plugin_tuples: infos.map(info => ({
 -           org: info.organization,
 -           name: info.plugin,
 -           version: info.version,
 -         })),
 -       },
 -     }),
 -     enabled: infos?.filter(i => !!i).length > 0,
 -     retry: 0,
 -   })
 - }
 - 
 - const usePluginTaskListKey = [NAME_SPACE, 'pluginTaskList']
 - export const usePluginTaskList = (category?: PluginType) => {
 -   const {
 -     canManagement,
 -   } = useReferenceSetting()
 -   const { refreshPluginList } = useRefreshPluginList()
 -   const {
 -     data,
 -     isFetched,
 -     isRefetching,
 -     refetch,
 -     ...rest
 -   } = useQuery({
 -     enabled: canManagement,
 -     queryKey: usePluginTaskListKey,
 -     queryFn: () => get<{ tasks: PluginTask[] }>('/workspaces/current/plugin/tasks?page=1&page_size=100'),
 -     refetchInterval: (lastQuery) => {
 -       const lastData = lastQuery.state.data
 -       const taskDone = lastData?.tasks.every(task => task.status === TaskStatus.success || task.status === TaskStatus.failed)
 -       return taskDone ? false : 5000
 -     },
 -   })
 - 
 -   useEffect(() => {
 -     // After first fetch, refresh plugin list each time all tasks are done
 -     if (!isRefetching) {
 -       const lastData = cloneDeep(data)
 -       const taskDone = lastData?.tasks.every(task => task.status === TaskStatus.success || task.status === TaskStatus.failed)
 -       const taskAllFailed = lastData?.tasks.every(task => task.status === TaskStatus.failed)
 -       if (taskDone) {
 -         if (lastData?.tasks.length && !taskAllFailed)
 -           refreshPluginList(category ? { category } as any : undefined, !category)
 -       }
 -     }
 -     // eslint-disable-next-line react-hooks/exhaustive-deps
 -   }, [isRefetching])
 - 
 -   const handleRefetch = useCallback(() => {
 -     refetch()
 -   }, [refetch])
 - 
 -   return {
 -     data,
 -     pluginTasks: data?.tasks || [],
 -     isFetched,
 -     handleRefetch,
 -     ...rest,
 -   }
 - }
 - 
 - export const useMutationClearTaskPlugin = () => {
 -   return useMutation({
 -     mutationFn: ({ taskId, pluginId }: { taskId: string; pluginId: string }) => {
 -       return post<{ success: boolean }>(`/workspaces/current/plugin/tasks/${taskId}/delete/${pluginId}`)
 -     },
 -   })
 - }
 - 
 - export const useMutationClearAllTaskPlugin = () => {
 -   return useMutation({
 -     mutationFn: () => {
 -       return post<{ success: boolean }>('/workspaces/current/plugin/tasks/delete_all')
 -     },
 -   })
 - }
 - 
 - export const usePluginManifestInfo = (pluginUID: string) => {
 -   return useQuery({
 -     enabled: !!pluginUID,
 -     queryKey: [[NAME_SPACE, 'manifest', pluginUID]],
 -     queryFn: () => getMarketplace<{ data: { plugin: PluginInfoFromMarketPlace, version: { version: string } } }>(`/plugins/${pluginUID}`),
 -     retry: 0,
 -   })
 - }
 - 
 - export const useDownloadPlugin = (info: { organization: string; pluginName: string; version: string }, needDownload: boolean) => {
 -   return useQuery({
 -     queryKey: [NAME_SPACE, 'downloadPlugin', info],
 -     queryFn: () => getMarketplace<Blob>(`/plugins/${info.organization}/${info.pluginName}/${info.version}/download`),
 -     enabled: needDownload,
 -     retry: 0,
 -   })
 - }
 - 
 - export const useMutationCheckDependencies = () => {
 -   return useMutation({
 -     mutationFn: (appId: string) => {
 -       return get<{ leaked_dependencies: Dependency[] }>(`/apps/imports/${appId}/check-dependencies`)
 -     },
 -   })
 - }
 - 
 - export const useModelInList = (currentProvider?: ModelProvider, modelId?: string) => {
 -   return useQuery({
 -     queryKey: ['modelInList', currentProvider?.provider, modelId],
 -     queryFn: async () => {
 -       if (!modelId || !currentProvider) return false
 -       try {
 -         const modelsData = await fetchModelProviderModelList(`/workspaces/current/model-providers/${currentProvider?.provider}/models`)
 -         return !!modelId && !!modelsData.data.find(item => item.model === modelId)
 -       }
 -       catch {
 -         return false
 -       }
 -     },
 -     enabled: !!modelId && !!currentProvider,
 -   })
 - }
 - 
 - export const usePluginInfo = (providerName?: string) => {
 -   return useQuery({
 -     queryKey: ['pluginInfo', providerName],
 -     queryFn: async () => {
 -       if (!providerName) return null
 -       const parts = providerName.split('/')
 -       const org = parts[0]
 -       const name = parts[1]
 -       try {
 -         const response = await fetchPluginInfoFromMarketPlace({ org, name })
 -         return response.data.plugin.category === PluginTypeEnum.model ? response.data.plugin : null
 -       }
 -       catch {
 -         return null
 -       }
 -     },
 -     enabled: !!providerName,
 -   })
 - }
 - 
 - export const useFetchDynamicOptions = (plugin_id: string, provider: string, action: string, parameter: string, provider_type: 'tool') => {
 -   return useMutation({
 -     mutationFn: () => get<{ options: FormOption[] }>('/workspaces/current/plugin/parameters/dynamic-options', {
 -       params: {
 -         plugin_id,
 -         provider,
 -         action,
 -         parameter,
 -         provider_type,
 -       },
 -     }),
 -   })
 - }
 
 
  |