Skip to content

Commit

Permalink
fix: error while importing local model is not shown (#3294)
Browse files Browse the repository at this point in the history
* fix: error while importing local model is not shown

Signed-off-by: James <namnh0122@gmail.com>

* fix: failed download should not be added to download state (#3297)

Signed-off-by: James <namnh0122@gmail.com>

---------

Signed-off-by: James <namnh0122@gmail.com>
  • Loading branch information
namchuai authored Aug 7, 2024
1 parent 3135ccc commit 26be941
Show file tree
Hide file tree
Showing 12 changed files with 120 additions and 146 deletions.
1 change: 0 additions & 1 deletion core/src/types/model/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
export * from './modelEntity'
export * from './modelInterface'
export * from './modelImport'
export * from './chatCompletion'
52 changes: 0 additions & 52 deletions core/src/types/model/modelInterface.ts

This file was deleted.

4 changes: 3 additions & 1 deletion web/hooks/useCortex.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import { UpdateConfigMutationVariables } from './useEngineMutation'
import { MessageCreateMutationVariables } from './useMessageCreateMutation'
import { MessageDeleteMutationVariables } from './useMessageDeleteMutation'
import { MessageUpdateMutationVariables } from './useMessageUpdateMutation'
import { DownloadModelMutationVariables } from './useModelDownloadMutation'

import { hostAtom } from '@/helpers/atoms/AppConfig.atom'

Expand Down Expand Up @@ -246,7 +247,8 @@ const useCortex = () => {
)

const downloadModel = useCallback(
async (modelId: string, fileName?: string, persistedModelId?: string) => {
async (variables: DownloadModelMutationVariables) => {
const { modelId, fileName, persistedModelId } = variables
const response = await fetch(`${host}/models/${modelId}/pull`, {
method: 'POST',
headers: {
Expand Down
21 changes: 8 additions & 13 deletions web/hooks/useHfModelFetchAndDownload.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,12 @@ import { useCallback } from 'react'
import { HuggingFaceRepoData } from '@janhq/core'
import { useQueryClient } from '@tanstack/react-query'

import { useSetAtom } from 'jotai'

import { toaster } from '@/containers/Toast'

import { fetchHuggingFaceRepoData } from '@/utils/huggingface'

import useCortex from './useCortex'
import { addDownloadModelStateAtom } from './useDownloadState'
import { fetchHuggingFaceRepoDataQueryKey } from './useHfRepoDataQuery'
import useModelDownloadMutation from './useModelDownloadMutation'

/**
* Fetches the data for a Hugging Face model and downloads it.
Expand All @@ -21,8 +18,7 @@ import { fetchHuggingFaceRepoDataQueryKey } from './useHfRepoDataQuery'
* @param modelHandle The model handle to fetch and download. E.g: "NousResearch/Hermes-2-Theta-Llama-3-8B-GGUF"
*/
const useHfModelFetchAndDownload = () => {
const addDownloadState = useSetAtom(addDownloadModelStateAtom)
const { downloadModel } = useCortex()
const downloadModelMutation = useModelDownloadMutation()
const queryClient = useQueryClient()

const fetchData = useCallback(
Expand Down Expand Up @@ -90,15 +86,14 @@ const useHfModelFetchAndDownload = () => {
.concat('_')
.concat(recommendedModel.rfilename)

addDownloadState(persistModelId)
await downloadModel(
modelHandle,
recommendedModel.rfilename,
persistModelId
)
downloadModelMutation.mutate({
modelId: modelHandle,
fileName: recommendedModel.rfilename,
persistedModelId: persistModelId,
})
},

[addDownloadState, downloadModel, fetchData]
[fetchData, downloadModelMutation]
)

return { fetchDataAndDownload }
Expand Down
49 changes: 49 additions & 0 deletions web/hooks/useModelDownloadMutation.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import { useMutation } from '@tanstack/react-query'

import { useSetAtom } from 'jotai'

import { toaster } from '@/containers/Toast'

import useCortex from './useCortex'
import { addDownloadModelStateAtom } from './useDownloadState'

export type DownloadModelMutationVariables = {
modelId: string
fileName?: string
persistedModelId?: string
}

const useModelDownloadMutation = () => {
const { downloadModel } = useCortex()
const addDownloadState = useSetAtom(addDownloadModelStateAtom)

return useMutation({
mutationFn: downloadModel,

onMutate: (variables) => {
console.debug('Downloading model', variables)
},

onSuccess: (data, variables) => {
console.debug('Download response success', data, variables)

const { persistedModelId, modelId } = variables
if (persistedModelId) {
addDownloadState(persistedModelId)
} else {
addDownloadState(modelId)
}
},

onError: (err, variables) => {
console.error('Failed to download model', err, variables)
toaster({
title: 'Failed to download model',
description: err.message,
type: 'error',
})
},
})
}

export default useModelDownloadMutation
1 change: 1 addition & 0 deletions web/hooks/useSendMessage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -503,6 +503,7 @@ const useSendMessage = () => {
chatCompletionStreaming,
setIsGeneratingResponse,
setShowWarningMultipleModelModal,
setChunkCount,
])

const sendMessage = useCallback(
Expand Down
17 changes: 6 additions & 11 deletions web/screens/HubScreen2/components/BuiltInModelCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,8 @@ import { toaster } from '@/containers/Toast'

import useAbortDownload from '@/hooks/useAbortDownload'
import useAssistantQuery from '@/hooks/useAssistantQuery'
import useCortex from '@/hooks/useCortex'
import {
addDownloadModelStateAtom,
downloadStateListAtom,
} from '@/hooks/useDownloadState'
import { downloadStateListAtom } from '@/hooks/useDownloadState'
import useModelDownloadMutation from '@/hooks/useModelDownloadMutation'
import useThreads from '@/hooks/useThreads'

import { formatDownloadPercentage } from '@/utils/converter'
Expand Down Expand Up @@ -73,9 +70,8 @@ type DownloadContainerProps = {
const DownloadContainer: React.FC<DownloadContainerProps> = ({
modelHandle,
}) => {
const { downloadModel } = useCortex()
const downloadModelMutation = useModelDownloadMutation()
const { abortDownload } = useAbortDownload()
const addDownloadState = useSetAtom(addDownloadModelStateAtom)
const setMainViewState = useSetAtom(mainViewStateAtom)
const { createThread } = useThreads()
const setDownloadLocalModelModalStage = useSetAtom(localModelModalStageAtom)
Expand All @@ -93,10 +89,9 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
[downloadedModels, modelId]
)

const onDownloadClick = useCallback(async () => {
addDownloadState(modelId)
await downloadModel(modelId)
}, [downloadModel, addDownloadState, modelId])
const onDownloadClick = useCallback(() => {
downloadModelMutation.mutate({ modelId })
}, [downloadModelMutation, modelId])

const onUseModelClick = useCallback(async () => {
if (!assistants || assistants.length === 0) {
Expand Down
20 changes: 9 additions & 11 deletions web/screens/HubScreen2/components/HfListModel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,10 @@ import { toaster } from '@/containers/Toast'
import useAbortDownload from '@/hooks/useAbortDownload'
import useAssistantQuery from '@/hooks/useAssistantQuery'

import useCortex from '@/hooks/useCortex'

import {
addDownloadModelStateAtom,
downloadStateListAtom,
} from '@/hooks/useDownloadState'
import { downloadStateListAtom } from '@/hooks/useDownloadState'

import useHfRepoDataQuery from '@/hooks/useHfRepoDataQuery'
import useModelDownloadMutation from '@/hooks/useModelDownloadMutation'
import useThreads from '@/hooks/useThreads'

import { formatDownloadPercentage, toGibibytes } from '@/utils/converter'
Expand Down Expand Up @@ -97,9 +93,8 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
modelHandle,
fileName,
}) => {
const { downloadModel } = useCortex()
const downloadModelMutation = useModelDownloadMutation()
const { abortDownload } = useAbortDownload()
const addDownloadState = useSetAtom(addDownloadModelStateAtom)
const setMainViewState = useSetAtom(mainViewStateAtom)
const { createThread } = useThreads()
const { data: assistants } = useAssistantQuery()
Expand All @@ -122,9 +117,12 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
)

const onDownloadClick = useCallback(async () => {
addDownloadState(persistModelId)
await downloadModel(modelHandle, fileName, persistModelId)
}, [addDownloadState, downloadModel, modelHandle, fileName, persistModelId])
downloadModelMutation.mutate({
modelId: modelHandle,
fileName: fileName,
persistedModelId: persistModelId,
})
}, [downloadModelMutation, modelHandle, fileName, persistModelId])

const onUseModelClick = useCallback(async () => {
if (!assistants || assistants.length === 0) {
Expand Down
18 changes: 6 additions & 12 deletions web/screens/HubScreen2/components/ListModel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,16 +9,12 @@ import { toaster } from '@/containers/Toast'
import useAbortDownload from '@/hooks/useAbortDownload'
import useAssistantQuery from '@/hooks/useAssistantQuery'

import useCortex from '@/hooks/useCortex'

import {
addDownloadModelStateAtom,
downloadStateListAtom,
} from '@/hooks/useDownloadState'
import { downloadStateListAtom } from '@/hooks/useDownloadState'

import useEngineQuery from '@/hooks/useEngineQuery'
import useHfEngineToBranchesQuery from '@/hooks/useHfEngineToBranchesQuery'

import useModelDownloadMutation from '@/hooks/useModelDownloadMutation'
import useThreads from '@/hooks/useThreads'

import { formatDownloadPercentage, toGibibytes } from '@/utils/converter'
Expand Down Expand Up @@ -150,9 +146,8 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
modelHandle,
branch,
}) => {
const { downloadModel } = useCortex()
const downloadModelMutation = useModelDownloadMutation()
const { abortDownload } = useAbortDownload()
const addDownloadState = useSetAtom(addDownloadModelStateAtom)
const setMainViewState = useSetAtom(mainViewStateAtom)
const { createThread } = useThreads()
const setDownloadLocalModelModalStage = useSetAtom(localModelModalStageAtom)
Expand All @@ -172,10 +167,9 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
[downloadedModels, modelId]
)

const onDownloadClick = useCallback(async () => {
addDownloadState(modelId)
await downloadModel(modelId)
}, [downloadModel, addDownloadState, modelId])
const onDownloadClick = useCallback(() => {
downloadModelMutation.mutate({ modelId })
}, [downloadModelMutation, modelId])

const onUseModelClick = useCallback(async () => {
if (!assistants || assistants.length === 0) {
Expand Down
21 changes: 10 additions & 11 deletions web/screens/HubScreen2/components/SliderItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,8 @@ import { toaster } from '@/containers/Toast'

import useAbortDownload from '@/hooks/useAbortDownload'
import useAssistantQuery from '@/hooks/useAssistantQuery'
import useCortex from '@/hooks/useCortex'
import {
addDownloadModelStateAtom,
downloadStateListAtom,
} from '@/hooks/useDownloadState'
import { downloadStateListAtom } from '@/hooks/useDownloadState'
import useModelDownloadMutation from '@/hooks/useModelDownloadMutation'
import { QuickStartModel } from '@/hooks/useModelHub'
import useThreads from '@/hooks/useThreads'

Expand Down Expand Up @@ -77,8 +74,7 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
modelHandle,
fileName,
}) => {
const { downloadModel } = useCortex()
const addDownloadState = useSetAtom(addDownloadModelStateAtom)
const downloadModelMutation = useModelDownloadMutation()
const setMainViewState = useSetAtom(mainViewStateAtom)
const { createThread } = useThreads()
const { data: assistants } = useAssistantQuery()
Expand All @@ -102,10 +98,13 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
[downloadedModels, persistModelId]
)

const onDownloadClick = useCallback(async () => {
addDownloadState(persistModelId)
await downloadModel(modelHandle, fileName, persistModelId)
}, [addDownloadState, downloadModel, modelHandle, fileName, persistModelId])
const onDownloadClick = useCallback(() => {
downloadModelMutation.mutate({
modelId: modelHandle,
fileName: fileName,
persistedModelId: persistModelId,
})
}, [downloadModelMutation, modelHandle, fileName, persistModelId])

const onUseModelClick = useCallback(async () => {
if (!assistants || assistants.length === 0) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,8 @@ import { toaster } from '@/containers/Toast'
import useAbortDownload from '@/hooks/useAbortDownload'
import useAssistantQuery from '@/hooks/useAssistantQuery'

import useCortex from '@/hooks/useCortex'

import {
addDownloadModelStateAtom,
downloadStateListAtom,
} from '@/hooks/useDownloadState'
import { downloadStateListAtom } from '@/hooks/useDownloadState'
import useModelDownloadMutation from '@/hooks/useModelDownloadMutation'
import useThreads from '@/hooks/useThreads'

import { formatDownloadPercentage, toGibibytes } from '@/utils/converter'
Expand Down Expand Up @@ -69,8 +65,7 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
modelHandle,
fileName,
}) => {
const { downloadModel } = useCortex()
const addDownloadState = useSetAtom(addDownloadModelStateAtom)
const downloadModelMutation = useModelDownloadMutation()
const setMainViewState = useSetAtom(mainViewStateAtom)
const setHfImportingStage = useSetAtom(importHuggingFaceModelStageAtom)
const { createThread } = useThreads()
Expand All @@ -93,10 +88,13 @@ const DownloadContainer: React.FC<DownloadContainerProps> = ({
[downloadedModels, persistModelId]
)

const onDownloadClick = useCallback(async () => {
addDownloadState(persistModelId)
await downloadModel(modelHandle, fileName, persistModelId)
}, [addDownloadState, downloadModel, modelHandle, fileName, persistModelId])
const onDownloadClick = useCallback(() => {
downloadModelMutation.mutate({
modelId: modelHandle,
fileName: fileName,
persistedModelId: persistModelId,
})
}, [downloadModelMutation, modelHandle, fileName, persistModelId])

const onUseModelClick = useCallback(async () => {
if (!assistants || assistants.length === 0) {
Expand Down
Loading

0 comments on commit 26be941

Please sign in to comment.