g6/packages/pc
2021-08-03 10:05:48 +08:00
..
src fix: update config for edge 2021-08-03 10:05:47 +08:00
stories chore: remove consoles in tests 2021-01-05 15:01:34 +08:00
tests/unit feat: updateLayout with align and alignPoint; 2021-08-03 10:05:48 +08:00
.babelrc.js feat: refactor G6 2020-12-04 20:54:45 +08:00
.eslintignore fix: resolve eslint 2021-01-06 20:07:29 +08:00
.fatherrc.js feat: refactor G6 2020-12-04 20:54:45 +08:00
.npmignore feat: refactor G6 2020-12-04 20:54:45 +08:00
global.d.ts feat: refactor G6 2020-12-04 20:54:45 +08:00
jest.config.js feat: refactor G6 2020-12-04 20:54:45 +08:00
package.json chore: use link versions 2021-08-03 10:05:47 +08:00
README-zh_CN.md docs: update readme 2021-06-04 16:29:10 +08:00
README.md docs: update readme 2021-06-04 16:29:10 +08:00
tsconfig.json chore: update config for packages 2021-02-01 11:23:57 +08:00
webpack.config.js feat: 嵌入式 worker 2021-02-20 12:12:00 +08:00
webpack.dev.config.js chore: update algorithm package to solve high cpu usage problem temporally; 2021-03-29 19:11:44 +08:00

G6: A Graph Visualization Framework in TypeScript.

travis-ci codecov typescript MIT npm package NPM downloads Percentage of issues still open

中文 README

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: {
    type: '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();

Edit compassionate-lalande-5lxm7

For more information of the usage, please refer to Getting Started.

Development

$ npm install

# run bootstrap to link the packages
$ npm run bootstrap

# build all the packages
$ npm run build:all

# run test case
$ npm run test

# run lint
$ npm run lint

# 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

Documents

G6 Communication Group

Welcome to join the G6 Communication Group or G6 Communication Group-2 (DingTalk groups). We also welcome the github issues.

How to Contribute

Please let us know what you are you going to help. Do check out issues for bug reports or suggestions first.

License

MIT license.