Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pb10005/diagram-vue
A editable SVG-based diagram component for Vue
https://github.com/pb10005/diagram-vue
bezier diagram diagram-vue json svg vue-component vue2
Last synced: 4 months ago
JSON representation
A editable SVG-based diagram component for Vue
- Host: GitHub
- URL: https://github.com/pb10005/diagram-vue
- Owner: pb10005
- License: mit
- Created: 2018-12-27T07:47:44.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-10T14:51:17.000Z (about 2 years ago)
- Last Synced: 2024-08-09T02:25:14.345Z (6 months ago)
- Topics: bezier, diagram, diagram-vue, json, svg, vue-component, vue2
- Language: Vue
- Homepage: https://diagramvue.netlify.com
- Size: 3.46 MB
- Stars: 105
- Watchers: 4
- Forks: 32
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - pb10005/diagram-vue - A editable SVG-based diagram component for Vue (json)
README
# diagram-vue
A SVG-based diagram component for Vue[data:image/s3,"s3://crabby-images/7a1b2/7a1b2794c514cb32730ebe1d54b3e7651d515072" alt="Codacy Badge"](https://app.codacy.com/app/pb10001/diagram-vue?utm_source=github.com&utm_medium=referral&utm_content=pb10001/diagram-vue&utm_campaign=Badge_Grade_Dashboard)
[data:image/s3,"s3://crabby-images/f4bcc/f4bccab31c9ec059d034db07045d84fe4f85ecbc" alt="npm version"](https://badge.fury.io/js/diagram-vue)
data:image/s3,"s3://crabby-images/6dae5/6dae56d49b94d13cf858149684fa80b4e80db1d0" alt="npm"
data:image/s3,"s3://crabby-images/c2d91/c2d91f508fb9eb05eb3649edf824ae9dd4b7f7aa" alt="npm"[Demo](https://diagramvue.netlify.com/)
data:image/s3,"s3://crabby-images/9dced/9dced20ed8b180ddf25a9e91312c6c677416909e" alt="Screen shot"
## Installation
```sh
npm i diagram-vue --save
```
## Usage
[data:image/s3,"s3://crabby-images/30d34/30d34521f10c786f5cd9a38072d0f1491464ec1f" alt="Edit diagram-vue"](https://codesandbox.io/s/q7wj02ny2w)
### Ready-to-use editor
#### 1. Import
```js
import { DiagramEditor } from "diagram-vue";
import "diagram-vue/dist/diagram.css";
```
#### 2. Template
```html```
See [Data specification](https://github.com/pb10005/diagram-vue/blob/master/DATA_SPECIFICATION.md).### Customization
#### 1. Import
```js
import Diagram from 'diagram-vue';
import "diagram-vue/dist/diagram.css";
```
#### 2. Template
```html```
#### 3. Props
```js
props: {
width: Number,
height: Number,
background: String,
nodes: Array,
links: Array,
editable: Boolean,
labels: Object,
fluid: Boolean
}
```
See [Data specification](https://github.com/pb10005/diagram-vue/blob/master/DATA_SPECIFICATION.md).#### 4. Events
```js
editNode(node /* selected node */) {
/* event handler */
},
editLink(link /* selected link */) {
/* event handler */
},
nodeChanged(obj /* array of nodes */) {
/* event handler */
const nodes = obj.nodes
},
linkChanged(obj /* array of links */) {
/* event handler */
const links = obj.links
},
nodeRemoved(id /*Identifier of node*/){
/* event handler */
},
linkRemoved(id /*Identifier of link*/){
/* event handler */
},
nodeClicked(id /* identifier of node */) {
/* event handler */
console.log("your clicked in node: ", id)
},
linkClicked(id /* identifier of link */) {
/* event handler */
console.log("your clicked in link: ", id)
}
```#### 5. Get SVG as String
Use plain JavaScript.
```js
document.getElementById('svg-diagram-show-area').innerHTML; // ...
```## Development
### Development Environment
See [diagram-vue-dev-env](https://github.com/pb10005/diagram-vue-dev-env)## Project setup
```
yarn install
```### Compiles and hot-reloads for development
```
yarn run serve
```### Compiles and minifies for production
```
yarn run build
```### Run your tests
```
yarn run test
```### Lints and fixes files
```
yarn run lint
```### Run your end-to-end tests
```
yarn run test:e2e
```### Run your unit tests
```
yarn run test:unit
```### Customize configuration
See [Configuration Reference](https://cli.vuejs.org/config/).