@visactor/vchart-extension 1.13.7-alpha.0 → 2.0.0-alpha.0
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 +2836 -3323
- package/build/index.min.js +2 -2
- package/cjs/charts/conversion-funnel/conversion-funnel.js +3 -2
- package/cjs/charts/conversion-funnel/conversion-funnel.js.map +1 -1
- package/cjs/components/series-break/series-break.js +2 -2
- package/cjs/components/series-break/series-break.js.map +1 -1
- package/cjs/components/series-break/util.js +6 -6
- package/cjs/components/series-break/util.js.map +1 -1
- package/esm/charts/conversion-funnel/conversion-funnel.js +4 -3
- package/esm/charts/conversion-funnel/conversion-funnel.js.map +1 -1
- package/esm/components/series-break/series-break.js +2 -2
- package/esm/components/series-break/series-break.js.map +1 -1
- package/esm/components/series-break/util.js +6 -6
- package/esm/components/series-break/util.js.map +1 -1
- package/package.json +8 -8
|
@@ -35,14 +35,14 @@ class ConversionFunnelSeries extends vchart_1.FunnelSeries {
|
|
|
35
35
|
null === (_a = super.afterCompile) || void 0 === _a || _a.call(this);
|
|
36
36
|
const rightGroup = this.getMarkInName("arrowRight");
|
|
37
37
|
rightGroup && rightGroup.getMarks().forEach((mark => {
|
|
38
|
-
mark.setDataView(this._arrowData), mark.compileData(), mark.
|
|
38
|
+
mark.setDataView(this._arrowData), mark.compileData(), mark.setTransform([ {
|
|
39
39
|
type: "filter",
|
|
40
40
|
callback: datum => "right" === datum.position
|
|
41
41
|
} ]);
|
|
42
42
|
}));
|
|
43
43
|
const leftGroup = this.getMarkInName("arrowLeft");
|
|
44
44
|
leftGroup && leftGroup.getMarks().forEach((mark => {
|
|
45
|
-
mark.setDataView(this._arrowData), mark.compileData(), mark.
|
|
45
|
+
mark.setDataView(this._arrowData), mark.compileData(), mark.setTransform([ {
|
|
46
46
|
type: "filter",
|
|
47
47
|
callback: datum => "left" === datum.position
|
|
48
48
|
} ]);
|
|
@@ -53,6 +53,7 @@ class ConversionFunnelSeries extends vchart_1.FunnelSeries {
|
|
|
53
53
|
exports.ConversionFunnelSeries = ConversionFunnelSeries;
|
|
54
54
|
|
|
55
55
|
const registerConversionFunnelChart = option => {
|
|
56
|
+
(0, vchart_1.registerMarkFilterTransform)();
|
|
56
57
|
const vchartConstructor = (null == option ? void 0 : option.VChart) || vchart_1.VChart;
|
|
57
58
|
vchartConstructor && (vchartConstructor.useChart([ ConversionFunnelChart ]), vchartConstructor.useSeries([ ConversionFunnelSeries ]));
|
|
58
59
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["charts/conversion-funnel/conversion-funnel.ts"],"names":[],"mappings":";;;AACA,
|
|
1
|
+
{"version":3,"sources":["charts/conversion-funnel/conversion-funnel.ts"],"names":[],"mappings":"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","file":"conversion-funnel.js","sourcesContent":["import type { IConversionFunnelChartSpecBase, IConversionFunnelSeriesSpecBase } from './interface';\nimport { VChart, FunnelChart, PREFIX, FunnelSeries, GroupMark, registerMarkFilterTransform } from '@visactor/vchart';\nimport { DataView } from '@visactor/vdataset';\nimport { ConversionFunnelChartSpecTransformer } from './conversion-funnel-transformer';\nimport { conversionArrowTransform } from './arrow-data-transform';\n\nexport class ConversionFunnelChart extends FunnelChart<IConversionFunnelChartSpecBase> {\n type = 'conversionFunnel';\n static type = 'conversionFunnel';\n\n declare _spec: IConversionFunnelChartSpecBase;\n\n static readonly transformerConstructor = ConversionFunnelChartSpecTransformer;\n readonly transformerConstructor = ConversionFunnelChartSpecTransformer;\n}\n\nexport class ConversionFunnelSeries extends FunnelSeries<IConversionFunnelSeriesSpecBase> {\n protected _arrowData?: DataView;\n\n initData() {\n super.initData();\n const { conversionArrow } = this._spec;\n if (conversionArrow && conversionArrow.arrows?.length) {\n this._arrowData = new DataView(this._dataSet, { name: `${PREFIX}_series_${this.id}_arrowData` });\n if (!this._dataSet.getTransform('conversionArrow')) {\n this._dataSet.registerTransform('conversionArrow', conversionArrowTransform);\n }\n this._arrowData.parse(conversionArrow).transform({\n type: 'conversionArrow',\n options: {\n categoryField: this._spec.categoryField\n }\n });\n }\n }\n\n afterCompile() {\n // @ts-ignore\n super.afterCompile?.();\n const rightGroup = this.getMarkInName('arrowRight') as unknown as GroupMark;\n if (rightGroup) {\n rightGroup.getMarks().forEach(mark => {\n mark.setDataView(this._arrowData);\n mark.compileData();\n mark.setTransform([\n {\n type: 'filter',\n callback: datum => datum.position === 'right'\n }\n ]);\n });\n }\n const leftGroup = this.getMarkInName('arrowLeft') as unknown as GroupMark;\n if (leftGroup) {\n leftGroup.getMarks().forEach(mark => {\n mark.setDataView(this._arrowData);\n mark.compileData();\n mark.setTransform([\n {\n type: 'filter',\n callback: datum => datum.position === 'left'\n }\n ]);\n });\n }\n }\n}\n\nexport const registerConversionFunnelChart = (option?: { VChart?: typeof VChart }) => {\n registerMarkFilterTransform();\n\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([ConversionFunnelChart]);\n vchartConstructor.useSeries([ConversionFunnelSeries]);\n }\n};\n\nexport const DEFAULT_ARROW_MARK_STYLE = {\n cornerRadius: 4,\n stroke: 'black',\n strokeOpacity: 1,\n lineWidth: 1,\n closePath: false,\n pickable: false\n};\n\nexport const DEFAULT_ARROW_SYMBOL_MARK_STYLE = {\n symbolType: 'triangle',\n size: 8,\n scaleX: 0.7,\n fill: 'black'\n};\n\nexport const DEFAULT_ARROW_TEXT_MARK_STYLE = {\n fill: '#606773',\n fontSize: 12\n};\n\nexport const DEFAULT_FUNNEL_BACKGROUND_MARK_STYLE = {\n fill: '#eff1f9'\n};\n"]}
|
|
@@ -14,7 +14,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
14
14
|
value: !0
|
|
15
15
|
}), exports.registerSeriesBreak = exports.SeriesBreakComponent = void 0;
|
|
16
16
|
|
|
17
|
-
const vrender_components_1 = require("@visactor/vrender-components"),
|
|
17
|
+
const vrender_components_1 = require("@visactor/vrender-components"), vrender_core_1 = require("@visactor/vrender-core"), vutils_1 = require("@visactor/vutils"), constant_1 = require("./constant"), vchart_1 = require("@visactor/vchart");
|
|
18
18
|
|
|
19
19
|
function generateZigzagPath(start, end, size, angle, isVertical = !1) {
|
|
20
20
|
const path = [], {x: startX, y: startY} = start, {x: endX, y: endY} = end, numZigzags = isVertical ? Math.floor((endY - startY) / (2 * size)) : Math.floor((endX - startX) / (2 * size)), angleRad = Math.PI / 180 * angle, deltaX = size * Math.cos(angleRad), deltaY = size * Math.sin(angleRad);
|
|
@@ -111,7 +111,7 @@ class SeriesBreakComponent extends vrender_components_1.AbstractComponent {
|
|
|
111
111
|
exports.SeriesBreakComponent = SeriesBreakComponent;
|
|
112
112
|
|
|
113
113
|
const registerSeriesBreak = () => {
|
|
114
|
-
|
|
114
|
+
vchart_1.Factory.registerGraphicComponent("seriesBreak", (attrs => new SeriesBreakComponent(attrs)));
|
|
115
115
|
};
|
|
116
116
|
|
|
117
117
|
exports.registerSeriesBreak = registerSeriesBreak;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["components/series-break/series-break.ts"],"names":[],"mappings":"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","file":"series-break.js","sourcesContent":["/**\n * @description vchart 自定义组件,用于实现 bar、area、line 这些图形的截断图形生成\n * @author zhangweixing\n */\n\nimport { AbstractComponent, Point } from '@visactor/vrender-components';\nimport { Factory } from '@visactor/vgrammar-core';\nimport { SeriesBreakAttrs, SeriesBreakData } from './type';\nimport { createGroup, createPath, IGraphic } from '@visactor/vrender-core';\nimport { isEmpty, isNumberClose, isValid } from '@visactor/vutils';\nimport { SERIES_BREAK } from './constant';\n\n/**\n * 求锯齿的路径(一个锯齿由向上和向下的两个线段组成)\n * @param start 锯齿的起始点\n * @param end 锯齿的结束点\n * @param size 锯齿的高度\n * @param angle 锯齿的角度\n * @param gap 两条锯齿的间距\n * @param isVertical 是否垂直\n * @returns\n */\nfunction generateZigzagPath(start: Point, end: Point, size: number, angle: number, isVertical = false) {\n const path = [];\n const { x: startX, y: startY } = start;\n const { x: endX, y: endY } = end;\n\n // 计算锯齿的数量\n const numZigzags = isVertical ? Math.floor((endY - startY) / (size * 2)) : Math.floor((endX - startX) / (size * 2));\n\n // 计算倾斜角度的增量\n const angleRad = (Math.PI / 180) * angle; // 转换为弧度\n const deltaX = size * Math.cos(angleRad);\n const deltaY = size * Math.sin(angleRad);\n\n // 添加第一条锯齿的起始点\n path.push(`M ${startX} ${startY}`);\n\n for (let i = 0; i <= numZigzags; i++) {\n const x = isVertical ? startX + (i % 2 === 0 ? deltaX : -deltaX) : startX + i * size * 2;\n const y = isVertical ? startY + i * size * 2 : i % 2 === 0 ? startY - deltaY : startY + deltaY;\n path.push(`L ${x} ${y}`);\n }\n\n // 添加第一条锯齿的结束点\n path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`);\n\n return path.join(' ');\n}\n\nconst checkOverlap = (prevData: SeriesBreakData[], newEntry: SeriesBreakData) => {\n const { start, end } = newEntry;\n const isVertical = start.x === end.x;\n const equalDim = isVertical ? 'x' : 'y';\n const diffDim = isVertical ? 'y' : 'x';\n let needAppend = true;\n const EPS = 1e-6;\n\n if (prevData.length) {\n prevData.forEach(prevEntry => {\n if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {\n // 判断是否有重叠,有重叠取交集\n const minDim = Math.min(start[diffDim], end[diffDim]);\n const maxDim = Math.max(start[diffDim], end[diffDim]);\n const prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const hasOverlap = !(maxDim < prevMinDim - EPS || minDim > prevMaxDim + EPS);\n\n if (hasOverlap) {\n prevEntry.start[diffDim] = Math.min(prevMinDim, minDim);\n prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim);\n needAppend = false;\n return;\n }\n }\n });\n }\n\n if (needAppend) {\n prevData.push(newEntry);\n }\n};\n\nexport class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {\n name = SERIES_BREAK;\n protected render() {\n this.removeAllChild();\n const { data = [] } = this.attribute as SeriesBreakAttrs;\n if (isEmpty(data)) {\n return;\n }\n // 去除重叠数据\n const verticalData: SeriesBreakData[] = [];\n const horizontalData: SeriesBreakData[] = [];\n\n data.forEach(breakData => {\n const { start, end } = breakData;\n const isVertical = start.x === end.x;\n\n checkOverlap(isVertical ? verticalData : horizontalData, breakData);\n });\n\n [...verticalData, ...horizontalData].forEach((breakData, id) => {\n const { start, end, size = 4, gap = 5, style = {}, ...rest } = breakData;\n const breakGroup = createGroup({});\n const isVertical = start.x === end.x;\n\n let startPathStart;\n let startPathEnd;\n let endPathStart;\n let endPathEnd;\n if (isVertical) {\n startPathStart = {\n x: start.x - gap / 2,\n y: start.y\n };\n startPathEnd = {\n x: end.x - gap / 2,\n y: end.y\n };\n endPathStart = {\n x: start.x + gap / 2,\n y: start.y\n };\n endPathEnd = {\n x: end.x + gap / 2,\n y: end.y\n };\n } else {\n startPathStart = {\n x: start.x,\n y: start.y - gap / 2\n };\n startPathEnd = {\n x: end.x,\n y: end.y - gap / 2\n };\n endPathStart = {\n x: start.x,\n y: start.y + gap / 2\n };\n endPathEnd = {\n x: end.x,\n y: end.y + gap / 2\n };\n }\n\n const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical);\n const centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical);\n const endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);\n breakGroup.add(\n createPath({\n path: startPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: endPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: centerPath,\n stroke: '#fff',\n lineWidth: gap,\n pickable: false,\n zIndex: 0\n })\n );\n\n breakGroup.name = 'series-break';\n breakGroup.data = rest;\n\n if (isValid(rest.axisId)) {\n breakGroup.id = `${rest.axisId ?? ''}_${id}`;\n }\n\n this.add(breakGroup);\n });\n }\n}\n\nexport const registerSeriesBreak = () => {\n Factory.registerGraphicComponent(\n 'seriesBreak',\n (attrs: Required<SeriesBreakAttrs>) => new SeriesBreakComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["components/series-break/series-break.ts"],"names":[],"mappings":"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","file":"series-break.js","sourcesContent":["/**\n * @description vchart 自定义组件,用于实现 bar、area、line 这些图形的截断图形生成\n * @author zhangweixing\n */\n\nimport { AbstractComponent, Point } from '@visactor/vrender-components';\nimport { SeriesBreakAttrs, SeriesBreakData } from './type';\nimport { createGroup, createPath, IGraphic } from '@visactor/vrender-core';\nimport { isEmpty, isNumberClose, isValid } from '@visactor/vutils';\nimport { SERIES_BREAK } from './constant';\nimport { Factory } from '@visactor/vchart';\n\n/**\n * 求锯齿的路径(一个锯齿由向上和向下的两个线段组成)\n * @param start 锯齿的起始点\n * @param end 锯齿的结束点\n * @param size 锯齿的高度\n * @param angle 锯齿的角度\n * @param gap 两条锯齿的间距\n * @param isVertical 是否垂直\n * @returns\n */\nfunction generateZigzagPath(start: Point, end: Point, size: number, angle: number, isVertical = false) {\n const path = [];\n const { x: startX, y: startY } = start;\n const { x: endX, y: endY } = end;\n\n // 计算锯齿的数量\n const numZigzags = isVertical ? Math.floor((endY - startY) / (size * 2)) : Math.floor((endX - startX) / (size * 2));\n\n // 计算倾斜角度的增量\n const angleRad = (Math.PI / 180) * angle; // 转换为弧度\n const deltaX = size * Math.cos(angleRad);\n const deltaY = size * Math.sin(angleRad);\n\n // 添加第一条锯齿的起始点\n path.push(`M ${startX} ${startY}`);\n\n for (let i = 0; i <= numZigzags; i++) {\n const x = isVertical ? startX + (i % 2 === 0 ? deltaX : -deltaX) : startX + i * size * 2;\n const y = isVertical ? startY + i * size * 2 : i % 2 === 0 ? startY - deltaY : startY + deltaY;\n path.push(`L ${x} ${y}`);\n }\n\n // 添加第一条锯齿的结束点\n path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`);\n\n return path.join(' ');\n}\n\nconst checkOverlap = (prevData: SeriesBreakData[], newEntry: SeriesBreakData) => {\n const { start, end } = newEntry;\n const isVertical = start.x === end.x;\n const equalDim = isVertical ? 'x' : 'y';\n const diffDim = isVertical ? 'y' : 'x';\n let needAppend = true;\n const EPS = 1e-6;\n\n if (prevData.length) {\n prevData.forEach(prevEntry => {\n if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {\n // 判断是否有重叠,有重叠取交集\n const minDim = Math.min(start[diffDim], end[diffDim]);\n const maxDim = Math.max(start[diffDim], end[diffDim]);\n const prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const hasOverlap = !(maxDim < prevMinDim - EPS || minDim > prevMaxDim + EPS);\n\n if (hasOverlap) {\n prevEntry.start[diffDim] = Math.min(prevMinDim, minDim);\n prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim);\n needAppend = false;\n return;\n }\n }\n });\n }\n\n if (needAppend) {\n prevData.push(newEntry);\n }\n};\n\nexport class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {\n name = SERIES_BREAK;\n protected render() {\n this.removeAllChild();\n const { data = [] } = this.attribute as SeriesBreakAttrs;\n if (isEmpty(data)) {\n return;\n }\n // 去除重叠数据\n const verticalData: SeriesBreakData[] = [];\n const horizontalData: SeriesBreakData[] = [];\n\n data.forEach(breakData => {\n const { start, end } = breakData;\n const isVertical = start.x === end.x;\n\n checkOverlap(isVertical ? verticalData : horizontalData, breakData);\n });\n\n [...verticalData, ...horizontalData].forEach((breakData, id) => {\n const { start, end, size = 4, gap = 5, style = {}, ...rest } = breakData;\n const breakGroup = createGroup({});\n const isVertical = start.x === end.x;\n\n let startPathStart;\n let startPathEnd;\n let endPathStart;\n let endPathEnd;\n if (isVertical) {\n startPathStart = {\n x: start.x - gap / 2,\n y: start.y\n };\n startPathEnd = {\n x: end.x - gap / 2,\n y: end.y\n };\n endPathStart = {\n x: start.x + gap / 2,\n y: start.y\n };\n endPathEnd = {\n x: end.x + gap / 2,\n y: end.y\n };\n } else {\n startPathStart = {\n x: start.x,\n y: start.y - gap / 2\n };\n startPathEnd = {\n x: end.x,\n y: end.y - gap / 2\n };\n endPathStart = {\n x: start.x,\n y: start.y + gap / 2\n };\n endPathEnd = {\n x: end.x,\n y: end.y + gap / 2\n };\n }\n\n const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical);\n const centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical);\n const endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);\n breakGroup.add(\n createPath({\n path: startPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: endPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: centerPath,\n stroke: '#fff',\n lineWidth: gap,\n pickable: false,\n zIndex: 0\n })\n );\n\n breakGroup.name = 'series-break';\n breakGroup.data = rest;\n\n if (isValid(rest.axisId)) {\n breakGroup.id = `${rest.axisId ?? ''}_${id}`;\n }\n\n this.add(breakGroup);\n });\n }\n}\n\nexport const registerSeriesBreak = () => {\n Factory.registerGraphicComponent(\n 'seriesBreak',\n (attrs: Required<SeriesBreakAttrs>) => new SeriesBreakComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
|
|
@@ -26,8 +26,8 @@ function getSeriesBreakConfig(axesSpec, axesIndex) {
|
|
|
26
26
|
const {range: range, breakSymbol: breakSymbol, gap: gap = 5} = breakConfig, pos1 = axisModel.valueToPosition(range[0]), pos2 = axisModel.valueToPosition(range[1]), posY = (pos1 + pos2) / 2 + (isHorizontal ? regionBounds.x1 : regionBounds.y1);
|
|
27
27
|
chart.getAllSeries().forEach((s => {
|
|
28
28
|
if ("bar" === s.type || "waterfall" === s.type) {
|
|
29
|
-
s.getMarkInName("bar").
|
|
30
|
-
const elementBounds = element.
|
|
29
|
+
s.getMarkInName("bar").getGraphics().forEach((element => {
|
|
30
|
+
const elementBounds = element.AABBBounds;
|
|
31
31
|
let startX, startY, endX, endY, shouldDrawBreak = !1;
|
|
32
32
|
isHorizontal ? (shouldDrawBreak = elementBounds.x1 < (pos1 + pos2 - gap) / 2 && elementBounds.x2 > (pos1 + pos2 + gap) / 2,
|
|
33
33
|
startX = posY, startY = Math.max(elementBounds.y1 + regionBounds.y1 - 2, regionBounds.y1),
|
|
@@ -50,8 +50,8 @@ function getSeriesBreakConfig(axesSpec, axesIndex) {
|
|
|
50
50
|
});
|
|
51
51
|
}));
|
|
52
52
|
} else if ("line" === s.type) {
|
|
53
|
-
s.getMarkInName(s.type).
|
|
54
|
-
getAreaOrLinePathPoints(
|
|
53
|
+
s.getMarkInName(s.type).getGraphics().forEach((graphicItem => {
|
|
54
|
+
getAreaOrLinePathPoints(graphicItem, "line").forEach((linePoints => {
|
|
55
55
|
getIntersectionsFromLineAndPolyline(isHorizontal ? {
|
|
56
56
|
start: {
|
|
57
57
|
x: (pos1 + pos2) / 2,
|
|
@@ -96,8 +96,8 @@ function getSeriesBreakConfig(axesSpec, axesIndex) {
|
|
|
96
96
|
}));
|
|
97
97
|
}));
|
|
98
98
|
} else if ("area" === s.type) {
|
|
99
|
-
s.getMarkInName("area").
|
|
100
|
-
getAreaOrLinePathPoints(
|
|
99
|
+
s.getMarkInName("area").getGraphics().forEach((graphicItem => {
|
|
100
|
+
getAreaOrLinePathPoints(graphicItem, "area").forEach((areaPoints => {
|
|
101
101
|
const intersections = getIntersectionsFromLineAndPolyline(isHorizontal ? {
|
|
102
102
|
start: {
|
|
103
103
|
x: (pos1 + pos2) / 2,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["components/series-break/util.ts"],"names":[],"mappings":"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","file":"util.js","sourcesContent":["/**\n * 支持轴翻转\n */\nimport type { ILinearAxisBreakSpec, ILinearAxisSpec } from '@visactor/vchart/esm/component/axis';\nimport { ICartesianSeries, ISpec } from '@visactor/vchart';\nimport { SeriesBreakData } from './type';\nimport { array, getIntersectPoint, IPointLike, isValid, PointService } from '@visactor/vutils';\nimport { Point } from '@visactor/vrender-components';\nimport { IArea, ILine } from '@visactor/vrender-core';\nimport { getAllRegionBounds } from '../../utils/element';\nimport { isNumberEqual } from '../../utils/math';\nimport { SERIES_BREAK } from './constant';\n\nconst barOffset = 2;\nconst lineOffset = 10;\nconst areaOffset = 0;\n\n/**\n * 获取系列标签的 spec 配置\n * @param position 显示位置\n * @param config 系列标签的样式配置\n * @returns\n */\nexport function getSeriesBreakConfig(axesSpec: ILinearAxisSpec[], axesIndex?: number[]) {\n return {\n type: 'component',\n componentType: SERIES_BREAK,\n interactive: true,\n zIndex: 500,\n\n style: {\n data: (datum: any, ctx: any) => {\n const seriesBreakData: SeriesBreakData[] = [];\n const vchart = ctx.vchart;\n const chart = vchart.getChart();\n const series = chart.getAllSeries()[0] as ICartesianSeries;\n const isHorizontal = series.direction === 'horizontal';\n axesSpec.forEach((spec: any, index: number) => {\n const axisId = spec.id;\n const axisModel = isValid(axisId)\n ? chart.getComponentByUserId(axisId)\n : axesIndex && isValid(axesIndex[index])\n ? chart.getComponentByIndex('axes', axesIndex[index])\n : chart.getComponentsByKey('axes').filter((axis: { getSpec: () => any }) => {\n const axisInnerSpec = axis.getSpec();\n\n return axisInnerSpec.breaks === spec.breaks;\n })?.[0];\n\n if (!axisModel) {\n return;\n }\n const parsedAxisId = axisId ?? `${axisModel.type}-${axisModel.id}`;\n\n const regionBounds = getAllRegionBounds(axisModel.getRegions());\n\n // todo 这里用到了内部变量,不太安全\n array(axisModel._break?.breaks).forEach((breakConfig: ILinearAxisBreakSpec) => {\n const { range, breakSymbol, gap = 5 } = breakConfig;\n const pos1 = axisModel.valueToPosition(range[0]);\n const pos2 = axisModel.valueToPosition(range[1]);\n\n const posY = (pos1 + pos2) / 2 + (isHorizontal ? regionBounds.x1 : regionBounds.y1);\n\n chart.getAllSeries().forEach((s: ICartesianSeries) => {\n if (s.type === 'bar' || s.type === 'waterfall') {\n const mark = s.getMarkInName('bar');\n const vgrammarElements = mark.getProduct().elements;\n vgrammarElements.forEach((element: any) => {\n const elementBounds = element.getBounds();\n let shouldDrawBreak = false;\n let startX;\n let startY;\n let endX;\n let endY;\n if (isHorizontal) {\n shouldDrawBreak =\n elementBounds.x1 < (pos1 + pos2 - (gap as number)) / 2 &&\n elementBounds.x2 > (pos1 + pos2 + gap) / 2;\n\n startX = posY;\n startY = Math.max(elementBounds.y1 + regionBounds.y1 - barOffset, regionBounds.y1);\n\n endX = posY;\n endY = Math.min(elementBounds.y2 + regionBounds.y1 + barOffset, regionBounds.y2);\n } else {\n shouldDrawBreak =\n elementBounds.y1 < (pos1 + pos2 - (gap as number)) / 2 &&\n elementBounds.y2 > (pos1 + pos2 + gap) / 2;\n startX = Math.max(elementBounds.x1 + regionBounds.x1 - barOffset, regionBounds.x1);\n startY = posY;\n endX = Math.min(elementBounds.x2 + regionBounds.x1 + barOffset, regionBounds.x2);\n endY = posY;\n }\n\n if (shouldDrawBreak) {\n seriesBreakData.push({\n start: {\n x: startX,\n y: startY\n },\n end: {\n x: endX,\n y: endY\n },\n gap: gap as number,\n style: breakSymbol?.style,\n axisId: parsedAxisId,\n data: range\n });\n }\n });\n } else if (s.type === 'line') {\n // 求水平直线/垂直线同 line path 的交点\n const mark = s.getMarkInName(s.type);\n const vgrammarElements = mark.getProduct().elements;\n vgrammarElements.forEach((element: any) => {\n const graphicItem = element.graphicItem;\n const points = getAreaOrLinePathPoints(graphicItem, 'line');\n points.forEach(linePoints => {\n // 开始查找交点\n const intersections = getIntersectionsFromLineAndPolyline(\n isHorizontal\n ? {\n start: { x: (pos1 + pos2) / 2, y: 0 },\n end: { x: (pos1 + pos2) / 2, y: regionBounds.y2 - regionBounds.y1 }\n }\n : {\n start: { x: 0, y: (pos1 + pos2) / 2 },\n end: { x: regionBounds.x2 - regionBounds.x1, y: (pos1 + pos2) / 2 }\n },\n linePoints\n );\n\n intersections.forEach(intersection => {\n let start;\n let end;\n if (isHorizontal) {\n start = {\n x: posY,\n y: Math.max(intersection[1] + regionBounds.y1 - lineOffset, regionBounds.y1)\n };\n end = {\n x: posY,\n y: Math.min(intersection[1] + regionBounds.y1 + lineOffset, regionBounds.y2)\n };\n } else {\n start = {\n x: Math.max(intersection[0] + regionBounds.x1 - lineOffset, regionBounds.x1),\n y: posY\n };\n end = {\n x: Math.min(intersection[0] + regionBounds.x1 + lineOffset, regionBounds.x2),\n y: posY\n };\n }\n seriesBreakData.push({\n start,\n end,\n gap: gap as number,\n style: breakSymbol?.style,\n axisId: parsedAxisId,\n data: range\n });\n });\n });\n });\n } else if (s.type === 'area') {\n // 默认面积去全部堆叠\n const mark = s.getMarkInName('area');\n const vgrammarElements = mark.getProduct().elements;\n vgrammarElements.forEach((element: any) => {\n const graphicItem = element.graphicItem;\n const points = getAreaOrLinePathPoints(graphicItem, 'area');\n points.forEach(areaPoints => {\n const intersections = getIntersectionsFromLineAndPolyline(\n isHorizontal\n ? {\n start: { x: (pos1 + pos2) / 2, y: 0 },\n end: { x: (pos1 + pos2) / 2, y: regionBounds.y2 - regionBounds.y1 }\n }\n : {\n start: { x: 0, y: (pos1 + pos2) / 2 },\n end: { x: regionBounds.x2 - regionBounds.x1, y: (pos1 + pos2) / 2 }\n },\n areaPoints\n );\n\n intersections.sort((a, b) => a[0] - b[0]);\n\n for (let index = 0; index < intersections.length - 1; index++) {\n const lineStart = {\n x: intersections[index][0],\n y: intersections[index][1]\n };\n const lineEnd = {\n x: intersections[index + 1][0],\n y: intersections[index + 1][1]\n };\n if (\n isPointInPolygon(\n isHorizontal\n ? {\n x: lineStart.x,\n y: (lineStart.y + lineEnd.y) / 2\n }\n : {\n x: (lineStart.x + lineEnd.x) / 2,\n y: lineStart.y\n },\n areaPoints\n )\n ) {\n let start;\n let end;\n if (isHorizontal) {\n start = {\n x: lineStart.x + regionBounds.x1,\n y: Math.max(lineStart.y + regionBounds.y1 - areaOffset, regionBounds.y1)\n };\n end = {\n x: lineEnd.x + regionBounds.x1,\n y: Math.min(lineEnd.y + regionBounds.y1 + areaOffset, regionBounds.y2)\n };\n } else {\n start = {\n x: Math.max(lineStart.x + regionBounds.x1 - areaOffset, regionBounds.x1),\n y: lineStart.y + regionBounds.y1\n };\n end = {\n x: Math.min(lineEnd.x + regionBounds.x1 + areaOffset, regionBounds.x2),\n y: lineEnd.y + regionBounds.y1\n };\n }\n seriesBreakData.push({\n start,\n end,\n gap: gap as number,\n style: breakSymbol?.style,\n axisId: parsedAxisId,\n data: range\n });\n }\n }\n });\n });\n }\n });\n });\n });\n\n return seriesBreakData;\n }\n }\n };\n}\n\nfunction getIntersectionsFromLineAndPolyline(line: { start: Point; end: Point }, points: Point[]) {\n const intersections: [number, number][] = [];\n for (let index = 1; index < points.length; index++) {\n const intersection = getIntersectPoint(\n [line.start.x, line.start.y],\n [line.end.x, line.end.y],\n [points[index].x, points[index].y],\n [points[index - 1].x, points[index - 1].y]\n );\n if (\n intersection &&\n !intersections.find(point =>\n isNumberEqual(\n PointService.distancePP(\n { x: point[0], y: point[1] },\n { x: (intersection as [number, number])[0], y: (intersection as [number, number])[1] }\n ),\n 0\n )\n )\n ) {\n intersections.push(intersection as [number, number]);\n }\n }\n return intersections;\n}\n\nfunction getAreaOrLinePathPoints(shape: IArea | ILine, type: 'line' | 'area') {\n const { points, segments } = shape.attribute;\n const pathPoints: Point[][] = [];\n let eachPathPoints: Point[] = [];\n const parsePoints = (points: IPointLike[]) => {\n if (points && points.length) {\n let basePoints: IPointLike[] = [];\n points.forEach(point => {\n if (point.defined === false) {\n pathPoints.push(eachPathPoints);\n if (type === 'area' && basePoints.length) {\n for (let i = basePoints.length - 1; i >= 0; i--) {\n eachPathPoints.push({\n x: basePoints[i].x,\n y: basePoints[i].y\n });\n }\n\n eachPathPoints.push(eachPathPoints[0]);\n }\n eachPathPoints = [];\n basePoints = [];\n } else {\n eachPathPoints.push({\n x: point.x,\n y: point.y\n });\n\n type === 'area' && basePoints.push({ x: point.x1 ?? point.x, y: point.y1 ?? point.y });\n }\n });\n\n if (type === 'area' && basePoints.length) {\n for (let i = basePoints.length - 1; i >= 0; i--) {\n eachPathPoints.push({\n x: basePoints[i].x,\n y: basePoints[i].y\n });\n }\n eachPathPoints.push(eachPathPoints[0]);\n }\n\n pathPoints.push(eachPathPoints);\n }\n };\n\n if (points && points.length) {\n parsePoints(points);\n } else if (segments && segments.length) {\n segments.forEach(seg => {\n parsePoints(seg.points);\n });\n }\n\n return pathPoints;\n}\n\nfunction isPointInPolygon(point: Point, polygon: Point[]) {\n const { x, y } = point;\n let inside = false;\n\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const { x: xi, y: yi } = polygon[i];\n const { x: xj, y: yj } = polygon[j];\n\n const intersect = yi > y !== yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi;\n if (intersect) {\n inside = !inside;\n }\n }\n\n return inside;\n}\n\nexport const appendSeriesBreakConfig = (rawSpec: ISpec) => {\n if (rawSpec.axes?.length) {\n const breakedAxes = rawSpec.axes.filter((axis: any) => axis.breaks && axis.breaks.length && axis.visible !== false);\n\n if (breakedAxes.length) {\n (rawSpec as any).customMark = array((rawSpec as any).customMark).filter(\n (obj: any) => obj.componentType !== SERIES_BREAK\n );\n (rawSpec as any).customMark.push(\n getSeriesBreakConfig(\n breakedAxes as ILinearAxisSpec[],\n breakedAxes.map(axisSpec => {\n return rawSpec.axes.indexOf(axisSpec as any);\n })\n )\n );\n return true;\n }\n }\n\n return false;\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["components/series-break/util.ts"],"names":[],"mappings":"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","file":"util.js","sourcesContent":["/**\n * 支持轴翻转\n */\nimport type { ILinearAxisBreakSpec, ILinearAxisSpec } from '@visactor/vchart/esm/component/axis';\nimport { ICartesianSeries, IMarkGraphic, ISpec } from '@visactor/vchart';\nimport { SeriesBreakData } from './type';\nimport { array, getIntersectPoint, IPointLike, isValid, PointService } from '@visactor/vutils';\nimport { Point } from '@visactor/vrender-components';\nimport { IArea, ILine } from '@visactor/vrender-core';\nimport { getAllRegionBounds } from '../../utils/element';\nimport { isNumberEqual } from '../../utils/math';\nimport { SERIES_BREAK } from './constant';\n\nconst barOffset = 2;\nconst lineOffset = 10;\nconst areaOffset = 0;\n\n/**\n * 获取系列标签的 spec 配置\n * @param position 显示位置\n * @param config 系列标签的样式配置\n * @returns\n */\nexport function getSeriesBreakConfig(axesSpec: ILinearAxisSpec[], axesIndex?: number[]) {\n return {\n type: 'component',\n componentType: SERIES_BREAK,\n interactive: true,\n zIndex: 500,\n\n style: {\n data: (datum: any, ctx: any) => {\n const seriesBreakData: SeriesBreakData[] = [];\n const vchart = ctx.vchart;\n const chart = vchart.getChart();\n const series = chart.getAllSeries()[0] as ICartesianSeries;\n const isHorizontal = series.direction === 'horizontal';\n axesSpec.forEach((spec: any, index: number) => {\n const axisId = spec.id;\n const axisModel = isValid(axisId)\n ? chart.getComponentByUserId(axisId)\n : axesIndex && isValid(axesIndex[index])\n ? chart.getComponentByIndex('axes', axesIndex[index])\n : chart.getComponentsByKey('axes').filter((axis: { getSpec: () => any }) => {\n const axisInnerSpec = axis.getSpec();\n\n return axisInnerSpec.breaks === spec.breaks;\n })?.[0];\n\n if (!axisModel) {\n return;\n }\n const parsedAxisId = axisId ?? `${axisModel.type}-${axisModel.id}`;\n\n const regionBounds = getAllRegionBounds(axisModel.getRegions());\n\n // todo 这里用到了内部变量,不太安全\n array(axisModel._break?.breaks).forEach((breakConfig: ILinearAxisBreakSpec) => {\n const { range, breakSymbol, gap = 5 } = breakConfig;\n const pos1 = axisModel.valueToPosition(range[0]);\n const pos2 = axisModel.valueToPosition(range[1]);\n\n const posY = (pos1 + pos2) / 2 + (isHorizontal ? regionBounds.x1 : regionBounds.y1);\n\n chart.getAllSeries().forEach((s: ICartesianSeries) => {\n if (s.type === 'bar' || s.type === 'waterfall') {\n const mark = s.getMarkInName('bar');\n const graphics = mark.getGraphics();\n\n graphics.forEach((element: IMarkGraphic) => {\n const elementBounds = element.AABBBounds;\n let shouldDrawBreak = false;\n let startX;\n let startY;\n let endX;\n let endY;\n if (isHorizontal) {\n shouldDrawBreak =\n elementBounds.x1 < (pos1 + pos2 - (gap as number)) / 2 &&\n elementBounds.x2 > (pos1 + pos2 + gap) / 2;\n\n startX = posY;\n startY = Math.max(elementBounds.y1 + regionBounds.y1 - barOffset, regionBounds.y1);\n\n endX = posY;\n endY = Math.min(elementBounds.y2 + regionBounds.y1 + barOffset, regionBounds.y2);\n } else {\n shouldDrawBreak =\n elementBounds.y1 < (pos1 + pos2 - (gap as number)) / 2 &&\n elementBounds.y2 > (pos1 + pos2 + gap) / 2;\n startX = Math.max(elementBounds.x1 + regionBounds.x1 - barOffset, regionBounds.x1);\n startY = posY;\n endX = Math.min(elementBounds.x2 + regionBounds.x1 + barOffset, regionBounds.x2);\n endY = posY;\n }\n\n if (shouldDrawBreak) {\n seriesBreakData.push({\n start: {\n x: startX,\n y: startY\n },\n end: {\n x: endX,\n y: endY\n },\n gap: gap as number,\n style: breakSymbol?.style,\n axisId: parsedAxisId,\n data: range\n });\n }\n });\n } else if (s.type === 'line') {\n // 求水平直线/垂直线同 line path 的交点\n const mark = s.getMarkInName(s.type);\n const graphics = mark.getGraphics();\n graphics.forEach(graphicItem => {\n const points = getAreaOrLinePathPoints(graphicItem, 'line');\n points.forEach(linePoints => {\n // 开始查找交点\n const intersections = getIntersectionsFromLineAndPolyline(\n isHorizontal\n ? {\n start: { x: (pos1 + pos2) / 2, y: 0 },\n end: { x: (pos1 + pos2) / 2, y: regionBounds.y2 - regionBounds.y1 }\n }\n : {\n start: { x: 0, y: (pos1 + pos2) / 2 },\n end: { x: regionBounds.x2 - regionBounds.x1, y: (pos1 + pos2) / 2 }\n },\n linePoints\n );\n\n intersections.forEach(intersection => {\n let start;\n let end;\n if (isHorizontal) {\n start = {\n x: posY,\n y: Math.max(intersection[1] + regionBounds.y1 - lineOffset, regionBounds.y1)\n };\n end = {\n x: posY,\n y: Math.min(intersection[1] + regionBounds.y1 + lineOffset, regionBounds.y2)\n };\n } else {\n start = {\n x: Math.max(intersection[0] + regionBounds.x1 - lineOffset, regionBounds.x1),\n y: posY\n };\n end = {\n x: Math.min(intersection[0] + regionBounds.x1 + lineOffset, regionBounds.x2),\n y: posY\n };\n }\n seriesBreakData.push({\n start,\n end,\n gap: gap as number,\n style: breakSymbol?.style,\n axisId: parsedAxisId,\n data: range\n });\n });\n });\n });\n } else if (s.type === 'area') {\n // 默认面积去全部堆叠\n const mark = s.getMarkInName('area');\n const graphics = mark.getGraphics();\n graphics.forEach(graphicItem => {\n const points = getAreaOrLinePathPoints(graphicItem, 'area');\n points.forEach(areaPoints => {\n const intersections = getIntersectionsFromLineAndPolyline(\n isHorizontal\n ? {\n start: { x: (pos1 + pos2) / 2, y: 0 },\n end: { x: (pos1 + pos2) / 2, y: regionBounds.y2 - regionBounds.y1 }\n }\n : {\n start: { x: 0, y: (pos1 + pos2) / 2 },\n end: { x: regionBounds.x2 - regionBounds.x1, y: (pos1 + pos2) / 2 }\n },\n areaPoints\n );\n\n intersections.sort((a, b) => a[0] - b[0]);\n\n for (let index = 0; index < intersections.length - 1; index++) {\n const lineStart = {\n x: intersections[index][0],\n y: intersections[index][1]\n };\n const lineEnd = {\n x: intersections[index + 1][0],\n y: intersections[index + 1][1]\n };\n if (\n isPointInPolygon(\n isHorizontal\n ? {\n x: lineStart.x,\n y: (lineStart.y + lineEnd.y) / 2\n }\n : {\n x: (lineStart.x + lineEnd.x) / 2,\n y: lineStart.y\n },\n areaPoints\n )\n ) {\n let start;\n let end;\n if (isHorizontal) {\n start = {\n x: lineStart.x + regionBounds.x1,\n y: Math.max(lineStart.y + regionBounds.y1 - areaOffset, regionBounds.y1)\n };\n end = {\n x: lineEnd.x + regionBounds.x1,\n y: Math.min(lineEnd.y + regionBounds.y1 + areaOffset, regionBounds.y2)\n };\n } else {\n start = {\n x: Math.max(lineStart.x + regionBounds.x1 - areaOffset, regionBounds.x1),\n y: lineStart.y + regionBounds.y1\n };\n end = {\n x: Math.min(lineEnd.x + regionBounds.x1 + areaOffset, regionBounds.x2),\n y: lineEnd.y + regionBounds.y1\n };\n }\n seriesBreakData.push({\n start,\n end,\n gap: gap as number,\n style: breakSymbol?.style,\n axisId: parsedAxisId,\n data: range\n });\n }\n }\n });\n });\n }\n });\n });\n });\n\n return seriesBreakData;\n }\n }\n };\n}\n\nfunction getIntersectionsFromLineAndPolyline(line: { start: Point; end: Point }, points: Point[]) {\n const intersections: [number, number][] = [];\n for (let index = 1; index < points.length; index++) {\n const intersection = getIntersectPoint(\n [line.start.x, line.start.y],\n [line.end.x, line.end.y],\n [points[index].x, points[index].y],\n [points[index - 1].x, points[index - 1].y]\n );\n if (\n intersection &&\n !intersections.find(point =>\n isNumberEqual(\n PointService.distancePP(\n { x: point[0], y: point[1] },\n { x: (intersection as [number, number])[0], y: (intersection as [number, number])[1] }\n ),\n 0\n )\n )\n ) {\n intersections.push(intersection as [number, number]);\n }\n }\n return intersections;\n}\n\nfunction getAreaOrLinePathPoints(shape: IArea | ILine, type: 'line' | 'area') {\n const { points, segments } = shape.attribute;\n const pathPoints: Point[][] = [];\n let eachPathPoints: Point[] = [];\n const parsePoints = (points: IPointLike[]) => {\n if (points && points.length) {\n let basePoints: IPointLike[] = [];\n points.forEach(point => {\n if (point.defined === false) {\n pathPoints.push(eachPathPoints);\n if (type === 'area' && basePoints.length) {\n for (let i = basePoints.length - 1; i >= 0; i--) {\n eachPathPoints.push({\n x: basePoints[i].x,\n y: basePoints[i].y\n });\n }\n\n eachPathPoints.push(eachPathPoints[0]);\n }\n eachPathPoints = [];\n basePoints = [];\n } else {\n eachPathPoints.push({\n x: point.x,\n y: point.y\n });\n\n type === 'area' && basePoints.push({ x: point.x1 ?? point.x, y: point.y1 ?? point.y });\n }\n });\n\n if (type === 'area' && basePoints.length) {\n for (let i = basePoints.length - 1; i >= 0; i--) {\n eachPathPoints.push({\n x: basePoints[i].x,\n y: basePoints[i].y\n });\n }\n eachPathPoints.push(eachPathPoints[0]);\n }\n\n pathPoints.push(eachPathPoints);\n }\n };\n\n if (points && points.length) {\n parsePoints(points);\n } else if (segments && segments.length) {\n segments.forEach(seg => {\n parsePoints(seg.points);\n });\n }\n\n return pathPoints;\n}\n\nfunction isPointInPolygon(point: Point, polygon: Point[]) {\n const { x, y } = point;\n let inside = false;\n\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const { x: xi, y: yi } = polygon[i];\n const { x: xj, y: yj } = polygon[j];\n\n const intersect = yi > y !== yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi;\n if (intersect) {\n inside = !inside;\n }\n }\n\n return inside;\n}\n\nexport const appendSeriesBreakConfig = (rawSpec: ISpec) => {\n if (rawSpec.axes?.length) {\n const breakedAxes = rawSpec.axes.filter((axis: any) => axis.breaks && axis.breaks.length && axis.visible !== false);\n\n if (breakedAxes.length) {\n (rawSpec as any).customMark = array((rawSpec as any).customMark).filter(\n (obj: any) => obj.componentType !== SERIES_BREAK\n );\n (rawSpec as any).customMark.push(\n getSeriesBreakConfig(\n breakedAxes as ILinearAxisSpec[],\n breakedAxes.map(axisSpec => {\n return rawSpec.axes.indexOf(axisSpec as any);\n })\n )\n );\n return true;\n }\n }\n\n return false;\n};\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { VChart, FunnelChart, PREFIX, FunnelSeries } from "@visactor/vchart";
|
|
1
|
+
import { VChart, FunnelChart, PREFIX, FunnelSeries, registerMarkFilterTransform } from "@visactor/vchart";
|
|
2
2
|
|
|
3
3
|
import { DataView } from "@visactor/vdataset";
|
|
4
4
|
|
|
@@ -34,14 +34,14 @@ export class ConversionFunnelSeries extends FunnelSeries {
|
|
|
34
34
|
null === (_a = super.afterCompile) || void 0 === _a || _a.call(this);
|
|
35
35
|
const rightGroup = this.getMarkInName("arrowRight");
|
|
36
36
|
rightGroup && rightGroup.getMarks().forEach((mark => {
|
|
37
|
-
mark.setDataView(this._arrowData), mark.compileData(), mark.
|
|
37
|
+
mark.setDataView(this._arrowData), mark.compileData(), mark.setTransform([ {
|
|
38
38
|
type: "filter",
|
|
39
39
|
callback: datum => "right" === datum.position
|
|
40
40
|
} ]);
|
|
41
41
|
}));
|
|
42
42
|
const leftGroup = this.getMarkInName("arrowLeft");
|
|
43
43
|
leftGroup && leftGroup.getMarks().forEach((mark => {
|
|
44
|
-
mark.setDataView(this._arrowData), mark.compileData(), mark.
|
|
44
|
+
mark.setDataView(this._arrowData), mark.compileData(), mark.setTransform([ {
|
|
45
45
|
type: "filter",
|
|
46
46
|
callback: datum => "left" === datum.position
|
|
47
47
|
} ]);
|
|
@@ -50,6 +50,7 @@ export class ConversionFunnelSeries extends FunnelSeries {
|
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
export const registerConversionFunnelChart = option => {
|
|
53
|
+
registerMarkFilterTransform();
|
|
53
54
|
const vchartConstructor = (null == option ? void 0 : option.VChart) || VChart;
|
|
54
55
|
vchartConstructor && (vchartConstructor.useChart([ ConversionFunnelChart ]), vchartConstructor.useSeries([ ConversionFunnelSeries ]));
|
|
55
56
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["charts/conversion-funnel/conversion-funnel.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAa,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"sources":["charts/conversion-funnel/conversion-funnel.ts"],"names":[],"mappings":"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","file":"conversion-funnel.js","sourcesContent":["import type { IConversionFunnelChartSpecBase, IConversionFunnelSeriesSpecBase } from './interface';\nimport { VChart, FunnelChart, PREFIX, FunnelSeries, GroupMark, registerMarkFilterTransform } from '@visactor/vchart';\nimport { DataView } from '@visactor/vdataset';\nimport { ConversionFunnelChartSpecTransformer } from './conversion-funnel-transformer';\nimport { conversionArrowTransform } from './arrow-data-transform';\n\nexport class ConversionFunnelChart extends FunnelChart<IConversionFunnelChartSpecBase> {\n type = 'conversionFunnel';\n static type = 'conversionFunnel';\n\n declare _spec: IConversionFunnelChartSpecBase;\n\n static readonly transformerConstructor = ConversionFunnelChartSpecTransformer;\n readonly transformerConstructor = ConversionFunnelChartSpecTransformer;\n}\n\nexport class ConversionFunnelSeries extends FunnelSeries<IConversionFunnelSeriesSpecBase> {\n protected _arrowData?: DataView;\n\n initData() {\n super.initData();\n const { conversionArrow } = this._spec;\n if (conversionArrow && conversionArrow.arrows?.length) {\n this._arrowData = new DataView(this._dataSet, { name: `${PREFIX}_series_${this.id}_arrowData` });\n if (!this._dataSet.getTransform('conversionArrow')) {\n this._dataSet.registerTransform('conversionArrow', conversionArrowTransform);\n }\n this._arrowData.parse(conversionArrow).transform({\n type: 'conversionArrow',\n options: {\n categoryField: this._spec.categoryField\n }\n });\n }\n }\n\n afterCompile() {\n // @ts-ignore\n super.afterCompile?.();\n const rightGroup = this.getMarkInName('arrowRight') as unknown as GroupMark;\n if (rightGroup) {\n rightGroup.getMarks().forEach(mark => {\n mark.setDataView(this._arrowData);\n mark.compileData();\n mark.setTransform([\n {\n type: 'filter',\n callback: datum => datum.position === 'right'\n }\n ]);\n });\n }\n const leftGroup = this.getMarkInName('arrowLeft') as unknown as GroupMark;\n if (leftGroup) {\n leftGroup.getMarks().forEach(mark => {\n mark.setDataView(this._arrowData);\n mark.compileData();\n mark.setTransform([\n {\n type: 'filter',\n callback: datum => datum.position === 'left'\n }\n ]);\n });\n }\n }\n}\n\nexport const registerConversionFunnelChart = (option?: { VChart?: typeof VChart }) => {\n registerMarkFilterTransform();\n\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([ConversionFunnelChart]);\n vchartConstructor.useSeries([ConversionFunnelSeries]);\n }\n};\n\nexport const DEFAULT_ARROW_MARK_STYLE = {\n cornerRadius: 4,\n stroke: 'black',\n strokeOpacity: 1,\n lineWidth: 1,\n closePath: false,\n pickable: false\n};\n\nexport const DEFAULT_ARROW_SYMBOL_MARK_STYLE = {\n symbolType: 'triangle',\n size: 8,\n scaleX: 0.7,\n fill: 'black'\n};\n\nexport const DEFAULT_ARROW_TEXT_MARK_STYLE = {\n fill: '#606773',\n fontSize: 12\n};\n\nexport const DEFAULT_FUNNEL_BACKGROUND_MARK_STYLE = {\n fill: '#eff1f9'\n};\n"]}
|
|
@@ -10,14 +10,14 @@ var __rest = this && this.__rest || function(s, e) {
|
|
|
10
10
|
|
|
11
11
|
import { AbstractComponent } from "@visactor/vrender-components";
|
|
12
12
|
|
|
13
|
-
import { Factory } from "@visactor/vgrammar-core";
|
|
14
|
-
|
|
15
13
|
import { createGroup, createPath } from "@visactor/vrender-core";
|
|
16
14
|
|
|
17
15
|
import { isEmpty, isNumberClose, isValid } from "@visactor/vutils";
|
|
18
16
|
|
|
19
17
|
import { SERIES_BREAK } from "./constant";
|
|
20
18
|
|
|
19
|
+
import { Factory } from "@visactor/vchart";
|
|
20
|
+
|
|
21
21
|
function generateZigzagPath(start, end, size, angle, isVertical = !1) {
|
|
22
22
|
const path = [], {x: startX, y: startY} = start, {x: endX, y: endY} = end, numZigzags = isVertical ? Math.floor((endY - startY) / (2 * size)) : Math.floor((endX - startX) / (2 * size)), angleRad = Math.PI / 180 * angle, deltaX = size * Math.cos(angleRad), deltaY = size * Math.sin(angleRad);
|
|
23
23
|
path.push(`M ${startX} ${startY}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["components/series-break/series-break.ts"],"names":[],"mappings":"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","file":"series-break.js","sourcesContent":["/**\n * @description vchart 自定义组件,用于实现 bar、area、line 这些图形的截断图形生成\n * @author zhangweixing\n */\n\nimport { AbstractComponent, Point } from '@visactor/vrender-components';\nimport { Factory } from '@visactor/vgrammar-core';\nimport { SeriesBreakAttrs, SeriesBreakData } from './type';\nimport { createGroup, createPath, IGraphic } from '@visactor/vrender-core';\nimport { isEmpty, isNumberClose, isValid } from '@visactor/vutils';\nimport { SERIES_BREAK } from './constant';\n\n/**\n * 求锯齿的路径(一个锯齿由向上和向下的两个线段组成)\n * @param start 锯齿的起始点\n * @param end 锯齿的结束点\n * @param size 锯齿的高度\n * @param angle 锯齿的角度\n * @param gap 两条锯齿的间距\n * @param isVertical 是否垂直\n * @returns\n */\nfunction generateZigzagPath(start: Point, end: Point, size: number, angle: number, isVertical = false) {\n const path = [];\n const { x: startX, y: startY } = start;\n const { x: endX, y: endY } = end;\n\n // 计算锯齿的数量\n const numZigzags = isVertical ? Math.floor((endY - startY) / (size * 2)) : Math.floor((endX - startX) / (size * 2));\n\n // 计算倾斜角度的增量\n const angleRad = (Math.PI / 180) * angle; // 转换为弧度\n const deltaX = size * Math.cos(angleRad);\n const deltaY = size * Math.sin(angleRad);\n\n // 添加第一条锯齿的起始点\n path.push(`M ${startX} ${startY}`);\n\n for (let i = 0; i <= numZigzags; i++) {\n const x = isVertical ? startX + (i % 2 === 0 ? deltaX : -deltaX) : startX + i * size * 2;\n const y = isVertical ? startY + i * size * 2 : i % 2 === 0 ? startY - deltaY : startY + deltaY;\n path.push(`L ${x} ${y}`);\n }\n\n // 添加第一条锯齿的结束点\n path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`);\n\n return path.join(' ');\n}\n\nconst checkOverlap = (prevData: SeriesBreakData[], newEntry: SeriesBreakData) => {\n const { start, end } = newEntry;\n const isVertical = start.x === end.x;\n const equalDim = isVertical ? 'x' : 'y';\n const diffDim = isVertical ? 'y' : 'x';\n let needAppend = true;\n const EPS = 1e-6;\n\n if (prevData.length) {\n prevData.forEach(prevEntry => {\n if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {\n // 判断是否有重叠,有重叠取交集\n const minDim = Math.min(start[diffDim], end[diffDim]);\n const maxDim = Math.max(start[diffDim], end[diffDim]);\n const prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const hasOverlap = !(maxDim < prevMinDim - EPS || minDim > prevMaxDim + EPS);\n\n if (hasOverlap) {\n prevEntry.start[diffDim] = Math.min(prevMinDim, minDim);\n prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim);\n needAppend = false;\n return;\n }\n }\n });\n }\n\n if (needAppend) {\n prevData.push(newEntry);\n }\n};\n\nexport class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {\n name = SERIES_BREAK;\n protected render() {\n this.removeAllChild();\n const { data = [] } = this.attribute as SeriesBreakAttrs;\n if (isEmpty(data)) {\n return;\n }\n // 去除重叠数据\n const verticalData: SeriesBreakData[] = [];\n const horizontalData: SeriesBreakData[] = [];\n\n data.forEach(breakData => {\n const { start, end } = breakData;\n const isVertical = start.x === end.x;\n\n checkOverlap(isVertical ? verticalData : horizontalData, breakData);\n });\n\n [...verticalData, ...horizontalData].forEach((breakData, id) => {\n const { start, end, size = 4, gap = 5, style = {}, ...rest } = breakData;\n const breakGroup = createGroup({});\n const isVertical = start.x === end.x;\n\n let startPathStart;\n let startPathEnd;\n let endPathStart;\n let endPathEnd;\n if (isVertical) {\n startPathStart = {\n x: start.x - gap / 2,\n y: start.y\n };\n startPathEnd = {\n x: end.x - gap / 2,\n y: end.y\n };\n endPathStart = {\n x: start.x + gap / 2,\n y: start.y\n };\n endPathEnd = {\n x: end.x + gap / 2,\n y: end.y\n };\n } else {\n startPathStart = {\n x: start.x,\n y: start.y - gap / 2\n };\n startPathEnd = {\n x: end.x,\n y: end.y - gap / 2\n };\n endPathStart = {\n x: start.x,\n y: start.y + gap / 2\n };\n endPathEnd = {\n x: end.x,\n y: end.y + gap / 2\n };\n }\n\n const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical);\n const centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical);\n const endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);\n breakGroup.add(\n createPath({\n path: startPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: endPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: centerPath,\n stroke: '#fff',\n lineWidth: gap,\n pickable: false,\n zIndex: 0\n })\n );\n\n breakGroup.name = 'series-break';\n breakGroup.data = rest;\n\n if (isValid(rest.axisId)) {\n breakGroup.id = `${rest.axisId ?? ''}_${id}`;\n }\n\n this.add(breakGroup);\n });\n }\n}\n\nexport const registerSeriesBreak = () => {\n Factory.registerGraphicComponent(\n 'seriesBreak',\n (attrs: Required<SeriesBreakAttrs>) => new SeriesBreakComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["components/series-break/series-break.ts"],"names":[],"mappings":"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","file":"series-break.js","sourcesContent":["/**\n * @description vchart 自定义组件,用于实现 bar、area、line 这些图形的截断图形生成\n * @author zhangweixing\n */\n\nimport { AbstractComponent, Point } from '@visactor/vrender-components';\nimport { SeriesBreakAttrs, SeriesBreakData } from './type';\nimport { createGroup, createPath, IGraphic } from '@visactor/vrender-core';\nimport { isEmpty, isNumberClose, isValid } from '@visactor/vutils';\nimport { SERIES_BREAK } from './constant';\nimport { Factory } from '@visactor/vchart';\n\n/**\n * 求锯齿的路径(一个锯齿由向上和向下的两个线段组成)\n * @param start 锯齿的起始点\n * @param end 锯齿的结束点\n * @param size 锯齿的高度\n * @param angle 锯齿的角度\n * @param gap 两条锯齿的间距\n * @param isVertical 是否垂直\n * @returns\n */\nfunction generateZigzagPath(start: Point, end: Point, size: number, angle: number, isVertical = false) {\n const path = [];\n const { x: startX, y: startY } = start;\n const { x: endX, y: endY } = end;\n\n // 计算锯齿的数量\n const numZigzags = isVertical ? Math.floor((endY - startY) / (size * 2)) : Math.floor((endX - startX) / (size * 2));\n\n // 计算倾斜角度的增量\n const angleRad = (Math.PI / 180) * angle; // 转换为弧度\n const deltaX = size * Math.cos(angleRad);\n const deltaY = size * Math.sin(angleRad);\n\n // 添加第一条锯齿的起始点\n path.push(`M ${startX} ${startY}`);\n\n for (let i = 0; i <= numZigzags; i++) {\n const x = isVertical ? startX + (i % 2 === 0 ? deltaX : -deltaX) : startX + i * size * 2;\n const y = isVertical ? startY + i * size * 2 : i % 2 === 0 ? startY - deltaY : startY + deltaY;\n path.push(`L ${x} ${y}`);\n }\n\n // 添加第一条锯齿的结束点\n path.push(`L ${isVertical ? startX : endX} ${isVertical ? endY : startY}`);\n\n return path.join(' ');\n}\n\nconst checkOverlap = (prevData: SeriesBreakData[], newEntry: SeriesBreakData) => {\n const { start, end } = newEntry;\n const isVertical = start.x === end.x;\n const equalDim = isVertical ? 'x' : 'y';\n const diffDim = isVertical ? 'y' : 'x';\n let needAppend = true;\n const EPS = 1e-6;\n\n if (prevData.length) {\n prevData.forEach(prevEntry => {\n if (isNumberClose(prevEntry.start[equalDim], start[equalDim])) {\n // 判断是否有重叠,有重叠取交集\n const minDim = Math.min(start[diffDim], end[diffDim]);\n const maxDim = Math.max(start[diffDim], end[diffDim]);\n const prevMinDim = Math.min(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const prevMaxDim = Math.max(prevEntry.start[diffDim], prevEntry.end[diffDim]);\n const hasOverlap = !(maxDim < prevMinDim - EPS || minDim > prevMaxDim + EPS);\n\n if (hasOverlap) {\n prevEntry.start[diffDim] = Math.min(prevMinDim, minDim);\n prevEntry.end[diffDim] = Math.max(prevMaxDim, maxDim);\n needAppend = false;\n return;\n }\n }\n });\n }\n\n if (needAppend) {\n prevData.push(newEntry);\n }\n};\n\nexport class SeriesBreakComponent extends AbstractComponent<Required<SeriesBreakAttrs>> {\n name = SERIES_BREAK;\n protected render() {\n this.removeAllChild();\n const { data = [] } = this.attribute as SeriesBreakAttrs;\n if (isEmpty(data)) {\n return;\n }\n // 去除重叠数据\n const verticalData: SeriesBreakData[] = [];\n const horizontalData: SeriesBreakData[] = [];\n\n data.forEach(breakData => {\n const { start, end } = breakData;\n const isVertical = start.x === end.x;\n\n checkOverlap(isVertical ? verticalData : horizontalData, breakData);\n });\n\n [...verticalData, ...horizontalData].forEach((breakData, id) => {\n const { start, end, size = 4, gap = 5, style = {}, ...rest } = breakData;\n const breakGroup = createGroup({});\n const isVertical = start.x === end.x;\n\n let startPathStart;\n let startPathEnd;\n let endPathStart;\n let endPathEnd;\n if (isVertical) {\n startPathStart = {\n x: start.x - gap / 2,\n y: start.y\n };\n startPathEnd = {\n x: end.x - gap / 2,\n y: end.y\n };\n endPathStart = {\n x: start.x + gap / 2,\n y: start.y\n };\n endPathEnd = {\n x: end.x + gap / 2,\n y: end.y\n };\n } else {\n startPathStart = {\n x: start.x,\n y: start.y - gap / 2\n };\n startPathEnd = {\n x: end.x,\n y: end.y - gap / 2\n };\n endPathStart = {\n x: start.x,\n y: start.y + gap / 2\n };\n endPathEnd = {\n x: end.x,\n y: end.y + gap / 2\n };\n }\n\n const startPath = generateZigzagPath(startPathStart, startPathEnd, size, isVertical ? 75 : 15, isVertical);\n const centerPath = generateZigzagPath(start, end, size, isVertical ? 75 : 15, isVertical);\n const endPath = generateZigzagPath(endPathStart, endPathEnd, size, isVertical ? 75 : 15, isVertical);\n breakGroup.add(\n createPath({\n path: startPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: endPath,\n stroke: '#000',\n lineWidth: 1,\n ...style,\n pickable: false,\n zIndex: 1\n })\n );\n breakGroup.add(\n createPath({\n path: centerPath,\n stroke: '#fff',\n lineWidth: gap,\n pickable: false,\n zIndex: 0\n })\n );\n\n breakGroup.name = 'series-break';\n breakGroup.data = rest;\n\n if (isValid(rest.axisId)) {\n breakGroup.id = `${rest.axisId ?? ''}_${id}`;\n }\n\n this.add(breakGroup);\n });\n }\n}\n\nexport const registerSeriesBreak = () => {\n Factory.registerGraphicComponent(\n 'seriesBreak',\n (attrs: Required<SeriesBreakAttrs>) => new SeriesBreakComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
|
|
@@ -26,8 +26,8 @@ export function getSeriesBreakConfig(axesSpec, axesIndex) {
|
|
|
26
26
|
const {range: range, breakSymbol: breakSymbol, gap: gap = 5} = breakConfig, pos1 = axisModel.valueToPosition(range[0]), pos2 = axisModel.valueToPosition(range[1]), posY = (pos1 + pos2) / 2 + (isHorizontal ? regionBounds.x1 : regionBounds.y1);
|
|
27
27
|
chart.getAllSeries().forEach((s => {
|
|
28
28
|
if ("bar" === s.type || "waterfall" === s.type) {
|
|
29
|
-
s.getMarkInName("bar").
|
|
30
|
-
const elementBounds = element.
|
|
29
|
+
s.getMarkInName("bar").getGraphics().forEach((element => {
|
|
30
|
+
const elementBounds = element.AABBBounds;
|
|
31
31
|
let startX, startY, endX, endY, shouldDrawBreak = !1;
|
|
32
32
|
isHorizontal ? (shouldDrawBreak = elementBounds.x1 < (pos1 + pos2 - gap) / 2 && elementBounds.x2 > (pos1 + pos2 + gap) / 2,
|
|
33
33
|
startX = posY, startY = Math.max(elementBounds.y1 + regionBounds.y1 - 2, regionBounds.y1),
|
|
@@ -50,8 +50,8 @@ export function getSeriesBreakConfig(axesSpec, axesIndex) {
|
|
|
50
50
|
});
|
|
51
51
|
}));
|
|
52
52
|
} else if ("line" === s.type) {
|
|
53
|
-
s.getMarkInName(s.type).
|
|
54
|
-
getAreaOrLinePathPoints(
|
|
53
|
+
s.getMarkInName(s.type).getGraphics().forEach((graphicItem => {
|
|
54
|
+
getAreaOrLinePathPoints(graphicItem, "line").forEach((linePoints => {
|
|
55
55
|
getIntersectionsFromLineAndPolyline(isHorizontal ? {
|
|
56
56
|
start: {
|
|
57
57
|
x: (pos1 + pos2) / 2,
|
|
@@ -96,8 +96,8 @@ export function getSeriesBreakConfig(axesSpec, axesIndex) {
|
|
|
96
96
|
}));
|
|
97
97
|
}));
|
|
98
98
|
} else if ("area" === s.type) {
|
|
99
|
-
s.getMarkInName("area").
|
|
100
|
-
getAreaOrLinePathPoints(
|
|
99
|
+
s.getMarkInName("area").getGraphics().forEach((graphicItem => {
|
|
100
|
+
getAreaOrLinePathPoints(graphicItem, "area").forEach((areaPoints => {
|
|
101
101
|
const intersections = getIntersectionsFromLineAndPolyline(isHorizontal ? {
|
|
102
102
|
start: {
|
|
103
103
|
x: (pos1 + pos2) / 2,
|