1 | "use strict";
|
2 | var __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 | };
|
13 | var __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 | }));
|
20 | var __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 | });
|
25 | var __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 | };
|
32 | var __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 | };
|
43 | var __importDefault = (this && this.__importDefault) || function (mod) {
|
44 | return (mod && mod.__esModule) ? mod : { "default": mod };
|
45 | };
|
46 | Object.defineProperty(exports, "__esModule", { value: true });
|
47 | var react_1 = __importDefault(require("react"));
|
48 | var util_1 = require("@antv/g2/lib/geometry/shape/area/util");
|
49 |
|
50 | require("@antv/g2/lib/geometry/shape/line");
|
51 | require("@antv/g2/lib/geometry/shape/area");
|
52 | var is_object_1 = __importDefault(require("@antv/util/lib/is-object"));
|
53 | var deep_mix_1 = __importDefault(require("@antv/util/lib/deep-mix"));
|
54 | var get_1 = __importDefault(require("@antv/util/lib/get"));
|
55 | var set_1 = __importDefault(require("@antv/util/lib/set"));
|
56 | var core_1 = require("../core");
|
57 | var d3Color = __importStar(require("d3-color"));
|
58 | var useChartView_1 = __importDefault(require("../hooks/useChartView"));
|
59 | var useChartInstance_1 = __importDefault(require("../hooks/useChartInstance"));
|
60 | var Line_1 = __importDefault(require("./Line"));
|
61 | var Point_1 = __importDefault(require("./Point"));
|
62 | var Area_1 = __importDefault(require("./Area"));
|
63 | var 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 | };
|
81 | var 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 |
|
89 | theme.geometries.area.gradient = areaStyle;
|
90 |
|
91 | theme.geometries.area['gradient-smooth'] = areaStyle;
|
92 | if (get_1.default(chart, ['options', 'tooltip']) !== false) {
|
93 |
|
94 | if (get_1.default(view, ['options', 'tooltip', 'shared']) === undefined) {
|
95 | set_1.default(view, ['options', 'tooltip', 'shared'], true);
|
96 | }
|
97 | ;
|
98 |
|
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 |
|
125 | core_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 |
|
134 | var shape = container.addShape({
|
135 | type: 'path',
|
136 | attrs: attrs,
|
137 | name: 'area',
|
138 | });
|
139 | return shape;
|
140 | },
|
141 | });
|
142 |
|
143 |
|
144 |
|
145 | core_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 |
|
155 | var shape = container.addShape({
|
156 | type: 'path',
|
157 | attrs: attrs,
|
158 | name: 'area',
|
159 | });
|
160 | return shape;
|
161 | }
|
162 | });
|
163 | exports.default = LineAdvance;
|
164 |
|
\ | No newline at end of file |