* feat: remote engine management * chore: fix linter issue * chore: remove unused imports * fix: populate engines, models and legacy settings (#4403) * fix: populate engines, models and legacy settings * chore: legacy logics update configured remote engine * fix: check exist path before reading * fix: engines and models persist - race condition * chore: update issue state * test: update test cases * chore: bring back Cortex extension settings * chore: setup button gear / plus based apikey * chore: fix remote engine from welcome screen * chore: resolve linter issue * chore: support request headers template * chore: update engines using header_template instead of api_key_template * chore: update models on changes * fix: anthropic response template * chore: fix welcome screen and debounce update value input * chore: update engines list on changes * chore: update engines list on change * chore: update desc form add modal remote engines * chore: bump cortex version to latest RC * chore: fix linter * fix: transform payload of Anthropic and OpenAI * fix: typo * fix: openrouter model id for auto routing * chore: remove remote engine URL setting * chore: add cohere engine and model support * fix: should not clean on app launch - models list display issue * fix: local engine check logic * chore: bump app version to latest release 0.5.13 * test: fix failed tests --------- Co-authored-by: Louis <louis@jan.ai>
73 lines
2.1 KiB
TypeScript
73 lines
2.1 KiB
TypeScript
'use client'
|
|
|
|
import { Fragment, useEffect } from 'react'
|
|
|
|
import { AppConfiguration, getUserHomePath } from '@janhq/core'
|
|
import { useSetAtom } from 'jotai'
|
|
|
|
import useAssistants from '@/hooks/useAssistants'
|
|
import useEngines from '@/hooks/useEngines'
|
|
import useGetSystemResources from '@/hooks/useGetSystemResources'
|
|
import useModels from '@/hooks/useModels'
|
|
import useThreads from '@/hooks/useThreads'
|
|
|
|
import { SettingScreenList } from '@/screens/Settings'
|
|
|
|
import { defaultJanDataFolderAtom } from '@/helpers/atoms/App.atom'
|
|
import {
|
|
janDataFolderPathAtom,
|
|
quickAskEnabledAtom,
|
|
} from '@/helpers/atoms/AppConfig.atom'
|
|
import { janSettingScreenAtom } from '@/helpers/atoms/Setting.atom'
|
|
|
|
const DataLoader: React.FC = () => {
|
|
const setJanDataFolderPath = useSetAtom(janDataFolderPathAtom)
|
|
const setQuickAskEnabled = useSetAtom(quickAskEnabledAtom)
|
|
const setJanDefaultDataFolder = useSetAtom(defaultJanDataFolderAtom)
|
|
const setJanSettingScreen = useSetAtom(janSettingScreenAtom)
|
|
const { getData: loadModels } = useModels()
|
|
const { getData: loadEngines } = useEngines()
|
|
|
|
useThreads()
|
|
useAssistants()
|
|
useGetSystemResources()
|
|
|
|
useEffect(() => {
|
|
// Load data once
|
|
loadModels()
|
|
loadEngines()
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, [])
|
|
|
|
useEffect(() => {
|
|
window.core?.api
|
|
?.getAppConfigurations()
|
|
?.then((appConfig: AppConfiguration) => {
|
|
setJanDataFolderPath(appConfig.data_folder)
|
|
setQuickAskEnabled(appConfig.quick_ask)
|
|
})
|
|
}, [setJanDataFolderPath, setQuickAskEnabled])
|
|
|
|
useEffect(() => {
|
|
async function getDefaultJanDataFolder() {
|
|
const defaultJanDataFolder = await getUserHomePath()
|
|
|
|
setJanDefaultDataFolder(defaultJanDataFolder)
|
|
}
|
|
getDefaultJanDataFolder()
|
|
}, [setJanDefaultDataFolder])
|
|
|
|
useEffect(() => {
|
|
const janSettingScreen = SettingScreenList.filter(
|
|
(screen) => window.electronAPI || screen !== 'Extensions'
|
|
)
|
|
setJanSettingScreen(janSettingScreen)
|
|
}, [setJanSettingScreen])
|
|
|
|
console.debug('Load Data...')
|
|
|
|
return <Fragment></Fragment>
|
|
}
|
|
|
|
export default DataLoader
|