jan/web/hooks/useGetConfiguredModels.ts
NamH 1bf4c1b621
feat: pre-populate Jan's /models folder (#796)
Signed-off-by: James <james@jan.ai>
Co-authored-by: James <james@jan.ai>
2023-12-01 18:03:51 +07:00

35 lines
939 B
TypeScript

import { useEffect, useState } from 'react'
import { ExtensionType, ModelExtension } from '@janhq/core'
import { Model } from '@janhq/core'
import { extensionManager } from '@/extension/ExtensionManager'
export function useGetConfiguredModels() {
const [loading, setLoading] = useState<boolean>(false)
const [models, setModels] = useState<Model[]>([])
const getConfiguredModels = async (): Promise<Model[]> => {
const models = await extensionManager
.get<ModelExtension>(ExtensionType.Model)
?.getConfiguredModels()
return models ?? []
}
async function fetchModels() {
setLoading(true)
const models = await getConfiguredModels()
if (process.env.NODE_ENV === 'development') {
// models = [dummyModel, ...models] // TODO: NamH add back dummy model later
}
setLoading(false)
setModels(models)
}
useEffect(() => {
fetchModels()
}, [])
return { loading, models }
}