chore: temporary disabled starter screen (#3663)
* chore: temporary disabeld starter screen * chore: create useStarter screen * chore: fix typo * chore: update config starter screen * chore: update comment code * chore: renmove some commented code
This commit is contained in:
parent
0cce4a0c83
commit
3ffaa1ef7f
78
web/hooks/useStarterScreen.ts
Normal file
78
web/hooks/useStarterScreen.ts
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
import { useState, useEffect } from 'react'
|
||||||
|
|
||||||
|
import { useAtomValue } from 'jotai'
|
||||||
|
|
||||||
|
import { localEngines } from '@/utils/modelEngine'
|
||||||
|
|
||||||
|
import { extensionManager } from '@/extension'
|
||||||
|
import { downloadedModelsAtom } from '@/helpers/atoms/Model.atom'
|
||||||
|
import { threadsAtom } from '@/helpers/atoms/Thread.atom'
|
||||||
|
|
||||||
|
export function useStarterScreen() {
|
||||||
|
const downloadedModels = useAtomValue(downloadedModelsAtom)
|
||||||
|
const threads = useAtomValue(threadsAtom)
|
||||||
|
|
||||||
|
const isDownloadALocalModel = downloadedModels.some((x) =>
|
||||||
|
localEngines.includes(x.engine)
|
||||||
|
)
|
||||||
|
|
||||||
|
const [extensionHasSettings, setExtensionHasSettings] = useState<
|
||||||
|
{ name?: string; setting: string; apiKey: string; provider: string }[]
|
||||||
|
>([])
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const getAllSettings = async () => {
|
||||||
|
const extensionsMenu: {
|
||||||
|
name?: string
|
||||||
|
setting: string
|
||||||
|
apiKey: string
|
||||||
|
provider: string
|
||||||
|
}[] = []
|
||||||
|
const extensions = extensionManager.getAll()
|
||||||
|
|
||||||
|
for (const extension of extensions) {
|
||||||
|
if (typeof extension.getSettings === 'function') {
|
||||||
|
const settings = await extension.getSettings()
|
||||||
|
|
||||||
|
if (
|
||||||
|
(settings && settings.length > 0) ||
|
||||||
|
(await extension.installationState()) !== 'NotRequired'
|
||||||
|
) {
|
||||||
|
extensionsMenu.push({
|
||||||
|
name: extension.productName,
|
||||||
|
setting: extension.name,
|
||||||
|
apiKey:
|
||||||
|
'apiKey' in extension && typeof extension.apiKey === 'string'
|
||||||
|
? extension.apiKey
|
||||||
|
: '',
|
||||||
|
provider:
|
||||||
|
'provider' in extension &&
|
||||||
|
typeof extension.provider === 'string'
|
||||||
|
? extension.provider
|
||||||
|
: '',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setExtensionHasSettings(extensionsMenu)
|
||||||
|
}
|
||||||
|
getAllSettings()
|
||||||
|
}, [])
|
||||||
|
|
||||||
|
const isAnyRemoteModelConfigured = extensionHasSettings.some(
|
||||||
|
(x) => x.apiKey.length > 1
|
||||||
|
)
|
||||||
|
|
||||||
|
let isShowStarterScreen
|
||||||
|
|
||||||
|
isShowStarterScreen =
|
||||||
|
!isAnyRemoteModelConfigured && !isDownloadALocalModel && !threads.length
|
||||||
|
|
||||||
|
// Remove this part when we rework on starter screen
|
||||||
|
isShowStarterScreen = false
|
||||||
|
|
||||||
|
return {
|
||||||
|
extensionHasSettings,
|
||||||
|
isShowStarterScreen,
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,11 +1,7 @@
|
|||||||
import { useEffect, useState } from 'react'
|
import { useStarterScreen } from '@/hooks/useStarterScreen'
|
||||||
|
|
||||||
import { useAtomValue } from 'jotai'
|
|
||||||
|
|
||||||
import ThreadLeftPanel from '@/screens/Thread/ThreadLeftPanel'
|
import ThreadLeftPanel from '@/screens/Thread/ThreadLeftPanel'
|
||||||
|
|
||||||
import { localEngines } from '@/utils/modelEngine'
|
|
||||||
|
|
||||||
import ThreadCenterPanel from './ThreadCenterPanel'
|
import ThreadCenterPanel from './ThreadCenterPanel'
|
||||||
import OnDeviceStarterScreen from './ThreadCenterPanel/ChatBody/OnDeviceStarterScreen'
|
import OnDeviceStarterScreen from './ThreadCenterPanel/ChatBody/OnDeviceStarterScreen'
|
||||||
import ModalCleanThread from './ThreadLeftPanel/ModalCleanThread'
|
import ModalCleanThread from './ThreadLeftPanel/ModalCleanThread'
|
||||||
@ -13,73 +9,12 @@ import ModalDeleteThread from './ThreadLeftPanel/ModalDeleteThread'
|
|||||||
import ModalEditTitleThread from './ThreadLeftPanel/ModalEditTitleThread'
|
import ModalEditTitleThread from './ThreadLeftPanel/ModalEditTitleThread'
|
||||||
import ThreadRightPanel from './ThreadRightPanel'
|
import ThreadRightPanel from './ThreadRightPanel'
|
||||||
|
|
||||||
import { extensionManager } from '@/extension'
|
|
||||||
import { downloadedModelsAtom } from '@/helpers/atoms/Model.atom'
|
|
||||||
import { threadsAtom } from '@/helpers/atoms/Thread.atom'
|
|
||||||
|
|
||||||
const ThreadScreen = () => {
|
const ThreadScreen = () => {
|
||||||
const downloadedModels = useAtomValue(downloadedModelsAtom)
|
const { extensionHasSettings, isShowStarterScreen } = useStarterScreen()
|
||||||
const threads = useAtomValue(threadsAtom)
|
|
||||||
|
|
||||||
const isDownloadALocalModel = downloadedModels.some((x) =>
|
|
||||||
localEngines.includes(x.engine)
|
|
||||||
)
|
|
||||||
|
|
||||||
const [extensionHasSettings, setExtensionHasSettings] = useState<
|
|
||||||
{ name?: string; setting: string; apiKey: string; provider: string }[]
|
|
||||||
>([])
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
const getAllSettings = async () => {
|
|
||||||
const extensionsMenu: {
|
|
||||||
name?: string
|
|
||||||
setting: string
|
|
||||||
apiKey: string
|
|
||||||
provider: string
|
|
||||||
}[] = []
|
|
||||||
const extensions = extensionManager.getAll()
|
|
||||||
|
|
||||||
for (const extension of extensions) {
|
|
||||||
if (typeof extension.getSettings === 'function') {
|
|
||||||
const settings = await extension.getSettings()
|
|
||||||
|
|
||||||
if (
|
|
||||||
(settings && settings.length > 0) ||
|
|
||||||
(await extension.installationState()) !== 'NotRequired'
|
|
||||||
) {
|
|
||||||
extensionsMenu.push({
|
|
||||||
name: extension.productName,
|
|
||||||
setting: extension.name,
|
|
||||||
apiKey:
|
|
||||||
'apiKey' in extension && typeof extension.apiKey === 'string'
|
|
||||||
? extension.apiKey
|
|
||||||
: '',
|
|
||||||
provider:
|
|
||||||
'provider' in extension &&
|
|
||||||
typeof extension.provider === 'string'
|
|
||||||
? extension.provider
|
|
||||||
: '',
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
setExtensionHasSettings(extensionsMenu)
|
|
||||||
}
|
|
||||||
getAllSettings()
|
|
||||||
}, [])
|
|
||||||
|
|
||||||
const isAnyRemoteModelConfigured = extensionHasSettings.some(
|
|
||||||
(x) => x.apiKey.length > 1
|
|
||||||
)
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="relative flex h-full w-full flex-1 overflow-x-hidden">
|
<div className="relative flex h-full w-full flex-1 overflow-x-hidden">
|
||||||
{!isAnyRemoteModelConfigured &&
|
{isShowStarterScreen ? (
|
||||||
!isDownloadALocalModel &&
|
<OnDeviceStarterScreen extensionHasSettings={extensionHasSettings} />
|
||||||
!threads.length ? (
|
|
||||||
<>
|
|
||||||
<OnDeviceStarterScreen extensionHasSettings={extensionHasSettings} />
|
|
||||||
</>
|
|
||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
<ThreadLeftPanel />
|
<ThreadLeftPanel />
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user