@visactor/vchart-extension 1.13.18 → 1.13.19-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 +13990 -0
- package/build/index.min.js +15 -0
- package/cjs/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
- package/cjs/charts/conversion-funnel/arrow-data-transform.js +99 -0
- package/cjs/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
- package/cjs/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
- package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js +196 -0
- package/cjs/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
- package/cjs/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
- package/cjs/charts/conversion-funnel/conversion-funnel.js +78 -0
- package/cjs/charts/conversion-funnel/conversion-funnel.js.map +1 -0
- package/cjs/charts/conversion-funnel/index.d.ts +2 -0
- package/cjs/charts/conversion-funnel/index.js +21 -0
- package/cjs/charts/conversion-funnel/index.js.map +1 -0
- package/cjs/charts/conversion-funnel/interface.d.ts +35 -0
- package/cjs/charts/conversion-funnel/interface.js +6 -0
- package/cjs/charts/conversion-funnel/interface.js.map +1 -0
- package/cjs/charts/conversion-funnel/util.d.ts +3 -0
- package/cjs/charts/conversion-funnel/util.js +17 -0
- package/cjs/charts/conversion-funnel/util.js.map +1 -0
- package/cjs/charts/ranking-bar/interface.d.ts +45 -0
- package/cjs/charts/ranking-bar/interface.js +6 -0
- package/cjs/charts/ranking-bar/interface.js.map +1 -0
- package/cjs/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
- package/cjs/charts/ranking-bar/ranking-bar-transformer.js +291 -0
- package/cjs/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
- package/cjs/charts/ranking-bar/ranking-bar.d.ts +16 -0
- package/cjs/charts/ranking-bar/ranking-bar.js +34 -0
- package/cjs/charts/ranking-bar/ranking-bar.js.map +1 -0
- package/cjs/charts/ranking-list/constant.d.ts +2 -0
- package/cjs/charts/ranking-list/constant.js +75 -0
- package/cjs/charts/ranking-list/constant.js.map +1 -0
- package/cjs/charts/ranking-list/interface.d.ts +74 -0
- package/cjs/charts/ranking-list/interface.js +6 -0
- package/cjs/charts/ranking-list/interface.js.map +1 -0
- package/cjs/charts/ranking-list/ranking-list-transformer.d.ts +459 -0
- package/cjs/charts/ranking-list/ranking-list-transformer.js +382 -0
- package/cjs/charts/ranking-list/ranking-list-transformer.js.map +1 -0
- package/cjs/charts/ranking-list/ranking-list.d.ts +16 -0
- package/cjs/charts/ranking-list/ranking-list.js +34 -0
- package/cjs/charts/ranking-list/ranking-list.js.map +1 -0
- package/cjs/charts/ranking-list/utils.d.ts +7 -0
- package/cjs/charts/ranking-list/utils.js +51 -0
- package/cjs/charts/ranking-list/utils.js.map +1 -0
- package/cjs/charts/sequence-scatter-kde/constant.d.ts +3 -0
- package/cjs/charts/sequence-scatter-kde/constant.js +7 -0
- package/cjs/charts/sequence-scatter-kde/constant.js.map +1 -0
- package/cjs/charts/sequence-scatter-kde/interface.d.ts +29 -0
- package/cjs/charts/sequence-scatter-kde/interface.js +6 -0
- package/cjs/charts/sequence-scatter-kde/interface.js.map +1 -0
- package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +6 -0
- package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +142 -0
- package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +1 -0
- package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +16 -0
- package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js +34 -0
- package/cjs/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +1 -0
- package/cjs/charts/sequence-scatter-kde/utils.d.ts +9 -0
- package/cjs/charts/sequence-scatter-kde/utils.js +42 -0
- package/cjs/charts/sequence-scatter-kde/utils.js.map +1 -0
- package/cjs/charts/sequence-scatter-link/interface.d.ts +59 -0
- package/cjs/charts/sequence-scatter-link/interface.js +6 -0
- package/cjs/charts/sequence-scatter-link/interface.js.map +1 -0
- package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +6 -0
- package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +328 -0
- package/cjs/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +1 -0
- package/cjs/charts/sequence-scatter-link/sequence-scatter-link.d.ts +16 -0
- package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js +34 -0
- package/cjs/charts/sequence-scatter-link/sequence-scatter-link.js.map +1 -0
- package/cjs/charts/sequence-scatter-link/utils.d.ts +9 -0
- package/cjs/charts/sequence-scatter-link/utils.js +108 -0
- package/cjs/charts/sequence-scatter-link/utils.js.map +1 -0
- package/cjs/charts/sequence-scatter-pixel/constant.d.ts +3 -0
- package/cjs/charts/sequence-scatter-pixel/constant.js +7 -0
- package/cjs/charts/sequence-scatter-pixel/constant.js.map +1 -0
- package/cjs/charts/sequence-scatter-pixel/interface.d.ts +29 -0
- package/cjs/charts/sequence-scatter-pixel/interface.js +6 -0
- package/cjs/charts/sequence-scatter-pixel/interface.js.map +1 -0
- package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +4 -0
- package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +68 -0
- package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +1 -0
- package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +16 -0
- package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +34 -0
- package/cjs/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +1 -0
- package/cjs/charts/sequence-scatter-pixel/utils.d.ts +3 -0
- package/cjs/charts/sequence-scatter-pixel/utils.js +53 -0
- package/cjs/charts/sequence-scatter-pixel/utils.js.map +1 -0
- package/cjs/components/bar-link/bar-link.d.ts +7 -0
- package/cjs/components/bar-link/bar-link.js +87 -0
- package/cjs/components/bar-link/bar-link.js.map +1 -0
- package/cjs/components/bar-link/constant.d.ts +1 -0
- package/cjs/components/bar-link/constant.js +6 -0
- package/cjs/components/bar-link/constant.js.map +1 -0
- package/cjs/components/bar-link/index.d.ts +4 -0
- package/cjs/components/bar-link/index.js +49 -0
- package/cjs/components/bar-link/index.js.map +1 -0
- package/cjs/components/bar-link/type.d.ts +27 -0
- package/cjs/components/bar-link/type.js +6 -0
- package/cjs/components/bar-link/type.js.map +1 -0
- package/cjs/components/bar-link/util.d.ts +22 -0
- package/cjs/components/bar-link/util.js +183 -0
- package/cjs/components/bar-link/util.js.map +1 -0
- package/cjs/components/series-break/constant.d.ts +1 -0
- package/cjs/components/series-break/constant.js +6 -0
- package/cjs/components/series-break/constant.js.map +1 -0
- package/cjs/components/series-break/index.d.ts +4 -0
- package/cjs/components/series-break/index.js +49 -0
- package/cjs/components/series-break/index.js.map +1 -0
- package/cjs/components/series-break/series-break.d.ts +7 -0
- package/cjs/components/series-break/series-break.js +118 -0
- package/cjs/components/series-break/series-break.js.map +1 -0
- package/cjs/components/series-break/type.d.ts +14 -0
- package/cjs/components/series-break/type.js +6 -0
- package/cjs/components/series-break/type.js.map +1 -0
- package/cjs/components/series-break/util.d.ts +13 -0
- package/cjs/components/series-break/util.js +248 -0
- package/cjs/components/series-break/util.js.map +1 -0
- package/cjs/components/series-label/constant.d.ts +1 -0
- package/cjs/components/series-label/constant.js +6 -0
- package/cjs/components/series-label/constant.js.map +1 -0
- package/cjs/components/series-label/index.d.ts +3 -0
- package/cjs/components/series-label/index.js +49 -0
- package/cjs/components/series-label/index.js.map +1 -0
- package/cjs/components/series-label/series-label.d.ts +7 -0
- package/cjs/components/series-label/series-label.js +114 -0
- package/cjs/components/series-label/series-label.js.map +1 -0
- package/cjs/components/series-label/type.d.ts +41 -0
- package/cjs/components/series-label/type.js +6 -0
- package/cjs/components/series-label/type.js.map +1 -0
- package/cjs/components/series-label/util.d.ts +33 -0
- package/cjs/components/series-label/util.js +152 -0
- package/cjs/components/series-label/util.js.map +1 -0
- package/cjs/index.d.ts +9 -0
- package/cjs/index.js +25 -0
- package/cjs/index.js.map +1 -0
- package/cjs/type/index.d.ts +1 -0
- package/cjs/type/index.js +21 -0
- package/cjs/type/index.js.map +1 -0
- package/cjs/type/type.d.ts +8 -0
- package/cjs/type/type.js +6 -0
- package/cjs/type/type.js.map +1 -0
- package/cjs/utils/element.d.ts +7 -0
- package/cjs/utils/element.js +21 -0
- package/cjs/utils/element.js.map +1 -0
- package/cjs/utils/math.d.ts +1 -0
- package/cjs/utils/math.js +10 -0
- package/cjs/utils/math.js.map +1 -0
- package/esm/charts/conversion-funnel/arrow-data-transform.d.ts +24 -0
- package/esm/charts/conversion-funnel/arrow-data-transform.js +94 -0
- package/esm/charts/conversion-funnel/arrow-data-transform.js.map +1 -0
- package/esm/charts/conversion-funnel/conversion-funnel-transformer.d.ts +7 -0
- package/esm/charts/conversion-funnel/conversion-funnel-transformer.js +192 -0
- package/esm/charts/conversion-funnel/conversion-funnel-transformer.js.map +1 -0
- package/esm/charts/conversion-funnel/conversion-funnel.d.ts +40 -0
- package/esm/charts/conversion-funnel/conversion-funnel.js +81 -0
- package/esm/charts/conversion-funnel/conversion-funnel.js.map +1 -0
- package/esm/charts/conversion-funnel/index.d.ts +2 -0
- package/esm/charts/conversion-funnel/index.js +4 -0
- package/esm/charts/conversion-funnel/index.js.map +1 -0
- package/esm/charts/conversion-funnel/interface.d.ts +35 -0
- package/esm/charts/conversion-funnel/interface.js +2 -0
- package/esm/charts/conversion-funnel/interface.js.map +1 -0
- package/esm/charts/conversion-funnel/util.d.ts +3 -0
- package/esm/charts/conversion-funnel/util.js +10 -0
- package/esm/charts/conversion-funnel/util.js.map +1 -0
- package/esm/charts/ranking-bar/interface.d.ts +45 -0
- package/esm/charts/ranking-bar/interface.js +2 -0
- package/esm/charts/ranking-bar/interface.js.map +1 -0
- package/esm/charts/ranking-bar/ranking-bar-transformer.d.ts +10 -0
- package/esm/charts/ranking-bar/ranking-bar-transformer.js +285 -0
- package/esm/charts/ranking-bar/ranking-bar-transformer.js.map +1 -0
- package/esm/charts/ranking-bar/ranking-bar.d.ts +16 -0
- package/esm/charts/ranking-bar/ranking-bar.js +27 -0
- package/esm/charts/ranking-bar/ranking-bar.js.map +1 -0
- package/esm/charts/ranking-list/constant.d.ts +2 -0
- package/esm/charts/ranking-list/constant.js +69 -0
- package/esm/charts/ranking-list/constant.js.map +1 -0
- package/esm/charts/ranking-list/interface.d.ts +74 -0
- package/esm/charts/ranking-list/interface.js +2 -0
- package/esm/charts/ranking-list/interface.js.map +1 -0
- package/esm/charts/ranking-list/ranking-list-transformer.d.ts +459 -0
- package/esm/charts/ranking-list/ranking-list-transformer.js +382 -0
- package/esm/charts/ranking-list/ranking-list-transformer.js.map +1 -0
- package/esm/charts/ranking-list/ranking-list.d.ts +16 -0
- package/esm/charts/ranking-list/ranking-list.js +27 -0
- package/esm/charts/ranking-list/ranking-list.js.map +1 -0
- package/esm/charts/ranking-list/utils.d.ts +7 -0
- package/esm/charts/ranking-list/utils.js +41 -0
- package/esm/charts/ranking-list/utils.js.map +1 -0
- package/esm/charts/sequence-scatter-kde/constant.d.ts +3 -0
- package/esm/charts/sequence-scatter-kde/constant.js +6 -0
- package/esm/charts/sequence-scatter-kde/constant.js.map +1 -0
- package/esm/charts/sequence-scatter-kde/interface.d.ts +29 -0
- package/esm/charts/sequence-scatter-kde/interface.js +2 -0
- package/esm/charts/sequence-scatter-kde/interface.js.map +1 -0
- package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.d.ts +6 -0
- package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js +137 -0
- package/esm/charts/sequence-scatter-kde/sequence-scatter-kde-transformer.js.map +1 -0
- package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.d.ts +16 -0
- package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js +28 -0
- package/esm/charts/sequence-scatter-kde/sequence-scatter-kde.js.map +1 -0
- package/esm/charts/sequence-scatter-kde/utils.d.ts +9 -0
- package/esm/charts/sequence-scatter-kde/utils.js +34 -0
- package/esm/charts/sequence-scatter-kde/utils.js.map +1 -0
- package/esm/charts/sequence-scatter-link/interface.d.ts +59 -0
- package/esm/charts/sequence-scatter-link/interface.js +2 -0
- package/esm/charts/sequence-scatter-link/interface.js.map +1 -0
- package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.d.ts +6 -0
- package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js +321 -0
- package/esm/charts/sequence-scatter-link/sequence-scatter-link-transformer.js.map +1 -0
- package/esm/charts/sequence-scatter-link/sequence-scatter-link.d.ts +16 -0
- package/esm/charts/sequence-scatter-link/sequence-scatter-link.js +28 -0
- package/esm/charts/sequence-scatter-link/sequence-scatter-link.js.map +1 -0
- package/esm/charts/sequence-scatter-link/utils.d.ts +9 -0
- package/esm/charts/sequence-scatter-link/utils.js +100 -0
- package/esm/charts/sequence-scatter-link/utils.js.map +1 -0
- package/esm/charts/sequence-scatter-pixel/constant.d.ts +3 -0
- package/esm/charts/sequence-scatter-pixel/constant.js +6 -0
- package/esm/charts/sequence-scatter-pixel/constant.js.map +1 -0
- package/esm/charts/sequence-scatter-pixel/interface.d.ts +29 -0
- package/esm/charts/sequence-scatter-pixel/interface.js +2 -0
- package/esm/charts/sequence-scatter-pixel/interface.js.map +1 -0
- package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.d.ts +4 -0
- package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js +64 -0
- package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.js.map +1 -0
- package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.d.ts +16 -0
- package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js +28 -0
- package/esm/charts/sequence-scatter-pixel/sequence-scatter-pixel.js.map +1 -0
- package/esm/charts/sequence-scatter-pixel/utils.d.ts +3 -0
- package/esm/charts/sequence-scatter-pixel/utils.js +45 -0
- package/esm/charts/sequence-scatter-pixel/utils.js.map +1 -0
- package/esm/components/bar-link/bar-link.d.ts +7 -0
- package/esm/components/bar-link/bar-link.js +85 -0
- package/esm/components/bar-link/bar-link.js.map +1 -0
- package/esm/components/bar-link/constant.d.ts +1 -0
- package/esm/components/bar-link/constant.js +2 -0
- package/esm/components/bar-link/constant.js.map +1 -0
- package/esm/components/bar-link/index.d.ts +4 -0
- package/esm/components/bar-link/index.js +8 -0
- package/esm/components/bar-link/index.js.map +1 -0
- package/esm/components/bar-link/type.d.ts +27 -0
- package/esm/components/bar-link/type.js +2 -0
- package/esm/components/bar-link/type.js.map +1 -0
- package/esm/components/bar-link/util.d.ts +22 -0
- package/esm/components/bar-link/util.js +178 -0
- package/esm/components/bar-link/util.js.map +1 -0
- package/esm/components/series-break/constant.d.ts +1 -0
- package/esm/components/series-break/constant.js +2 -0
- package/esm/components/series-break/constant.js.map +1 -0
- package/esm/components/series-break/index.d.ts +4 -0
- package/esm/components/series-break/index.js +8 -0
- package/esm/components/series-break/index.js.map +1 -0
- package/esm/components/series-break/series-break.d.ts +7 -0
- package/esm/components/series-break/series-break.js +115 -0
- package/esm/components/series-break/series-break.js.map +1 -0
- package/esm/components/series-break/type.d.ts +14 -0
- package/esm/components/series-break/type.js +2 -0
- package/esm/components/series-break/type.js.map +1 -0
- package/esm/components/series-break/util.d.ts +13 -0
- package/esm/components/series-break/util.js +244 -0
- package/esm/components/series-break/util.js.map +1 -0
- package/esm/components/series-label/constant.d.ts +1 -0
- package/esm/components/series-label/constant.js +2 -0
- package/esm/components/series-label/constant.js.map +1 -0
- package/esm/components/series-label/index.d.ts +3 -0
- package/esm/components/series-label/index.js +6 -0
- package/esm/components/series-label/index.js.map +1 -0
- package/esm/components/series-label/series-label.d.ts +7 -0
- package/esm/components/series-label/series-label.js +110 -0
- package/esm/components/series-label/series-label.js.map +1 -0
- package/esm/components/series-label/type.d.ts +41 -0
- package/esm/components/series-label/type.js +2 -0
- package/esm/components/series-label/type.js.map +1 -0
- package/esm/components/series-label/util.d.ts +33 -0
- package/esm/components/series-label/util.js +144 -0
- package/esm/components/series-label/util.js.map +1 -0
- package/esm/index.d.ts +9 -0
- package/esm/index.js +17 -0
- package/esm/index.js.map +1 -0
- package/esm/type/index.d.ts +1 -0
- package/esm/type/index.js +2 -0
- package/esm/type/index.js.map +1 -0
- package/esm/type/type.d.ts +8 -0
- package/esm/type/type.js +2 -0
- package/esm/type/type.js.map +1 -0
- package/esm/utils/element.d.ts +7 -0
- package/esm/utils/element.js +15 -0
- package/esm/utils/element.js.map +1 -0
- package/esm/utils/math.d.ts +1 -0
- package/esm/utils/math.js +4 -0
- package/esm/utils/math.js.map +1 -0
- package/package.json +6 -6
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.SequenceScatterPixelChartSpecTransformer = void 0;
|
|
6
|
+
|
|
7
|
+
const vchart_1 = require("@visactor/vchart"), utils_1 = require("./utils"), constant_1 = require("./constant");
|
|
8
|
+
|
|
9
|
+
class SequenceScatterPixelChartSpecTransformer extends vchart_1.CommonChartSpecTransformer {
|
|
10
|
+
transformSpec(spec) {
|
|
11
|
+
var _a, _b, _c, _d, _e;
|
|
12
|
+
super.transformSpec(spec);
|
|
13
|
+
const dataSpecs = (0, utils_1.processSequenceData)(spec);
|
|
14
|
+
spec.type = "common", spec.dataKey = constant_1.DATA_KEY, spec.data = dataSpecs[0].data,
|
|
15
|
+
spec.width = 300, spec.height = 300, spec.autoFit = !1, spec.series = [ {
|
|
16
|
+
type: "scatter",
|
|
17
|
+
xField: spec.xField,
|
|
18
|
+
yField: spec.yField
|
|
19
|
+
} ], spec.player && (spec.player = Object.assign(Object.assign({}, spec.player), {
|
|
20
|
+
specs: dataSpecs
|
|
21
|
+
}), spec.animationAppear = {
|
|
22
|
+
duration: null !== (_b = null === (_a = spec.player) || void 0 === _a ? void 0 : _a.duration) && void 0 !== _b ? _b : 2e3,
|
|
23
|
+
easing: "linear"
|
|
24
|
+
}, spec.animationUpdate = {
|
|
25
|
+
duration: null !== (_d = null === (_c = spec.player) || void 0 === _c ? void 0 : _c.duration) && void 0 !== _d ? _d : 2e3,
|
|
26
|
+
easing: "linear"
|
|
27
|
+
}), spec.axes = [ {
|
|
28
|
+
orient: "left",
|
|
29
|
+
type: "linear"
|
|
30
|
+
}, {
|
|
31
|
+
orient: "bottom",
|
|
32
|
+
label: {
|
|
33
|
+
visible: !0
|
|
34
|
+
},
|
|
35
|
+
type: "linear"
|
|
36
|
+
} ], spec.customMark = [ {
|
|
37
|
+
type: "image",
|
|
38
|
+
dataIndex: 2,
|
|
39
|
+
style: {
|
|
40
|
+
x: 0,
|
|
41
|
+
y: 0,
|
|
42
|
+
width: 300,
|
|
43
|
+
height: 300,
|
|
44
|
+
image: datum => datum.imageData,
|
|
45
|
+
zIndex: -1
|
|
46
|
+
}
|
|
47
|
+
}, {
|
|
48
|
+
type: "text",
|
|
49
|
+
dataIndex: 1,
|
|
50
|
+
style: Object.assign({
|
|
51
|
+
text: datum => datum.inter,
|
|
52
|
+
x: 50,
|
|
53
|
+
y: () => 10,
|
|
54
|
+
textBaseline: "top",
|
|
55
|
+
textAlign: "left",
|
|
56
|
+
fontSize: 100,
|
|
57
|
+
fontWeight: "bolder",
|
|
58
|
+
fill: "black",
|
|
59
|
+
fillOpacity: .2
|
|
60
|
+
}, null === (_e = spec.infoLabel) || void 0 === _e ? void 0 : _e.style)
|
|
61
|
+
} ], spec.tooltip = {
|
|
62
|
+
visible: !1
|
|
63
|
+
}, super.transformSpec(spec);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
exports.SequenceScatterPixelChartSpecTransformer = SequenceScatterPixelChartSpecTransformer;
|
|
68
|
+
//# sourceMappingURL=sequence-scatter-pixel-transformer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/sequence-scatter-pixel/sequence-scatter-pixel-transformer.ts"],"names":[],"mappings":";;;AAEA,6CAA8D;AAC9D,mCAA8C;AAC9C,yCAAsC;AAEtC,MAAa,wCAAyC,SAAQ,mCAA+B;IAC3F,aAAa,CAAC,IAAS;;QACrB,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC1B,MAAM,SAAS,GAAG,IAAA,2BAAmB,EAAC,IAA4C,CAAC,CAAC;QAEpF,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,mBAAQ,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAE9B,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,CAAC,MAAM,GAAG;YACZ;gBACE,IAAI,EAAE,SAAS;gBACf,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,MAAM,EAAE,IAAI,CAAC,MAAM;aACpB;SACF,CAAC;QAEF,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,mCACN,IAAI,CAAC,MAAM,KACd,KAAK,EAAE,SAAS,GACjB,CAAC;YACF,IAAI,CAAC,eAAe,GAAG;gBACrB,QAAQ,EAAE,MAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,mCAAI,IAAI;gBACvC,MAAM,EAAE,QAAQ;aACjB,CAAC;YAEF,IAAI,CAAC,eAAe,GAAG;gBACrB,QAAQ,EAAE,MAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,mCAAI,IAAI;gBACvC,MAAM,EAAE,QAAQ;aACjB,CAAC;SACH;QAED,IAAI,CAAC,IAAI,GAAG;YACV;gBACE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,MAAM,EAAE,QAAQ;gBAChB,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;gBACxB,IAAI,EAAE,QAAQ;aACf;SACF,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG;YAEhB;gBACE,IAAI,EAAE,OAAO;gBACb,SAAS,EAAE,CAAC;gBACZ,KAAK,EAAE;oBACL,CAAC,EAAE,CAAC;oBACJ,CAAC,EAAE,CAAC;oBACJ,KAAK,EAAE,GAAG;oBACV,MAAM,EAAE,GAAG;oBACX,KAAK,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS;oBACxC,MAAM,EAAE,CAAC,CAAC;iBACX;aACF;YACD;gBACE,IAAI,EAAE,MAAM;gBACZ,SAAS,EAAE,CAAC;gBACZ,KAAK,kBACH,IAAI,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,EACtC,CAAC,EAAE,EAAE,EACL,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EACX,YAAY,EAAE,KAAK,EACnB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,GAAG,EACb,UAAU,EAAE,QAAQ,EACpB,IAAI,EAAE,OAAO,EACb,WAAW,EAAE,GAAG,IACb,MAAA,IAAI,CAAC,SAAS,0CAAE,KAAK,CACzB;aACF;SACF,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG;YACb,OAAO,EAAE,KAAK;SACf,CAAC;QAEF,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;CACF;AAvFD,4FAuFC","file":"sequence-scatter-pixel-transformer.js","sourcesContent":["import { Datum } from '@visactor/vchart/src/typings';\nimport type { ISequenceScatterPixelSpec } from './interface';\nimport { CommonChartSpecTransformer } from '@visactor/vchart';\nimport { processSequenceData } from './utils';\nimport { DATA_KEY } from './constant';\n\nexport class SequenceScatterPixelChartSpecTransformer extends CommonChartSpecTransformer<any> {\n transformSpec(spec: any): void {\n super.transformSpec(spec);\n const dataSpecs = processSequenceData(spec as unknown as ISequenceScatterPixelSpec);\n\n spec.type = 'common';\n spec.dataKey = DATA_KEY;\n spec.data = dataSpecs[0].data;\n\n spec.width = 300;\n spec.height = 300;\n spec.autoFit = false;\n\n spec.series = [\n {\n type: 'scatter',\n xField: spec.xField,\n yField: spec.yField\n }\n ];\n\n if (spec.player) {\n spec.player = {\n ...spec.player,\n specs: dataSpecs\n };\n spec.animationAppear = {\n duration: spec.player?.duration ?? 2000,\n easing: 'linear'\n };\n\n spec.animationUpdate = {\n duration: spec.player?.duration ?? 2000,\n easing: 'linear'\n };\n }\n\n spec.axes = [\n {\n orient: 'left',\n type: 'linear'\n },\n {\n orient: 'bottom',\n label: { visible: true },\n type: 'linear'\n }\n ];\n\n spec.customMark = [\n // 背景图像\n {\n type: 'image',\n dataIndex: 2,\n style: {\n x: 0,\n y: 0,\n width: 300,\n height: 300,\n image: (datum: Datum) => datum.imageData,\n zIndex: -1\n }\n },\n {\n type: 'text',\n dataIndex: 1,\n style: {\n text: (datum: Datum) => datum['inter'],\n x: 50,\n y: () => 10,\n textBaseline: 'top',\n textAlign: 'left',\n fontSize: 100,\n fontWeight: 'bolder',\n fill: 'black',\n fillOpacity: 0.2,\n ...spec.infoLabel?.style\n }\n }\n ];\n\n spec.tooltip = {\n visible: false\n };\n\n super.transformSpec(spec);\n }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ISequenceScatterPixelSpec } from './interface';
|
|
2
|
+
import { VChart, BaseChart } from '@visactor/vchart';
|
|
3
|
+
import { SequenceScatterPixelChartSpecTransformer } from './sequence-scatter-pixel-transformer';
|
|
4
|
+
export declare class SequenceScatterPixel extends BaseChart<Omit<ISequenceScatterPixelSpec, 'data'>> {
|
|
5
|
+
type: string;
|
|
6
|
+
static type: string;
|
|
7
|
+
static readonly view: string;
|
|
8
|
+
_spec: ISequenceScatterPixelSpec;
|
|
9
|
+
static readonly transformerConstructor: typeof SequenceScatterPixelChartSpecTransformer;
|
|
10
|
+
readonly transformerConstructor: typeof SequenceScatterPixelChartSpecTransformer;
|
|
11
|
+
init(): void;
|
|
12
|
+
protected isValid(): boolean;
|
|
13
|
+
}
|
|
14
|
+
export declare const registerSequenceScatterPixel: (option?: {
|
|
15
|
+
VChart?: typeof VChart;
|
|
16
|
+
}) => void;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.registerSequenceScatterPixel = exports.SequenceScatterPixel = void 0;
|
|
6
|
+
|
|
7
|
+
const vchart_1 = require("@visactor/vchart"), sequence_scatter_pixel_transformer_1 = require("./sequence-scatter-pixel-transformer");
|
|
8
|
+
|
|
9
|
+
class SequenceScatterPixel extends vchart_1.BaseChart {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments), this.type = "sequenceScatterPixel", this.transformerConstructor = sequence_scatter_pixel_transformer_1.SequenceScatterPixelChartSpecTransformer;
|
|
12
|
+
}
|
|
13
|
+
init() {
|
|
14
|
+
this.isValid() && super.init();
|
|
15
|
+
}
|
|
16
|
+
isValid() {
|
|
17
|
+
var _a, _b, _c, _d;
|
|
18
|
+
const {xField: xField, yField: yField, data: data} = this._spec;
|
|
19
|
+
return xField && yField ? !!data || (null === (_d = (_c = this._option).onError) || void 0 === _d || _d.call(_c, "Data is required"),
|
|
20
|
+
!1) : (null === (_b = (_a = this._option).onError) || void 0 === _b || _b.call(_a, "Missing Required Config: `xField`, `yField` "),
|
|
21
|
+
!1);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
exports.SequenceScatterPixel = SequenceScatterPixel, SequenceScatterPixel.type = "sequenceScatterPixel",
|
|
26
|
+
SequenceScatterPixel.view = "singleDefault", SequenceScatterPixel.transformerConstructor = sequence_scatter_pixel_transformer_1.SequenceScatterPixelChartSpecTransformer;
|
|
27
|
+
|
|
28
|
+
const registerSequenceScatterPixel = option => {
|
|
29
|
+
const vchartConstructor = (null == option ? void 0 : option.VChart) || vchart_1.VChart;
|
|
30
|
+
vchartConstructor && vchartConstructor.useChart([ SequenceScatterPixel, vchart_1.ScatterChart ]);
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
exports.registerSequenceScatterPixel = registerSequenceScatterPixel;
|
|
34
|
+
//# sourceMappingURL=sequence-scatter-pixel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/sequence-scatter-pixel/sequence-scatter-pixel.ts"],"names":[],"mappings":";;;AACA,6CAAmE;AACnE,6FAAgG;AAEhG,MAAa,oBAAqB,SAAQ,kBAAkD;IAA5F;;QACE,SAAI,GAAG,sBAAsB,CAAC;QAOrB,2BAAsB,GAAG,6EAAwC,CAAC;IAqB7E,CAAC;IAnBC,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE;YACnB,OAAO;SACR;QACD,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC;IAES,OAAO;;QACf,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5C,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,EAAE;YACtB,MAAA,MAAA,IAAI,CAAC,OAAO,EAAC,OAAO,mDAAG,8CAA8C,CAAC,CAAC;YACvE,OAAO,KAAK,CAAC;SACd;QACD,IAAI,CAAC,IAAI,EAAE;YACT,MAAA,MAAA,IAAI,CAAC,OAAO,EAAC,OAAO,mDAAG,kBAAkB,CAAC,CAAC;YAC3C,OAAO,KAAK,CAAC;SACd;QACD,OAAO,IAAI,CAAC;IACd,CAAC;;AA5BH,oDA6BC;AA3BQ,yBAAI,GAAG,sBAAsB,CAAC;AACrB,yBAAI,GAAW,eAAe,CAAC;AAI/B,2CAAsB,GAAG,6EAAwC,CAAC;AAwB7E,MAAM,4BAA4B,GAAG,CAAC,MAAmC,EAAE,EAAE;IAClF,MAAM,iBAAiB,GAAG,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,KAAI,eAAM,CAAC;IACnD,IAAI,iBAAiB,EAAE;QACrB,iBAAiB,CAAC,QAAQ,CAAC,CAAC,oBAAoB,EAAE,qBAAY,CAAC,CAAC,CAAC;KAClE;AACH,CAAC,CAAC;AALW,QAAA,4BAA4B,gCAKvC","file":"sequence-scatter-pixel.js","sourcesContent":["import { ISequenceScatterPixelSpec } from './interface';\nimport { VChart, BaseChart, ScatterChart } from '@visactor/vchart';\nimport { SequenceScatterPixelChartSpecTransformer } from './sequence-scatter-pixel-transformer';\n\nexport class SequenceScatterPixel extends BaseChart<Omit<ISequenceScatterPixelSpec, 'data'>> {\n type = 'sequenceScatterPixel';\n static type = 'sequenceScatterPixel';\n static readonly view: string = 'singleDefault';\n\n declare _spec: ISequenceScatterPixelSpec;\n\n static readonly transformerConstructor = SequenceScatterPixelChartSpecTransformer;\n readonly transformerConstructor = SequenceScatterPixelChartSpecTransformer;\n\n init() {\n if (!this.isValid()) {\n return;\n }\n super.init();\n }\n\n protected isValid() {\n const { xField, yField, data } = this._spec;\n if (!xField || !yField) {\n this._option.onError?.('Missing Required Config: `xField`, `yField` ');\n return false;\n }\n if (!data) {\n this._option.onError?.('Data is required');\n return false;\n }\n return true;\n }\n}\n\nexport const registerSequenceScatterPixel = (option?: { VChart?: typeof VChart }) => {\n const vchartConstructor = option?.VChart || VChart;\n if (vchartConstructor) {\n vchartConstructor.useChart([SequenceScatterPixel, ScatterChart]);\n }\n};\n"]}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.processSequenceData = exports.createImageDataFromColorMatrix = void 0;
|
|
6
|
+
|
|
7
|
+
const constant_1 = require("./constant");
|
|
8
|
+
|
|
9
|
+
function createImageDataFromColorMatrix(colorMatrix, spec) {
|
|
10
|
+
var _a;
|
|
11
|
+
if ("undefined" == typeof document) throw new Error("Canvas rendering requires browser environment with document object");
|
|
12
|
+
const canvas = document.createElement("canvas");
|
|
13
|
+
canvas.width = spec.width, canvas.height = spec.height;
|
|
14
|
+
const ctx = canvas.getContext("2d");
|
|
15
|
+
if (!ctx) throw new Error("Failed to get 2D rendering context from canvas");
|
|
16
|
+
const imageData = ctx.createImageData(spec.width, spec.height);
|
|
17
|
+
for (let y = 0; y < 300; y++) for (let x = 0; x < 300; x++) {
|
|
18
|
+
const rgb = (null === (_a = colorMatrix[y]) || void 0 === _a ? void 0 : _a[x]) || [ 0, 0, 0 ], pixelIndex = 4 * (300 * y + x);
|
|
19
|
+
imageData.data[pixelIndex] = Math.round(255 * rgb[0]), imageData.data[pixelIndex + 1] = Math.round(255 * rgb[1]),
|
|
20
|
+
imageData.data[pixelIndex + 2] = Math.round(255 * rgb[2]), imageData.data[pixelIndex + 3] = 255;
|
|
21
|
+
}
|
|
22
|
+
return ctx.putImageData(imageData, 0, 0), canvas.toDataURL("image/png");
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
function processSequenceData(spec) {
|
|
26
|
+
const result = [];
|
|
27
|
+
return Object.keys(spec.data).forEach((inter => {
|
|
28
|
+
let backgroundData = null;
|
|
29
|
+
if (spec.backgroundColors && spec.backgroundColors[inter]) {
|
|
30
|
+
backgroundData = {
|
|
31
|
+
imageData: createImageDataFromColorMatrix(spec.backgroundColors[inter], spec)
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
result.push({
|
|
35
|
+
data: [ {
|
|
36
|
+
id: "nodes",
|
|
37
|
+
values: spec.data[inter].map(((d, i) => Object.assign(Object.assign({}, d), {
|
|
38
|
+
[constant_1.DATA_KEY]: i
|
|
39
|
+
})))
|
|
40
|
+
}, {
|
|
41
|
+
id: "inter",
|
|
42
|
+
values: [ {
|
|
43
|
+
inter: inter
|
|
44
|
+
} ]
|
|
45
|
+
}, {
|
|
46
|
+
id: constant_1.BACKGROUND_KEY,
|
|
47
|
+
values: backgroundData ? [ backgroundData ] : []
|
|
48
|
+
} ]
|
|
49
|
+
});
|
|
50
|
+
})), result;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
exports.createImageDataFromColorMatrix = createImageDataFromColorMatrix, exports.processSequenceData = processSequenceData;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["charts/sequence-scatter-pixel/utils.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["import { ISequenceScatterPixelSpec } from './interface';\nimport { BACKGROUND_KEY, DATA_KEY } from './constant';\n\n// 将RGB三元组数组转换为Canvas可用的imageData\nexport function createImageDataFromColorMatrix(colorMatrix: any[][], spec: ISequenceScatterPixelSpec): string | null {\n // 浏览器环境检查\n if (typeof document === 'undefined') {\n throw new Error('Canvas rendering requires browser environment with document object'); // 非浏览器环境下返回null\n }\n\n // 创建Canvas离屏渲染\n const canvas = document.createElement('canvas');\n canvas.width = spec.width;\n canvas.height = spec.height;\n const ctx = canvas.getContext('2d');\n\n if (!ctx) {\n throw new Error('Failed to get 2D rendering context from canvas'); // Canvas context creation failed\n }\n\n // 创建imageData\n const imageData = ctx.createImageData(spec.width, spec.height);\n\n // 填充像素数据\n for (let y = 0; y < 300; y++) {\n for (let x = 0; x < 300; x++) {\n const rgb = colorMatrix[y]?.[x] || [0, 0, 0];\n const pixelIndex = (y * 300 + x) * 4;\n\n // 转换0-1范围到0-255\n imageData.data[pixelIndex] = Math.round(rgb[0] * 255); // R\n imageData.data[pixelIndex + 1] = Math.round(rgb[1] * 255); // G\n imageData.data[pixelIndex + 2] = Math.round(rgb[2] * 255); // B\n imageData.data[pixelIndex + 3] = 255; // A (完全不透明)\n }\n }\n\n // 将imageData绘制到canvas然后返回dataURL\n ctx.putImageData(imageData, 0, 0);\n return canvas.toDataURL('image/png');\n}\n\nexport function processSequenceData(spec: ISequenceScatterPixelSpec) {\n const result: any[] = [];\n Object.keys(spec.data).forEach(inter => {\n let backgroundData = null;\n if (spec.backgroundColors && spec.backgroundColors[inter]) {\n const imageData = createImageDataFromColorMatrix(spec.backgroundColors[inter], spec);\n backgroundData = { imageData };\n }\n result.push({\n data: [\n {\n id: 'nodes',\n values: spec.data[inter].map((d, i) => {\n return { ...d, [DATA_KEY]: i };\n })\n },\n {\n id: 'inter',\n values: [\n {\n inter\n }\n ]\n },\n {\n id: BACKGROUND_KEY,\n values: backgroundData ? [backgroundData] : []\n }\n ]\n });\n });\n return result;\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AbstractComponent } from '@visactor/vrender-components';
|
|
2
|
+
import { BarLinkAttrs } from './type';
|
|
3
|
+
export declare class BarLinkComponent extends AbstractComponent<Required<BarLinkAttrs>> {
|
|
4
|
+
name: string;
|
|
5
|
+
protected render(): void;
|
|
6
|
+
}
|
|
7
|
+
export declare const registerBarLink: () => void;
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: !0
|
|
5
|
+
}), exports.registerBarLink = exports.BarLinkComponent = void 0;
|
|
6
|
+
|
|
7
|
+
const vrender_components_1 = require("@visactor/vrender-components"), vutils_1 = require("@visactor/vutils"), vgrammar_core_1 = require("@visactor/vgrammar-core"), vrender_core_1 = require("@visactor/vrender-core"), vchart_1 = require("@visactor/vchart"), constant_1 = require("./constant");
|
|
8
|
+
|
|
9
|
+
class BarLinkComponent extends vrender_components_1.AbstractComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments), this.name = constant_1.BAR_LINK;
|
|
12
|
+
}
|
|
13
|
+
render() {
|
|
14
|
+
const {data: data, linkStyle: linkStyle, areaStyle: areaStyle, styleMap: styleMap, label: label, linkType: linkType = "total"} = this.attribute;
|
|
15
|
+
(0, vutils_1.isEmpty)(data) || (this.removeAllChild(), data.forEach(((datum, index) => {
|
|
16
|
+
var _a, _b, _c, _d, _e;
|
|
17
|
+
const {linePoints: linePoints, areaPoints: areaPoints, id: id = index, color: color, data: curData} = datum;
|
|
18
|
+
if (areaPoints && !1 !== (null === (_a = null == styleMap ? void 0 : styleMap[`area-${id}`]) || void 0 === _a ? void 0 : _a.visible)) {
|
|
19
|
+
const area = (0, vrender_core_1.createArea)(Object.assign(Object.assign({
|
|
20
|
+
points: areaPoints,
|
|
21
|
+
fillOpacity: .3,
|
|
22
|
+
fill: color,
|
|
23
|
+
zIndex: 0
|
|
24
|
+
}, areaStyle), null == styleMap ? void 0 : styleMap[`area-${id}`]));
|
|
25
|
+
area.name = "bar-link-area", area.id = `area-${id}`, this.add(area);
|
|
26
|
+
}
|
|
27
|
+
if (linePoints && !1 !== (null === (_b = null == styleMap ? void 0 : styleMap[`line-${id}`]) || void 0 === _b ? void 0 : _b.visible) && 0 !== (null === (_c = null == linkStyle ? void 0 : linkStyle.lineStyle) || void 0 === _c ? void 0 : _c.lineWidth) && 0 !== (null === (_d = null == styleMap ? void 0 : styleMap[`line-${id}`]) || void 0 === _d ? void 0 : _d.lineWidth)) {
|
|
28
|
+
const {startSymbol: startSymbol = {}, endSymbol: endSymbol = {}, lineStyle: lineStyle} = linkStyle || {}, startSymbolAttrs = (0,
|
|
29
|
+
vutils_1.cloneDeep)(startSymbol), endSymbolAttrs = (0, vutils_1.cloneDeep)(endSymbol);
|
|
30
|
+
(null == styleMap ? void 0 : styleMap[`line-${id}`]) && styleMap[`line-${id}`].stroke && (startSymbolAttrs.style = Object.assign(Object.assign({}, startSymbolAttrs.style), {
|
|
31
|
+
color: styleMap[`line-${id}`].stroke
|
|
32
|
+
}), endSymbolAttrs.style = Object.assign(Object.assign({}, endSymbolAttrs.style), {
|
|
33
|
+
color: styleMap[`line-${id}`].stroke
|
|
34
|
+
})), startSymbolAttrs.symbolType || startSymbolAttrs.originSymbolType || (startSymbolAttrs.originSymbolType = "solidArrow"),
|
|
35
|
+
endSymbolAttrs.symbolType || endSymbolAttrs.originSymbolType || (endSymbolAttrs.originSymbolType = "solidArrow");
|
|
36
|
+
const line = new vrender_components_1.Segment({
|
|
37
|
+
points: linePoints,
|
|
38
|
+
startSymbol: Object.assign({
|
|
39
|
+
size: 8
|
|
40
|
+
}, startSymbolAttrs),
|
|
41
|
+
endSymbol: Object.assign({
|
|
42
|
+
size: 8
|
|
43
|
+
}, endSymbolAttrs),
|
|
44
|
+
lineStyle: Object.assign(Object.assign({
|
|
45
|
+
lineDash: [ 3, 3 ],
|
|
46
|
+
lineWidth: 1,
|
|
47
|
+
stroke: "#000"
|
|
48
|
+
}, lineStyle), null == styleMap ? void 0 : styleMap[`line-${id}`]),
|
|
49
|
+
pickable: !0,
|
|
50
|
+
childrenPickable: !1,
|
|
51
|
+
zIndex: 1
|
|
52
|
+
});
|
|
53
|
+
line.name = "bar-link-line", line.id = `line-${id}`, this.add(line);
|
|
54
|
+
}
|
|
55
|
+
if ((null == label ? void 0 : label.visible) && !1 !== (null === (_e = null == styleMap ? void 0 : styleMap[`label-${id}`]) || void 0 === _e ? void 0 : _e.visible)) {
|
|
56
|
+
const {style: style, formatMethod: formatMethod} = label, [startData, endData] = curData;
|
|
57
|
+
let startValue = startData[vchart_1.STACK_FIELD_END], endValue = endData[vchart_1.STACK_FIELD_END];
|
|
58
|
+
"value" === linkType && (startValue = startData[vchart_1.STACK_FIELD_END] - startData[vchart_1.STACK_FIELD_START],
|
|
59
|
+
endValue = endData[vchart_1.STACK_FIELD_END] - endData[vchart_1.STACK_FIELD_START]);
|
|
60
|
+
const value = endValue - startValue, percentage = (endValue - startValue) / startValue * 100, text = (0,
|
|
61
|
+
vrender_core_1.createText)(Object.assign(Object.assign({
|
|
62
|
+
x: .5 * (linePoints[0].x + linePoints[1].x),
|
|
63
|
+
y: .5 * (linePoints[0].y + linePoints[1].y),
|
|
64
|
+
text: formatMethod ? formatMethod(value, percentage, curData) : `${value} ${percentage}`,
|
|
65
|
+
fontSize: 14,
|
|
66
|
+
fill: "#000",
|
|
67
|
+
stroke: "#fff",
|
|
68
|
+
lineWidth: 1,
|
|
69
|
+
textAlign: "center",
|
|
70
|
+
textBaseline: "middle",
|
|
71
|
+
background: "#fff",
|
|
72
|
+
zIndex: 2
|
|
73
|
+
}, style), null == styleMap ? void 0 : styleMap[`label-${id}`]));
|
|
74
|
+
text.name = "bar-link-label", text.id = `label-${id}`, this.add(text);
|
|
75
|
+
}
|
|
76
|
+
})));
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
exports.BarLinkComponent = BarLinkComponent;
|
|
81
|
+
|
|
82
|
+
const registerBarLink = () => {
|
|
83
|
+
vgrammar_core_1.Factory.registerGraphicComponent(constant_1.BAR_LINK, (attrs => new BarLinkComponent(attrs)));
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
exports.registerBarLink = registerBarLink;
|
|
87
|
+
//# sourceMappingURL=bar-link.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/bar-link/bar-link.ts"],"names":[],"mappings":"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","file":"bar-link.js","sourcesContent":["/**\n * @description 堆叠柱系列的连接线组件\n * @author zhangweixing\n */\nimport { AbstractComponent, Segment } from '@visactor/vrender-components';\nimport { cloneDeep, isEmpty } from '@visactor/vutils';\nimport { Factory } from '@visactor/vgrammar-core';\nimport { type IGraphic, type ILineGraphicAttribute, createArea, createText } from '@visactor/vrender-core';\nimport { STACK_FIELD_END, STACK_FIELD_START } from '@visactor/vchart';\nimport { BarLinkAttrs } from './type';\nimport { BAR_LINK } from './constant';\n\nexport class BarLinkComponent extends AbstractComponent<Required<BarLinkAttrs>> {\n name = BAR_LINK;\n\n protected render() {\n const { data, linkStyle, areaStyle, styleMap, label, linkType = 'total' } = this.attribute as BarLinkLineAttrs;\n if (isEmpty(data)) {\n return;\n }\n this.removeAllChild();\n data.forEach((datum, index) => {\n const { linePoints, areaPoints, id = index, color, data: curData } = datum;\n\n if (areaPoints && styleMap?.[`area-${id}`]?.visible !== false) {\n // 先绘制面\n const area = createArea({\n points: areaPoints,\n fillOpacity: 0.3,\n fill: color,\n zIndex: 0,\n ...areaStyle,\n ...styleMap?.[`area-${id}`]\n });\n area.name = 'bar-link-area';\n area.id = `area-${id}`;\n this.add(area);\n }\n\n if (\n linePoints &&\n styleMap?.[`line-${id}`]?.visible !== false &&\n linkStyle?.lineStyle?.lineWidth !== 0 &&\n styleMap?.[`line-${id}`]?.lineWidth !== 0\n ) {\n // 再绘制点\n const { startSymbol = {}, endSymbol = {}, lineStyle } = linkStyle || {};\n\n const startSymbolAttrs = cloneDeep(startSymbol);\n const endSymbolAttrs = cloneDeep(endSymbol);\n if (styleMap?.[`line-${id}`] && styleMap[`line-${id}`].stroke) {\n (startSymbolAttrs as any).style = {\n ...(startSymbolAttrs as any).style,\n color: styleMap[`line-${id}`].stroke\n };\n (endSymbolAttrs as any).style = {\n ...(endSymbolAttrs as any).style,\n color: styleMap[`line-${id}`].stroke\n };\n }\n\n if (!(startSymbolAttrs as any).symbolType && !(startSymbolAttrs as any).originSymbolType) {\n (startSymbolAttrs as any).originSymbolType = 'solidArrow';\n }\n if (!(endSymbolAttrs as any).symbolType && !(endSymbolAttrs as any).originSymbolType) {\n (endSymbolAttrs as any).originSymbolType = 'solidArrow';\n }\n const line = new Segment({\n points: linePoints,\n startSymbol: {\n size: 8,\n ...startSymbolAttrs\n },\n endSymbol: {\n size: 8,\n ...endSymbolAttrs\n },\n lineStyle: {\n lineDash: [3, 3],\n lineWidth: 1,\n stroke: '#000',\n ...lineStyle,\n ...styleMap?.[`line-${id}`]\n } as ILineGraphicAttribute,\n pickable: true,\n childrenPickable: false,\n zIndex: 1\n });\n line.name = 'bar-link-line';\n line.id = `line-${id}`;\n this.add(line as unknown as IGraphic);\n }\n\n if (label?.visible && styleMap?.[`label-${id}`]?.visible !== false) {\n const { style, formatMethod } = label;\n\n const [startData, endData] = curData;\n\n let startValue = startData[STACK_FIELD_END];\n let endValue = endData[STACK_FIELD_END];\n if (linkType === 'value') {\n startValue = startData[STACK_FIELD_END] - startData[STACK_FIELD_START];\n endValue = endData[STACK_FIELD_END] - endData[STACK_FIELD_START];\n }\n\n const value = endValue - startValue;\n const percentage = ((endValue - startValue) / startValue) * 100;\n\n const text = createText({\n x: (linePoints[0].x + linePoints[1].x) * 0.5,\n y: (linePoints[0].y + linePoints[1].y) * 0.5,\n text: formatMethod ? formatMethod(value, percentage, curData) : `${value} ${percentage}`,\n fontSize: 14,\n fill: '#000',\n stroke: '#fff',\n lineWidth: 1,\n textAlign: 'center',\n textBaseline: 'middle',\n background: '#fff',\n zIndex: 2,\n ...style,\n ...styleMap?.[`label-${id}`]\n });\n text.name = 'bar-link-label';\n text.id = `label-${id}`;\n this.add(text);\n }\n });\n }\n}\n\nexport const registerBarLink = () => {\n Factory.registerGraphicComponent(\n BAR_LINK,\n (attrs: Required<BarLinkAttrs>) => new BarLinkComponent(attrs) as unknown as IGraphic\n );\n};\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const BAR_LINK = "barLink";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/bar-link/constant.ts"],"names":[],"mappings":";;;AAAa,QAAA,QAAQ,GAAG,SAAS,CAAC","file":"constant.js","sourcesContent":["export const BAR_LINK = 'barLink';\n"]}
|
|
@@ -0,0 +1,49 @@
|
|
|
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
|
+
}), exports.appendBarLinkConfig = exports.getBarLinkConfig = exports.registerBarLink = exports.BarLinkComponent = void 0;
|
|
21
|
+
|
|
22
|
+
var bar_link_1 = require("./bar-link");
|
|
23
|
+
|
|
24
|
+
Object.defineProperty(exports, "BarLinkComponent", {
|
|
25
|
+
enumerable: !0,
|
|
26
|
+
get: function() {
|
|
27
|
+
return bar_link_1.BarLinkComponent;
|
|
28
|
+
}
|
|
29
|
+
}), Object.defineProperty(exports, "registerBarLink", {
|
|
30
|
+
enumerable: !0,
|
|
31
|
+
get: function() {
|
|
32
|
+
return bar_link_1.registerBarLink;
|
|
33
|
+
}
|
|
34
|
+
}), __exportStar(require("./type"), exports);
|
|
35
|
+
|
|
36
|
+
var util_1 = require("./util");
|
|
37
|
+
|
|
38
|
+
Object.defineProperty(exports, "getBarLinkConfig", {
|
|
39
|
+
enumerable: !0,
|
|
40
|
+
get: function() {
|
|
41
|
+
return util_1.getBarLinkConfig;
|
|
42
|
+
}
|
|
43
|
+
}), Object.defineProperty(exports, "appendBarLinkConfig", {
|
|
44
|
+
enumerable: !0,
|
|
45
|
+
get: function() {
|
|
46
|
+
return util_1.appendBarLinkConfig;
|
|
47
|
+
}
|
|
48
|
+
}), __exportStar(require("./constant"), exports);
|
|
49
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/bar-link/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,uCAA+D;AAAtD,4GAAA,gBAAgB,OAAA;AAAE,2GAAA,eAAe,OAAA;AAC1C,yCAAuB;AACvB,+BAA+D;AAAtD,wGAAA,gBAAgB,OAAA;AAAE,2GAAA,mBAAmB,OAAA;AAC9C,6CAA2B","file":"index.js","sourcesContent":["export { BarLinkComponent, registerBarLink } from './bar-link';\nexport * from './type';\nexport { getBarLinkConfig, appendBarLinkConfig } from './util';\nexport * from './constant';\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { IAreaGraphicAttribute, IGroupGraphicAttribute, ILineGraphicAttribute, ITextGraphicAttribute } from '@visactor/vrender-core';
|
|
2
|
+
import type { SegmentAttributes } from '@visactor/vrender-components';
|
|
3
|
+
import type { Dict, IPointLike } from '@visactor/vutils';
|
|
4
|
+
export type Point = {
|
|
5
|
+
x: number;
|
|
6
|
+
y: number;
|
|
7
|
+
};
|
|
8
|
+
export type BarLinkDatum = {
|
|
9
|
+
areaPoints: [IPointLike, IPointLike];
|
|
10
|
+
linePoints: [IPointLike, IPointLike];
|
|
11
|
+
id?: string;
|
|
12
|
+
color?: string;
|
|
13
|
+
data: [Dict<any>, Dict<any>];
|
|
14
|
+
};
|
|
15
|
+
export interface BarLinkAttrs extends IGroupGraphicAttribute {
|
|
16
|
+
data: BarLinkDatum[];
|
|
17
|
+
linkType?: 'total' | 'value';
|
|
18
|
+
doFill?: boolean;
|
|
19
|
+
linkStyle?: Pick<SegmentAttributes, 'startSymbol' | 'endSymbol' | 'lineStyle'>;
|
|
20
|
+
areaStyle?: IAreaGraphicAttribute;
|
|
21
|
+
styleMap?: Record<string, ILineGraphicAttribute>;
|
|
22
|
+
label?: {
|
|
23
|
+
visible?: boolean;
|
|
24
|
+
style?: ITextGraphicAttribute;
|
|
25
|
+
formatMethod?: (value: number, percent: number, data: [any, any]) => (string | number) | (string | number)[];
|
|
26
|
+
};
|
|
27
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["components/bar-link/type.ts"],"names":[],"mappings":"","file":"type.js","sourcesContent":["import type {\n IAreaGraphicAttribute,\n IGroupGraphicAttribute,\n ILineGraphicAttribute,\n ITextGraphicAttribute\n} from '@visactor/vrender-core';\nimport type { SegmentAttributes } from '@visactor/vrender-components';\nimport type { Dict, IPointLike } from '@visactor/vutils';\n\nexport type Point = {\n x: number;\n y: number;\n};\n\nexport type BarLinkDatum = {\n /**\n * 用于绘制的面积的坐标点\n */\n areaPoints: [IPointLike, IPointLike];\n /**\n * 用于绘制线的坐标点\n */\n linePoints: [IPointLike, IPointLike];\n\n /**\n * 唯一标识,如果不声明,则默认使用数据索引\n */\n id?: string;\n color?: string;\n /**\n * 点携带的图形数据\n */\n data: [Dict<any>, Dict<any>];\n};\n\nexport interface BarLinkAttrs extends IGroupGraphicAttribute {\n data: BarLinkDatum[];\n /**\n * 连接类型\n * 1. 'total' 累计值进行连接\n * 2. 'value' 本身值连接\n */\n linkType?: 'total' | 'value';\n /**\n * 是否填充\n */\n doFill?: boolean;\n linkStyle?: Pick<SegmentAttributes, 'startSymbol' | 'endSymbol' | 'lineStyle'>;\n areaStyle?: IAreaGraphicAttribute;\n /**\n * 用于配置各个线的样式,key 对应线的 id,主要用于连接线的编辑场景\n * 1. 删除:{ visible: false }\n * 2. 样式编辑:{ stroke: 'red' }\n */\n styleMap?: Record<string, ILineGraphicAttribute>;\n label?: {\n visible?: boolean;\n style?: ITextGraphicAttribute;\n formatMethod?: (value: number, percent: number, data: [any, any]) => (string | number) | (string | number)[];\n };\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { IElement } from '@visactor/vgrammar-core';
|
|
2
|
+
import type { Dict } from '@visactor/vutils';
|
|
3
|
+
import type { BarLinkAttrs, BarLinkDatum } from './type';
|
|
4
|
+
import type { ISpec } from '@visactor/vchart';
|
|
5
|
+
export declare function groupBarsByFields(elements: IElement[], groupFields: string[]): Dict<IElement[]>;
|
|
6
|
+
export declare function getLinkData(currentElement: IElement, nextElement: IElement, config: {
|
|
7
|
+
isHorizontal: boolean;
|
|
8
|
+
isXAxisInverse: boolean;
|
|
9
|
+
isYAxisInverse: boolean;
|
|
10
|
+
linkType: string;
|
|
11
|
+
doFill: boolean;
|
|
12
|
+
regionStartX: number;
|
|
13
|
+
regionStartY: number;
|
|
14
|
+
}): BarLinkDatum;
|
|
15
|
+
export declare function getBarLinkConfig(style?: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'>, extraStyle?: any): {
|
|
16
|
+
type: string;
|
|
17
|
+
componentType: string;
|
|
18
|
+
zIndex: number;
|
|
19
|
+
interactive: boolean;
|
|
20
|
+
style: any;
|
|
21
|
+
};
|
|
22
|
+
export declare function appendBarLinkConfig(rawSpec: ISpec, barLinkSpec?: Pick<BarLinkAttrs, 'areaStyle' | 'label' | 'linkStyle' | 'styleMap' | 'doFill' | 'linkType'>): void;
|