Please read the documentation https://vue-diagram-editor.js.org (includes demo)
The main purpose of this component is to make it possible to use any component within each node of the diagram.
- scoped-slot for node
- ripple (pulsable) node
- any number of instances per page
- customizable node color
- customizable node pulse color
It's recommended to install vue-diagram-editor via npm, and build your app using a bundler like webpack:
npm install vue-diagram-editorRequires Vue 2.6+
<template>
  <VueDiagramEditor
    ref="diagram"
    :node-color="nodeColor"
    :node-pulsable="nodePulsable"
  >
    <pre slot="node" slot-scope="{node}">{{ format(node) }}</pre>
  </VueDiagramEditor>
</template>
<script>
import VueDiagramEditor from 'vue-diagram-editor';
import 'vue-diagram-editor/dist/vue-diagram-editor.css';
export default {
  name: 'simple-example',
  components: {
    VueDiagramEditor
  },
  data: () => ({
    nodes: {
      'node-1': {
        id: 'node-1',
        title: 'My node 1',
        size: {
          width: 200,
          height: 220
        },
        portsOut: {
          default: 'out port default'
        }
      },
      'node-2': {
        id: 'node-2',
        title: 'My node 2',
        size: {
          width: 200,
          height: 220
        },
        coordinates: {
          x: 280,
          y: 100
        },
        portsIn: {
          default: 'in port'
        }
      },
    },
    links: {
      'link-1': {
        id: 'link-1',
        start_id: 'node-1',
        start_port: 'default',
        end_id: 'node-2',
        end_port: 'default'
      }
    }
  }),
  mounted() {
    this.init();
  },
  methods: {
    init() {
      this.$refs.diagram.setModel({
        nodes: this.nodes,
        links: this.links
      });
    },
    format(node) {
      return JSON.stringify(node, null, 2);
    },
    nodeColor(node) {
      if (node.coordinates.x > 200) {
        return '#0f0';
      }
      if (node.coordinates.y > 200) {
        return '#f00';
      }
      return '#00f';
    },
    nodePulsable(node) {
      return node.coordinates.y > 200;
    }
  }
};
</script>If you just don't want to use webpack or any other bundlers, you can simply include the standalone UMD build in your page. In this way, make sure Vue as a dependency is included before vue-diagram-editor.
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <script src="https://cdn.jsdelivr.net/npm/[email protected]"></script>
  <script src="https://cdn.jsdelivr.net/npm/vue-diagram-editor@^1/dist/vue-diagram-editor.umd.min.js"></script>
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/vue-diagram-editor@^1/dist/vue-diagram-editor.min.css">
</head>
<body>
  <div id="app">
    <diagram-editor ref="diagram"></diagram-editor>
  </div>
  <script>
    // register the component
    Vue.component('diagram-editor', VueDiagramEditor.Diagram);
    new Vue({
      el: '#app',
      data: {
        nodes: {
          'node-1': {
            id: 'node-1',
            title: 'My node 1',
            size: {
              width: 200,
              height: 220
            },
            portsOut: {
              default: ''
            }
          },
          'node-2': {
            id: 'node-2',
            title: 'My node 2',
            size: {
              width: 200,
              height: 220
            },
            coordinates: {
              x: 280,
              y: 100
            },
            portsIn: {
              default: 'in port'
            }
          },
        },
        links: {
          'link-1': {
            id: 'link-1',
            start_id: 'node-1',
            start_port: 'default',
            end_id: 'node-2',
            end_port: 'default'
          }
        }
      },
      mounted() {
        this.init();
      },
      methods: {
        init() {
          this.$refs.diagram.setModel({
            nodes: this.nodes,
            links: this.links
          });
        }
      }
    });
  </script>
