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

* Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * perf: workflow ux * system config * Newflow (#89) * docs: Add doc for Xinference (#1266) Signed-off-by: Carson Yang <yangchuansheng33@gmail.com> * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * perf: workflow ux * system config * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * rename code * move code * update flow * input type selector * perf: workflow runtime * feat: node adapt newflow * feat: adapt plugin * feat: 360 connection * check workflow * perf: flow 性能 * change plugin input type (#81) * change plugin input type * plugin label mode * perf: nodecard * debug * perf: debug ui * connection ui * change workflow ui (#82) * feat: workflow debug * adapt openAPI for new workflow (#83) * adapt openAPI for new workflow * i18n * perf: plugin debug * plugin input ui * delete * perf: global variable select * fix rebase * perf: workflow performance * feat: input render type icon * input icon * adapt flow (#84) * adapt newflow * temp * temp * fix * feat: app schedule trigger * feat: app schedule trigger * perf: schedule ui * feat: ioslatevm run js code * perf: workflow varialbe table ui * feat: adapt simple mode * feat: adapt input params * output * feat: adapt tamplate * fix: ts * add if-else module (#86) * perf: worker * if else node * perf: tiktoken worker * fix: ts * perf: tiktoken * fix if-else node (#87) * fix if-else node * type * fix * perf: audio render * perf: Parallel worker * log * perf: if else node * adapt plugin * prompt * perf: reference ui * reference ui * handle ux * template ui and plugin tool * adapt v1 workflow * adapt v1 workflow completions * perf: time variables * feat: workflow keyboard shortcuts * adapt v1 workflow * update workflow example doc (#88) * fix: simple mode select tool --------- Signed-off-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com> * doc * perf: extract node * extra node field * update plugin version * doc * variable * change doc & fix prompt editor (#90) * fold workflow code * value type label --------- Signed-off-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
135 lines
4.1 KiB
TypeScript
135 lines
4.1 KiB
TypeScript
import { FlowNodeOutputTypeEnum, FlowNodeTypeEnum } from './node/constant';
|
|
import {
|
|
WorkflowIOValueTypeEnum,
|
|
NodeInputKeyEnum,
|
|
VariableInputEnum,
|
|
variableMap
|
|
} from './constants';
|
|
import { FlowNodeInputItemType, FlowNodeOutputItemType } from './type/io.d';
|
|
import { StoreNodeItemType } from './type';
|
|
import type {
|
|
VariableItemType,
|
|
AppTTSConfigType,
|
|
AppWhisperConfigType,
|
|
AppScheduledTriggerConfigType
|
|
} from '../app/type';
|
|
import { EditorVariablePickerType } from '../../../web/components/common/Textarea/PromptEditor/type';
|
|
import { defaultWhisperConfig } from '../app/constants';
|
|
|
|
export const getHandleId = (nodeId: string, type: 'source' | 'target', key: string) => {
|
|
return `${nodeId}-${type}-${key}`;
|
|
};
|
|
|
|
export const checkInputIsReference = (input: FlowNodeInputItemType) => {
|
|
const value = input.value;
|
|
if (
|
|
Array.isArray(value) &&
|
|
value.length === 2 &&
|
|
typeof value[0] === 'string' &&
|
|
typeof value[1] === 'string'
|
|
) {
|
|
return true;
|
|
}
|
|
return false;
|
|
};
|
|
|
|
/* node */
|
|
export const getGuideModule = (modules: StoreNodeItemType[]) =>
|
|
modules.find((item) => item.flowNodeType === FlowNodeTypeEnum.systemConfig);
|
|
|
|
export const splitGuideModule = (guideModules?: StoreNodeItemType) => {
|
|
const welcomeText: string =
|
|
guideModules?.inputs?.find((item) => item.key === NodeInputKeyEnum.welcomeText)?.value || '';
|
|
|
|
const variableModules: VariableItemType[] =
|
|
guideModules?.inputs.find((item) => item.key === NodeInputKeyEnum.variables)?.value || [];
|
|
|
|
const questionGuide: boolean =
|
|
!!guideModules?.inputs?.find((item) => item.key === NodeInputKeyEnum.questionGuide)?.value ||
|
|
false;
|
|
|
|
const ttsConfig: AppTTSConfigType = guideModules?.inputs?.find(
|
|
(item) => item.key === NodeInputKeyEnum.tts
|
|
)?.value || { type: 'web' };
|
|
|
|
const whisperConfig: AppWhisperConfigType =
|
|
guideModules?.inputs?.find((item) => item.key === NodeInputKeyEnum.whisper)?.value ||
|
|
defaultWhisperConfig;
|
|
|
|
const scheduledTriggerConfig: AppScheduledTriggerConfigType | null =
|
|
guideModules?.inputs?.find((item) => item.key === NodeInputKeyEnum.scheduleTrigger)?.value ??
|
|
null;
|
|
|
|
return {
|
|
welcomeText,
|
|
variableModules,
|
|
questionGuide,
|
|
ttsConfig,
|
|
whisperConfig,
|
|
scheduledTriggerConfig
|
|
};
|
|
};
|
|
|
|
export const getOrInitModuleInputValue = (input: FlowNodeInputItemType) => {
|
|
if (input.value !== undefined || !input.valueType) return input.value;
|
|
|
|
const map: Record<string, any> = {
|
|
[WorkflowIOValueTypeEnum.boolean]: false,
|
|
[WorkflowIOValueTypeEnum.number]: 0,
|
|
[WorkflowIOValueTypeEnum.string]: ''
|
|
};
|
|
|
|
return map[input.valueType];
|
|
};
|
|
|
|
export const getModuleInputUiField = (input: FlowNodeInputItemType) => {
|
|
// if (input.renderTypeList === FlowNodeInputTypeEnum.input || input.type === FlowNodeInputTypeEnum.textarea) {
|
|
// return {
|
|
// placeholder: input.placeholder || input.description
|
|
// };
|
|
// }
|
|
return {};
|
|
};
|
|
|
|
export const pluginData2FlowNodeIO = (
|
|
nodes: StoreNodeItemType[]
|
|
): {
|
|
inputs: FlowNodeInputItemType[];
|
|
outputs: FlowNodeOutputItemType[];
|
|
} => {
|
|
const pluginInput = nodes.find((node) => node.flowNodeType === FlowNodeTypeEnum.pluginInput);
|
|
const pluginOutput = nodes.find((node) => node.flowNodeType === FlowNodeTypeEnum.pluginOutput);
|
|
|
|
return {
|
|
inputs: pluginInput
|
|
? pluginInput.inputs.map((item) => ({
|
|
...item,
|
|
...getModuleInputUiField(item),
|
|
value: getOrInitModuleInputValue(item),
|
|
canEdit: false
|
|
}))
|
|
: [],
|
|
outputs: pluginOutput
|
|
? [
|
|
...pluginOutput.inputs.map((item) => ({
|
|
id: item.key,
|
|
type: FlowNodeOutputTypeEnum.static,
|
|
key: item.key,
|
|
valueType: item.valueType,
|
|
label: item.label || item.key,
|
|
description: item.description
|
|
}))
|
|
]
|
|
: []
|
|
};
|
|
};
|
|
|
|
export const formatEditorVariablePickerIcon = (
|
|
variables: { key: string; label: string; type?: `${VariableInputEnum}` }[]
|
|
): EditorVariablePickerType[] => {
|
|
return variables.map((item) => ({
|
|
...item,
|
|
icon: item.type ? variableMap[item.type]?.icon : variableMap['input'].icon
|
|
}));
|
|
};
|