* fix: remove DefaultTeam (#4037) * fix :Get application bound knowledge base information logical rewrite (#4057) * fix :Get application bound knowledge base information logical rewrite * fix :Get application bound knowledge base information logical rewrite * fix :Get application bound knowledge base information logical rewrite * fix :Get application bound knowledge base information logical rewrite * update package * fix: import dataset step error;perf: ai proxy avatar (#4074) * perf: pg config params * perf: ai proxy avatar * fix: import dataset step error * feat: data input ux * perf: app dataset rewite * fix: 文本提取不支持arrayString,arrayNumber等jsonSchema (#4079) * update doc ;perf: model test (#4098) * perf: extract array * update doc * perf: model test * perf: model test * perf: think tag parse (#4102) * chat quote reader (#3912) * init chat quote full text reader * linked structure * dataset data linked * optimize code * fix ts build * test finish * delete log * fix * fix ts * fix ts * remove nextId * initial scroll * fix * fix * perf: chunk read (#4109) * package * perf: chunk read * feat: api dataset support pdf parse;fix: chunk reader auth (#4117) * feat: api dataset support pdf parse * fix: chunk reader auth * feat: invitation link (#3979) * feat: invitation link schema and apis * feat: add invitation link * feat: member status: active, leave, forbidden * fix: expires show hours and minutes * feat: invalid invitation link hint * fix: typo * chore: fix typo & i18n * fix * pref: fe * feat: add ttl index for 30-day-clean-up * perf: invite member code (#4118) * perf: invite member code * fix: ts * fix: model test channel id;fix: quote reader (#4123) * fix: model test channel id * fix: quote reader * fix chat quote reader (#4125) * perf: model test;perf: sidebar trigger (#4127) * fix: import dataset step error;perf: ai proxy avatar (#4074) * perf: pg config params * perf: ai proxy avatar * fix: import dataset step error * feat: data input ux * perf: app dataset rewite * perf: model test * perf: sidebar trigger * lock * update nanoid version * fix: select component ux * fix: ts * fix: vitest * remove test * fix: prompt toolcall ui (#4139) * load log error adapt * fix: prompt toolcall ui * perf: commercial function tip * update package * pref: copy link (#4147) * fix(i18n): namespace (#4143) * hiden dataset source (#4152) * hiden dataset source * perf: reader * chore: move all tests into a single folder (#4160) * fix modal close scroll (#4162) * fix modal close scroll * update refresh * feat: rerank modal select and weight (#4164) * fix loadInitData refresh (#4169) * fix * fix * form input number default & api dataset max token * feat: mix search weight (#4170) * feat: mix search weight * feat: svg render * fix: avatar error remove (#4173) * fix: avatar error remove * fix: index * fix: guide * fix: auth * update package;fix: input data model ui (#4181) * update package * fix: ts * update config * update jieba package * add type sign * fix: input data ui * fix: page title refresh (#4186) * fix: ts * update jieba package * fix: page title refresh * fix: remove member length check when opening invite create modal (#4193) * add env to check internal ip (#4187) * fix: ts * update jieba package * add env to check internal ip * package * fix: jieba * reset package * update config * fix: jieba package * init shell * init version * change team reload * update jieba package (#4200) * update jieba package * package * update package * remove invalid code * action * package (#4201) * package * update package * remove invalid code * package * remove i18n tip (#4202) * doc (#4205) * fix: i18n (#4208) * fix: next config (#4207) * reset package * i18n * update config * i18n * remove log --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com> Co-authored-by: gggaaallleee <91131304+gggaaallleee@users.noreply.github.com> Co-authored-by: shilin <39396378+shilin66@users.noreply.github.com> Co-authored-by: heheer <heheer@sealos.io>
190 lines
6.0 KiB
TypeScript
190 lines
6.0 KiB
TypeScript
import { create } from 'zustand';
|
|
import { devtools, persist } from 'zustand/middleware';
|
|
import { immer } from 'zustand/middleware/immer';
|
|
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: '/app/list',
|
|
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
|
|
})
|
|
}
|
|
)
|
|
)
|
|
);
|