Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/n-yousefi/Arg-Graph

a simple JQuery library to create or edit directed graphs.
https://github.com/n-yousefi/Arg-Graph

diagram directed-graphs flowchart free graph html javascript jquery svg

Last synced: 3 months ago
JSON representation

a simple JQuery library to create or edit directed graphs.

Awesome Lists containing this project

README

        

# Note: This repository is no longer in active development or maintenance.
# We highly encourage you to consider [connect-it](https://github.com/n-yousefi/connect-it) instead.

## Arg-Graph

[Arg](https://en.wikipedia.org/wiki/Arg_e_Bam)-Graph is a simple free library for creating dynamic Directed Graph using JQuery which enables you to draw SVG based connectors (lines, arrows) between DOM nodes via drag and drop.

![Directed Javascript graph](https://github.com/n-yousefi/Arg-Graph/blob/master/demo.png)
## Examples/Demos
The best way to become acquainted with the library is to see [Demos](https://n-yousefi.github.io/Arg-Graph/arg-graph-1.1/Example1.html)

## How it works
### Creating digraph:
You can create a digraph (directed graph) easily by calling the "ArgGraph" function.
```html



```
```javascript
var argGraph=$('.arg-Graph').ArgGraph();
```
### Adding new nodes:
#### Append html code
You can append new items to the container div, as html code. like this:
```html


Title




Title




```
Now you must refresh the graph by calling 'refresh' function.
```javascript
argGraph.refresh()
```
#### import new item/s
Creating a JavaScript object and import that to the graph:
```javascript
newItem = {
"id": "item1",
"text": "Start",
"position": {
"left": "259px",
"top": "22px"
},
"neighbors": [
"item2",
"item3"
]
}
argGraph.import(newItem)
```
Note: You can append multiple items as array object using "import" function.
#### import JSON object
You can import this object as JSON format by calling "importJson" function.
```javascript
var json=JSON.stringify(newItem,null,4);
argGraph.importJson(json);
```

### Output
By calling "export"/"exportJson" function you can get a JavaScript/JSON object similar to the import object format:
```javascript
var json = argGraph.exportJson();

result:
[
{
"id": "item7",
"text": "Test",
"position": {
"left": "531.328px",
"top": "406px"
},
"neighbors": [
"item8"
]
},
{
"id": "item8",
"text": "Deployment",
"position": {
"left": "373.328px",
"top": "463px"
},
"neighbors": [
"item9"
]
},
{
"id": "item9",
"text": "Test",
"position": {
"left": "239.328px",
"top": "515px"
},
"neighbors": ""
}
]
```

## Author
Naser Yousefi