</body>
</html>| Prop | Required | Default | Description | 
|---|---|---|---|
| id | no | generated ulid identifier | Unique identifier of node | 
| title | yes | - | Title of node | 
| coordinates | no | {x:10,y:10} | Node coordinates object. Must contain this two numerical properties: xandy | 
| size | no | {width:150, height:150} | Node size object. Must contain this two numerical properties: widthandheight | 
| portsIn | no | {} | The node's incoming ports object. Object keys are port names and values are port headers | 
| portsOut | no | {} | The node's outgoing ports object. Object keys are port names and values are port headers | 
| data | no | {} | Custom data object. May be useful when handling events | 
| Prop | Required | Type/Default | Description | 
|---|---|---|---|
| id | no | String / generated ulid identifier | Unique identifier of link | 
| start_id | yes | String / - | ID of the node from which this link starts | 
| start_port | no | String / "default" | The name of the outgoing port of the node from which this link begins | 
| end_id | yes | String / - | ID of the node where this link ends | 
| end_port | no | String / "default" | The name of the incoming port of the node where this link ends | 
| Name | Type / Default | Description | 
|---|---|---|
| height | Type: Number Default: 500 | Block height with Vue-Diagram-Editor | 
| zoomEnabled | Type: Boolean Default: true | Allows to scale the diagram | 
| nodeColor | Type: Function: String Default: node => "#66cc00" | The function takes object of Nodeas parameter and must return a string with a hexadecimal color representation. Avoid heavy computation in this function | 
| nodeDeletable | Type: Function: Boolean Default: node => true | Shows or hides the delete node button | 
| nodePulsable | Type: Function: Boolean Default: node => false | Enables or disables the ripple of a specific node. Avoid heavy computation in this function | 
| nodePulseColor | Type: Function: String Default: node => "#f00" | Determines the color of the node's ripple (in the case when nodePulsablereturnstrue). Avoid heavy computation in this function | 
| beforeDeleteNode | Type: Function: Boolean Default: node => true | In the case when the node is deletable, it is executed immediately before deleting. If the function returns false, the node is not deleted. Avoid heavy computation in this function | 
| beforeDeleteLink | Type: Function: Boolean Default: link => true | Executed immediately before the link is removed. If the function returns false, the link is not removed. Avoid heavy computation in this function | 
| portDisabled | Type: Function: Boolean Default: ({id,type,port}) => false | Determines if the port is blocked for communication. If the port is disabled, you will not be able to create a new link or click on it. Accepts an object with properties: id- node identifier,type- port type (inorout),port- port name | 
| portAvailable | Type: Function: Boolean Default: ({id,type,port,activePort}) => true | This function is executed at the moment of hovering to the port when a new link is creating. Accepts an object with properties: id- node identifier,type- port type (inorout),port- port nameactivePort- Object with the data of the starting port of the link being created | 
| preventMouseEventsDefault | Type: Boolean Default: true | Stops handling native events see | 
| Name | Params | Return | Description | 
|---|---|---|---|
| setModel(model) | model.nodes- Array or collection of node structure objectsmodel.links- Array or collection of link structure objects | void | The method completely re-initializes the diagram model | 
| serialize() | - | {nodes:[{...},{...}], links:[{...}]} | Method returns an object with arrays of nodes and links | 
| addNode(node) | node- node structure object | void | Method new node to the diagram model | 
| addLink(link) | link- link structure object | void | Method new link to the diagram model | 
| updateNode(params) | params.idnode IDparams.namenode property nameparams.valuenode property value | void | Update root property of node | 
| deleteNode(id) | id- node ID | void | the method simulates a click on the button to delete a node | 
| deleteLink(id) | id- link ID | void | the method lowers the deletion of the link. | 
| enableDblClickZoom() | - | void | see | 
| disableDblClickZoom() | - | void | see | 
| isDblClickZoomEnabled() | - | Boolean | see | 
| enableMouseWheelZoom() | - | void | see | 
| disableMouseWheelZoom() | - | void | see | 
| isMouseWheelZoomEnabled() | - | Boolean | see | 
| resetZoom() | - | void | see | 
| updateBBox() | - | void | see | 
| fit() | - | void | see | 
| contain() | - | void | see | 
| center() | - | void | see | 
| Name | Data | Description | 
|---|---|---|
| select-node | nodeId | When a node is selected, an event with the node identifier is emitted | 
| deleted-node | nodeId | When deleting a node, an event with the node identifier is emitted | 
| deleted-link | linkId | When deleting a link, an event with the identifier of the deleted link is emitted | 
| updated-node | Node | Updated node object | 
| click-port | { "id": "node-id", "type": "in", "port": "port_name" } | The event is emitted when a port is clicked. The event sends an object with a node identifier ( id), porttype(inorout) and port name | 
| created-link | Link | The event is emitted after creating a new link | 
Best way to contribute is to create a pull request. In order to create a pull request:
- Fork this repository
- Clone repository fork (created in previous step) locally (on your machine)
- Ensure that you have nodejs and npm installed locally
- In console:
- cdinto project folder
- npm install && npm run dev
 
- After change is done lint project npm run lint
- Commit only meaningful changes. Do not commit distribution files (dist folder). Distribution files are built only before a release
- Push your changes into your fork
- Create a pull request
