import { useCallback, useEffect } from 'react' import { ExtensionTypeEnum, Model, ModelEvent, ModelExtension, ModelFile, events, } from '@janhq/core' import { useSetAtom } from 'jotai' import { extensionManager } from '@/extension' import { configuredModelsAtom, defaultModelAtom, downloadedModelsAtom, } from '@/helpers/atoms/Model.atom' const useModels = () => { const setDownloadedModels = useSetAtom(downloadedModelsAtom) const setConfiguredModels = useSetAtom(configuredModelsAtom) const setDefaultModel = useSetAtom(defaultModelAtom) const getData = useCallback(() => { const getDownloadedModels = async () => { const models = await getLocalDownloadedModels() setDownloadedModels(models) } const getConfiguredModels = async () => { const models = await getLocalConfiguredModels() setConfiguredModels(models) } const getDefaultModel = async () => { const defaultModel = await getLocalDefaultModel() setDefaultModel(defaultModel) } Promise.all([ getDownloadedModels(), getConfiguredModels(), getDefaultModel(), ]) }, [setDownloadedModels, setConfiguredModels, setDefaultModel]) useEffect(() => { // Try get data on mount getData() // Listen for model updates events.on(ModelEvent.OnModelsUpdate, async () => getData()) return () => { // Remove listener on unmount events.off(ModelEvent.OnModelsUpdate, async () => {}) } }, [getData]) } const getLocalDefaultModel = async (): Promise => extensionManager .get(ExtensionTypeEnum.Model) ?.getDefaultModel() const getLocalConfiguredModels = async (): Promise => extensionManager .get(ExtensionTypeEnum.Model) ?.getConfiguredModels() ?? [] const getLocalDownloadedModels = async (): Promise => extensionManager .get(ExtensionTypeEnum.Model) ?.getDownloadedModels() ?? [] export default useModels