* Dashboard submenu (#4545) * add app submenu (#4452) * add app submenu * fix * width & i18n * optimize submenu code (#4515) * optimize submenu code * fix * fix * fix * fix ts * perf: dashboard sub menu * doc --------- Co-authored-by: heheer <heheer@sealos.io> * feat: value format test * doc * Mcp export (#4555) * feat: mcp server * feat: mcp server * feat: mcp server build * update doc * perf: path selector (#4556) * perf: path selector * fix: docker file path * perf: add image endpoint to dataset search (#4557) * perf: add image endpoint to dataset search * fix: mcp_server url * human in loop (#4558) * Support interactive nodes for loops, and enhance the function of merging nested and loop node history messages. (#4552) * feat: add LoopInteractive definition * feat: Support LoopInteractive type and update related logic * fix: Refactor loop handling logic and improve output value initialization * feat: Add mergeSignId to dispatchLoop and dispatchRunAppNode responses * feat: Enhance mergeChatResponseData to recursively merge plugin details and improve response handling * refactor: Remove redundant comments in mergeChatResponseData for clarity * perf: loop interactive * perf: human in loop --------- Co-authored-by: Theresa <63280168+sd0ric4@users.noreply.github.com> * mcp server ui * integrate mcp (#4549) * integrate mcp * delete unused code * fix ts * bug fix * fix * support whole mcp tools * add try catch * fix * fix * fix ts * fix test * fix ts * fix: interactive in v1 completions * doc * fix: router path * fix mcp integrate (#4563) * fix mcp integrate * fix ui * fix: mcp ux * feat: mcp call title * remove repeat loading * fix mcp tools avatar (#4564) * fix * fix avatar * fix update version * update doc * fix: value format * close server and remove cache * perf: avatar --------- Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: Theresa <63280168+sd0ric4@users.noreply.github.com>
188 lines
5.9 KiB
TypeScript
188 lines
5.9 KiB
TypeScript
import { create, devtools, persist, immer } from '@fastgpt/web/common/zustand';
|
|
import axios from 'axios';
|
|
import { OAuthEnum } from '@fastgpt/global/support/user/constant';
|
|
import type {
|
|
TTSModelType,
|
|
LLMModelItemType,
|
|
RerankModelItemType,
|
|
EmbeddingModelItemType,
|
|
STTModelType
|
|
} from '@fastgpt/global/core/ai/model.d';
|
|
import { InitDateResponse } from '@/global/common/api/systemRes';
|
|
import { FastGPTFeConfigsType } from '@fastgpt/global/common/system/types';
|
|
import { SubPlanType } from '@fastgpt/global/support/wallet/sub/type';
|
|
import { ModelTypeEnum } from '@fastgpt/global/core/ai/model';
|
|
import { TeamErrEnum } from '@fastgpt/global/common/error/code/team';
|
|
import { SystemDefaultModelType } from '@fastgpt/service/core/ai/type';
|
|
|
|
type LoginStoreType = { provider: `${OAuthEnum}`; lastRoute: string; state: string };
|
|
|
|
export type NotSufficientModalType =
|
|
| TeamErrEnum.datasetSizeNotEnough
|
|
| TeamErrEnum.aiPointsNotEnough
|
|
| TeamErrEnum.datasetAmountNotEnough
|
|
| TeamErrEnum.teamMemberOverSize
|
|
| TeamErrEnum.appAmountNotEnough;
|
|
|
|
type State = {
|
|
initd: boolean;
|
|
setInitd: () => void;
|
|
|
|
lastRoute: string;
|
|
setLastRoute: (e: string) => void;
|
|
lastAppListRouteType?: string;
|
|
setLastAppListRouteType: (e?: string) => void;
|
|
|
|
loginStore?: LoginStoreType;
|
|
setLoginStore: (e?: LoginStoreType) => void;
|
|
|
|
loading: boolean;
|
|
setLoading: (val: boolean) => null;
|
|
gitStar: number;
|
|
loadGitStar: () => Promise<void>;
|
|
|
|
notSufficientModalType?: NotSufficientModalType;
|
|
setNotSufficientModalType: (val?: NotSufficientModalType) => void;
|
|
|
|
initDataBufferId?: string;
|
|
feConfigs: FastGPTFeConfigsType;
|
|
subPlans?: SubPlanType;
|
|
systemVersion: string;
|
|
defaultModels: SystemDefaultModelType;
|
|
llmModelList: LLMModelItemType[];
|
|
datasetModelList: LLMModelItemType[];
|
|
getVlmModelList: () => LLMModelItemType[];
|
|
embeddingModelList: EmbeddingModelItemType[];
|
|
ttsModelList: TTSModelType[];
|
|
reRankModelList: RerankModelItemType[];
|
|
sttModelList: STTModelType[];
|
|
initStaticData: (e: InitDateResponse) => void;
|
|
appType?: string;
|
|
setAppType: (e?: string) => void;
|
|
};
|
|
|
|
export const useSystemStore = create<State>()(
|
|
devtools(
|
|
persist(
|
|
immer((set, get) => ({
|
|
appType: undefined,
|
|
setAppType(e) {
|
|
set((state) => {
|
|
state.appType = e;
|
|
});
|
|
},
|
|
initd: false,
|
|
setInitd() {
|
|
set((state) => {
|
|
state.initd = true;
|
|
});
|
|
},
|
|
lastRoute: '/dashboard/apps',
|
|
setLastRoute(e) {
|
|
set((state) => {
|
|
state.lastRoute = e;
|
|
});
|
|
},
|
|
lastAppListRouteType: undefined,
|
|
setLastAppListRouteType(e) {
|
|
set((state) => {
|
|
state.lastAppListRouteType = e;
|
|
});
|
|
},
|
|
loginStore: undefined,
|
|
setLoginStore(e) {
|
|
set((state) => {
|
|
state.loginStore = e;
|
|
});
|
|
},
|
|
loading: false,
|
|
setLoading: (val: boolean) => {
|
|
set((state) => {
|
|
state.loading = val;
|
|
});
|
|
return null;
|
|
},
|
|
|
|
gitStar: 20000,
|
|
async loadGitStar() {
|
|
if (!get().feConfigs?.show_git) return;
|
|
try {
|
|
const { data: git } = await axios.get('https://api.github.com/repos/labring/FastGPT');
|
|
|
|
set((state) => {
|
|
state.gitStar = git.stargazers_count;
|
|
});
|
|
} catch (error) {}
|
|
},
|
|
|
|
notSufficientModalType: undefined,
|
|
setNotSufficientModalType(type) {
|
|
set((state) => {
|
|
state.notSufficientModalType = type;
|
|
});
|
|
},
|
|
|
|
initDataBufferId: undefined,
|
|
feConfigs: {},
|
|
subPlans: undefined,
|
|
systemVersion: '0.0.0',
|
|
defaultModels: {},
|
|
llmModelList: [],
|
|
datasetModelList: [],
|
|
embeddingModelList: [],
|
|
ttsModelList: [],
|
|
reRankModelList: [],
|
|
sttModelList: [],
|
|
getVlmModelList: () => {
|
|
return get().llmModelList.filter((item) => item.vision);
|
|
},
|
|
initStaticData(res) {
|
|
set((state) => {
|
|
state.initDataBufferId = res.bufferId;
|
|
|
|
state.feConfigs = res.feConfigs ?? state.feConfigs;
|
|
state.subPlans = res.subPlans ?? state.subPlans;
|
|
state.systemVersion = res.systemVersion ?? state.systemVersion;
|
|
|
|
state.llmModelList =
|
|
res.activeModelList?.filter((item) => item.type === ModelTypeEnum.llm) ??
|
|
state.llmModelList;
|
|
state.datasetModelList = state.llmModelList.filter((item) => item.datasetProcess);
|
|
state.embeddingModelList =
|
|
res.activeModelList?.filter((item) => item.type === ModelTypeEnum.embedding) ??
|
|
state.embeddingModelList;
|
|
state.ttsModelList =
|
|
res.activeModelList?.filter((item) => item.type === ModelTypeEnum.tts) ??
|
|
state.ttsModelList;
|
|
state.reRankModelList =
|
|
res.activeModelList?.filter((item) => item.type === ModelTypeEnum.rerank) ??
|
|
state.reRankModelList;
|
|
state.sttModelList =
|
|
res.activeModelList?.filter((item) => item.type === ModelTypeEnum.stt) ??
|
|
state.sttModelList;
|
|
|
|
state.defaultModels = res.defaultModels ?? state.defaultModels;
|
|
});
|
|
}
|
|
})),
|
|
{
|
|
name: 'globalStore',
|
|
partialize: (state) => ({
|
|
loginStore: state.loginStore,
|
|
initDataBufferId: state.initDataBufferId,
|
|
feConfigs: state.feConfigs,
|
|
subPlans: state.subPlans,
|
|
systemVersion: state.systemVersion,
|
|
defaultModels: state.defaultModels,
|
|
llmModelList: state.llmModelList,
|
|
datasetModelList: state.datasetModelList,
|
|
embeddingModelList: state.embeddingModelList,
|
|
ttsModelList: state.ttsModelList,
|
|
reRankModelList: state.reRankModelList,
|
|
sttModelList: state.sttModelList
|
|
})
|
|
}
|
|
)
|
|
)
|
|
);
|