@shenghuabi/workflow 1.1.6 → 1.1.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.d.ts +1 -0
- package/index.js +54 -53
- package/index.js.map +4 -4
- package/index.mjs +44 -44
- package/index.mjs.map +4 -4
- package/inline/node/text/main/runner.d.ts +0 -1
- package/package.json +2 -2
- package/runner/runner-item.d.ts +3 -2
- package/test/util/text-input/main/runner.d.ts +0 -1
- package/{inline/node/chat/util → util}/useChat.d.ts +1 -1
package/index.d.ts
CHANGED
package/index.js
CHANGED
|
@@ -68,12 +68,13 @@ __export(workflow_exports, {
|
|
|
68
68
|
createResultData: () => createResultData,
|
|
69
69
|
flatFilterHandleList: () => flatFilterHandleList,
|
|
70
70
|
llmModelConfig: () => llmModelConfig,
|
|
71
|
-
serializeLexicalTextarea: () => serializeLexicalTextarea
|
|
71
|
+
serializeLexicalTextarea: () => serializeLexicalTextarea,
|
|
72
|
+
useChat: () => useChat
|
|
72
73
|
});
|
|
73
74
|
module.exports = __toCommonJS(workflow_exports);
|
|
74
75
|
|
|
75
76
|
// packages/workflow/workflow-parser.service.ts
|
|
76
|
-
var
|
|
77
|
+
var import_static_injector11 = require("static-injector");
|
|
77
78
|
var import_graphology = __toESM(require("graphology"), 1);
|
|
78
79
|
var import_react = require("@xyflow/react");
|
|
79
80
|
|
|
@@ -560,16 +561,17 @@ var import_compat = require("es-toolkit/compat");
|
|
|
560
561
|
var NodeRunnerBase = class {
|
|
561
562
|
node = (0, import_static_injector3.inject)(CurrentNodeToken);
|
|
562
563
|
callNode = (0, import_static_injector3.inject)(CurrentCallNodeToken, { optional: true }) ?? void 0;
|
|
563
|
-
|
|
564
|
+
runnerContext = (0, import_static_injector3.inject)(CurrentContextToken);
|
|
564
565
|
injector = (0, import_static_injector3.inject)(import_static_injector3.Injector);
|
|
565
566
|
emitter = (0, import_static_injector3.inject)(WorkflowEmitter);
|
|
566
567
|
abortSignal = (0, import_static_injector3.inject)(AbortSignalToken);
|
|
567
568
|
inputs = (0, import_static_injector3.inject)(NodeInputsToken);
|
|
569
|
+
environmentContextData = (0, import_static_injector3.inject)(EnviromentParametersToken);
|
|
568
570
|
async run() {
|
|
569
571
|
throw new Error("待实现");
|
|
570
572
|
}
|
|
571
573
|
#modelConfig = (0, import_static_injector3.inject)(ModelOptionsToken, { optional: true }) ?? void 0;
|
|
572
|
-
|
|
574
|
+
nodeContextData$$ = (0, import_static_injector3.computed)(() => this.injector.get(NodeContextToken)());
|
|
573
575
|
mergeChatModel(input) {
|
|
574
576
|
const chatService = this.injector.get(ChatServiceToken);
|
|
575
577
|
let presetConfig = {};
|
|
@@ -702,7 +704,7 @@ var TemplateFormatService = class extends import_static_injector4.RootStaticInje
|
|
|
702
704
|
// packages/workflow/inline/node/chat/main/runner.ts
|
|
703
705
|
var import_util3 = require("@cyia/util");
|
|
704
706
|
|
|
705
|
-
// packages/workflow/
|
|
707
|
+
// packages/workflow/util/useChat.ts
|
|
706
708
|
var import_static_injector5 = require("static-injector");
|
|
707
709
|
|
|
708
710
|
// packages/workflow/util/serialize-text-template.ts
|
|
@@ -725,7 +727,7 @@ function serializeLexicalTextarea(input, options) {
|
|
|
725
727
|
}).trim();
|
|
726
728
|
}
|
|
727
729
|
|
|
728
|
-
// packages/workflow/
|
|
730
|
+
// packages/workflow/util/useChat.ts
|
|
729
731
|
function useChat() {
|
|
730
732
|
const contextProvider = (0, import_static_injector5.inject)(NodeContextToken);
|
|
731
733
|
const environmentContext = (0, import_static_injector5.inject)(EnviromentParametersToken);
|
|
@@ -916,16 +918,14 @@ var TEXT_NODE_DEFINE = v7.object({
|
|
|
916
918
|
});
|
|
917
919
|
|
|
918
920
|
// packages/workflow/inline/node/text/main/runner.ts
|
|
919
|
-
var import_static_injector7 = require("static-injector");
|
|
920
921
|
var TextareaRunner = class extends NodeRunnerBase {
|
|
921
|
-
environmentContext = (0, import_static_injector7.inject)(EnviromentParametersToken);
|
|
922
922
|
async run() {
|
|
923
923
|
return async () => {
|
|
924
924
|
let metadataList;
|
|
925
|
-
const context = await this.
|
|
925
|
+
const context = await this.nodeContextData$$();
|
|
926
926
|
const value = serializeLexicalTextarea(this.inputs.value, {
|
|
927
927
|
context,
|
|
928
|
-
environmentContext: this.
|
|
928
|
+
environmentContext: this.environmentContextData,
|
|
929
929
|
onMetadata(metadata) {
|
|
930
930
|
metadataList = metadata;
|
|
931
931
|
}
|
|
@@ -979,12 +979,12 @@ var ITERATION_NODE_DEFINE = v8.pipe(
|
|
|
979
979
|
);
|
|
980
980
|
|
|
981
981
|
// packages/workflow/runner/workflow-runner.service.ts
|
|
982
|
-
var
|
|
982
|
+
var import_static_injector9 = require("static-injector");
|
|
983
983
|
|
|
984
984
|
// packages/workflow/inline/node/input-params/main/runner.ts
|
|
985
|
-
var
|
|
985
|
+
var import_static_injector7 = require("static-injector");
|
|
986
986
|
var InputParamsRunner = class extends NodeRunnerBase {
|
|
987
|
-
#env = (0,
|
|
987
|
+
#env = (0, import_static_injector7.inject)(EnviromentParametersToken);
|
|
988
988
|
async run() {
|
|
989
989
|
const data = this.#env;
|
|
990
990
|
return async (id) => {
|
|
@@ -1000,9 +1000,9 @@ var InputParamsRunner = class extends NodeRunnerBase {
|
|
|
1000
1000
|
};
|
|
1001
1001
|
|
|
1002
1002
|
// packages/workflow/inline/node/iteration/main/iteration-start.runner.ts
|
|
1003
|
-
var
|
|
1003
|
+
var import_static_injector8 = require("static-injector");
|
|
1004
1004
|
var IterationStartRunner = class extends NodeRunnerBase {
|
|
1005
|
-
#nodeParentMap = (0,
|
|
1005
|
+
#nodeParentMap = (0, import_static_injector8.inject)(NodeParentMapToken);
|
|
1006
1006
|
async run() {
|
|
1007
1007
|
const data = this.#nodeParentMap.get(this.node.parentId);
|
|
1008
1008
|
return async (id) => {
|
|
@@ -1051,15 +1051,15 @@ var v9 = __toESM(require("valibot"), 1);
|
|
|
1051
1051
|
var import_util4 = require("@cyia/util");
|
|
1052
1052
|
var import_fast_equals = require("fast-equals");
|
|
1053
1053
|
var WorkflowRunnerContext = class {
|
|
1054
|
-
#injector = (0,
|
|
1055
|
-
data = (0,
|
|
1056
|
-
parent = (0,
|
|
1054
|
+
#injector = (0, import_static_injector9.inject)(import_static_injector9.Injector);
|
|
1055
|
+
data = (0, import_static_injector9.inject)(CurrentWorkflowToken);
|
|
1056
|
+
parent = (0, import_static_injector9.inject)(ParentContextToken);
|
|
1057
1057
|
#callCache = /* @__PURE__ */ new Map();
|
|
1058
1058
|
#outputCache = /* @__PURE__ */ new Map();
|
|
1059
|
-
inputs = (0,
|
|
1060
|
-
#plugin = (0,
|
|
1061
|
-
#emitter = (0,
|
|
1062
|
-
#inlineNode = (0,
|
|
1059
|
+
inputs = (0, import_static_injector9.inject)(InputsToken);
|
|
1060
|
+
#plugin = (0, import_static_injector9.inject)(WorkflowPluginService);
|
|
1061
|
+
#emitter = (0, import_static_injector9.inject)(WorkflowEmitter);
|
|
1062
|
+
#inlineNode = (0, import_static_injector9.inject)(InlineNodeService);
|
|
1063
1063
|
async #getNodeRunner(type) {
|
|
1064
1064
|
return this.#inlineNode.getNodeRunner(type) ?? ItemRunnerObject[type] ?? await this.#plugin.getNodeRunner(type);
|
|
1065
1065
|
}
|
|
@@ -1097,7 +1097,7 @@ var WorkflowRunnerContext = class {
|
|
|
1097
1097
|
// 当前node 调用 node context
|
|
1098
1098
|
async #createNodeRunner(item, inputParams, contextFactory, callNode) {
|
|
1099
1099
|
const define = await this.#getNodeRunner(item.type);
|
|
1100
|
-
return (0,
|
|
1100
|
+
return (0, import_static_injector9.createInjector)({
|
|
1101
1101
|
providers: [
|
|
1102
1102
|
define,
|
|
1103
1103
|
{ provide: CurrentNodeToken, useValue: item },
|
|
@@ -1111,7 +1111,7 @@ var WorkflowRunnerContext = class {
|
|
|
1111
1111
|
parent: this.#injector
|
|
1112
1112
|
}).get(define);
|
|
1113
1113
|
}
|
|
1114
|
-
#abort = (0,
|
|
1114
|
+
#abort = (0, import_static_injector9.inject)(AbortSignalToken);
|
|
1115
1115
|
async #runItem(node, callNode, input) {
|
|
1116
1116
|
try {
|
|
1117
1117
|
if (this.#abort?.aborted) {
|
|
@@ -1228,12 +1228,12 @@ var WorkflowRunnerContext = class {
|
|
|
1228
1228
|
}
|
|
1229
1229
|
};
|
|
1230
1230
|
var WorkflowRunnerService = class {
|
|
1231
|
-
#injector = (0,
|
|
1231
|
+
#injector = (0, import_static_injector9.inject)(import_static_injector9.Injector);
|
|
1232
1232
|
/** 自己使用
|
|
1233
1233
|
* @internal
|
|
1234
1234
|
*/
|
|
1235
1235
|
createContext(data, parent, parentInjector) {
|
|
1236
|
-
return (0,
|
|
1236
|
+
return (0, import_static_injector9.createInjector)({
|
|
1237
1237
|
providers: [
|
|
1238
1238
|
WorkflowRunnerContext,
|
|
1239
1239
|
{ provide: CurrentWorkflowToken, useValue: data },
|
|
@@ -1248,7 +1248,7 @@ var WorkflowRunnerService = class {
|
|
|
1248
1248
|
}
|
|
1249
1249
|
/** 入口 */
|
|
1250
1250
|
run(wofkflowData, input, ob, signal2, providers) {
|
|
1251
|
-
const injector = (0,
|
|
1251
|
+
const injector = (0, import_static_injector9.createInjector)({
|
|
1252
1252
|
providers: [
|
|
1253
1253
|
WorkflowEmitter,
|
|
1254
1254
|
{ provide: AbortSignalToken, useValue: signal2 },
|
|
@@ -1272,9 +1272,9 @@ var WorkflowRunnerService = class {
|
|
|
1272
1272
|
|
|
1273
1273
|
// packages/workflow/inline/node/iteration/main/runner.ts
|
|
1274
1274
|
var import_util5 = require("@cyia/util");
|
|
1275
|
-
var
|
|
1275
|
+
var import_static_injector10 = require("static-injector");
|
|
1276
1276
|
var IterationRunner = class extends NodeRunnerBase {
|
|
1277
|
-
#nodeParentMap = (0,
|
|
1277
|
+
#nodeParentMap = (0, import_static_injector10.inject)(NodeParentMapToken);
|
|
1278
1278
|
async run() {
|
|
1279
1279
|
const inputs = this.inputs;
|
|
1280
1280
|
const value = inputs.list;
|
|
@@ -1290,7 +1290,7 @@ var IterationRunner = class extends NodeRunnerBase {
|
|
|
1290
1290
|
await this.injector.get(WorkflowRunnerService).createContext(
|
|
1291
1291
|
//迭代只有一个子流
|
|
1292
1292
|
this.node.subFlowList[0].flow,
|
|
1293
|
-
this.
|
|
1293
|
+
this.runnerContext,
|
|
1294
1294
|
this.injector
|
|
1295
1295
|
).run()
|
|
1296
1296
|
);
|
|
@@ -1498,7 +1498,7 @@ var NodeGroup = class {
|
|
|
1498
1498
|
return this.#group.get(type) || [];
|
|
1499
1499
|
}
|
|
1500
1500
|
};
|
|
1501
|
-
var WorkflowDataToken = new
|
|
1501
|
+
var WorkflowDataToken = new import_static_injector11.InjectionToken(
|
|
1502
1502
|
"WorkflowData"
|
|
1503
1503
|
);
|
|
1504
1504
|
var WorkflowPreParser = class {
|
|
@@ -1511,17 +1511,17 @@ var WorkflowPreParser = class {
|
|
|
1511
1511
|
* 所有独立块都是找到独立节点后终止
|
|
1512
1512
|
*/
|
|
1513
1513
|
#nodeGroup = new NodeGroup();
|
|
1514
|
-
#data = (0,
|
|
1515
|
-
#plugin = (0,
|
|
1516
|
-
#inlineNodeService = (0,
|
|
1517
|
-
#fullBlockObject$$ = (0,
|
|
1514
|
+
#data = (0, import_static_injector11.inject)(WorkflowDataToken);
|
|
1515
|
+
#plugin = (0, import_static_injector11.inject)(WorkflowPluginService);
|
|
1516
|
+
#inlineNodeService = (0, import_static_injector11.inject)(InlineNodeService);
|
|
1517
|
+
#fullBlockObject$$ = (0, import_static_injector11.computed)(
|
|
1518
1518
|
() => ({
|
|
1519
1519
|
...this.#inlineNodeService.conditionNodeList(),
|
|
1520
1520
|
...this.#plugin.conditionNodeList$$(),
|
|
1521
1521
|
["iteration" /* iteration */]: true
|
|
1522
1522
|
})
|
|
1523
1523
|
);
|
|
1524
|
-
#conditionBlockObject$$ = (0,
|
|
1524
|
+
#conditionBlockObject$$ = (0, import_static_injector11.computed)(
|
|
1525
1525
|
() => ({
|
|
1526
1526
|
...this.#inlineNodeService.conditionNodeList(),
|
|
1527
1527
|
...this.#plugin.conditionNodeList$$()
|
|
@@ -1613,8 +1613,8 @@ var WorkflowPreParser = class {
|
|
|
1613
1613
|
}
|
|
1614
1614
|
};
|
|
1615
1615
|
var WorkflowParserService = class {
|
|
1616
|
-
#injector = (0,
|
|
1617
|
-
#inlineNode = (0,
|
|
1616
|
+
#injector = (0, import_static_injector11.inject)(import_static_injector11.Injector);
|
|
1617
|
+
#inlineNode = (0, import_static_injector11.inject)(InlineNodeService);
|
|
1618
1618
|
constructor() {
|
|
1619
1619
|
this.#inlineNode.register(index_node_exports);
|
|
1620
1620
|
}
|
|
@@ -1627,7 +1627,7 @@ var WorkflowParserService = class {
|
|
|
1627
1627
|
*
|
|
1628
1628
|
*/
|
|
1629
1629
|
parse(data) {
|
|
1630
|
-
const injector = (0,
|
|
1630
|
+
const injector = (0, import_static_injector11.createInjector)({
|
|
1631
1631
|
providers: [
|
|
1632
1632
|
WorkflowPreParser,
|
|
1633
1633
|
{ provide: WorkflowDataToken, useValue: data }
|
|
@@ -1653,14 +1653,14 @@ var WorkflowParserService = class {
|
|
|
1653
1653
|
};
|
|
1654
1654
|
|
|
1655
1655
|
// packages/workflow/workflow-exec.service.ts
|
|
1656
|
-
var
|
|
1656
|
+
var import_static_injector13 = require("static-injector");
|
|
1657
1657
|
var import_rxjs3 = require("rxjs");
|
|
1658
1658
|
|
|
1659
1659
|
// packages/workflow/preset/context-build.service.ts
|
|
1660
|
-
var
|
|
1660
|
+
var import_static_injector12 = require("static-injector");
|
|
1661
1661
|
var ContextBuildService = class {
|
|
1662
|
-
template = (0,
|
|
1663
|
-
parser = (0,
|
|
1662
|
+
template = (0, import_static_injector12.inject)(TemplateFormatService);
|
|
1663
|
+
parser = (0, import_static_injector12.inject)(WorkflowParserService);
|
|
1664
1664
|
createWorkflow(input) {
|
|
1665
1665
|
const result = this.template.parse(
|
|
1666
1666
|
input.template.flatMap(
|
|
@@ -1695,8 +1695,8 @@ var ContextBuildService = class {
|
|
|
1695
1695
|
|
|
1696
1696
|
// packages/workflow/workflow-exec.service.ts
|
|
1697
1697
|
var WorkflowExecService = class {
|
|
1698
|
-
#parser = (0,
|
|
1699
|
-
#runner = (0,
|
|
1698
|
+
#parser = (0, import_static_injector13.inject)(WorkflowParserService);
|
|
1699
|
+
#runner = (0, import_static_injector13.inject)(WorkflowRunnerService);
|
|
1700
1700
|
parse(data) {
|
|
1701
1701
|
return this.#parser.parse(data);
|
|
1702
1702
|
}
|
|
@@ -1730,7 +1730,7 @@ var WorkflowExecService = class {
|
|
|
1730
1730
|
throw error;
|
|
1731
1731
|
}
|
|
1732
1732
|
}
|
|
1733
|
-
#contextBuild = (0,
|
|
1733
|
+
#contextBuild = (0, import_static_injector13.inject)(ContextBuildService);
|
|
1734
1734
|
async agentChat(input, fn, abort) {
|
|
1735
1735
|
const workflow = this.#contextBuild.createWorkflow(input);
|
|
1736
1736
|
const subject = new import_rxjs3.Subject();
|
|
@@ -1754,15 +1754,15 @@ var WorkflowExecService = class {
|
|
|
1754
1754
|
};
|
|
1755
1755
|
|
|
1756
1756
|
// packages/workflow/workflow-select.service.ts
|
|
1757
|
-
var
|
|
1757
|
+
var import_static_injector15 = require("static-injector");
|
|
1758
1758
|
var import_vfs22 = require("@cyia/vfs2");
|
|
1759
1759
|
|
|
1760
1760
|
// packages/workflow/workflow-file.service.ts
|
|
1761
|
-
var
|
|
1761
|
+
var import_static_injector14 = require("static-injector");
|
|
1762
1762
|
var import_vfs2 = require("@cyia/vfs2");
|
|
1763
1763
|
var import_bundle_file = require("@cyia/bundle-file");
|
|
1764
1764
|
var WorkflowFileService = class {
|
|
1765
|
-
#config = (0,
|
|
1765
|
+
#config = (0, import_static_injector14.inject)(WorkflowConfigToken);
|
|
1766
1766
|
#fileMap = /* @__PURE__ */ new Map();
|
|
1767
1767
|
getFile(filePath) {
|
|
1768
1768
|
const nFilePath = import_vfs2.path.normalize(filePath);
|
|
@@ -1796,9 +1796,9 @@ var WorkflowFileService = class {
|
|
|
1796
1796
|
|
|
1797
1797
|
// packages/workflow/workflow-select.service.ts
|
|
1798
1798
|
var WorkflowSelectService = class {
|
|
1799
|
-
#fileService = (0,
|
|
1800
|
-
#config = (0,
|
|
1801
|
-
#vfs = (0,
|
|
1799
|
+
#fileService = (0, import_static_injector15.inject)(WorkflowFileService);
|
|
1800
|
+
#config = (0, import_static_injector15.inject)(WorkflowConfigToken);
|
|
1801
|
+
#vfs = (0, import_static_injector15.computed)(
|
|
1802
1802
|
() => (0, import_vfs22.createNormalizeVfs)({
|
|
1803
1803
|
dir: this.#config().dir
|
|
1804
1804
|
})
|
|
@@ -1887,6 +1887,7 @@ var WORKFLOW_MODULE = {
|
|
|
1887
1887
|
createResultData,
|
|
1888
1888
|
flatFilterHandleList,
|
|
1889
1889
|
llmModelConfig,
|
|
1890
|
-
serializeLexicalTextarea
|
|
1890
|
+
serializeLexicalTextarea,
|
|
1891
|
+
useChat
|
|
1891
1892
|
});
|
|
1892
1893
|
//# sourceMappingURL=index.js.map
|