93e9fa854c
* feat: register node from xml string or xml string genrator * feat: add register xml node to interface and stroy book * fix: merge register to node & basic props back to shape options * fix: delete unused static function on shape * feat: xml node update when setState * feat: simple template renderer on xml * feat: simple template renderer on xml * fix: xml node update state style error * chore: remove lodash dependency * fix: remove xml html node after compile * feat: support loose json and object wrapped with {{ }} * feat: add test for new xml parser * feat: using style from cfg into xml node * feat: using style from cfg into xml node * fix: node style not rollback with the style * fix: remove unused var * feat: xml node using single-node setState methods * feat: register node from xml string or xml string genrator * feat: add register xml node to interface and stroy book * fix: merge register to node & basic props back to shape options * fix: delete unused static function on shape * feat: xml node update when setState * feat: simple template renderer on xml * feat: simple template renderer on xml * fix: xml node update state style error * chore: remove lodash dependency * fix: remove xml html node after compile * feat: support loose json and object wrapped with {{ }} * feat: add test for new xml parser * feat: using style from cfg into xml node * fix: xml node state style not correct (#1916) * feat: using style from cfg into xml node * fix: node style not rollback with the style * fix: remove unused var * feat: xml node using single-node setState methods * fix: update & state * fix: {{}} replace bug and only keyshape inherit origin attrs * lint: fix line problem in xml * fix: xml node parse error and origin style only used on keyshape (#1942) * feat: using style from cfg into xml node * fix: node style not rollback with the style * fix: remove unused var * feat: xml node using single-node setState methods * fix: {{}} replace bug and only keyshape inherit origin attrs * lint: fix line problem in xml * fix: test xml node * fix: fix image node problem * doc: add xml node examples * feat: add jsx key for node extend * feat: add next key to keep shape display inline * fix: xml json parse bug cause boolean not supported * fix: lint problem * fix: coveage fix Co-authored-by: Moyee <576375879@qq.com> |
||
---|---|---|
.github | ||
.storybook | ||
.vscode | ||
docs | ||
examples | ||
site | ||
src | ||
stories | ||
tests/unit | ||
.babelrc.js | ||
.browserslistrc | ||
.editorconfig | ||
.eslintignore | ||
.eslintrc.js | ||
.fatherrc.js | ||
.gitignore | ||
.gitlab-ci.yml | ||
.npmignore | ||
.prettierignore | ||
.prettierrc.js | ||
.travis.yml | ||
api-extractor.json | ||
CHANGELOG.md | ||
CNAME | ||
CONTRIBUTING.md | ||
CONTRIBUTING.zh-CN.md | ||
gatsby-browser.js | ||
gatsby-config.js | ||
global.d.ts | ||
jest.config.js | ||
LICENSE | ||
package.json | ||
README-zh_CN.md | ||
README.md | ||
tsconfig.json | ||
webpack.config.js | ||
webpack.dev.config.js |
G6: A Graph Visualization Framework in TypeScript.
What is G6
G6 is a graph visualization engine, which provides a set of basic mechanisms, including rendering, layout, analysis, interaction, animation, and other auxiliary tools. G6 aims to simplify the relationships, and help people to obtain the insight of relational data.
Developers are able to build graph visualization analysis applications or graph visualization modeling applications easily.
Powerful Animation and Interactions
Powerful Layouts
Features
- Abundant Built-in Items: Nodes and edges with free configurations;
- Steerable Interactions: More than 10 basic interaction behaviors ;
- Powerful Layout: More than 10 layout algorithms;
- Convenient Components: Outstanding ability and performance;
- Friendly User Experience: Complete documents for different levels of user requirements. TypeScript supported.
G6 concentrates on the principle of 'good by default'. In addition, the custom mechanism of the item, interation behavior, and layout satisfies the customazation requirements.
Abundant Built-in Items
Installation
$ npm install @antv/g6
Usage
import G6 from '@antv/g6';
const data = {
nodes: [
{
id: 'node1',
label: 'Circle1',
x: 150,
y: 150,
},
{
id: 'node2',
label: 'Circle2',
x: 400,
y: 150,
},
],
edges: [
{
source: 'node1',
target: 'node2',
},
],
};
const graph = new G6.Graph({
container: 'container',
width: 500,
height: 500,
defaultNode: {
shape: 'circle',
size: [100],
color: '#5B8FF9',
style: {
fill: '#9EC9FF',
lineWidth: 3,
},
labelCfg: {
style: {
fill: '#fff',
fontSize: 20,
},
},
},
defaultEdge: {
style: {
stroke: '#e2e2e2',
},
},
});
graph.data(data);
graph.render();
For more information of the usage, please refer to Getting Started.
Development
$ npm install
# run test case
$ npm test
# run test case in watch mode
npm test -- --watch ./tests/unit/algorithm/find-path-spec
DEBUG_MODE=1 npm test -- --watch ./tests/unit/algorithm/find-path-spec
# build watching file changes and run demos
$ npm run demos
Documents
G6 Communication Group
Users are welcome to join the G6 Communication Group or G6 Communication Group-2 (They are DingTalk groups). We also welcome the github issues. The Group is full, join Group-2 instead.
How to Contribute
Please let us know what you are you going to help. Do check out issues for bug reports or suggestions first.
To become a contributor, please follow our contributing guide.