Skip to content

Commit

Permalink
Merge pull request #86 from sgratzl/release/v4.2.5
Browse files Browse the repository at this point in the history
Release v4.2.5
  • Loading branch information
sgratzl authored Sep 17, 2023
2 parents c324521 + 77f3933 commit 19bd88e
Show file tree
Hide file tree
Showing 5 changed files with 110 additions and 5 deletions.
1 change: 1 addition & 0 deletions docs/.vitepress/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ export default defineConfig({
{ text: 'Tree with Labels', link: '/examples/label' },
{ text: 'Directed Tree', link: '/examples/directed' },
{ text: 'Tree Orientations', link: '/examples/orientation' },
{ text: 'Fully Linked', link: '/examples/linked' },
],
},
{
Expand Down
24 changes: 24 additions & 0 deletions docs/examples/linked.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
---
title: Linked
---

# Linked

<script setup>
import {config} from './linked';
</script>

<ForceDirectedGraphChart
:options="config.options"
:data="config.data"
/>

### Code

:::code-group

<<< ./linked.ts#config [config]

<<< ./linked.ts#data [data]

:::
55 changes: 55 additions & 0 deletions docs/examples/linked.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
import type { ChartConfiguration } from 'chart.js';
import type {} from '../../src';
import 'chartjs-plugin-datalabels';

// #region data

const edges = [
{ source: 1, target: 0 },
{ source: 2, target: 0 },
{ source: 2, target: 1 },
{ source: 3, target: 1 },
{ source: 3, target: 0 },
{ source: 3, target: 2 },
];

const widths = [2, 5, 10, 15, 20, 25];
const dashes = [
[2, 2],
[5, 5],
[10, 10],
[15, 15],
[20, 20],
[25, 25],
];
const colors = ['blue', 'red', 'green', 'purple', 'pink', 'yellow'];
const nodeColors = ['yellow', 'pink', 'teal', 'violet'];

export const data: ChartConfiguration<'tree'>['data'] = {
labels: ['A', 'B', 'C', 'D'],
datasets: [
{
data: [{}, {}, {}, {}],
edges: edges,
pointRadius: 20,
pointBackgroundColor: (ctx) => nodeColors[ctx.index],
edgeLineBorderWidth: (ctx) => widths[ctx.index],
edgeLineBorderDash: (ctx) => dashes[ctx.index],
edgeLineBorderColor: (ctx) => colors[ctx.index],
},
],
};
// #endregion data
// #region config
export const config: ChartConfiguration<'tree'> = {
type: 'forceDirectedGraph',
data,
options: {
scales: {
x: { min: -1.5, max: 1.5 },
y: { min: -1.5, max: 1.5 },
},
plugins: { legend: { display: false } },
},
};
// #endregion config
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "chartjs-chart-graph",
"description": "Chart.js module for charting graphs",
"version": "4.2.4",
"version": "4.2.5",
"author": {
"name": "Samuel Gratzl",
"email": "[email protected]",
Expand Down
33 changes: 29 additions & 4 deletions src/controllers/GraphController.ts
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,8 @@ export class GraphController extends ScatterController {
this.stopLayout();
}

declare getContext: (index: number, active: boolean, mode: UpdateMode) => unknown;

/**
* @hidden
*/
Expand All @@ -215,14 +217,33 @@ export class GraphController extends ScatterController {
_cachedDataOpts: this._cachedDataOpts,
dataElementType: this.dataElementType,
_sharedOptions: this._sharedOptions,
// getDataset: this.getDataset,
// getParsed: this.getParsed,
};
this._cachedDataOpts = {};
this.dataElementType = this.edgeElementType;
this._sharedOptions = this._edgeSharedOptions;

const dataset = this.getDataset();
const meta = this._cachedMeta;
const nodes = meta.data;
const nodeElements = meta.data;
const data = (this._cachedMeta as unknown as IExtendedChartMeta)._parsedEdges;

// get generic context to prefill cache
this.getContext(-1, false, mode);
this.getDataset = () => {
return new Proxy(dataset, {
get(obj: any, prop: string) {
return prop === 'data' ? obj.edges ?? [] : obj[prop];
},
});
};
this.getParsed = (index: number) => {
return data[index] as any;
};
// patch meta to store edges
meta.data = (meta as any).edges;

const reset = mode === 'reset';

const firstOpts = this.resolveDataElementOptions(start, mode);
Expand Down Expand Up @@ -253,11 +274,11 @@ export class GraphController extends ScatterController {
const parsed = data[index];

const properties: any = {
source: nodes[parsed.source],
target: nodes[parsed.target],
source: nodeElements[parsed.source],
target: nodeElements[parsed.target],
points: Array.isArray(parsed.points) ? parsed.points.map((p) => copyPoint(p)) : [],
};
properties.points._source = nodes[parsed.source];
properties.points._source = nodeElements[parsed.source];
if (includeOptions) {
if (sharedOptions !== dummyShared) {
properties.options = sharedOptions;
Expand All @@ -271,6 +292,10 @@ export class GraphController extends ScatterController {

this._edgeSharedOptions = this._sharedOptions;
Object.assign(this, bak);
delete (this as any).getDataset;
delete (this as any).getParsed;
// patch meta to store edges
meta.data = nodeElements;
}

/**
Expand Down

0 comments on commit 19bd88e

Please sign in to comment.