mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 13:03:50 +00:00

* perf: redirect request and err log replace perf: dataset openapi feat: session fix: retry input error feat: 468 doc sub page feat: standard sub perf: rerank tip perf: rerank tip perf: api sdk perf: openapi sub plan perf: sub ui fix: ts * perf: init log * fix: variable select * sub page * icon * perf: llm model config * perf: menu ux * perf: system store * perf: publish app name * fix: init data * perf: flow edit ux * fix: value type format and ux * fix prompt editor default value (#13) * fix prompt editor default value * fix prompt editor update when not focus * add key with variable --------- Co-authored-by: Archer <545436317@qq.com> * fix: value type * doc * i18n * import path * home page * perf: mongo session running * fix: ts * perf: use toast * perf: flow edit * perf: sse response * slider ui * fetch error * fix prompt editor rerender when not focus by key defaultvalue (#14) * perf: prompt editor * feat: dataset search concat * perf: doc * fix:ts * perf: doc * fix json editor onblur value (#15) * faq * vector model default config * ipv6 --------- Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
134 lines
4.3 KiB
TypeScript
134 lines
4.3 KiB
TypeScript
import type { AppSimpleEditFormType } from '../app/type';
|
|
import { FlowNodeTypeEnum } from '../module/node/constant';
|
|
import { ModuleOutputKeyEnum, ModuleInputKeyEnum } from '../module/constants';
|
|
import type { FlowNodeInputItemType } from '../module/node/type.d';
|
|
import { getGuideModule, splitGuideModule } from '../module/utils';
|
|
import { ModuleItemType } from '../module/type.d';
|
|
import { DatasetSearchModeEnum } from '../dataset/constants';
|
|
|
|
export const getDefaultAppForm = (templateId = 'fastgpt-universal'): AppSimpleEditFormType => {
|
|
return {
|
|
templateId,
|
|
aiSettings: {
|
|
model: 'gpt-3.5-turbo',
|
|
systemPrompt: '',
|
|
temperature: 0,
|
|
isResponseAnswerText: true,
|
|
quotePrompt: '',
|
|
quoteTemplate: '',
|
|
maxToken: 4000
|
|
},
|
|
cfr: {
|
|
background: ''
|
|
},
|
|
dataset: {
|
|
datasets: [],
|
|
similarity: 0.4,
|
|
limit: 1500,
|
|
searchEmptyText: '',
|
|
searchMode: DatasetSearchModeEnum.embedding,
|
|
usingReRank: false
|
|
},
|
|
userGuide: {
|
|
welcomeText: '',
|
|
variables: [],
|
|
questionGuide: false,
|
|
tts: {
|
|
type: 'web'
|
|
}
|
|
}
|
|
};
|
|
};
|
|
|
|
/* format app modules to edit form */
|
|
export const appModules2Form = ({
|
|
templateId,
|
|
modules
|
|
}: {
|
|
modules: ModuleItemType[];
|
|
templateId: string;
|
|
}) => {
|
|
const defaultAppForm = getDefaultAppForm(templateId);
|
|
|
|
const findInputValueByKey = (inputs: FlowNodeInputItemType[], key: string) => {
|
|
return inputs.find((item) => item.key === key)?.value;
|
|
};
|
|
|
|
modules.forEach((module) => {
|
|
if (module.flowType === FlowNodeTypeEnum.chatNode) {
|
|
defaultAppForm.aiSettings.model = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiModel
|
|
);
|
|
defaultAppForm.aiSettings.systemPrompt = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiSystemPrompt
|
|
);
|
|
defaultAppForm.aiSettings.temperature = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiChatTemperature
|
|
);
|
|
defaultAppForm.aiSettings.maxToken = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiChatMaxToken
|
|
);
|
|
defaultAppForm.aiSettings.quoteTemplate = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiChatQuoteTemplate
|
|
);
|
|
defaultAppForm.aiSettings.quotePrompt = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiChatQuotePrompt
|
|
);
|
|
} else if (module.flowType === FlowNodeTypeEnum.datasetSearchNode) {
|
|
defaultAppForm.dataset.datasets = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSelectList
|
|
);
|
|
defaultAppForm.dataset.similarity = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSimilarity
|
|
);
|
|
defaultAppForm.dataset.limit = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetMaxTokens
|
|
);
|
|
defaultAppForm.dataset.searchMode =
|
|
findInputValueByKey(module.inputs, ModuleInputKeyEnum.datasetSearchMode) ||
|
|
DatasetSearchModeEnum.embedding;
|
|
defaultAppForm.dataset.usingReRank = !!findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSearchUsingReRank
|
|
);
|
|
|
|
// empty text
|
|
const emptyOutputs =
|
|
module.outputs.find((item) => item.key === ModuleOutputKeyEnum.datasetIsEmpty)?.targets ||
|
|
[];
|
|
const emptyOutput = emptyOutputs[0];
|
|
if (emptyOutput) {
|
|
const target = modules.find((item) => item.moduleId === emptyOutput.moduleId);
|
|
defaultAppForm.dataset.searchEmptyText =
|
|
target?.inputs?.find((item) => item.key === ModuleInputKeyEnum.answerText)?.value || '';
|
|
}
|
|
} else if (module.flowType === FlowNodeTypeEnum.userGuide) {
|
|
const { welcomeText, variableModules, questionGuide, ttsConfig } = splitGuideModule(
|
|
getGuideModule(modules)
|
|
);
|
|
defaultAppForm.userGuide = {
|
|
welcomeText: welcomeText,
|
|
variables: variableModules,
|
|
questionGuide: questionGuide,
|
|
tts: ttsConfig
|
|
};
|
|
} else if (module.flowType === FlowNodeTypeEnum.cfr) {
|
|
const value = module.inputs.find((item) => item.key === ModuleInputKeyEnum.aiSystemPrompt);
|
|
if (value) {
|
|
defaultAppForm.cfr.background = value.value;
|
|
}
|
|
}
|
|
});
|
|
|
|
return defaultAppForm;
|
|
};
|