Migrated repository
Go to file
2021-02-03 22:30:35 +08:00
.github ci: revert to pull_request (#2638) 2021-02-03 22:30:35 +08:00
.vscode feat: add label background 2020-03-26 00:17:21 +08:00
packages chore: update config for packages 2021-02-01 11:23:57 +08:00
.babelrc.js chore: update bablerc, package.json, and webpack.config.js. 2020-08-11 16:16:16 +08:00
.browserslistrc fix not support ie11 2019-10-28 17:27:25 +08:00
.editorconfig refactor 2.0 2018-06-05 23:58:10 +08:00
.eslintignore style: fix eslint bugs 2020-08-17 18:50:55 +08:00
.eslintrc.js fix: resolve eslint problem 2021-01-19 10:00:58 +08:00
.fatherrc.js fix: update types path 2020-01-16 20:14:41 +08:00
.gitignore fix: refactor package core 2020-12-14 12:00:17 +08:00
.gitlab-ci.yml chore: prettier all code 2020-02-14 11:30:12 +08:00
.npmignore fix: G6 package delete public and .cache file 2019-11-17 10:40:36 +08:00
.prettierignore chore: prettier all code 2020-02-14 11:30:12 +08:00
.prettierrc.js chore: update scaffold 2020-01-02 21:04:40 +08:00
.travis.yml test: add codecov 2020-08-17 18:50:55 +08:00
CHANGELOG.md fix: polyline with negative endpoints; fix: polyline direction when linkCenter; fix: remove g6-core browser since it has no umd output; feat: custom texts for the time range and time point text in timeBar plugin; chore: types for strict mode; 2021-02-01 11:23:57 +08:00
lerna.json fix: addItem with array property; chore: remove console 2021-01-07 15:47:43 +08:00
LICENSE refactor 2.0 2018-06-05 23:58:10 +08:00
package.json fix: wrong style for modelRect after updating and state changing, closes: #2613; fix: drag-canvas with shouldBegin false, closes: #2571; fix: pack plugin with es module, closes: #2577; feat: dijkstra with multiple shortest paths, closes: #2297; fix: setMode while the delegates of brush-select and drag-node is on the canvas, closes: #2607; docs: update the english TimeBar docs, closes: #2597; fix: TimeBar time point switch text configurable, closes: #2597; 2021-02-01 11:23:57 +08:00
README-zh_CN.md fix: wrong style for modelRect after updating and state changing, closes: #2613; fix: drag-canvas with shouldBegin false, closes: #2571; fix: pack plugin with es module, closes: #2577; feat: dijkstra with multiple shortest paths, closes: #2297; fix: setMode while the delegates of brush-select and drag-node is on the canvas, closes: #2607; docs: update the english TimeBar docs, closes: #2597; fix: TimeBar time point switch text configurable, closes: #2597; 2021-02-01 11:23:57 +08:00
README.md fix: wrong style for modelRect after updating and state changing, closes: #2613; fix: drag-canvas with shouldBegin false, closes: #2571; fix: pack plugin with es module, closes: #2577; feat: dijkstra with multiple shortest paths, closes: #2297; fix: setMode while the delegates of brush-select and drag-node is on the canvas, closes: #2607; docs: update the english TimeBar docs, closes: #2597; fix: TimeBar time point switch text configurable, closes: #2597; 2021-02-01 11:23:57 +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

# lerna bootstrap for multiple packages
$ npm run bootstrap

# build the packages
$ npm run build:all

# if you wanna watch one of the packages, e.g. packages/core
$ cd ./packages/core
$ npm run watch

# 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.

License

MIT license.