@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 CHANGED
@@ -13,3 +13,4 @@ export * from './plugin/plugin.service';
13
13
  export * from './type/type';
14
14
  export * from './workflow-file.service';
15
15
  export * from './util/serialize-text-template';
16
+ export * from './util/useChat';
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 import_static_injector12 = require("static-injector");
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
- context = (0, import_static_injector3.inject)(CurrentContextToken);
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
- context$$ = (0, import_static_injector3.computed)(() => this.injector.get(NodeContextToken)());
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/inline/node/chat/util/useChat.ts
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/inline/node/chat/util/useChat.ts
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.context$$();
925
+ const context = await this.nodeContextData$$();
926
926
  const value = serializeLexicalTextarea(this.inputs.value, {
927
927
  context,
928
- environmentContext: this.environmentContext,
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 import_static_injector10 = require("static-injector");
982
+ var import_static_injector9 = require("static-injector");
983
983
 
984
984
  // packages/workflow/inline/node/input-params/main/runner.ts
985
- var import_static_injector8 = require("static-injector");
985
+ var import_static_injector7 = require("static-injector");
986
986
  var InputParamsRunner = class extends NodeRunnerBase {
987
- #env = (0, import_static_injector8.inject)(EnviromentParametersToken);
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 import_static_injector9 = require("static-injector");
1003
+ var import_static_injector8 = require("static-injector");
1004
1004
  var IterationStartRunner = class extends NodeRunnerBase {
1005
- #nodeParentMap = (0, import_static_injector9.inject)(NodeParentMapToken);
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, import_static_injector10.inject)(import_static_injector10.Injector);
1055
- data = (0, import_static_injector10.inject)(CurrentWorkflowToken);
1056
- parent = (0, import_static_injector10.inject)(ParentContextToken);
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, import_static_injector10.inject)(InputsToken);
1060
- #plugin = (0, import_static_injector10.inject)(WorkflowPluginService);
1061
- #emitter = (0, import_static_injector10.inject)(WorkflowEmitter);
1062
- #inlineNode = (0, import_static_injector10.inject)(InlineNodeService);
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, import_static_injector10.createInjector)({
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, import_static_injector10.inject)(AbortSignalToken);
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, import_static_injector10.inject)(import_static_injector10.Injector);
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, import_static_injector10.createInjector)({
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, import_static_injector10.createInjector)({
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 import_static_injector11 = require("static-injector");
1275
+ var import_static_injector10 = require("static-injector");
1276
1276
  var IterationRunner = class extends NodeRunnerBase {
1277
- #nodeParentMap = (0, import_static_injector11.inject)(NodeParentMapToken);
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.context,
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 import_static_injector12.InjectionToken(
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, import_static_injector12.inject)(WorkflowDataToken);
1515
- #plugin = (0, import_static_injector12.inject)(WorkflowPluginService);
1516
- #inlineNodeService = (0, import_static_injector12.inject)(InlineNodeService);
1517
- #fullBlockObject$$ = (0, import_static_injector12.computed)(
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, import_static_injector12.computed)(
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, import_static_injector12.inject)(import_static_injector12.Injector);
1617
- #inlineNode = (0, import_static_injector12.inject)(InlineNodeService);
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, import_static_injector12.createInjector)({
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 import_static_injector14 = require("static-injector");
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 import_static_injector13 = require("static-injector");
1660
+ var import_static_injector12 = require("static-injector");
1661
1661
  var ContextBuildService = class {
1662
- template = (0, import_static_injector13.inject)(TemplateFormatService);
1663
- parser = (0, import_static_injector13.inject)(WorkflowParserService);
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, import_static_injector14.inject)(WorkflowParserService);
1699
- #runner = (0, import_static_injector14.inject)(WorkflowRunnerService);
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, import_static_injector14.inject)(ContextBuildService);
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 import_static_injector16 = require("static-injector");
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 import_static_injector15 = require("static-injector");
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, import_static_injector15.inject)(WorkflowConfigToken);
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, import_static_injector16.inject)(WorkflowFileService);
1800
- #config = (0, import_static_injector16.inject)(WorkflowConfigToken);
1801
- #vfs = (0, import_static_injector16.computed)(
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