@babsey/code-graph 0.0.4 → 0.0.6

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.
@@ -1722,10 +1722,10 @@ const DEFAULT_SETTINGS = {
1722
1722
  },
1723
1723
  displayValueOnHover: false
1724
1724
  };
1725
- function useCodeGraph(existingEditor) {
1726
- const viewModel = useBaklava(existingEditor);
1725
+ function useCodeGraph(props) {
1726
+ const viewModel = useBaklava(props?.existingEditor);
1727
+ viewModel.code = props?.code ? new props.code(viewModel) : new Code(viewModel);
1727
1728
  addToolbarCommands(viewModel);
1728
- viewModel.code = new Code(viewModel);
1729
1729
  const settings = {};
1730
1730
  Object.keys(DEFAULT_SETTINGS).forEach((K) => {
1731
1731
  settings[K] = typeof DEFAULT_SETTINGS[K] === "object" ? { ...viewModel.settings[K], ...DEFAULT_SETTINGS[K] } : DEFAULT_SETTINGS[K];
@@ -1743,17 +1743,21 @@ function useCodeGraph(existingEditor) {
1743
1743
  viewModel.displayedGraph.events.addNode.subscribe(token, (node) => node.code = viewModel.code);
1744
1744
  viewModel.engine.events.beforeRun.subscribe(token, () => {
1745
1745
  viewModel.engine.pause();
1746
- viewModel.code.onCodeUpdate();
1747
- viewModel.code.sortNodes();
1748
- viewModel.code.updateOutputVariableNames();
1746
+ if (viewModel.code) {
1747
+ viewModel.code.onCodeUpdate();
1748
+ viewModel.code.sortNodes();
1749
+ viewModel.code.updateOutputVariableNames();
1750
+ }
1749
1751
  viewModel.engine.resume();
1750
1752
  });
1751
1753
  viewModel.engine.events.afterRun.subscribe(token, (result) => {
1752
1754
  viewModel.engine.pause();
1753
1755
  applyResult(result, viewModel.editor);
1754
1756
  transferCodeScript(viewModel.displayedGraph);
1755
- viewModel.code.renderNodeCodes();
1756
- viewModel.code.renderCode();
1757
+ if (viewModel.code) {
1758
+ viewModel.code.renderNodeCodes();
1759
+ viewModel.code.renderCode();
1760
+ }
1757
1761
  viewModel.engine.resume();
1758
1762
  });
1759
1763
  viewModel.state.token = token;
@@ -1719,10 +1719,10 @@
1719
1719
  },
1720
1720
  displayValueOnHover: false
1721
1721
  };
1722
- function useCodeGraph(existingEditor) {
1723
- const viewModel = baklavajs.useBaklava(existingEditor);
1722
+ function useCodeGraph(props) {
1723
+ const viewModel = baklavajs.useBaklava(props?.existingEditor);
1724
+ viewModel.code = props?.code ? new props.code(viewModel) : new Code(viewModel);
1724
1725
  addToolbarCommands(viewModel);
1725
- viewModel.code = new Code(viewModel);
1726
1726
  const settings = {};
1727
1727
  Object.keys(DEFAULT_SETTINGS).forEach((K) => {
1728
1728
  settings[K] = typeof DEFAULT_SETTINGS[K] === "object" ? { ...viewModel.settings[K], ...DEFAULT_SETTINGS[K] } : DEFAULT_SETTINGS[K];
@@ -1740,17 +1740,21 @@
1740
1740
  viewModel.displayedGraph.events.addNode.subscribe(token, (node) => node.code = viewModel.code);
1741
1741
  viewModel.engine.events.beforeRun.subscribe(token, () => {
1742
1742
  viewModel.engine.pause();
1743
- viewModel.code.onCodeUpdate();
1744
- viewModel.code.sortNodes();
1745
- viewModel.code.updateOutputVariableNames();
1743
+ if (viewModel.code) {
1744
+ viewModel.code.onCodeUpdate();
1745
+ viewModel.code.sortNodes();
1746
+ viewModel.code.updateOutputVariableNames();
1747
+ }
1746
1748
  viewModel.engine.resume();
1747
1749
  });
1748
1750
  viewModel.engine.events.afterRun.subscribe(token, (result) => {
1749
1751
  viewModel.engine.pause();
1750
1752
  baklavajs.applyResult(result, viewModel.editor);
1751
1753
  transferCodeScript(viewModel.displayedGraph);
1752
- viewModel.code.renderNodeCodes();
1753
- viewModel.code.renderCode();
1754
+ if (viewModel.code) {
1755
+ viewModel.code.renderNodeCodes();
1756
+ viewModel.code.renderCode();
1757
+ }
1754
1758
  viewModel.engine.resume();
1755
1759
  });
1756
1760
  viewModel.state.token = token;
@@ -2,7 +2,7 @@ import { DependencyEngine, Editor, IBaklavaViewModel } from 'baklavajs';
2
2
  import { UnwrapRef } from 'vue';
3
3
  import { Code } from './code';
4
4
  export interface ICodeGraphViewModel extends IBaklavaViewModel {
5
- code: Code;
5
+ code: Code | undefined;
6
6
  engine: DependencyEngine;
7
7
  state: UnwrapRef<{
8
8
  modules: Record<string, string>;
@@ -11,4 +11,7 @@ export interface ICodeGraphViewModel extends IBaklavaViewModel {
11
11
  subscribe: () => void;
12
12
  unsubscribe: () => void;
13
13
  }
14
- export declare function useCodeGraph(existingEditor?: Editor): ICodeGraphViewModel;
14
+ export declare function useCodeGraph(props?: {
15
+ existingEditor?: Editor;
16
+ code?: new (viewModel: ICodeGraphViewModel) => Code;
17
+ }): ICodeGraphViewModel;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@babsey/code-graph",
3
- "version": "0.0.4",
3
+ "version": "0.0.6",
4
4
  "author": "babsey <spreizer@web.de>",
5
5
  "license": "MIT",
6
6
  "type": "module",