@visactor/vchart-extension 1.13.22-alpha.1 → 1.13.22-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/index.js +256 -24
- package/build/index.min.js +2 -2
- package/cjs/charts/compare-sankey/compare-sankey.d.ts +1 -3
- package/cjs/charts/compare-sankey/compare-sankey.js +3 -24
- package/cjs/charts/compare-sankey/compare-sankey.js.map +1 -1
- package/cjs/charts/compare-sankey/utils.d.ts +8 -0
- package/cjs/charts/compare-sankey/utils.js +36 -2
- package/cjs/charts/compare-sankey/utils.js.map +1 -1
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.d.ts +8 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.js +85 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff-data.js.map +1 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.d.ts +7 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.js +25 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff-transformer.js.map +1 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff.d.ts +34 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff.js +98 -0
- package/cjs/charts/compare-sankey-diff/compare-sankey-diff.js.map +1 -0
- package/cjs/charts/compare-sankey-diff/index.d.ts +2 -0
- package/cjs/charts/compare-sankey-diff/index.js +20 -0
- package/cjs/charts/compare-sankey-diff/index.js.map +1 -0
- package/cjs/charts/compare-sankey-diff/interface.d.ts +24 -0
- package/cjs/charts/compare-sankey-diff/interface.js +6 -0
- package/cjs/charts/compare-sankey-diff/interface.js.map +1 -0
- package/cjs/charts/conversion-funnel/index.js +2 -1
- package/cjs/charts/sequence-scatter-kde/constant.js +1 -2
- package/cjs/charts/sequence-scatter-link/interface.js +2 -1
- package/cjs/components/bar-link/index.js +1 -2
- package/cjs/components/series-break/series-break.js +2 -1
- package/cjs/components/series-label/constant.js +1 -1
- package/cjs/components/series-label/index.js +1 -1
- package/cjs/components/series-label/series-label.js +1 -1
- package/cjs/components/series-label/type.js +1 -1
- package/cjs/components/series-label/util.js +1 -1
- package/cjs/index.d.ts +1 -0
- package/cjs/index.js +3 -2
- package/cjs/index.js.map +1 -1
- package/esm/charts/compare-sankey/compare-sankey.d.ts +1 -3
- package/esm/charts/compare-sankey/compare-sankey.js +4 -25
- package/esm/charts/compare-sankey/compare-sankey.js.map +1 -1
- package/esm/charts/compare-sankey/utils.d.ts +8 -0
- package/esm/charts/compare-sankey/utils.js +33 -0
- package/esm/charts/compare-sankey/utils.js.map +1 -1
- package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.d.ts +8 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.js +77 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff-data.js.map +1 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.d.ts +7 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.js +17 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff-transformer.js.map +1 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff.d.ts +34 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff.js +97 -0
- package/esm/charts/compare-sankey-diff/compare-sankey-diff.js.map +1 -0
- package/esm/charts/compare-sankey-diff/index.d.ts +2 -0
- package/esm/charts/compare-sankey-diff/index.js +3 -0
- package/esm/charts/compare-sankey-diff/index.js.map +1 -0
- package/esm/charts/compare-sankey-diff/interface.d.ts +24 -0
- package/esm/charts/compare-sankey-diff/interface.js +2 -0
- package/esm/charts/compare-sankey-diff/interface.js.map +1 -0
- package/esm/charts/conversion-funnel/index.js +2 -1
- package/esm/charts/sequence-scatter-kde/constant.js +1 -2
- package/esm/charts/sequence-scatter-link/interface.js +2 -1
- package/esm/components/bar-link/index.js +1 -2
- package/esm/components/series-break/series-break.js +2 -1
- package/esm/components/series-label/constant.js +1 -1
- package/esm/components/series-label/index.js +1 -1
- package/esm/components/series-label/series-label.js +1 -1
- package/esm/components/series-label/type.js +1 -1
- package/esm/components/series-label/util.js +1 -1
- package/esm/index.d.ts +1 -0
- package/esm/index.js +2 -0
- package/esm/index.js.map +1 -1
- package/package.json +4 -4
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import type { ICompareSankeyChartSpecBase, ICompareSankeySeriesSpecBase } from './interface';
|
|
2
2
|
import { VChart, SankeyChart, SankeySeries } from '@visactor/vchart';
|
|
3
|
-
import { DataView } from '@visactor/vdataset';
|
|
4
3
|
import { CompareSankeyChartSpecTransformer } from './compare-sankey-transformer';
|
|
5
4
|
import type { IElement } from '@visactor/vgrammar-core';
|
|
6
5
|
type Datum = any;
|
|
@@ -15,7 +14,6 @@ export declare class CompareSankeyChart extends SankeyChart<ICompareSankeyChartS
|
|
|
15
14
|
export declare class CompareSankeySeries extends SankeySeries<ICompareSankeySeriesSpecBase> {
|
|
16
15
|
type: string;
|
|
17
16
|
static type: string;
|
|
18
|
-
protected _arrowData?: DataView;
|
|
19
17
|
private _subData;
|
|
20
18
|
private _activeLinkData;
|
|
21
19
|
private _activeLinkMark;
|
|
@@ -37,7 +35,7 @@ export declare class CompareSankeySeries extends SankeySeries<ICompareSankeySeri
|
|
|
37
35
|
getNodeDatumInSubTree(filter: (n: any) => boolean): {
|
|
38
36
|
[key: string]: any;
|
|
39
37
|
type: string;
|
|
40
|
-
datum:
|
|
38
|
+
datum: any[];
|
|
41
39
|
}[];
|
|
42
40
|
}
|
|
43
41
|
export declare const registerCompareSankeyChart: (option?: {
|
|
@@ -1,15 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var __rest = this && this.__rest || function(s, e) {
|
|
4
|
-
var t = {};
|
|
5
|
-
for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
|
|
6
|
-
if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
|
|
7
|
-
var i = 0;
|
|
8
|
-
for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
|
|
9
|
-
}
|
|
10
|
-
return t;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
3
|
Object.defineProperty(exports, "__esModule", {
|
|
14
4
|
value: !0
|
|
15
5
|
}), exports.registerCompareSankeyChart = exports.CompareSankeySeries = exports.CompareSankeyChart = void 0;
|
|
@@ -185,24 +175,13 @@ class CompareSankeySeries extends vchart_1.SankeySeries {
|
|
|
185
175
|
}));
|
|
186
176
|
}
|
|
187
177
|
getSubNodeDatum(filter) {
|
|
188
|
-
return this._nodeMark.getProductElements()
|
|
178
|
+
return (0, utils_1.getSubNodeDatum)(this._nodeMark.getProductElements(), filter);
|
|
189
179
|
}
|
|
190
180
|
getNodeDatumInTree(filter) {
|
|
191
|
-
|
|
192
|
-
return this._rawData.latestData[0].nodes.forEach((node => {
|
|
193
|
-
(0, utils_1.traverseTree)([ node ], (node => {
|
|
194
|
-
filter(node) && result.push(node);
|
|
195
|
-
}));
|
|
196
|
-
})), result;
|
|
181
|
+
return (0, utils_1.getNodeDatumInTree)(this._rawData.latestData[0].nodes, filter);
|
|
197
182
|
}
|
|
198
183
|
getNodeDatumInSubTree(filter) {
|
|
199
|
-
|
|
200
|
-
return this._rawData.latestData[0].subNode.forEach((subNode => {
|
|
201
|
-
const {nodes: nodes} = subNode, result = __rest(subNode, [ "nodes" ]);
|
|
202
|
-
result.datum = [], nodes.forEach((node => {
|
|
203
|
-
filter(node) && result.datum.push(node);
|
|
204
|
-
})), list.push(result);
|
|
205
|
-
})), list;
|
|
184
|
+
return (0, utils_1.getNodeDatumInSubTree)(this._rawData.latestData[0].subNode, filter);
|
|
206
185
|
}
|
|
207
186
|
}
|
|
208
187
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["charts/compare-sankey/compare-sankey.ts"],"names":[],"mappings":"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","file":"compare-sankey.js","sourcesContent":["import type { SankeyLinkElement } from '@visactor/vgrammar-sankey';\nimport type { ICompareSankeyChartSpecBase, ICompareSankeySeriesSpecBase } from './interface';\nimport type { ILinkPathMarkSpec, IRectMarkSpec } from '@visactor/vchart';\nimport {\n VChart,\n SankeyChart,\n SankeySeries,\n registerDataSetInstanceTransform,\n STATE_VALUE_ENUM,\n AttributeLevel,\n DEFAULT_DATA_INDEX,\n DEFAULT_DATA_KEY\n} from '@visactor/vchart';\nimport { DataView } from '@visactor/vdataset';\nimport { CompareSankeyChartSpecTransformer } from './compare-sankey-transformer';\nimport { compareSankeySubNodes } from './compare-sankey-sub-nodes';\nimport type { ILinkPathMark } from '@visactor/vchart/src/mark/interface';\nimport { compareSankeySubData } from './compare-sankey-sub-data';\nimport type { IElement } from '@visactor/vgrammar-core';\nimport { getDatumOfGraphic } from '../../utils/mark';\nimport { traverseTree } from './utils';\n\ntype Datum = any;\n\nexport class CompareSankeyChart extends SankeyChart<ICompareSankeyChartSpecBase> {\n type = 'compareSankey';\n static type = 'compareSankey';\n readonly seriesType = CompareSankeySeries.type;\n\n declare _spec: ICompareSankeyChartSpecBase;\n\n static readonly transformerConstructor = CompareSankeyChartSpecTransformer;\n readonly transformerConstructor = CompareSankeyChartSpecTransformer;\n}\n\nexport class CompareSankeySeries extends SankeySeries<ICompareSankeySeriesSpecBase> {\n // @ts-ignore\n type = 'compareSankey';\n static type = 'compareSankey';\n\n protected _arrowData?: DataView;\n\n private _subData: DataView;\n\n private _activeLinkData: DataView;\n private _activeLinkMark: ILinkPathMark;\n\n initData() {\n super.initData();\n // 此时 viewData 已经初始化完成\n // 创建 第二层 viewDataActive\n //\n const { dataSet } = this._option;\n\n const compareSubData = new DataView(dataSet, { name: `compare-sankey-sub-data-${this.id}-data` });\n compareSubData.parse([this.getViewData()], {\n type: 'dataview'\n });\n this._subData = compareSubData;\n\n const compareNodeData = new DataView(dataSet, { name: `compare-sankey-node-${this.id}-data` });\n compareNodeData.parse([compareSubData], {\n type: 'dataview'\n });\n\n // 注册对比布局函数,计算拆解 nodes 的信息\n registerDataSetInstanceTransform(this._dataSet, 'compareSankeySubData', compareSankeySubData);\n compareSubData.transform({\n type: 'compareSankeySubData',\n options: {\n rawData: () => this.getRawData(),\n valueField: this._valueField,\n nodeKey: this._spec.nodeKey,\n subNodeGap: this._spec.subNodeGap ?? 2,\n subNodeMinSize: this._spec.subNodeMinSize ?? 0\n }\n });\n registerDataSetInstanceTransform(this._dataSet, 'compareSankeySubNodes', compareSankeySubNodes);\n compareNodeData.transform({\n type: 'compareSankeySubNodes'\n });\n this._nodesSeriesData.getDataView().parse([compareNodeData], {\n type: 'dataview'\n });\n\n // 激活时的linkData\n this._activeLinkData = new DataView(dataSet, { name: `compare-sankey-link-${this.id}-data` });\n }\n\n initEvent() {\n super.initEvent();\n this._activeLinkData?.target.addListener('change', this.activeLinkDataUpdate.bind(this));\n }\n\n initMark() {\n super.initMark();\n\n const linkMark = this._createMark(\n { ...SankeySeries.mark.link, name: 'activeLink' },\n {\n dataView: this._activeLinkData\n }\n ) as ILinkPathMark;\n if (linkMark) {\n this._activeLinkMark = linkMark;\n }\n }\n compileData() {\n super.compileData();\n this._activeLinkMark?.compileData();\n }\n\n _initLinkMarkStyle() {\n super._initLinkMarkStyle();\n // (this._activeLinkMark as any).setGlyphConfig({\n // direction: this.direction\n // });\n this._activeLinkMark.setAttribute('direction', this.direction);\n\n this.setMarkStyle<ILinkPathMarkSpec>(\n this._activeLinkMark,\n {\n x0: (datum: Datum) => datum.x0,\n x1: (datum: Datum) => datum.x1,\n y0: (datum: Datum) => datum.y0,\n y1: (datum: Datum) => datum.y1,\n thickness: (datum: Datum) => datum.thickness\n },\n STATE_VALUE_ENUM.STATE_NORMAL,\n AttributeLevel.Series\n );\n\n this.setMarkStyle(\n this._activeLinkMark,\n {\n fill: this._fillActiveLink\n },\n STATE_VALUE_ENUM.STATE_NORMAL,\n AttributeLevel.User_Mark\n );\n }\n\n _initNodeMarkStyle() {\n super._initNodeMarkStyle();\n if (this._spec.compareNodeColor) {\n this.setMarkStyle<IRectMarkSpec>(\n this._nodeMark,\n {\n fill: this._fillCompareNode\n },\n 'normal',\n AttributeLevel.User_Mark\n );\n }\n }\n\n private activeLinkDataUpdate() {\n this._activeLinkMark.getData().updateData();\n }\n\n protected _fillCompareNode = (datum: Datum) => {\n if (this._spec.compareNodeColor?.[datum.type]) {\n return this._spec.compareNodeColor[datum.type];\n }\n return this._spec.node.style?.fill ?? this._fillByNode(datum);\n };\n\n protected _fillActiveLink = (datum: Datum) => {\n if (this._spec.compareLinkColor?.[datum.type]) {\n return this._spec.compareLinkColor[datum.type];\n }\n return this._spec.link.style?.fill ?? this._fillByLink(datum);\n };\n\n protected _handleNodeRelatedClick(element: IElement, highlightState: string, blurState: string) {\n const nodeDatum = element.getDatum();\n // 节点\n const allNodeElements = this._nodeMark.getProductElements();\n if (!allNodeElements || !allNodeElements.length) {\n return;\n }\n // 边\n const allLinkElements = this._linkMark.getProductElements();\n if (!allLinkElements || !allLinkElements.length) {\n return;\n }\n\n // 原始 link 全部进入blur状态\n allLinkElements.forEach(el => {\n el.removeState([STATE_VALUE_ENUM.STATE_SANKEY_EMPHASIS]);\n });\n this._highLightElements(allLinkElements, [], highlightState, blurState);\n\n const nodeDatums = allNodeElements.map(el => getDatumOfGraphic(el) as Datum);\n const pickNodeDatums = nodeDatums.filter(d => d.key === nodeDatum.key);\n // 层级型数据\n const highlightLinksData: any[] = [];\n // 高亮节点key\n const highlightNodeKeys: (string | number)[] = pickNodeDatums.map(d => d.key);\n\n // 上游路径始终只选取第一个\n this._activeTargetLink(\n nodeDatum,\n pickNodeDatums,\n allNodeElements,\n allLinkElements,\n highlightNodeKeys,\n highlightLinksData,\n highlightState,\n blurState\n );\n this._activeSourceLink(\n nodeDatum,\n pickNodeDatums,\n nodeDatums,\n allNodeElements,\n highlightNodeKeys,\n highlightLinksData,\n highlightState,\n blurState\n );\n this._highLightElements(allNodeElements, highlightNodeKeys as string[], highlightState, blurState);\n this._activeLinkData.parseNewData(highlightLinksData);\n\n this._needClear = true;\n }\n\n private _activeTargetLink(\n nodeDatum: Datum,\n pickNodeDatums: Datum[],\n allNodeElements: any[],\n allLinkElements: any[],\n highlightNodeKeys: (string | number)[],\n highlightLinksData: any[],\n highlightState: string,\n blurState: string\n ) {\n this._handleClearEmpty(highlightState, blurState);\n const sourceNode = nodeDatum.sourceNode;\n // 上游路径始终只选取第一个\n const firstTarget = sourceNode.targetLinks[0];\n if (!firstTarget) {\n return;\n }\n let percent = 0;\n pickNodeDatums.forEach(n => {\n const link = n.targetLinks.find((l: any) => l.key === firstTarget.key);\n if (link) {\n const p = link.value / firstTarget.value;\n const key = firstTarget.key + '_' + n.type;\n const activeLink = {\n ...firstTarget,\n // 起点重新分配\n y0: firstTarget.y0 - firstTarget.thickness / 2 + (percent + p / 2) * firstTarget.thickness,\n y1: n.y0 + (p * firstTarget.thickness) / 2,\n thickness: p * firstTarget.thickness,\n key,\n type: n.type,\n [DEFAULT_DATA_INDEX]: highlightLinksData.length,\n [DEFAULT_DATA_KEY]: key\n };\n highlightLinksData.push(activeLink);\n percent += p;\n }\n });\n\n // 第一个 path 中上流路径上的 node 全部高亮\n highlightNodeKeys.push(...firstTarget.parents, nodeDatum.key);\n const linkKeys: string[] = [];\n // 找到对应的原始 link 也都高亮\n for (let i = 0; i < firstTarget.parents.length - 1; i++) {\n linkKeys.push(firstTarget.parents[i] + '-' + firstTarget.parents[i + 1]);\n }\n this._highLightElements(allLinkElements, linkKeys, highlightState, blurState);\n }\n\n private _activeSourceLink(\n nodeDatum: Datum,\n pickNodeDatums: Datum[],\n allNodeDatums: Datum[],\n allNodeElements: any[],\n highlightNodeKeys: (string | number)[],\n highlightLinksData: any[],\n highlightState: string,\n blurState: string\n ) {\n this._handleClearEmpty(highlightState, blurState);\n const sourceNode = nodeDatum.sourceNode;\n // 下游路径始需要全部处理\n const sourceLinks = sourceNode.sourceLinks;\n if (!sourceLinks?.length) {\n return;\n }\n\n const sourceValueTemp: { [key: string]: number } = {};\n sourceLinks.forEach((sourceLink: SankeyLinkElement) => {\n highlightNodeKeys.push(sourceLink.target);\n pickNodeDatums.forEach((n, index) => {\n sourceValueTemp[n.type] = sourceValueTemp[n.type] ?? 0;\n const link = n.sourceLinks.find((l: SankeyLinkElement) => l.key === sourceLink.key);\n if (link) {\n const p = link.value / n.value;\n const totalSize = n.y1 - n.y0;\n const size = totalSize * p;\n const key = sourceLink.key + '_' + n.type;\n const activeLink = {\n ...sourceLink,\n // 起点重新分配\n y0: n.y0 + sourceValueTemp[n.type] * totalSize + size / 2,\n thickness: size,\n key,\n type: n.type,\n [DEFAULT_DATA_INDEX]: highlightLinksData.length,\n [DEFAULT_DATA_KEY]: key\n };\n // y1 分为第一个和在其他\n if (index === 0) {\n // 与原始link的起点\n activeLink.y1 = sourceLink.y1 - sourceLink.thickness / 2 + size / 2;\n } else {\n // 与目标子 node 的 y0 对齐\n const targetNode = allNodeDatums.find(_n => _n.key === link.target && _n.type === n.type);\n if (targetNode) {\n activeLink.y1 = targetNode.y0 + size / 2;\n } else {\n // 错误的情况\n return;\n }\n }\n highlightLinksData.push(activeLink);\n sourceValueTemp[n.type] += p;\n }\n });\n });\n }\n\n protected _handleClearEmpty(highlightState: string, blurState: string) {\n super._handleClearEmpty(highlightState, blurState);\n this._activeLinkData.parseNewData([]);\n\n // 同时需要清除 hover\n const allNodeElements = this._nodeMark.getProductElements();\n if (allNodeElements || !allNodeElements.length) {\n allNodeElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n\n // 同时需要清除 hover\n const allLinkElements = this._linkMark.getProductElements();\n if (allLinkElements || !allLinkElements.length) {\n allLinkElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n }\n\n public getSubNodeDatum(filter: (n: Datum) => boolean) {\n return this._nodeMark.getProductElements().filter((n: Datum) => filter(n.data[0]));\n }\n\n public getNodeDatumInTree(filter: (n: any) => boolean) {\n const result: Datum[] = [];\n const nodes = this._rawData.latestData[0].nodes;\n\n nodes.forEach((node: any) => {\n traverseTree([node], (node: any) => {\n if (filter(node)) {\n result.push(node);\n }\n });\n });\n return result;\n }\n\n public getNodeDatumInSubTree(filter: (n: any) => boolean) {\n const list: {\n type: string;\n datum: Datum[];\n [key: string]: any;\n }[] = [];\n const subNodes = this._rawData.latestData[0].subNode;\n subNodes.forEach((subNode: any) => {\n const { nodes, ...result } = subNode;\n result.datum = [];\n nodes.forEach((node: any) => {\n if (filter(node)) {\n result.datum.push(node);\n }\n });\n list.push(result);\n });\n return list;\n }\n}\n\nexport const registerCompareSankeyChart = (option?: { VChart?: typeof VChart }) => {\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([CompareSankeyChart]);\n vchartConstructor.useSeries([CompareSankeySeries]);\n }\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["charts/compare-sankey/compare-sankey.ts"],"names":[],"mappings":"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","file":"compare-sankey.js","sourcesContent":["import type { SankeyLinkElement } from '@visactor/vgrammar-sankey';\nimport type { ICompareSankeyChartSpecBase, ICompareSankeySeriesSpecBase } from './interface';\nimport type { ILinkPathMarkSpec, IRectMarkSpec } from '@visactor/vchart';\nimport {\n VChart,\n SankeyChart,\n SankeySeries,\n registerDataSetInstanceTransform,\n STATE_VALUE_ENUM,\n AttributeLevel,\n DEFAULT_DATA_INDEX,\n DEFAULT_DATA_KEY\n} from '@visactor/vchart';\nimport { DataView } from '@visactor/vdataset';\nimport { CompareSankeyChartSpecTransformer } from './compare-sankey-transformer';\nimport { compareSankeySubNodes } from './compare-sankey-sub-nodes';\nimport type { ILinkPathMark } from '@visactor/vchart/src/mark/interface';\nimport { compareSankeySubData } from './compare-sankey-sub-data';\nimport type { IElement } from '@visactor/vgrammar-core';\nimport { getDatumOfGraphic } from '../../utils/mark';\nimport { getNodeDatumInSubTree, getNodeDatumInTree, getSubNodeDatum } from './utils';\n\ntype Datum = any;\n\nexport class CompareSankeyChart extends SankeyChart<ICompareSankeyChartSpecBase> {\n type = 'compareSankey';\n static type = 'compareSankey';\n readonly seriesType = CompareSankeySeries.type;\n\n declare _spec: ICompareSankeyChartSpecBase;\n\n static readonly transformerConstructor = CompareSankeyChartSpecTransformer;\n readonly transformerConstructor = CompareSankeyChartSpecTransformer;\n}\n\nexport class CompareSankeySeries extends SankeySeries<ICompareSankeySeriesSpecBase> {\n // @ts-ignore\n type = 'compareSankey';\n static type = 'compareSankey';\n\n private _subData: DataView;\n\n private _activeLinkData: DataView;\n private _activeLinkMark: ILinkPathMark;\n\n initData() {\n super.initData();\n // 此时 viewData 已经初始化完成\n // 创建 第二层 viewDataActive\n //\n const { dataSet } = this._option;\n\n const compareSubData = new DataView(dataSet, { name: `compare-sankey-sub-data-${this.id}-data` });\n compareSubData.parse([this.getViewData()], {\n type: 'dataview'\n });\n this._subData = compareSubData;\n\n const compareNodeData = new DataView(dataSet, { name: `compare-sankey-node-${this.id}-data` });\n compareNodeData.parse([compareSubData], {\n type: 'dataview'\n });\n\n // 注册对比布局函数,计算拆解 nodes 的信息\n registerDataSetInstanceTransform(this._dataSet, 'compareSankeySubData', compareSankeySubData);\n compareSubData.transform({\n type: 'compareSankeySubData',\n options: {\n rawData: () => this.getRawData(),\n valueField: this._valueField,\n nodeKey: this._spec.nodeKey,\n subNodeGap: this._spec.subNodeGap ?? 2,\n subNodeMinSize: this._spec.subNodeMinSize ?? 0\n }\n });\n registerDataSetInstanceTransform(this._dataSet, 'compareSankeySubNodes', compareSankeySubNodes);\n compareNodeData.transform({\n type: 'compareSankeySubNodes'\n });\n this._nodesSeriesData.getDataView().parse([compareNodeData], {\n type: 'dataview'\n });\n\n // 激活时的linkData\n this._activeLinkData = new DataView(dataSet, { name: `compare-sankey-link-${this.id}-data` });\n }\n\n initEvent() {\n super.initEvent();\n this._activeLinkData?.target.addListener('change', this.activeLinkDataUpdate.bind(this));\n }\n\n initMark() {\n super.initMark();\n\n const linkMark = this._createMark(\n { ...SankeySeries.mark.link, name: 'activeLink' },\n {\n dataView: this._activeLinkData\n }\n ) as ILinkPathMark;\n if (linkMark) {\n this._activeLinkMark = linkMark;\n }\n }\n compileData() {\n super.compileData();\n this._activeLinkMark?.compileData();\n }\n\n _initLinkMarkStyle() {\n super._initLinkMarkStyle();\n // (this._activeLinkMark as any).setGlyphConfig({\n // direction: this.direction\n // });\n this._activeLinkMark.setAttribute('direction', this.direction);\n\n this.setMarkStyle<ILinkPathMarkSpec>(\n this._activeLinkMark,\n {\n x0: (datum: Datum) => datum.x0,\n x1: (datum: Datum) => datum.x1,\n y0: (datum: Datum) => datum.y0,\n y1: (datum: Datum) => datum.y1,\n thickness: (datum: Datum) => datum.thickness\n },\n STATE_VALUE_ENUM.STATE_NORMAL,\n AttributeLevel.Series\n );\n\n this.setMarkStyle(\n this._activeLinkMark,\n {\n fill: this._fillActiveLink\n },\n STATE_VALUE_ENUM.STATE_NORMAL,\n AttributeLevel.User_Mark\n );\n }\n\n _initNodeMarkStyle() {\n super._initNodeMarkStyle();\n if (this._spec.compareNodeColor) {\n this.setMarkStyle<IRectMarkSpec>(\n this._nodeMark,\n {\n fill: this._fillCompareNode\n },\n 'normal',\n AttributeLevel.User_Mark\n );\n }\n }\n\n private activeLinkDataUpdate() {\n this._activeLinkMark.getData().updateData();\n }\n\n protected _fillCompareNode = (datum: Datum) => {\n if (this._spec.compareNodeColor?.[datum.type]) {\n return this._spec.compareNodeColor[datum.type];\n }\n return this._spec.node.style?.fill ?? this._fillByNode(datum);\n };\n\n protected _fillActiveLink = (datum: Datum) => {\n if (this._spec.compareLinkColor?.[datum.type]) {\n return this._spec.compareLinkColor[datum.type];\n }\n return this._spec.link.style?.fill ?? this._fillByLink(datum);\n };\n\n protected _handleNodeRelatedClick(element: IElement, highlightState: string, blurState: string) {\n const nodeDatum = element.getDatum();\n // 节点\n const allNodeElements = this._nodeMark.getProductElements();\n if (!allNodeElements || !allNodeElements.length) {\n return;\n }\n // 边\n const allLinkElements = this._linkMark.getProductElements();\n if (!allLinkElements || !allLinkElements.length) {\n return;\n }\n\n // 原始 link 全部进入blur状态\n allLinkElements.forEach(el => {\n el.removeState([STATE_VALUE_ENUM.STATE_SANKEY_EMPHASIS]);\n });\n this._highLightElements(allLinkElements, [], highlightState, blurState);\n\n const nodeDatums = allNodeElements.map(el => getDatumOfGraphic(el) as Datum);\n const pickNodeDatums = nodeDatums.filter(d => d.key === nodeDatum.key);\n // 层级型数据\n const highlightLinksData: any[] = [];\n // 高亮节点key\n const highlightNodeKeys: (string | number)[] = pickNodeDatums.map(d => d.key);\n\n // 上游路径始终只选取第一个\n this._activeTargetLink(\n nodeDatum,\n pickNodeDatums,\n allNodeElements,\n allLinkElements,\n highlightNodeKeys,\n highlightLinksData,\n highlightState,\n blurState\n );\n this._activeSourceLink(\n nodeDatum,\n pickNodeDatums,\n nodeDatums,\n allNodeElements,\n highlightNodeKeys,\n highlightLinksData,\n highlightState,\n blurState\n );\n this._highLightElements(allNodeElements, highlightNodeKeys as string[], highlightState, blurState);\n this._activeLinkData.parseNewData(highlightLinksData);\n\n this._needClear = true;\n }\n\n private _activeTargetLink(\n nodeDatum: Datum,\n pickNodeDatums: Datum[],\n allNodeElements: any[],\n allLinkElements: any[],\n highlightNodeKeys: (string | number)[],\n highlightLinksData: any[],\n highlightState: string,\n blurState: string\n ) {\n this._handleClearEmpty(highlightState, blurState);\n const sourceNode = nodeDatum.sourceNode;\n // 上游路径始终只选取第一个\n const firstTarget = sourceNode.targetLinks[0];\n if (!firstTarget) {\n return;\n }\n let percent = 0;\n pickNodeDatums.forEach(n => {\n const link = n.targetLinks.find((l: any) => l.key === firstTarget.key);\n if (link) {\n const p = link.value / firstTarget.value;\n const key = firstTarget.key + '_' + n.type;\n const activeLink = {\n ...firstTarget,\n // 起点重新分配\n y0: firstTarget.y0 - firstTarget.thickness / 2 + (percent + p / 2) * firstTarget.thickness,\n y1: n.y0 + (p * firstTarget.thickness) / 2,\n thickness: p * firstTarget.thickness,\n key,\n type: n.type,\n [DEFAULT_DATA_INDEX]: highlightLinksData.length,\n [DEFAULT_DATA_KEY]: key\n };\n highlightLinksData.push(activeLink);\n percent += p;\n }\n });\n\n // 第一个 path 中上流路径上的 node 全部高亮\n highlightNodeKeys.push(...firstTarget.parents, nodeDatum.key);\n const linkKeys: string[] = [];\n // 找到对应的原始 link 也都高亮\n for (let i = 0; i < firstTarget.parents.length - 1; i++) {\n linkKeys.push(firstTarget.parents[i] + '-' + firstTarget.parents[i + 1]);\n }\n this._highLightElements(allLinkElements, linkKeys, highlightState, blurState);\n }\n\n private _activeSourceLink(\n nodeDatum: Datum,\n pickNodeDatums: Datum[],\n allNodeDatums: Datum[],\n allNodeElements: any[],\n highlightNodeKeys: (string | number)[],\n highlightLinksData: any[],\n highlightState: string,\n blurState: string\n ) {\n this._handleClearEmpty(highlightState, blurState);\n const sourceNode = nodeDatum.sourceNode;\n // 下游路径始需要全部处理\n const sourceLinks = sourceNode.sourceLinks;\n if (!sourceLinks?.length) {\n return;\n }\n\n const sourceValueTemp: { [key: string]: number } = {};\n sourceLinks.forEach((sourceLink: SankeyLinkElement) => {\n highlightNodeKeys.push(sourceLink.target);\n pickNodeDatums.forEach((n, index) => {\n sourceValueTemp[n.type] = sourceValueTemp[n.type] ?? 0;\n const link = n.sourceLinks.find((l: SankeyLinkElement) => l.key === sourceLink.key);\n if (link) {\n const p = link.value / n.value;\n const totalSize = n.y1 - n.y0;\n const size = totalSize * p;\n const key = sourceLink.key + '_' + n.type;\n const activeLink = {\n ...sourceLink,\n // 起点重新分配\n y0: n.y0 + sourceValueTemp[n.type] * totalSize + size / 2,\n thickness: size,\n key,\n type: n.type,\n [DEFAULT_DATA_INDEX]: highlightLinksData.length,\n [DEFAULT_DATA_KEY]: key\n };\n // y1 分为第一个和在其他\n if (index === 0) {\n // 与原始link的起点\n activeLink.y1 = sourceLink.y1 - sourceLink.thickness / 2 + size / 2;\n } else {\n // 与目标子 node 的 y0 对齐\n const targetNode = allNodeDatums.find(_n => _n.key === link.target && _n.type === n.type);\n if (targetNode) {\n activeLink.y1 = targetNode.y0 + size / 2;\n } else {\n // 错误的情况\n return;\n }\n }\n highlightLinksData.push(activeLink);\n sourceValueTemp[n.type] += p;\n }\n });\n });\n }\n\n protected _handleClearEmpty(highlightState: string, blurState: string) {\n super._handleClearEmpty(highlightState, blurState);\n this._activeLinkData.parseNewData([]);\n\n // 同时需要清除 hover\n const allNodeElements = this._nodeMark.getProductElements();\n if (allNodeElements || !allNodeElements.length) {\n allNodeElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n\n // 同时需要清除 hover\n const allLinkElements = this._linkMark.getProductElements();\n if (allLinkElements || !allLinkElements.length) {\n allLinkElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n }\n\n public getSubNodeDatum(filter: (n: Datum) => boolean) {\n return getSubNodeDatum(this._nodeMark.getProductElements(), filter);\n }\n\n public getNodeDatumInTree(filter: (n: any) => boolean) {\n return getNodeDatumInTree(this._rawData.latestData[0].nodes, filter);\n }\n\n public getNodeDatumInSubTree(filter: (n: any) => boolean) {\n return getNodeDatumInSubTree(this._rawData.latestData[0].subNode, filter);\n }\n}\n\nexport const registerCompareSankeyChart = (option?: { VChart?: typeof VChart }) => {\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([CompareSankeyChart]);\n vchartConstructor.useSeries([CompareSankeySeries]);\n }\n};\n"]}
|
|
@@ -1 +1,9 @@
|
|
|
1
|
+
import { Datum, IElement } from '@visactor/vgrammar-core';
|
|
1
2
|
export declare const traverseTree: (subTree: any[], callback: (node: any) => void) => void;
|
|
3
|
+
export declare function getSubNodeDatum(allNodeElements: IElement[], filter: (n: any) => boolean): IElement[];
|
|
4
|
+
export declare function getNodeDatumInTree(nodes: any[], filter: (n: any) => boolean): any[];
|
|
5
|
+
export declare function getNodeDatumInSubTree(subNodes: any[], filter: (n: any) => boolean): {
|
|
6
|
+
[key: string]: any;
|
|
7
|
+
type: string;
|
|
8
|
+
datum: Datum[];
|
|
9
|
+
}[];
|
|
@@ -1,8 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var __rest = this && this.__rest || function(s, e) {
|
|
4
|
+
var t = {};
|
|
5
|
+
for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
|
|
6
|
+
if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
|
|
7
|
+
var i = 0;
|
|
8
|
+
for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
|
|
3
13
|
Object.defineProperty(exports, "__esModule", {
|
|
4
14
|
value: !0
|
|
5
|
-
}), exports.traverseTree = void 0;
|
|
15
|
+
}), exports.getNodeDatumInSubTree = exports.getNodeDatumInTree = exports.getSubNodeDatum = exports.traverseTree = void 0;
|
|
6
16
|
|
|
7
17
|
const traverseTree = (subTree, callback) => {
|
|
8
18
|
subTree.forEach((node => {
|
|
@@ -10,5 +20,29 @@ const traverseTree = (subTree, callback) => {
|
|
|
10
20
|
}));
|
|
11
21
|
};
|
|
12
22
|
|
|
13
|
-
|
|
23
|
+
function getSubNodeDatum(allNodeElements, filter) {
|
|
24
|
+
return allNodeElements.filter((n => filter(n.data[0])));
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function getNodeDatumInTree(nodes, filter) {
|
|
28
|
+
const result = [];
|
|
29
|
+
return nodes.forEach((node => {
|
|
30
|
+
(0, exports.traverseTree)([ node ], (node => {
|
|
31
|
+
filter(node) && result.push(node);
|
|
32
|
+
}));
|
|
33
|
+
})), result;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function getNodeDatumInSubTree(subNodes, filter) {
|
|
37
|
+
const list = [];
|
|
38
|
+
return subNodes.forEach((subNode => {
|
|
39
|
+
const {nodes: nodes} = subNode, result = __rest(subNode, [ "nodes" ]);
|
|
40
|
+
result.datum = [], nodes.forEach((node => {
|
|
41
|
+
filter(node) && result.datum.push(node);
|
|
42
|
+
})), list.push(result);
|
|
43
|
+
})), list;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
exports.traverseTree = traverseTree, exports.getSubNodeDatum = getSubNodeDatum,
|
|
47
|
+
exports.getNodeDatumInTree = getNodeDatumInTree, exports.getNodeDatumInSubTree = getNodeDatumInSubTree;
|
|
14
48
|
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["charts/compare-sankey/utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"sources":["charts/compare-sankey/utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAGO,MAAM,YAAY,GAAG,CAAC,OAAc,EAAE,QAA6B,EAAE,EAAE;IAC5E,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QACrB,QAAQ,CAAC,IAAI,CAAC,CAAC;QACf,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACzC,IAAA,oBAAY,EAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;SACvC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,YAAY,gBAOvB;AAuBF,SAAgB,eAAe,CAAC,eAA2B,EAAE,MAA2B;IACtF,OAAO,eAAe,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/D,CAAC;AAFD,0CAEC;AAKD,SAAgB,kBAAkB,CAAC,KAAY,EAAE,MAA2B;IAC1E,MAAM,MAAM,GAAU,EAAE,CAAC;IACzB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;QAC1B,IAAA,oBAAY,EAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAS,EAAE,EAAE;YACjC,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE;gBAChB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACnB;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAChB,CAAC;AAVD,gDAUC;AAED,SAAgB,qBAAqB,CAAC,QAAe,EAAE,MAA2B;IAChF,MAAM,IAAI,GAIJ,EAAE,CAAC;IACT,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;QAChC,MAAM,EAAE,KAAK,KAAgB,OAAO,EAAlB,MAAM,UAAK,OAAO,EAA9B,SAAoB,CAAU,CAAC;QACrC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;QAClB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YAC1B,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE;gBAChB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpB,CAAC,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAjBD,sDAiBC","file":"utils.js","sourcesContent":["import { Datum, IElement } from '@visactor/vgrammar-core';\n\n// 遍历树,桑基图节点通过 callback 返回到调用方\nexport const traverseTree = (subTree: any[], callback: (node: any) => void) => {\n subTree.forEach(node => {\n callback(node);\n if (node.children && node.children.length) {\n traverseTree(node.children, callback);\n }\n });\n};\n\n/**\n * 通过节点获取链接节点\n * 规则如下\n * 1. 节点有 children 时,链接节点为 children 中第一个节点\n * 2. 节点无 children 时,链接节点为父节点\n */\n// export const getLinkNodeInFSAT = (\n// node: any,\n// allNodeElements: IElement[],\n// allLinkElements: IElement[],\n// viewData: DataView\n// ) => {\n// return {\n// nodeKey: [],\n// linkKey: []\n// } as { nodeKey: string[]; linkKey: string[] };\n// };\n\n/**\n * 获取符合条件的子节点元素\n */\nexport function getSubNodeDatum(allNodeElements: IElement[], filter: (n: any) => boolean) {\n return allNodeElements.filter((n: any) => filter(n.data[0]));\n}\n\n/**\n * 在原始树结构中查找符合条件的节点\n */\nexport function getNodeDatumInTree(nodes: any[], filter: (n: any) => boolean) {\n const result: any[] = [];\n nodes.forEach((node: any) => {\n traverseTree([node], (node: any) => {\n if (filter(node)) {\n result.push(node);\n }\n });\n });\n return result;\n}\n\nexport function getNodeDatumInSubTree(subNodes: any[], filter: (n: any) => boolean) {\n const list: {\n type: string;\n datum: Datum[];\n [key: string]: any;\n }[] = [];\n subNodes.forEach((subNode: any) => {\n const { nodes, ...result } = subNode;\n result.datum = [];\n nodes.forEach((node: any) => {\n if (filter(node)) {\n result.datum.push(node);\n }\n });\n list.push(result);\n });\n return list;\n}\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { DataView } from '@visactor/vdataset';
|
|
2
|
+
export interface ICompareSankeyLayoutOpt {
|
|
3
|
+
rawData: () => DataView;
|
|
4
|
+
nodeKey: string;
|
|
5
|
+
subNodeGap: number;
|
|
6
|
+
subNodeMinSize?: number;
|
|
7
|
+
}
|
|
8
|
+
export declare const compareSankeyDiffSubData: (data: Array<DataView>, opt: ICompareSankeyLayoutOpt) => {};
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __rest = this && this.__rest || function(s, e) {
|
|
4
|
+
var t = {};
|
|
5
|
+
for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
|
|
6
|
+
if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
|
|
7
|
+
var i = 0;
|
|
8
|
+
for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
Object.defineProperty(exports, "__esModule", {
|
|
14
|
+
value: !0
|
|
15
|
+
}), exports.compareSankeyDiffSubData = void 0;
|
|
16
|
+
|
|
17
|
+
const compareSankeyDiffSubData = (data, opt) => {
|
|
18
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
19
|
+
const viewData = data[0];
|
|
20
|
+
if (!(null === (_a = viewData.latestData) || void 0 === _a ? void 0 : _a.length)) return {};
|
|
21
|
+
const subNodeMinSize = null !== (_b = opt.subNodeMinSize) && void 0 !== _b ? _b : 0, subNodeGap = opt.subNodeGap, subDataList = [], sankeyLayoutTransform = viewData.dataSet.getTransform("sankeyLayout"), sankeyTransformOption = Object.assign({}, viewData.transformsArr.find((t => "sankeyLayout" === t.type)).options);
|
|
22
|
+
delete sankeyTransformOption.customLayout;
|
|
23
|
+
const viewDataLatest = viewData.latestData[0];
|
|
24
|
+
null === (_g = null === (_f = null === (_e = null === (_d = null === (_c = viewData.rawData) || void 0 === _c ? void 0 : _c[0]) || void 0 === _d ? void 0 : _d.latestData) || void 0 === _e ? void 0 : _e[0]) || void 0 === _f ? void 0 : _f.subNode) || void 0 === _g || _g.forEach((subGroup => {
|
|
25
|
+
const {nodes: nodes} = subGroup, rest = __rest(subGroup, [ "nodes" ]), data = sankeyLayoutTransform([ Object.assign({
|
|
26
|
+
nodes: nodes
|
|
27
|
+
}, rest) ], sankeyTransformOption);
|
|
28
|
+
Object.keys(rest).forEach((key => {
|
|
29
|
+
data[0].nodes.forEach((n => {
|
|
30
|
+
n[key] = rest[key];
|
|
31
|
+
}));
|
|
32
|
+
})), subDataList.push({
|
|
33
|
+
data: data,
|
|
34
|
+
external: rest
|
|
35
|
+
});
|
|
36
|
+
}));
|
|
37
|
+
const subCount = subDataList.length;
|
|
38
|
+
viewData.latestData[0].nodes.forEach(((n, index) => {
|
|
39
|
+
let currentY = n.y0;
|
|
40
|
+
const totalSize = n.y1 - n.y0 - (subCount - 1) * subNodeGap, totalValue = n.value;
|
|
41
|
+
subDataList.forEach((subData => {
|
|
42
|
+
var _a;
|
|
43
|
+
let subN = subData.data[0].nodes[index];
|
|
44
|
+
if (subN.key !== n.key && (subN = subData.data[0].nodes.find((n => n.key == n.key))),
|
|
45
|
+
!subN) return;
|
|
46
|
+
const percent = 0 === totalValue ? 0 : subN.value / totalValue, nodeSize = Math.max(subNodeMinSize, totalSize * percent), diffX = n.x0 - subN.x0, lastY0 = subN.y0, lastSize = subN.y1 - subN.y0, sizeMultiply = nodeSize / lastSize;
|
|
47
|
+
subN._compare_compute_temp = {
|
|
48
|
+
diffX: diffX,
|
|
49
|
+
lastY0: lastY0,
|
|
50
|
+
lastSize: lastSize,
|
|
51
|
+
sizeMultiply: sizeMultiply
|
|
52
|
+
}, subN.x0 = n.x0, subN.x1 = n.x1, subN.y0 = currentY, subN.y1 = currentY + nodeSize,
|
|
53
|
+
currentY += nodeSize + subNodeGap, null === (_a = subN.sourceLinks) || void 0 === _a || _a.forEach((link => {
|
|
54
|
+
var _a;
|
|
55
|
+
link.type = subN.type, link.x0 = (null !== (_a = link.x0) && void 0 !== _a ? _a : 0) + diffX,
|
|
56
|
+
link.thickness = link.thickness * sizeMultiply, link.y0 = (link.y0 - lastY0) * sizeMultiply + subN.y0,
|
|
57
|
+
link.sourceRect && (link.sourceRect.x0 = subN.x0, link.sourceRect.x1 = subN.x1,
|
|
58
|
+
link.sourceRect.y0 = subN.y0, link.sourceRect.y1 = subN.y1);
|
|
59
|
+
}));
|
|
60
|
+
}));
|
|
61
|
+
})), subDataList.forEach((subData => {
|
|
62
|
+
subData.data[0].nodes.forEach((n => {
|
|
63
|
+
var _a;
|
|
64
|
+
const {diffX: diffX, lastY0: lastY0, sizeMultiply: sizeMultiply} = n._compare_compute_temp;
|
|
65
|
+
null === (_a = n.targetLinks) || void 0 === _a || _a.forEach((link => {
|
|
66
|
+
var _a;
|
|
67
|
+
link.x1 = (null !== (_a = link.x1) && void 0 !== _a ? _a : 0) + diffX, link.y1 = (link.y1 - lastY0) * sizeMultiply + n.y0,
|
|
68
|
+
link.targetRect && (link.targetRect.x0 = n.x0, link.targetRect.x1 = n.x1, link.targetRect.y0 = n.y0,
|
|
69
|
+
link.targetRect.y1 = n.y1);
|
|
70
|
+
}));
|
|
71
|
+
}));
|
|
72
|
+
}));
|
|
73
|
+
const finalViewData = {
|
|
74
|
+
columns: [],
|
|
75
|
+
links: [],
|
|
76
|
+
nodes: []
|
|
77
|
+
};
|
|
78
|
+
return finalViewData.columns = viewDataLatest.columns.reduce(((prev, cur, curIndex) => (prev.push(subDataList.reduce(((prev, cur) => prev.concat(cur.data[0].columns[curIndex])), [])),
|
|
79
|
+
prev)), []), finalViewData.links = subDataList.reduce(((prev, cur) => prev.concat(cur.data[0].links)), []),
|
|
80
|
+
finalViewData.nodes = subDataList.reduce(((prev, cur) => prev.concat(cur.data[0].nodes)), []),
|
|
81
|
+
[ finalViewData ];
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
exports.compareSankeyDiffSubData = compareSankeyDiffSubData;
|
|
85
|
+
//# sourceMappingURL=compare-sankey-diff-data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/compare-sankey-diff/compare-sankey-diff-data.ts"],"names":[],"mappings":"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","file":"compare-sankey-diff-data.js","sourcesContent":["import type { DataView } from '@visactor/vdataset';\nimport { SankeyNodeElement } from '@visactor/vgrammar-sankey';\n\nexport interface ICompareSankeyLayoutOpt {\n rawData: () => DataView;\n nodeKey: string;\n subNodeGap: number;\n subNodeMinSize?: number;\n}\n\nexport const compareSankeyDiffSubData = (data: Array<DataView>, opt: ICompareSankeyLayoutOpt) => {\n const viewData = data[0] as DataView;\n if (!viewData.latestData?.length) {\n return {};\n }\n\n const subNodeMinSize = opt.subNodeMinSize ?? 0;\n const subNodeGap = opt.subNodeGap;\n const subDataList: { data: any[]; external: any }[] = [];\n const sankeyLayoutTransform = viewData.dataSet.getTransform('sankeyLayout');\n const sankeyTransformOption = { ...viewData.transformsArr.find(t => t.type === 'sankeyLayout').options };\n // 自定义 layout 后处理不执行\n delete sankeyTransformOption.customLayout;\n const viewDataLatest = viewData.latestData[0];\n // 使用每一个对比数据生成对比节点和对比边\n viewData.rawData?.[0]?.latestData?.[0]?.subNode?.forEach((subGroup: any) => {\n const { nodes, ...rest } = subGroup;\n const data = sankeyLayoutTransform([{ nodes, ...rest }], sankeyTransformOption);\n Object.keys(rest).forEach(key => {\n data[0].nodes.forEach((n: { [x: string]: any }) => {\n n[key] = rest[key];\n });\n });\n subDataList.push({ data: data, external: rest });\n });\n\n const subCount = subDataList.length;\n viewData.latestData[0].nodes.forEach((n: SankeyNodeElement, index: number) => {\n let currentY = n.y0;\n const totalSize = n.y1 - n.y0 - (subCount - 1) * subNodeGap;\n const totalValue = n.value;\n subDataList.forEach((subData: any) => {\n let subN = subData.data[0].nodes[index] as SankeyNodeElement;\n if (subN.key !== n.key) {\n subN = subData.data[0].nodes.find((n: SankeyNodeElement) => n.key === n.key);\n }\n if (!subN) {\n return;\n }\n const percent = totalValue === 0 ? 0 : subN.value / totalValue;\n const nodeSize = Math.max(subNodeMinSize, totalSize * percent);\n\n // x 方向偏移\n const diffX = n.x0 - subN.x0;\n const lastY0 = subN.y0;\n const lastSize = subN.y1 - subN.y0;\n const sizeMultiply = nodeSize / lastSize;\n\n // @ts-expect-error\n subN._compare_compute_temp = {\n diffX,\n lastY0,\n lastSize,\n sizeMultiply\n };\n\n subN.x0 = n.x0;\n subN.x1 = n.x1;\n subN.y0 = currentY;\n subN.y1 = currentY + nodeSize;\n currentY += nodeSize + subNodeGap;\n\n // updateLink // 只更新 source Link\n subN.sourceLinks?.forEach(link => {\n // @ts-expect-error\n link.type = subN.type;\n link.x0 = (link.x0 ?? 0) + diffX;\n link.thickness = link.thickness * sizeMultiply;\n link.y0 = (link.y0 - lastY0) * sizeMultiply + subN.y0;\n\n if (link.sourceRect) {\n link.sourceRect.x0 = subN.x0;\n link.sourceRect.x1 = subN.x1;\n link.sourceRect.y0 = subN.y0;\n link.sourceRect.y1 = subN.y1;\n }\n });\n });\n });\n\n // 最后更新一次target Link\n subDataList.forEach((subData: any) => {\n subData.data[0].nodes.forEach((n: SankeyNodeElement) => {\n // @ts-expect-error\n const { diffX, lastY0, sizeMultiply } = n._compare_compute_temp;\n // target Link\n n.targetLinks?.forEach(link => {\n link.x1 = (link.x1 ?? 0) + diffX;\n link.y1 = (link.y1 - lastY0) * sizeMultiply + n.y0;\n\n if (link.targetRect) {\n link.targetRect.x0 = n.x0;\n link.targetRect.x1 = n.x1;\n link.targetRect.y0 = n.y0;\n link.targetRect.y1 = n.y1;\n }\n });\n });\n });\n\n const finalViewData: { columns: any[]; links: any[]; nodes: any[] } = {\n columns: [],\n links: [],\n nodes: []\n };\n // 合并节点和边\n finalViewData.columns = viewDataLatest.columns.reduce((prev: any[], cur: any, curIndex: number) => {\n prev.push(subDataList.reduce((prev, cur) => prev.concat(cur.data[0].columns[curIndex]), []));\n return prev;\n }, []);\n finalViewData.links = subDataList.reduce((prev, cur) => prev.concat(cur.data[0].links), []);\n finalViewData.nodes = subDataList.reduce((prev, cur) => prev.concat(cur.data[0].nodes), []);\n return [finalViewData];\n};\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ICompareSankeyDiffChartSpecBase } from './interface';
|
|
2
|
+
import { SankeyChartSpecTransformer } from '@visactor/vchart';
|
|
3
|
+
export declare class CompareSankeyDiffChartSpecTransformer extends SankeyChartSpecTransformer<ICompareSankeyDiffChartSpecBase> {
|
|
4
|
+
seriesType: string;
|
|
5
|
+
transformSpec(spec: ICompareSankeyDiffChartSpecBase): void;
|
|
6
|
+
_getDefaultSeriesSpec(spec: ICompareSankeyDiffChartSpecBase): any;
|
|
7
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.CompareSankeyDiffChartSpecTransformer = void 0;
|
|
6
|
+
|
|
7
|
+
const vchart_1 = require("@visactor/vchart");
|
|
8
|
+
|
|
9
|
+
class CompareSankeyDiffChartSpecTransformer extends vchart_1.SankeyChartSpecTransformer {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments), this.seriesType = "compareSankeyDiff";
|
|
12
|
+
}
|
|
13
|
+
transformSpec(spec) {
|
|
14
|
+
super.transformSpec(spec);
|
|
15
|
+
}
|
|
16
|
+
_getDefaultSeriesSpec(spec) {
|
|
17
|
+
const seriesSpec = super._getDefaultSeriesSpec(spec);
|
|
18
|
+
return seriesSpec.subNodeGap = spec.subNodeGap, seriesSpec.subNodeMinSize = spec.subNodeMinSize,
|
|
19
|
+
seriesSpec.compareNodeColor = spec.compareNodeColor, seriesSpec.compareLinkColor = spec.compareLinkColor,
|
|
20
|
+
seriesSpec;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
exports.CompareSankeyDiffChartSpecTransformer = CompareSankeyDiffChartSpecTransformer;
|
|
25
|
+
//# sourceMappingURL=compare-sankey-diff-transformer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/compare-sankey-diff/compare-sankey-diff-transformer.ts"],"names":[],"mappings":";;;AACA,6CAA8D;AAM9D,MAAa,qCAAsC,SAAQ,mCAA2D;IAAtH;;QACE,eAAU,GAAG,mBAAmB,CAAC;IAmBnC,CAAC;IAfC,aAAa,CAAC,IAAqC;QACjD,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAKD,qBAAqB,CAAC,IAAqC;QACzD,MAAM,UAAU,GAAG,KAAK,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QACpD,UAA2C,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QACzE,UAA2C,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QACjF,UAA2C,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACrF,UAA2C,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACtF,OAAO,UAAU,CAAC;IACpB,CAAC;CACF;AApBD,sFAoBC","file":"compare-sankey-diff-transformer.js","sourcesContent":["import type { ICompareSankeyDiffChartSpecBase, ICompareSankeyDiffSeriesSpec } from './interface';\nimport { SankeyChartSpecTransformer } from '@visactor/vchart';\n\n/**\n * compare-sankey-diff 图表规格转换器\n */\n// @ts-expect-error\nexport class CompareSankeyDiffChartSpecTransformer extends SankeyChartSpecTransformer<ICompareSankeyDiffChartSpecBase> {\n seriesType = 'compareSankeyDiff';\n /**\n * 转换外部传入的图表规格\n */\n transformSpec(spec: ICompareSankeyDiffChartSpecBase): void {\n super.transformSpec(spec);\n }\n\n /**\n * 生成默认的系列规格,并将图表级配置下发到系列\n */\n _getDefaultSeriesSpec(spec: ICompareSankeyDiffChartSpecBase) {\n const seriesSpec = super._getDefaultSeriesSpec(spec);\n (seriesSpec as ICompareSankeyDiffSeriesSpec).subNodeGap = spec.subNodeGap;\n (seriesSpec as ICompareSankeyDiffSeriesSpec).subNodeMinSize = spec.subNodeMinSize;\n (seriesSpec as ICompareSankeyDiffSeriesSpec).compareNodeColor = spec.compareNodeColor;\n (seriesSpec as ICompareSankeyDiffSeriesSpec).compareLinkColor = spec.compareLinkColor;\n return seriesSpec;\n }\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { ICompareSankeyDiffChartSpecBase, ICompareSankeyDiffSeriesSpecBase } from './interface';
|
|
2
|
+
import { VChart, SankeyChart, SankeySeries } from '@visactor/vchart';
|
|
3
|
+
import { CompareSankeyDiffChartSpecTransformer } from './compare-sankey-diff-transformer';
|
|
4
|
+
type Datum = any;
|
|
5
|
+
export declare class CompareSankeyDiffChart extends SankeyChart<ICompareSankeyDiffChartSpecBase> {
|
|
6
|
+
type: string;
|
|
7
|
+
static type: string;
|
|
8
|
+
readonly seriesType: string;
|
|
9
|
+
_spec: ICompareSankeyDiffChartSpecBase;
|
|
10
|
+
static readonly transformerConstructor: typeof CompareSankeyDiffChartSpecTransformer;
|
|
11
|
+
readonly transformerConstructor: typeof CompareSankeyDiffChartSpecTransformer;
|
|
12
|
+
}
|
|
13
|
+
export declare class CompareSankeyDiffSeries extends SankeySeries<ICompareSankeyDiffSeriesSpecBase> {
|
|
14
|
+
type: string;
|
|
15
|
+
static type: string;
|
|
16
|
+
initData(): void;
|
|
17
|
+
compileData(): void;
|
|
18
|
+
_initLinkMarkStyle(): void;
|
|
19
|
+
_initNodeMarkStyle(): void;
|
|
20
|
+
protected _fillCompareNode: (datum: any) => any;
|
|
21
|
+
protected _fillCompareLink: (datum: any) => any;
|
|
22
|
+
protected _handleClearEmpty(highlightState: string, blurState: string): void;
|
|
23
|
+
getSubNodeDatum(filter: (n: Datum) => boolean): import("@visactor/vgrammar-core").IElement[];
|
|
24
|
+
getNodeDatumInTree(filter: (n: any) => boolean): any[];
|
|
25
|
+
getNodeDatumInSubTree(filter: (n: any) => boolean): {
|
|
26
|
+
[key: string]: any;
|
|
27
|
+
type: string;
|
|
28
|
+
datum: any[];
|
|
29
|
+
}[];
|
|
30
|
+
}
|
|
31
|
+
export declare const registerCompareSankeyDiffChart: (option?: {
|
|
32
|
+
VChart?: typeof VChart;
|
|
33
|
+
}) => void;
|
|
34
|
+
export {};
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.registerCompareSankeyDiffChart = exports.CompareSankeyDiffSeries = exports.CompareSankeyDiffChart = void 0;
|
|
6
|
+
|
|
7
|
+
const vchart_1 = require("@visactor/vchart"), vdataset_1 = require("@visactor/vdataset"), compare_sankey_diff_transformer_1 = require("./compare-sankey-diff-transformer"), compare_sankey_diff_data_1 = require("./compare-sankey-diff-data"), utils_1 = require("../compare-sankey/utils");
|
|
8
|
+
|
|
9
|
+
class CompareSankeyDiffChart extends vchart_1.SankeyChart {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments), this.type = "compareSankeyDiff", this.seriesType = CompareSankeyDiffSeries.type,
|
|
12
|
+
this.transformerConstructor = compare_sankey_diff_transformer_1.CompareSankeyDiffChartSpecTransformer;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
exports.CompareSankeyDiffChart = CompareSankeyDiffChart, CompareSankeyDiffChart.type = "compareSankeyDiff",
|
|
17
|
+
CompareSankeyDiffChart.transformerConstructor = compare_sankey_diff_transformer_1.CompareSankeyDiffChartSpecTransformer;
|
|
18
|
+
|
|
19
|
+
class CompareSankeyDiffSeries extends vchart_1.SankeySeries {
|
|
20
|
+
constructor() {
|
|
21
|
+
super(...arguments), this.type = "compareSankeyDiff", this._fillCompareNode = datum => {
|
|
22
|
+
var _a, _b, _c, _d;
|
|
23
|
+
const specAny = this._spec;
|
|
24
|
+
return (null === (_a = specAny.compareNodeColor) || void 0 === _a ? void 0 : _a[datum.type]) ? specAny.compareNodeColor[datum.type] : null !== (_d = null === (_c = null === (_b = this._spec.node) || void 0 === _b ? void 0 : _b.style) || void 0 === _c ? void 0 : _c.fill) && void 0 !== _d ? _d : this._fillByNode(datum);
|
|
25
|
+
}, this._fillCompareLink = datum => {
|
|
26
|
+
var _a, _b, _c, _d;
|
|
27
|
+
const specAny = this._spec;
|
|
28
|
+
return (null === (_a = specAny.compareLinkColor) || void 0 === _a ? void 0 : _a[datum.type]) ? specAny.compareLinkColor[datum.type] : null !== (_d = null === (_c = null === (_b = this._spec.link) || void 0 === _b ? void 0 : _b.style) || void 0 === _c ? void 0 : _c.fill) && void 0 !== _d ? _d : this._fillByLink(datum);
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
initData() {
|
|
32
|
+
var _a, _b;
|
|
33
|
+
super.initData();
|
|
34
|
+
const {dataSet: dataSet} = this._option, compareData = new vdataset_1.DataView(dataSet, {
|
|
35
|
+
name: `compare-sankey-diff-compare-data-${this.id}-data`
|
|
36
|
+
});
|
|
37
|
+
compareData.parse([ this.getViewData() ], {
|
|
38
|
+
type: "dataview"
|
|
39
|
+
}), (0, vchart_1.registerDataSetInstanceTransform)(this._dataSet, "compareSankeyDiffSubData", compare_sankey_diff_data_1.compareSankeyDiffSubData),
|
|
40
|
+
compareData.transform({
|
|
41
|
+
type: "compareSankeyDiffSubData",
|
|
42
|
+
options: {
|
|
43
|
+
rawData: () => this.getRawData(),
|
|
44
|
+
valueField: this._valueField,
|
|
45
|
+
nodeKey: this._spec.nodeKey,
|
|
46
|
+
subNodeGap: null !== (_a = this._spec.subNodeGap) && void 0 !== _a ? _a : 2,
|
|
47
|
+
subNodeMinSize: null !== (_b = this._spec.subNodeMinSize) && void 0 !== _b ? _b : 0
|
|
48
|
+
}
|
|
49
|
+
}), this._nodesSeriesData.getDataView().parse([ compareData ], {
|
|
50
|
+
type: "dataview"
|
|
51
|
+
}), this._linksSeriesData.getDataView().parse([ compareData ], {
|
|
52
|
+
type: "dataview"
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
compileData() {
|
|
56
|
+
super.compileData();
|
|
57
|
+
}
|
|
58
|
+
_initLinkMarkStyle() {
|
|
59
|
+
super._initLinkMarkStyle(), this._spec.compareLinkColor && this.setMarkStyle(this._linkMark, {
|
|
60
|
+
fill: this._fillCompareLink
|
|
61
|
+
}, "normal", vchart_1.AttributeLevel.User_Mark);
|
|
62
|
+
}
|
|
63
|
+
_initNodeMarkStyle() {
|
|
64
|
+
super._initNodeMarkStyle(), this._spec.compareNodeColor && this.setMarkStyle(this._nodeMark, {
|
|
65
|
+
fill: this._fillCompareNode
|
|
66
|
+
}, "normal", vchart_1.AttributeLevel.User_Mark);
|
|
67
|
+
}
|
|
68
|
+
_handleClearEmpty(highlightState, blurState) {
|
|
69
|
+
super._handleClearEmpty(highlightState, blurState);
|
|
70
|
+
const allNodeElements = this._nodeMark.getProductElements();
|
|
71
|
+
!allNodeElements && allNodeElements.length || allNodeElements.forEach((el => {
|
|
72
|
+
el.removeState(vchart_1.STATE_VALUE_ENUM.STATE_HOVER);
|
|
73
|
+
}));
|
|
74
|
+
const allLinkElements = this._linkMark.getProductElements();
|
|
75
|
+
!allLinkElements && allLinkElements.length || allLinkElements.forEach((el => {
|
|
76
|
+
el.removeState(vchart_1.STATE_VALUE_ENUM.STATE_HOVER);
|
|
77
|
+
}));
|
|
78
|
+
}
|
|
79
|
+
getSubNodeDatum(filter) {
|
|
80
|
+
return (0, utils_1.getSubNodeDatum)(this._nodeMark.getProductElements(), filter);
|
|
81
|
+
}
|
|
82
|
+
getNodeDatumInTree(filter) {
|
|
83
|
+
return (0, utils_1.getNodeDatumInTree)(this._rawData.latestData[0].nodes, filter);
|
|
84
|
+
}
|
|
85
|
+
getNodeDatumInSubTree(filter) {
|
|
86
|
+
return (0, utils_1.getNodeDatumInSubTree)(this._rawData.latestData[0].subNode, filter);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
exports.CompareSankeyDiffSeries = CompareSankeyDiffSeries, CompareSankeyDiffSeries.type = "compareSankeyDiff";
|
|
91
|
+
|
|
92
|
+
const registerCompareSankeyDiffChart = option => {
|
|
93
|
+
const vchartConstructor = (null == option ? void 0 : option.VChart) || vchart_1.VChart;
|
|
94
|
+
vchartConstructor && (vchartConstructor.useChart([ CompareSankeyDiffChart ]), vchartConstructor.useSeries([ CompareSankeyDiffSeries ]));
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
exports.registerCompareSankeyDiffChart = registerCompareSankeyDiffChart;
|
|
98
|
+
//# sourceMappingURL=compare-sankey-diff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/compare-sankey-diff/compare-sankey-diff.ts"],"names":[],"mappings":"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","file":"compare-sankey-diff.js","sourcesContent":["import type { ICompareSankeyDiffChartSpecBase, ICompareSankeyDiffSeriesSpecBase } from './interface';\nimport type { IRectMarkSpec } from '@visactor/vchart';\nimport {\n VChart,\n SankeyChart,\n SankeySeries,\n registerDataSetInstanceTransform,\n STATE_VALUE_ENUM,\n AttributeLevel\n} from '@visactor/vchart';\nimport { DataView } from '@visactor/vdataset';\nimport { CompareSankeyDiffChartSpecTransformer } from './compare-sankey-diff-transformer';\nimport { compareSankeyDiffSubData } from './compare-sankey-diff-data';\nimport { getNodeDatumInSubTree, getNodeDatumInTree, getSubNodeDatum } from '../compare-sankey/utils';\n\ntype Datum = any;\n/**\n * compare-sankey-diff 图表类\n */\n// @ts-expect-error\nexport class CompareSankeyDiffChart extends SankeyChart<ICompareSankeyDiffChartSpecBase> {\n type = 'compareSankeyDiff';\n static type = 'compareSankeyDiff';\n readonly seriesType = CompareSankeyDiffSeries.type;\n\n declare _spec: ICompareSankeyDiffChartSpecBase;\n\n static readonly transformerConstructor = CompareSankeyDiffChartSpecTransformer;\n readonly transformerConstructor = CompareSankeyDiffChartSpecTransformer;\n}\n\n/**\n * compare-sankey-diff 系列类\n */\n// @ts-expect-error\nexport class CompareSankeyDiffSeries extends SankeySeries<ICompareSankeyDiffSeriesSpecBase> {\n // @ts-ignore\n type = 'compareSankeyDiff';\n static type = 'compareSankeyDiff';\n\n /**\n * 初始化数据视图,构建子节点数据与对比节点数据\n */\n initData() {\n super.initData();\n const { dataSet } = this._option;\n\n // 数据逻辑变化\n // 使用原始总计数据生成原始节点位置 这里可以不变\n // 使用每一个对比数据生成对比节点和对比边\n // 使用总计数据的节点位置更新对比数据的节点位置\n // 使用对比数据的点更新对比数据的边\n // 新数据以来原始数据,以来原始数据结果\n\n const compareData = new DataView(dataSet, { name: `compare-sankey-diff-compare-data-${this.id}-data` });\n compareData.parse([this.getViewData()], { type: 'dataview' });\n\n // 注册并执行子节点拆解与聚合\n registerDataSetInstanceTransform(this._dataSet, 'compareSankeyDiffSubData', compareSankeyDiffSubData);\n compareData.transform({\n type: 'compareSankeyDiffSubData',\n options: {\n rawData: () => this.getRawData(),\n valueField: this._valueField,\n nodeKey: this._spec.nodeKey,\n subNodeGap: (this._spec as any).subNodeGap ?? 2,\n subNodeMinSize: (this._spec as any).subNodeMinSize ?? 0\n }\n });\n\n this._nodesSeriesData.getDataView().parse([compareData], {\n type: 'dataview'\n });\n this._linksSeriesData.getDataView().parse([compareData], {\n type: 'dataview'\n });\n }\n\n /**\n * 编译数据\n */\n compileData() {\n super.compileData();\n }\n\n /**\n * 初始化链接样式(激活态)\n */\n _initLinkMarkStyle() {\n super._initLinkMarkStyle();\n if ((this._spec as any).compareLinkColor) {\n this.setMarkStyle<IRectMarkSpec>(\n this._linkMark,\n { fill: this._fillCompareLink },\n 'normal',\n AttributeLevel.User_Mark\n );\n }\n }\n\n /**\n * 初始化节点样式(支持对比颜色)\n */\n _initNodeMarkStyle() {\n super._initNodeMarkStyle();\n if ((this._spec as any).compareNodeColor) {\n this.setMarkStyle<IRectMarkSpec>(\n this._nodeMark,\n { fill: this._fillCompareNode },\n 'normal',\n AttributeLevel.User_Mark\n );\n }\n }\n\n /**\n * 计算节点填充色(支持 compareNodeColor)\n */\n protected _fillCompareNode = (datum: any) => {\n const specAny = this._spec as any;\n if (specAny.compareNodeColor?.[datum.type]) {\n return specAny.compareNodeColor[datum.type];\n }\n return this._spec.node?.style?.fill ?? this._fillByNode(datum);\n };\n\n /**\n * 计算激活态链接填充色(支持 compareLinkColor)\n */\n protected _fillCompareLink = (datum: any) => {\n const specAny = this._spec as any;\n if (specAny.compareLinkColor?.[datum.type]) {\n return specAny.compareLinkColor[datum.type];\n }\n return this._spec.link?.style?.fill ?? this._fillByLink(datum);\n };\n\n /**\n * 清除状态时同时清空激活态链接与 hover\n */\n protected _handleClearEmpty(highlightState: string, blurState: string) {\n super._handleClearEmpty(highlightState, blurState);\n\n const allNodeElements = this._nodeMark.getProductElements();\n if (allNodeElements || !allNodeElements.length) {\n allNodeElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n\n const allLinkElements = this._linkMark.getProductElements();\n if (allLinkElements || !allLinkElements.length) {\n allLinkElements.forEach(el => {\n el.removeState(STATE_VALUE_ENUM.STATE_HOVER);\n });\n }\n }\n\n public getSubNodeDatum(filter: (n: Datum) => boolean) {\n return getSubNodeDatum(this._nodeMark.getProductElements(), filter);\n }\n\n public getNodeDatumInTree(filter: (n: any) => boolean) {\n return getNodeDatumInTree(this._rawData.latestData[0].nodes, filter);\n }\n\n public getNodeDatumInSubTree(filter: (n: any) => boolean) {\n return getNodeDatumInSubTree(this._rawData.latestData[0].subNode, filter);\n }\n}\n\n/**\n * 注册 compare-sankey-diff 图表与系列\n */\nexport const registerCompareSankeyDiffChart = (option?: { VChart?: typeof VChart }) => {\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([CompareSankeyDiffChart]);\n vchartConstructor.useSeries([CompareSankeyDiffSeries]);\n }\n};\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __createBinding = this && this.__createBinding || (Object.create ? function(o, m, k, k2) {
|
|
4
|
+
void 0 === k2 && (k2 = k);
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
desc && !("get" in desc ? !m.__esModule : desc.writable || desc.configurable) || (desc = {
|
|
7
|
+
enumerable: !0,
|
|
8
|
+
get: function() {
|
|
9
|
+
return m[k];
|
|
10
|
+
}
|
|
11
|
+
}), Object.defineProperty(o, k2, desc);
|
|
12
|
+
} : function(o, m, k, k2) {
|
|
13
|
+
void 0 === k2 && (k2 = k), o[k2] = m[k];
|
|
14
|
+
}), __exportStar = this && this.__exportStar || function(m, exports) {
|
|
15
|
+
for (var p in m) "default" === p || Object.prototype.hasOwnProperty.call(exports, p) || __createBinding(exports, m, p);
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
Object.defineProperty(exports, "__esModule", {
|
|
19
|
+
value: !0
|
|
20
|
+
}), __exportStar(require("./interface"), exports), __exportStar(require("./compare-sankey-diff"), exports);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/compare-sankey-diff/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,wDAAsC","file":"index.js","sourcesContent":["export * from './interface';\nexport * from './compare-sankey-diff';\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { ISankeyChartSpec, ISankeySeriesSpec } from '@visactor/vchart';
|
|
2
|
+
export interface ICompareSankeyDiffSpec {
|
|
3
|
+
subNodeGap?: number;
|
|
4
|
+
subNodeMinSize?: number;
|
|
5
|
+
compareNodeColor?: {
|
|
6
|
+
[key: string]: string;
|
|
7
|
+
};
|
|
8
|
+
compareLinkColor?: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
};
|
|
11
|
+
emphasis?: Omit<ISankeySeriesSpec['emphasis'], 'effect'> & {
|
|
12
|
+
effect?: ISankeySeriesSpec['emphasis']['effect'] | 'related-node';
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
export interface ICompareSankeyDiffSeriesSpecBase extends Omit<ISankeySeriesSpec, 'emphasis'>, ICompareSankeyDiffSpec {
|
|
16
|
+
}
|
|
17
|
+
export interface ICompareSankeyDiffChartSpecBase extends Omit<ISankeyChartSpec, 'emphasis'>, ICompareSankeyDiffSpec {
|
|
18
|
+
}
|
|
19
|
+
export interface ICompareSankeyDiffSeriesSpec extends Omit<ICompareSankeyDiffSeriesSpecBase, 'type' | 'series'> {
|
|
20
|
+
type: 'compareSankeyDiff';
|
|
21
|
+
}
|
|
22
|
+
export interface ICompareSankeyDiffChartSpec extends Omit<ICompareSankeyDiffChartSpecBase, 'type' | 'series'> {
|
|
23
|
+
type: 'compareSankeyDiff';
|
|
24
|
+
}
|