UNPKG

6.75 kBJavaScriptView Raw
1"use strict";
2var __assign = (this && this.__assign) || function () {
3 __assign = Object.assign || function(t) {
4 for (var s, i = 1, n = arguments.length; i < n; i++) {
5 s = arguments[i];
6 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7 t[p] = s[p];
8 }
9 return t;
10 };
11 return __assign.apply(this, arguments);
12};
13var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14 if (k2 === undefined) k2 = k;
15 Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
16}) : (function(o, m, k, k2) {
17 if (k2 === undefined) k2 = k;
18 o[k2] = m[k];
19}));
20var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
21 Object.defineProperty(o, "default", { enumerable: true, value: v });
22}) : function(o, v) {
23 o["default"] = v;
24});
25var __importStar = (this && this.__importStar) || function (mod) {
26 if (mod && mod.__esModule) return mod;
27 var result = {};
28 if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
29 __setModuleDefault(result, mod);
30 return result;
31};
32var __rest = (this && this.__rest) || function (s, e) {
33 var t = {};
34 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
35 t[p] = s[p];
36 if (s != null && typeof Object.getOwnPropertySymbols === "function")
37 for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
38 if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
39 t[p[i]] = s[p[i]];
40 }
41 return t;
42};
43var __importDefault = (this && this.__importDefault) || function (mod) {
44 return (mod && mod.__esModule) ? mod : { "default": mod };
45};
46Object.defineProperty(exports, "__esModule", { value: true });
47var react_1 = __importDefault(require("react"));
48var util_1 = require("@antv/g2/lib/geometry/shape/area/util");
49// 按需使用需要加载图形
50require("@antv/g2/lib/geometry/shape/line");
51require("@antv/g2/lib/geometry/shape/area");
52var is_object_1 = __importDefault(require("@antv/util/lib/is-object"));
53var deep_mix_1 = __importDefault(require("@antv/util/lib/deep-mix"));
54var get_1 = __importDefault(require("@antv/util/lib/get"));
55var set_1 = __importDefault(require("@antv/util/lib/set"));
56var core_1 = require("../core");
57var d3Color = __importStar(require("d3-color"));
58var useChartView_1 = __importDefault(require("../hooks/useChartView"));
59var useChartInstance_1 = __importDefault(require("../hooks/useChartInstance"));
60var Line_1 = __importDefault(require("./Line"));
61var Point_1 = __importDefault(require("./Point"));
62var Area_1 = __importDefault(require("./Area"));
63var areaStyle = {
64 "default": {
65 "style": {
66 "fill": "#5B8FF9",
67 "fillOpacity": 0.25,
68 "stroke": null
69 }
70 },
71 "active": {
72 "style": { "fillOpacity": 0.5 }
73 },
74 "inactive": {
75 "style": { "fillOpacity": 0.4 }
76 },
77 "selected": {
78 "style": { "fillOpacity": 0.5 }
79 }
80};
81var LineAdvance = function (props) {
82 var point = props.point, area = props.area, shape = props.shape, cfg = __rest(props, ["point", "area", "shape"]);
83 var pointCfg = { shape: 'circle' };
84 var chart = useChartInstance_1.default();
85 var view = useChartView_1.default();
86 var areaCfg = { shape: shape === 'smooth' ? 'gradient-smooth' : 'gradient' };
87 var theme = view.getTheme();
88 // todo: 需要g2层修改
89 theme.geometries.area.gradient = areaStyle;
90 // todo: 需要g2层修改
91 theme.geometries.area['gradient-smooth'] = areaStyle;
92 if (get_1.default(chart, ['options', 'tooltip']) !== false) {
93 // 默认为shared
94 if (get_1.default(view, ['options', 'tooltip', 'shared']) === undefined) {
95 set_1.default(view, ['options', 'tooltip', 'shared'], true);
96 }
97 ;
98 // 默认showCrosshairs
99 if (get_1.default(view, ['options', 'tooltip', 'showCrosshairs']) === undefined) {
100 set_1.default(view, ['options', 'tooltip', 'showCrosshairs'], true);
101 }
102 ;
103 if (get_1.default(view, ['options', 'tooltip', 'showMarkers']) === undefined) {
104 set_1.default(view, ['options', 'tooltip', 'showMarkers'], true);
105 }
106 ;
107 }
108 if (is_object_1.default(pointCfg)) {
109 deep_mix_1.default(pointCfg, point);
110 }
111 if (is_object_1.default(areaCfg)) {
112 deep_mix_1.default(areaCfg, area);
113 }
114 return (react_1.default.createElement(react_1.default.Fragment, null,
115 react_1.default.createElement(Line_1.default, __assign({ shape: shape, state: {
116 default: { style: { shadowColor: '#ddd', shadowBlur: 3, shadowOffsetY: 2 } },
117 active: { style: { shadowColor: '#ddd', shadowBlur: 3, shadowOffsetY: 5 } },
118 } }, cfg)),
119 !!area && react_1.default.createElement(Area_1.default, __assign({}, cfg, { tooltip: false }, areaCfg)),
120 !!point && react_1.default.createElement(Point_1.default, __assign({ size: 3 }, cfg, { state: {
121 active: { style: { stroke: '#fff', lineWidth: 1.5, strokeOpacity: 0.9 } },
122 }, tooltip: false }, pointCfg))));
123};
124// Area 几何标记默认的 shape:填充的区域图
125core_1.registerShape('area', 'gradient', {
126 draw: function (cfg, container) {
127 var attrs = util_1.getShapeAttrs(cfg, false, false, this);
128 var c = attrs.fill;
129 var clr = d3Color.color(c);
130 if (clr) {
131 attrs.fill = "l (90) 0:" + d3Color.rgb(clr.r, clr.g, clr.b, 1).formatRgb() + " 1:" + d3Color.rgb(clr.r, clr.g, clr.b, 0.1).formatRgb();
132 }
133 // attrs.fill = 'red';
134 var shape = container.addShape({
135 type: 'path',
136 attrs: attrs,
137 name: 'area',
138 });
139 return shape;
140 },
141});
142/**
143 * 填充的平滑曲面图
144 */
145core_1.registerShape('area', 'gradient-smooth', {
146 draw: function (cfg, container) {
147 var coordinate = this.coordinate;
148 var attrs = util_1.getShapeAttrs(cfg, false, true, this, util_1.getConstraint(coordinate));
149 var c = attrs.fill;
150 var clr = d3Color.color(c);
151 if (clr) {
152 attrs.fill = "l (90) 0:" + d3Color.rgb(clr.r, clr.g, clr.b, 1).formatRgb() + " 1:" + d3Color.rgb(clr.r, clr.g, clr.b, 0.1).formatRgb();
153 }
154 // attrs.fill = 'red';
155 var shape = container.addShape({
156 type: 'path',
157 attrs: attrs,
158 name: 'area',
159 });
160 return shape;
161 }
162});
163exports.default = LineAdvance;
164//# sourceMappingURL=LineAdvance.js.map
\No newline at end of file