ngx-graph-new
Version:
Modify the ngx-chart version is used
125 lines (109 loc) • 3.4 kB
Markdown
//gitter.im/swimlane/ngx-graph](https://badges.gitter.im/swimlane/ngx-graph.svg)](https://gitter.im/swimlane/ngx-graph?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
A Graph visualization for angular
https://swimlane.github.io/ngx-graph/
* Custom templates for nodes and edges
* Automatic layout using [Dagre](https://github.com/cpettitt/dagre)
* Animations
This library is focused on handling graph data (anything with nodes and edges) rather than chart data. Currently the only visualization uses the Dagre layout, which is specialized for directed graphs. The plan is to implement multiple visualisations for graph data within this same library. Eventually, `ngx-charts-force-directed-graph` may be imported into this library as another option to visualize your graph data.
## Installation
1. `npm install @swimlane/ngx-graph --save`
2. Make sure the peer dependencies are installed (d3)
3. Import `NgxGraphModule` into your module
4. Use the `ngx-graph` component in your components
```
<ngx-graph
class="chart-container"
[ ]="view"
[ ]="showLegend"
[ ]="hierarchialGraph.links"
(legendLabelClick)="onLegendLabelClick($event)"
[ ]="hierarchialGraph.nodes"
[ ]="colorScheme"
[ ]="orientation"
[ ]="curve"
(select)="select($event)">
<ng-template
<svg:marker id="arrow" viewBox="0 -5 10 10" refX="8" refY="0" markerWidth="4" markerHeight="4" orient="auto">
<svg:path d="M0,-5L10,0L0,5" class="arrow-head" />
</svg:marker>
</ng-template>
<ng-template
<svg:g class="node"
ngx-tooltip
[ ]="'top'"
[ ]="'tooltip'"
[ ]="node.label">
<svg:rect [attr.width]="node.width" [attr.height]="node.height" [attr.fill]="node.options.color" />
<svg:text alignment-baseline="central" [attr.x]="10" [attr.y]="node.height / 2">{{node.label}}</svg:text>
</svg:g>
</ng-template>
<ng-template
<svg:g class="edge">
<svg:path
stroke-width="2"
marker-end="url(#arrow)" >
</svg:path>
</svg:g>
</ng-template>
</ngx-graph>
```
```
[
{
id: 'start',
label: 'start'
}, {
id: '1',
label: 'Query ThreatConnect',
}, {
id: '2',
label: 'Query XForce',
}, {
id: '3',
label: 'Format Results'
}, {
id: '4',
label: 'Search Splunk'
}, {
id: '5',
label: 'Block LDAP'
}, {
id: '6',
label: 'Email Results'
}
]
```
```
[
{
source: 'start',
target: '1',
label: 'links to'
}, {
source: 'start',
target: '2'
}, {
source: '1',
target: '3',
label: 'related to'
}, {
source: '2',
target: '4'
}, {
source: '2',
target: '6'
}, {
source: '3',
target: '5'
}
]
```
`ngx-graph` is a [Swimlane](http://swimlane.com) open-source project; we believe in giving back to the open-source community by sharing some of the projects we build for our application. Swimlane is an automated cyber security operations and incident response platform that enables cyber security teams to leverage threat intelligence, speed up incident response and automate security operations.
[![Join the chat at https: