@delon/chart 15.2.1 → 16.0.0-beta.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/bar/bar.component.d.ts +1 -1
- package/card/card.component.d.ts +1 -1
- package/chart-echarts/echarts.component.d.ts +1 -1
- package/core/g2.base.component.d.ts +1 -1
- package/custom/custom.component.d.ts +1 -1
- package/esm2022/bar/bar.component.mjs +144 -0
- package/esm2022/bar/bar.module.mjs +22 -0
- package/esm2022/card/card.component.mjs +56 -0
- package/esm2022/card/card.module.mjs +23 -0
- package/esm2022/chart-echarts/echarts.component.mjs +162 -0
- package/esm2022/chart-echarts/echarts.module.mjs +21 -0
- package/esm2022/chart-echarts/echarts.service.mjs +61 -0
- package/esm2022/core/g2.base.component.mjs +115 -0
- package/esm2022/core/g2.servicce.mjs +55 -0
- package/esm2022/custom/custom.component.mjs +70 -0
- package/esm2022/custom/custom.module.mjs +21 -0
- package/esm2022/gauge/gauge.component.mjs +171 -0
- package/esm2022/gauge/gauge.module.mjs +21 -0
- package/esm2022/mini-area/mini-area.component.mjs +135 -0
- package/esm2022/mini-area/mini-area.module.mjs +20 -0
- package/esm2022/mini-bar/mini-bar.component.mjs +102 -0
- package/esm2022/mini-bar/mini-bar.module.mjs +20 -0
- package/esm2022/mini-progress/mini-progress.component.mjs +47 -0
- package/esm2022/mini-progress/mini-progress.module.mjs +22 -0
- package/esm2022/number-info/number-info.component.mjs +46 -0
- package/esm2022/number-info/number-info.module.mjs +22 -0
- package/esm2022/pie/pie.component.mjs +223 -0
- package/esm2022/pie/pie.module.mjs +23 -0
- package/esm2022/radar/radar.component.mjs +150 -0
- package/esm2022/radar/radar.module.mjs +23 -0
- package/esm2022/single-bar/single-bar.component.mjs +128 -0
- package/esm2022/single-bar/single-bar.module.mjs +20 -0
- package/esm2022/tag-cloud/tag-cloud.component.mjs +163 -0
- package/esm2022/tag-cloud/tag-cloud.module.mjs +21 -0
- package/esm2022/timeline/timeline.component.mjs +206 -0
- package/esm2022/timeline/timeline.module.mjs +22 -0
- package/esm2022/trend/trend.component.mjs +53 -0
- package/esm2022/trend/trend.module.mjs +21 -0
- package/esm2022/water-wave/water-wave.component.mjs +221 -0
- package/esm2022/water-wave/water-wave.module.mjs +21 -0
- package/{fesm2020 → fesm2022}/bar.mjs +9 -9
- package/{fesm2020 → fesm2022}/bar.mjs.map +1 -1
- package/{fesm2015 → fesm2022}/card.mjs +7 -7
- package/{fesm2015 → fesm2022}/card.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/chart-echarts.mjs +12 -12
- package/fesm2022/chart-echarts.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/core.mjs +6 -6
- package/fesm2022/core.mjs.map +1 -0
- package/{fesm2015 → fesm2022}/custom.mjs +9 -9
- package/fesm2022/custom.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/gauge.mjs +7 -7
- package/fesm2022/gauge.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/mini-area.mjs +7 -7
- package/{fesm2020 → fesm2022}/mini-area.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mini-bar.mjs +7 -7
- package/{fesm2020 → fesm2022}/mini-bar.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/mini-progress.mjs +7 -7
- package/{fesm2020 → fesm2022}/mini-progress.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/number-info.mjs +7 -7
- package/{fesm2015 → fesm2022}/number-info.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/pie.mjs +7 -7
- package/{fesm2020 → fesm2022}/pie.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/radar.mjs +7 -7
- package/{fesm2020 → fesm2022}/radar.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/single-bar.mjs +7 -7
- package/fesm2022/single-bar.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/tag-cloud.mjs +7 -7
- package/{fesm2020 → fesm2022}/tag-cloud.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/timeline.mjs +9 -9
- package/{fesm2020 → fesm2022}/timeline.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/trend.mjs +9 -9
- package/fesm2022/trend.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/water-wave.mjs +7 -7
- package/fesm2022/water-wave.mjs.map +1 -0
- package/gauge/gauge.component.d.ts +1 -1
- package/mini-area/mini-area.component.d.ts +1 -1
- package/mini-bar/mini-bar.component.d.ts +1 -1
- package/mini-progress/mini-progress.component.d.ts +1 -1
- package/number-info/number-info.component.d.ts +1 -1
- package/package.json +60 -100
- package/pie/pie.component.d.ts +1 -1
- package/radar/radar.component.d.ts +1 -1
- package/single-bar/single-bar.component.d.ts +1 -1
- package/tag-cloud/tag-cloud.component.d.ts +1 -1
- package/timeline/timeline.component.d.ts +1 -1
- package/trend/trend.component.d.ts +1 -1
- package/water-wave/water-wave.component.d.ts +1 -1
- package/esm2020/bar/bar.component.mjs +0 -143
- package/esm2020/bar/bar.module.mjs +0 -21
- package/esm2020/card/card.component.mjs +0 -55
- package/esm2020/card/card.module.mjs +0 -22
- package/esm2020/chart-echarts/echarts.component.mjs +0 -161
- package/esm2020/chart-echarts/echarts.module.mjs +0 -20
- package/esm2020/chart-echarts/echarts.service.mjs +0 -60
- package/esm2020/core/g2.base.component.mjs +0 -114
- package/esm2020/core/g2.servicce.mjs +0 -54
- package/esm2020/custom/custom.component.mjs +0 -69
- package/esm2020/custom/custom.module.mjs +0 -20
- package/esm2020/gauge/gauge.component.mjs +0 -170
- package/esm2020/gauge/gauge.module.mjs +0 -20
- package/esm2020/mini-area/mini-area.component.mjs +0 -134
- package/esm2020/mini-area/mini-area.module.mjs +0 -19
- package/esm2020/mini-bar/mini-bar.component.mjs +0 -101
- package/esm2020/mini-bar/mini-bar.module.mjs +0 -19
- package/esm2020/mini-progress/mini-progress.component.mjs +0 -46
- package/esm2020/mini-progress/mini-progress.module.mjs +0 -21
- package/esm2020/number-info/number-info.component.mjs +0 -45
- package/esm2020/number-info/number-info.module.mjs +0 -21
- package/esm2020/pie/pie.component.mjs +0 -222
- package/esm2020/pie/pie.module.mjs +0 -22
- package/esm2020/radar/radar.component.mjs +0 -149
- package/esm2020/radar/radar.module.mjs +0 -22
- package/esm2020/single-bar/single-bar.component.mjs +0 -127
- package/esm2020/single-bar/single-bar.module.mjs +0 -19
- package/esm2020/tag-cloud/tag-cloud.component.mjs +0 -162
- package/esm2020/tag-cloud/tag-cloud.module.mjs +0 -20
- package/esm2020/timeline/timeline.component.mjs +0 -205
- package/esm2020/timeline/timeline.module.mjs +0 -21
- package/esm2020/trend/trend.component.mjs +0 -52
- package/esm2020/trend/trend.module.mjs +0 -20
- package/esm2020/water-wave/water-wave.component.mjs +0 -220
- package/esm2020/water-wave/water-wave.module.mjs +0 -20
- package/fesm2015/bar.mjs +0 -168
- package/fesm2015/bar.mjs.map +0 -1
- package/fesm2015/chart-echarts.mjs +0 -241
- package/fesm2015/chart-echarts.mjs.map +0 -1
- package/fesm2015/core.mjs +0 -186
- package/fesm2015/core.mjs.map +0 -1
- package/fesm2015/custom.mjs.map +0 -1
- package/fesm2015/gauge.mjs +0 -194
- package/fesm2015/gauge.mjs.map +0 -1
- package/fesm2015/mini-area.mjs +0 -157
- package/fesm2015/mini-area.mjs.map +0 -1
- package/fesm2015/mini-bar.mjs +0 -124
- package/fesm2015/mini-bar.mjs.map +0 -1
- package/fesm2015/mini-progress.mjs +0 -71
- package/fesm2015/mini-progress.mjs.map +0 -1
- package/fesm2015/number-info.mjs +0 -70
- package/fesm2015/pie.mjs +0 -248
- package/fesm2015/pie.mjs.map +0 -1
- package/fesm2015/radar.mjs +0 -175
- package/fesm2015/radar.mjs.map +0 -1
- package/fesm2015/single-bar.mjs +0 -148
- package/fesm2015/single-bar.mjs.map +0 -1
- package/fesm2015/tag-cloud.mjs +0 -176
- package/fesm2015/tag-cloud.mjs.map +0 -1
- package/fesm2015/timeline.mjs +0 -228
- package/fesm2015/timeline.mjs.map +0 -1
- package/fesm2015/trend.mjs +0 -76
- package/fesm2015/trend.mjs.map +0 -1
- package/fesm2015/water-wave.mjs +0 -244
- package/fesm2015/water-wave.mjs.map +0 -1
- package/fesm2020/card.mjs +0 -81
- package/fesm2020/card.mjs.map +0 -1
- package/fesm2020/chart-echarts.mjs.map +0 -1
- package/fesm2020/chart.mjs +0 -7
- package/fesm2020/chart.mjs.map +0 -1
- package/fesm2020/core.mjs.map +0 -1
- package/fesm2020/custom.mjs +0 -93
- package/fesm2020/custom.mjs.map +0 -1
- package/fesm2020/gauge.mjs.map +0 -1
- package/fesm2020/number-info.mjs.map +0 -1
- package/fesm2020/single-bar.mjs.map +0 -1
- package/fesm2020/trend.mjs.map +0 -1
- package/fesm2020/water-wave.mjs.map +0 -1
- /package/{esm2020 → esm2022}/bar/bar.mjs +0 -0
- /package/{esm2020 → esm2022}/bar/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/card/card.mjs +0 -0
- /package/{esm2020 → esm2022}/card/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/chart-echarts/chart-echarts.mjs +0 -0
- /package/{esm2020 → esm2022}/chart-echarts/echarts.types.mjs +0 -0
- /package/{esm2020 → esm2022}/chart-echarts/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/chart.mjs +0 -0
- /package/{esm2020 → esm2022}/core/core.mjs +0 -0
- /package/{esm2020 → esm2022}/core/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/core/types/interaction.mjs +0 -0
- /package/{esm2020 → esm2022}/core/types/time.mjs +0 -0
- /package/{esm2020 → esm2022}/core/utils.mjs +0 -0
- /package/{esm2020 → esm2022}/custom/custom.mjs +0 -0
- /package/{esm2020 → esm2022}/custom/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/gauge/gauge.mjs +0 -0
- /package/{esm2020 → esm2022}/gauge/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/mini-area/mini-area.mjs +0 -0
- /package/{esm2020 → esm2022}/mini-area/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/mini-bar/mini-bar.mjs +0 -0
- /package/{esm2020 → esm2022}/mini-bar/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/mini-progress/mini-progress.mjs +0 -0
- /package/{esm2020 → esm2022}/mini-progress/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/number-info/number-info.mjs +0 -0
- /package/{esm2020 → esm2022}/number-info/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/pie/pie.mjs +0 -0
- /package/{esm2020 → esm2022}/pie/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/radar/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/radar/radar.mjs +0 -0
- /package/{esm2020 → esm2022}/single-bar/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/single-bar/single-bar.mjs +0 -0
- /package/{esm2020 → esm2022}/tag-cloud/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/tag-cloud/tag-cloud.mjs +0 -0
- /package/{esm2020 → esm2022}/timeline/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/timeline/timeline.mjs +0 -0
- /package/{esm2020 → esm2022}/trend/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/trend/trend.mjs +0 -0
- /package/{esm2020 → esm2022}/water-wave/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/water-wave/water-wave.mjs +0 -0
- /package/{fesm2015 → fesm2022}/chart.mjs +0 -0
- /package/{fesm2015 → fesm2022}/chart.mjs.map +0 -0
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Directive, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
3
|
+
import { Subject, filter, takeUntil } from 'rxjs';
|
|
4
|
+
import { InputBoolean, InputNumber, ZoneOutside } from '@delon/util/decorator';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "./g2.servicce";
|
|
7
|
+
import * as i2 from "@angular/cdk/platform";
|
|
8
|
+
class G2BaseComponent {
|
|
9
|
+
get chart() {
|
|
10
|
+
return this._chart;
|
|
11
|
+
}
|
|
12
|
+
get winG2() {
|
|
13
|
+
return window.G2;
|
|
14
|
+
}
|
|
15
|
+
constructor(srv, el, ngZone, platform, cdr) {
|
|
16
|
+
this.srv = srv;
|
|
17
|
+
this.el = el;
|
|
18
|
+
this.ngZone = ngZone;
|
|
19
|
+
this.platform = platform;
|
|
20
|
+
this.cdr = cdr;
|
|
21
|
+
this.repaint = true;
|
|
22
|
+
this.destroy$ = new Subject();
|
|
23
|
+
this.loaded = false;
|
|
24
|
+
this.delay = 0;
|
|
25
|
+
this.ready = new EventEmitter();
|
|
26
|
+
this.theme = srv.cog.theme;
|
|
27
|
+
this.srv.notify
|
|
28
|
+
.pipe(takeUntil(this.destroy$), filter(() => !this.loaded))
|
|
29
|
+
.subscribe(() => this.load());
|
|
30
|
+
}
|
|
31
|
+
/** G2数据变更 */
|
|
32
|
+
changeData() { }
|
|
33
|
+
/** 等同 `ngOnInit` */
|
|
34
|
+
onInit() { }
|
|
35
|
+
/** 等同 `ngOnChanges` */
|
|
36
|
+
onChanges(_) { }
|
|
37
|
+
load() {
|
|
38
|
+
this.ngZone.run(() => {
|
|
39
|
+
this.loaded = true;
|
|
40
|
+
this.cdr.detectChanges();
|
|
41
|
+
});
|
|
42
|
+
setTimeout(() => this.install(), this.delay);
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
if (!this.platform.isBrowser) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
this.onInit();
|
|
49
|
+
if (this.winG2) {
|
|
50
|
+
this.load();
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this.srv.libLoad();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
ngOnChanges(changes) {
|
|
57
|
+
this.onChanges(changes);
|
|
58
|
+
const isOnlyChangeData = this.onlyChangeData
|
|
59
|
+
? this.onlyChangeData(changes)
|
|
60
|
+
: Object.keys(changes).length === 1 && !!changes.data;
|
|
61
|
+
if (isOnlyChangeData) {
|
|
62
|
+
this.changeData();
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
if (!this.chart || !this.repaint)
|
|
66
|
+
return;
|
|
67
|
+
this.ngZone.runOutsideAngular(() => {
|
|
68
|
+
this.destroyChart().install();
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
destroyChart() {
|
|
72
|
+
if (this._chart) {
|
|
73
|
+
this._chart.destroy();
|
|
74
|
+
}
|
|
75
|
+
return this;
|
|
76
|
+
}
|
|
77
|
+
ngOnDestroy() {
|
|
78
|
+
if (this.resize$) {
|
|
79
|
+
this.resize$.unsubscribe();
|
|
80
|
+
}
|
|
81
|
+
this.destroy$.next();
|
|
82
|
+
this.destroy$.complete();
|
|
83
|
+
this.destroyChart();
|
|
84
|
+
}
|
|
85
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2BaseComponent, deps: [{ token: i1.G2Service }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i2.Platform }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
86
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.4", type: G2BaseComponent, inputs: { repaint: "repaint", delay: "delay", theme: "theme" }, outputs: { ready: "ready" }, viewQueries: [{ propertyName: "node", first: true, predicate: ["container"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0 }); }
|
|
87
|
+
}
|
|
88
|
+
__decorate([
|
|
89
|
+
InputBoolean()
|
|
90
|
+
], G2BaseComponent.prototype, "repaint", void 0);
|
|
91
|
+
__decorate([
|
|
92
|
+
InputNumber()
|
|
93
|
+
], G2BaseComponent.prototype, "delay", void 0);
|
|
94
|
+
__decorate([
|
|
95
|
+
ZoneOutside()
|
|
96
|
+
], G2BaseComponent.prototype, "load", null);
|
|
97
|
+
__decorate([
|
|
98
|
+
ZoneOutside()
|
|
99
|
+
], G2BaseComponent.prototype, "destroyChart", null);
|
|
100
|
+
export { G2BaseComponent };
|
|
101
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2BaseComponent, decorators: [{
|
|
102
|
+
type: Directive
|
|
103
|
+
}], ctorParameters: function () { return [{ type: i1.G2Service }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: i2.Platform }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { repaint: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], node: [{
|
|
106
|
+
type: ViewChild,
|
|
107
|
+
args: ['container', { static: true }]
|
|
108
|
+
}], delay: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], theme: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], ready: [{
|
|
113
|
+
type: Output
|
|
114
|
+
}], load: [], destroyChart: [] } });
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"g2.base.component.js","sourceRoot":"","sources":["../../../../../packages/chart/core/g2.base.component.ts"],"names":[],"mappings":";AACA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAKL,MAAM,EAEN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAgB,MAAM,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAIhE,OAAO,EAAgB,YAAY,EAAE,WAAW,EAAe,WAAW,EAAE,MAAM,uBAAuB,CAAC;;;;AAK1G,MACsB,eAAe;IACnC,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,KAAK;QACP,OAAQ,MAAoB,CAAC,EAAE,CAAC;IAClC,CAAC;IAED,YACY,GAAc,EACd,EAA2B,EAC3B,MAAc,EACd,QAAkB,EAClB,GAAsB;QAJtB,QAAG,GAAH,GAAG,CAAW;QACd,OAAE,GAAF,EAAE,CAAyB;QAC3B,WAAM,GAAN,MAAM,CAAQ;QACd,aAAQ,GAAR,QAAQ,CAAU;QAClB,QAAG,GAAH,GAAG,CAAmB;QAYT,YAAO,GAAG,IAAI,CAAC;QAI9B,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEzC,WAAM,GAAG,KAAK,CAAC;QAES,UAAK,GAAG,CAAC,CAAC;QAEf,UAAK,GAAG,IAAI,YAAY,EAAS,CAAC;QApBnD,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,KAAM,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,MAAM;aACZ,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAC3B;aACA,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAClC,CAAC;IAoBD,aAAa;IACb,UAAU,KAAU,CAAC;IAErB,oBAAoB;IACpB,MAAM,KAAU,CAAC;IAEjB,uBAAuB;IACvB,SAAS,CAAC,CAAgB,IAAS,CAAC;IAG5B,IAAI;QACV,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC5B,OAAO;SACR;QACD,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;aAAM;YACL,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACpB;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAExB,MAAM,gBAAgB,GAAG,IAAI,CAAC,cAAc;YAC1C,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YAC9B,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;QACxD,IAAI,gBAAgB,EAAE;YACpB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;SACR;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QACzC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YACjC,IAAI,CAAC,YAAY,EAAE,CAAC,OAAO,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;IACL,CAAC;IAGS,YAAY;QACpB,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;SACvB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;SAC5B;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;8GAxGmB,eAAe;kGAAf,eAAe;;AA0BV;IAAf,YAAY,EAAE;gDAAgB;AAQhB;IAAd,WAAW,EAAE;8CAAW;AAmB1B;IADP,WAAW,EAAE;2CAOb;AA+BS;IADT,WAAW,EAAE;mDAMb;SA/FmB,eAAe;2FAAf,eAAe;kBADpC,SAAS;qMA2BiB,OAAO;sBAA/B,KAAK;gBAE8C,IAAI;sBAAvD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAMhB,KAAK;sBAA5B,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACa,KAAK;sBAAvB,MAAM;gBAiBC,IAAI,MAqCF,YAAY","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { Subject, Subscription, filter, takeUntil } from 'rxjs';\n\nimport type { Chart, Types } from '@antv/g2';\n\nimport { BooleanInput, InputBoolean, InputNumber, NumberInput, ZoneOutside } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { G2Service } from './g2.servicce';\n\n@Directive()\nexport abstract class G2BaseComponent implements OnInit, OnChanges, OnDestroy {\n  get chart(): Chart {\n    return this._chart;\n  }\n\n  get winG2(): NzSafeAny {\n    return (window as NzSafeAny).G2;\n  }\n\n  constructor(\n    protected srv: G2Service,\n    protected el: ElementRef<HTMLElement>,\n    protected ngZone: NgZone,\n    protected platform: Platform,\n    protected cdr: ChangeDetectorRef\n  ) {\n    this.theme = srv.cog.theme!;\n    this.srv.notify\n      .pipe(\n        takeUntil(this.destroy$),\n        filter(() => !this.loaded)\n      )\n      .subscribe(() => this.load());\n  }\n  static ngAcceptInputType_repaint: BooleanInput;\n  static ngAcceptInputType_delay: NumberInput;\n  @Input() @InputBoolean() repaint = true;\n\n  @ViewChild('container', { static: true }) protected node!: ElementRef;\n  protected resize$?: Subscription;\n  protected destroy$ = new Subject<void>();\n  protected _chart!: Chart;\n  loaded = false;\n\n  @Input() @InputNumber() delay = 0;\n  @Input() theme: string | Types.LooseObject;\n  @Output() readonly ready = new EventEmitter<Chart>();\n\n  /** 检查是否只变更数据 */\n  onlyChangeData?: (changes: SimpleChanges) => boolean;\n\n  abstract install(): void;\n\n  /** G2数据变更 */\n  changeData(): void {}\n\n  /** 等同 `ngOnInit` */\n  onInit(): void {}\n\n  /** 等同 `ngOnChanges` */\n  onChanges(_: SimpleChanges): void {}\n\n  @ZoneOutside()\n  private load(): void {\n    this.ngZone.run(() => {\n      this.loaded = true;\n      this.cdr.detectChanges();\n    });\n    setTimeout(() => this.install(), this.delay);\n  }\n\n  ngOnInit(): void {\n    if (!this.platform.isBrowser) {\n      return;\n    }\n    this.onInit();\n    if (this.winG2) {\n      this.load();\n    } else {\n      this.srv.libLoad();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.onChanges(changes);\n\n    const isOnlyChangeData = this.onlyChangeData\n      ? this.onlyChangeData(changes)\n      : Object.keys(changes).length === 1 && !!changes.data;\n    if (isOnlyChangeData) {\n      this.changeData();\n      return;\n    }\n    if (!this.chart || !this.repaint) return;\n    this.ngZone.runOutsideAngular(() => {\n      this.destroyChart().install();\n    });\n  }\n\n  @ZoneOutside()\n  protected destroyChart(): this {\n    if (this._chart) {\n      this._chart.destroy();\n    }\n    return this;\n  }\n\n  ngOnDestroy(): void {\n    if (this.resize$) {\n      this.resize$.unsubscribe();\n    }\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.destroyChart();\n  }\n}\n"]}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@delon/util/config";
|
|
5
|
+
import * as i2 from "@delon/util/other";
|
|
6
|
+
class G2Service {
|
|
7
|
+
get cog() {
|
|
8
|
+
return this._cog;
|
|
9
|
+
}
|
|
10
|
+
set cog(val) {
|
|
11
|
+
this._cog = this.cogSrv.merge('chart', {
|
|
12
|
+
theme: '',
|
|
13
|
+
libs: [
|
|
14
|
+
'https://gw.alipayobjects.com/os/lib/antv/g2/4.1.46/dist/g2.min.js',
|
|
15
|
+
'https://gw.alipayobjects.com/os/lib/antv/data-set/0.11.8/dist/data-set.js'
|
|
16
|
+
]
|
|
17
|
+
}, val);
|
|
18
|
+
}
|
|
19
|
+
constructor(cogSrv, lazySrv) {
|
|
20
|
+
this.cogSrv = cogSrv;
|
|
21
|
+
this.lazySrv = lazySrv;
|
|
22
|
+
this.loading = false;
|
|
23
|
+
this.loaded = false;
|
|
24
|
+
this.notify$ = new Subject();
|
|
25
|
+
this.cog = { theme: '' };
|
|
26
|
+
}
|
|
27
|
+
libLoad() {
|
|
28
|
+
if (this.loading) {
|
|
29
|
+
if (this.loaded) {
|
|
30
|
+
this.notify$.next();
|
|
31
|
+
}
|
|
32
|
+
return this;
|
|
33
|
+
}
|
|
34
|
+
this.loading = true;
|
|
35
|
+
this.lazySrv.load(this.cog.libs).then(() => {
|
|
36
|
+
this.loaded = true;
|
|
37
|
+
this.notify$.next();
|
|
38
|
+
});
|
|
39
|
+
return this;
|
|
40
|
+
}
|
|
41
|
+
get notify() {
|
|
42
|
+
return this.notify$.asObservable();
|
|
43
|
+
}
|
|
44
|
+
ngOnDestroy() {
|
|
45
|
+
this.notify$.unsubscribe();
|
|
46
|
+
}
|
|
47
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2Service, deps: [{ token: i1.AlainConfigService }, { token: i2.LazyService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
48
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2Service, providedIn: 'root' }); }
|
|
49
|
+
}
|
|
50
|
+
export { G2Service };
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2Service, decorators: [{
|
|
52
|
+
type: Injectable,
|
|
53
|
+
args: [{ providedIn: 'root' }]
|
|
54
|
+
}], ctorParameters: function () { return [{ type: i1.AlainConfigService }, { type: i2.LazyService }]; } });
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZzIuc2VydmljY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jaGFydC9jb3JlL2cyLnNlcnZpY2NlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFDdEQsT0FBTyxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7OztBQUszQyxNQUNhLFNBQVM7SUFNcEIsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFDRCxJQUFJLEdBQUcsQ0FBQyxHQUFxQjtRQUMzQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUMzQixPQUFPLEVBQ1A7WUFDRSxLQUFLLEVBQUUsRUFBRTtZQUNULElBQUksRUFBRTtnQkFDSixtRUFBbUU7Z0JBQ25FLDJFQUEyRTthQUM1RTtTQUNrQixFQUNyQixHQUFHLENBQ0gsQ0FBQztJQUNMLENBQUM7SUFFRCxZQUFvQixNQUEwQixFQUFVLE9BQW9CO1FBQXhELFdBQU0sR0FBTixNQUFNLENBQW9CO1FBQVUsWUFBTyxHQUFQLE9BQU8sQ0FBYTtRQXJCcEUsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixXQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ2YsWUFBTyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFvQnBDLElBQUksQ0FBQyxHQUFHLEdBQUcsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDaEIsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO2dCQUNmLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7YUFDckI7WUFDRCxPQUFPLElBQUksQ0FBQztTQUNiO1FBQ0QsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQzFDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDO1lBQ25CLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDckMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzdCLENBQUM7OEdBaERVLFNBQVM7a0hBQVQsU0FBUyxjQURJLE1BQU07O1NBQ25CLFNBQVM7MkZBQVQsU0FBUztrQkFEckIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgQWxhaW5DaGFydENvbmZpZywgQWxhaW5Db25maWdTZXJ2aWNlIH0gZnJvbSAnQGRlbG9uL3V0aWwvY29uZmlnJztcbmltcG9ydCB7IExhenlTZXJ2aWNlIH0gZnJvbSAnQGRlbG9uL3V0aWwvb3RoZXInO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIEcyU2VydmljZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgX2NvZyE6IEFsYWluQ2hhcnRDb25maWc7XG4gIHByaXZhdGUgbG9hZGluZyA9IGZhbHNlO1xuICBwcml2YXRlIGxvYWRlZCA9IGZhbHNlO1xuICBwcml2YXRlIG5vdGlmeSQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIGdldCBjb2coKTogQWxhaW5DaGFydENvbmZpZyB7XG4gICAgcmV0dXJuIHRoaXMuX2NvZztcbiAgfVxuICBzZXQgY29nKHZhbDogQWxhaW5DaGFydENvbmZpZykge1xuICAgIHRoaXMuX2NvZyA9IHRoaXMuY29nU3J2Lm1lcmdlKFxuICAgICAgJ2NoYXJ0JyxcbiAgICAgIHtcbiAgICAgICAgdGhlbWU6ICcnLFxuICAgICAgICBsaWJzOiBbXG4gICAgICAgICAgJ2h0dHBzOi8vZ3cuYWxpcGF5b2JqZWN0cy5jb20vb3MvbGliL2FudHYvZzIvNC4xLjQ2L2Rpc3QvZzIubWluLmpzJyxcbiAgICAgICAgICAnaHR0cHM6Ly9ndy5hbGlwYXlvYmplY3RzLmNvbS9vcy9saWIvYW50di9kYXRhLXNldC8wLjExLjgvZGlzdC9kYXRhLXNldC5qcydcbiAgICAgICAgXVxuICAgICAgfSBhcyBBbGFpbkNoYXJ0Q29uZmlnLFxuICAgICAgdmFsXG4gICAgKSE7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNvZ1NydjogQWxhaW5Db25maWdTZXJ2aWNlLCBwcml2YXRlIGxhenlTcnY6IExhenlTZXJ2aWNlKSB7XG4gICAgdGhpcy5jb2cgPSB7IHRoZW1lOiAnJyB9O1xuICB9XG5cbiAgbGliTG9hZCgpOiB0aGlzIHtcbiAgICBpZiAodGhpcy5sb2FkaW5nKSB7XG4gICAgICBpZiAodGhpcy5sb2FkZWQpIHtcbiAgICAgICAgdGhpcy5ub3RpZnkkLm5leHQoKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cbiAgICB0aGlzLmxvYWRpbmcgPSB0cnVlO1xuICAgIHRoaXMubGF6eVNydi5sb2FkKHRoaXMuY29nLmxpYnMhKS50aGVuKCgpID0+IHtcbiAgICAgIHRoaXMubG9hZGVkID0gdHJ1ZTtcbiAgICAgIHRoaXMubm90aWZ5JC5uZXh0KCk7XG4gICAgfSk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBnZXQgbm90aWZ5KCk6IE9ic2VydmFibGU8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLm5vdGlmeSQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLm5vdGlmeSQudW5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { fromEvent, debounceTime, takeUntil } from 'rxjs';
|
|
4
|
+
import { G2BaseComponent } from '@delon/chart/core';
|
|
5
|
+
import { InputNumber } from '@delon/util/decorator';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "ng-zorro-antd/skeleton";
|
|
9
|
+
class G2CustomComponent extends G2BaseComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.resizeTime = 0;
|
|
13
|
+
this.render = new EventEmitter();
|
|
14
|
+
this.resize = new EventEmitter();
|
|
15
|
+
this.destroy = new EventEmitter();
|
|
16
|
+
}
|
|
17
|
+
// #endregion
|
|
18
|
+
install() {
|
|
19
|
+
this.el.nativeElement.innerHTML = '';
|
|
20
|
+
this.render.emit(this.el);
|
|
21
|
+
this.installResizeEvent();
|
|
22
|
+
}
|
|
23
|
+
installResizeEvent() {
|
|
24
|
+
if (this.resizeTime <= 0)
|
|
25
|
+
return;
|
|
26
|
+
fromEvent(window, 'resize')
|
|
27
|
+
.pipe(takeUntil(this.destroy$), debounceTime(Math.min(200, this.resizeTime)))
|
|
28
|
+
.subscribe(() => this.resize.emit(this.el));
|
|
29
|
+
}
|
|
30
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2CustomComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.4", type: G2CustomComponent, selector: "g2,g2-custom", inputs: { height: "height", resizeTime: "resizeTime" }, outputs: { render: "render", resize: "resize", destroy: "destroy" }, host: { properties: { "style.height.px": "height" } }, exportAs: ["g2Custom"], usesInheritance: true, ngImport: i0, template: `
|
|
32
|
+
<nz-skeleton *ngIf="!loaded"></nz-skeleton>
|
|
33
|
+
<ng-content></ng-content>
|
|
34
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.NzSkeletonComponent, selector: "nz-skeleton", inputs: ["nzActive", "nzLoading", "nzRound", "nzTitle", "nzAvatar", "nzParagraph"], exportAs: ["nzSkeleton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
35
|
+
}
|
|
36
|
+
__decorate([
|
|
37
|
+
InputNumber()
|
|
38
|
+
], G2CustomComponent.prototype, "height", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
InputNumber()
|
|
41
|
+
], G2CustomComponent.prototype, "resizeTime", void 0);
|
|
42
|
+
export { G2CustomComponent };
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2CustomComponent, decorators: [{
|
|
44
|
+
type: Component,
|
|
45
|
+
args: [{
|
|
46
|
+
selector: 'g2,g2-custom',
|
|
47
|
+
exportAs: 'g2Custom',
|
|
48
|
+
template: `
|
|
49
|
+
<nz-skeleton *ngIf="!loaded"></nz-skeleton>
|
|
50
|
+
<ng-content></ng-content>
|
|
51
|
+
`,
|
|
52
|
+
host: {
|
|
53
|
+
'[style.height.px]': 'height'
|
|
54
|
+
},
|
|
55
|
+
preserveWhitespaces: false,
|
|
56
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
57
|
+
encapsulation: ViewEncapsulation.None
|
|
58
|
+
}]
|
|
59
|
+
}], propDecorators: { height: [{
|
|
60
|
+
type: Input
|
|
61
|
+
}], resizeTime: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], render: [{
|
|
64
|
+
type: Output
|
|
65
|
+
}], resize: [{
|
|
66
|
+
type: Output
|
|
67
|
+
}], destroy: [{
|
|
68
|
+
type: Output
|
|
69
|
+
}] } });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NoYXJ0L2N1c3RvbS9jdXN0b20uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFFVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTFELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFlLE1BQU0sdUJBQXVCLENBQUM7Ozs7QUFFakUsTUFjYSxpQkFBa0IsU0FBUSxlQUFlO0lBZHREOztRQXFCMEIsZUFBVSxHQUFHLENBQUMsQ0FBQztRQUNwQixXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztRQUN4QyxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztRQUN4QyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztLQWlCN0Q7SUFmQyxhQUFhO0lBRWIsT0FBTztRQUNMLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7UUFDckMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFTyxrQkFBa0I7UUFDeEIsSUFBSSxJQUFJLENBQUMsVUFBVSxJQUFJLENBQUM7WUFBRSxPQUFPO1FBRWpDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDO2FBQ3hCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQzthQUM1RSxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDaEQsQ0FBQzs4R0ExQlUsaUJBQWlCO2tHQUFqQixpQkFBaUIsdVJBWGxCOzs7R0FHVDs7QUFjdUI7SUFBZCxXQUFXLEVBQUU7aURBQWlCO0FBQ2hCO0lBQWQsV0FBVyxFQUFFO3FEQUFnQjtTQVA1QixpQkFBaUI7MkZBQWpCLGlCQUFpQjtrQkFkN0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsUUFBUSxFQUFFLFVBQVU7b0JBQ3BCLFFBQVEsRUFBRTs7O0dBR1Q7b0JBQ0QsSUFBSSxFQUFFO3dCQUNKLG1CQUFtQixFQUFFLFFBQVE7cUJBQzlCO29CQUNELG1CQUFtQixFQUFFLEtBQUs7b0JBQzFCLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEM7OEJBT3lCLE1BQU07c0JBQTdCLEtBQUs7Z0JBQ2tCLFVBQVU7c0JBQWpDLEtBQUs7Z0JBQ2EsTUFBTTtzQkFBeEIsTUFBTTtnQkFDWSxNQUFNO3NCQUF4QixNQUFNO2dCQUNZLE9BQU87c0JBQXpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZnJvbUV2ZW50LCBkZWJvdW5jZVRpbWUsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBHMkJhc2VDb21wb25lbnQgfSBmcm9tICdAZGVsb24vY2hhcnQvY29yZSc7XG5pbXBvcnQgeyBJbnB1dE51bWJlciwgTnVtYmVySW5wdXQgfSBmcm9tICdAZGVsb24vdXRpbC9kZWNvcmF0b3InO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdnMixnMi1jdXN0b20nLFxuICBleHBvcnRBczogJ2cyQ3VzdG9tJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bnotc2tlbGV0b24gKm5nSWY9XCIhbG9hZGVkXCI+PC9uei1za2VsZXRvbj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIGAsXG4gIGhvc3Q6IHtcbiAgICAnW3N0eWxlLmhlaWdodC5weF0nOiAnaGVpZ2h0J1xuICB9LFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgRzJDdXN0b21Db21wb25lbnQgZXh0ZW5kcyBHMkJhc2VDb21wb25lbnQge1xuICBzdGF0aWMgbmdBY2NlcHRJbnB1dFR5cGVfaGVpZ2h0OiBOdW1iZXJJbnB1dDtcbiAgc3RhdGljIG5nQWNjZXB0SW5wdXRUeXBlX3Jlc2l6ZVRpbWU6IE51bWJlcklucHV0O1xuXG4gIC8vICNyZWdpb24gZmllbGRzXG5cbiAgQElucHV0KCkgQElucHV0TnVtYmVyKCkgaGVpZ2h0PzogbnVtYmVyO1xuICBASW5wdXQoKSBASW5wdXROdW1iZXIoKSByZXNpemVUaW1lID0gMDtcbiAgQE91dHB1dCgpIHJlYWRvbmx5IHJlbmRlciA9IG5ldyBFdmVudEVtaXR0ZXI8RWxlbWVudFJlZj4oKTtcbiAgQE91dHB1dCgpIHJlYWRvbmx5IHJlc2l6ZSA9IG5ldyBFdmVudEVtaXR0ZXI8RWxlbWVudFJlZj4oKTtcbiAgQE91dHB1dCgpIHJlYWRvbmx5IGRlc3Ryb3kgPSBuZXcgRXZlbnRFbWl0dGVyPEVsZW1lbnRSZWY+KCk7XG5cbiAgLy8gI2VuZHJlZ2lvblxuXG4gIGluc3RhbGwoKTogdm9pZCB7XG4gICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LmlubmVySFRNTCA9ICcnO1xuICAgIHRoaXMucmVuZGVyLmVtaXQodGhpcy5lbCk7XG4gICAgdGhpcy5pbnN0YWxsUmVzaXplRXZlbnQoKTtcbiAgfVxuXG4gIHByaXZhdGUgaW5zdGFsbFJlc2l6ZUV2ZW50KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnJlc2l6ZVRpbWUgPD0gMCkgcmV0dXJuO1xuXG4gICAgZnJvbUV2ZW50KHdpbmRvdywgJ3Jlc2l6ZScpXG4gICAgICAucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCksIGRlYm91bmNlVGltZShNYXRoLm1pbigyMDAsIHRoaXMucmVzaXplVGltZSkpKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB0aGlzLnJlc2l6ZS5lbWl0KHRoaXMuZWwpKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { NzSkeletonModule } from 'ng-zorro-antd/skeleton';
|
|
4
|
+
import { G2CustomComponent } from './custom.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const COMPONENTS = [G2CustomComponent];
|
|
7
|
+
class G2CustomModule {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2CustomModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
9
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.4", ngImport: i0, type: G2CustomModule, declarations: [G2CustomComponent], imports: [CommonModule, NzSkeletonModule], exports: [G2CustomComponent] }); }
|
|
10
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2CustomModule, imports: [CommonModule, NzSkeletonModule] }); }
|
|
11
|
+
}
|
|
12
|
+
export { G2CustomModule };
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2CustomModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: [CommonModule, NzSkeletonModule],
|
|
17
|
+
declarations: COMPONENTS,
|
|
18
|
+
exports: COMPONENTS
|
|
19
|
+
}]
|
|
20
|
+
}] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NoYXJ0L2N1c3RvbS9jdXN0b20ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTFELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQUV2RCxNQUFNLFVBQVUsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFFdkMsTUFLYSxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxpQkFQUCxpQkFBaUIsYUFHekIsWUFBWSxFQUFFLGdCQUFnQixhQUh0QixpQkFBaUI7K0dBT3hCLGNBQWMsWUFKZixZQUFZLEVBQUUsZ0JBQWdCOztTQUk3QixjQUFjOzJGQUFkLGNBQWM7a0JBTDFCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGdCQUFnQixDQUFDO29CQUN6QyxZQUFZLEVBQUUsVUFBVTtvQkFDeEIsT0FBTyxFQUFFLFVBQVU7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE56U2tlbGV0b25Nb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL3NrZWxldG9uJztcblxuaW1wb3J0IHsgRzJDdXN0b21Db21wb25lbnQgfSBmcm9tICcuL2N1c3RvbS5jb21wb25lbnQnO1xuXG5jb25zdCBDT01QT05FTlRTID0gW0cyQ3VzdG9tQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTnpTa2VsZXRvbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogQ09NUE9ORU5UUyxcbiAgZXhwb3J0czogQ09NUE9ORU5UU1xufSlcbmV4cG9ydCBjbGFzcyBHMkN1c3RvbU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { G2BaseComponent } from '@delon/chart/core';
|
|
4
|
+
import { InputNumber } from '@delon/util/decorator';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "ng-zorro-antd/skeleton";
|
|
8
|
+
class G2GaugeComponent extends G2BaseComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.color = '#2f9cff';
|
|
12
|
+
this.padding = [10, 10, 30, 10];
|
|
13
|
+
}
|
|
14
|
+
// #endregion
|
|
15
|
+
install() {
|
|
16
|
+
// 自定义Shape 部分
|
|
17
|
+
this.winG2.registerShape('point', 'pointer', {
|
|
18
|
+
draw(cfg, container) {
|
|
19
|
+
const group = container.addGroup({});
|
|
20
|
+
// 获取极坐标系下画布中心点
|
|
21
|
+
const center = this.parsePoint({ x: 0, y: 0 });
|
|
22
|
+
// 绘制指针
|
|
23
|
+
group.addShape('line', {
|
|
24
|
+
attrs: {
|
|
25
|
+
x1: center.x,
|
|
26
|
+
y1: center.y,
|
|
27
|
+
x2: cfg.x,
|
|
28
|
+
y2: cfg.y,
|
|
29
|
+
stroke: cfg.color,
|
|
30
|
+
lineWidth: 2.5,
|
|
31
|
+
lineCap: 'round'
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
group.addShape('circle', {
|
|
35
|
+
attrs: {
|
|
36
|
+
x: center.x,
|
|
37
|
+
y: center.y,
|
|
38
|
+
r: 5.75,
|
|
39
|
+
stroke: cfg.color,
|
|
40
|
+
lineWidth: 2,
|
|
41
|
+
fill: '#fff'
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
return group;
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
const { el, height, padding, format, theme } = this;
|
|
48
|
+
const chart = (this._chart = new this.winG2.Chart({
|
|
49
|
+
container: el.nativeElement,
|
|
50
|
+
autoFit: true,
|
|
51
|
+
height,
|
|
52
|
+
padding,
|
|
53
|
+
theme
|
|
54
|
+
}));
|
|
55
|
+
chart.legend(false);
|
|
56
|
+
chart.animate(false);
|
|
57
|
+
chart.tooltip(false);
|
|
58
|
+
chart.coordinate('polar', {
|
|
59
|
+
startAngle: (-9 / 8) * Math.PI,
|
|
60
|
+
endAngle: (1 / 8) * Math.PI,
|
|
61
|
+
radius: 0.75
|
|
62
|
+
});
|
|
63
|
+
chart.scale('value', {
|
|
64
|
+
min: 0,
|
|
65
|
+
max: 100,
|
|
66
|
+
nice: true,
|
|
67
|
+
tickCount: 6
|
|
68
|
+
});
|
|
69
|
+
chart.axis('1', false);
|
|
70
|
+
chart.axis('value', {
|
|
71
|
+
line: null,
|
|
72
|
+
label: {
|
|
73
|
+
offset: -14,
|
|
74
|
+
formatter: format
|
|
75
|
+
},
|
|
76
|
+
tickLine: null,
|
|
77
|
+
grid: null
|
|
78
|
+
});
|
|
79
|
+
chart.point().position('value*1').shape('pointer');
|
|
80
|
+
this.ready.next(chart);
|
|
81
|
+
this.changeData();
|
|
82
|
+
chart.render();
|
|
83
|
+
}
|
|
84
|
+
changeData() {
|
|
85
|
+
const { _chart, percent, color, bgColor, title } = this;
|
|
86
|
+
if (!_chart)
|
|
87
|
+
return;
|
|
88
|
+
const data = [{ name: title, value: percent }];
|
|
89
|
+
const val = data[0].value;
|
|
90
|
+
_chart.annotation().clear(true);
|
|
91
|
+
_chart.geometries[0].color(color);
|
|
92
|
+
// 绘制仪表盘背景
|
|
93
|
+
_chart.annotation().arc({
|
|
94
|
+
top: false,
|
|
95
|
+
start: [0, 0.95],
|
|
96
|
+
end: [100, 0.95],
|
|
97
|
+
style: {
|
|
98
|
+
stroke: bgColor,
|
|
99
|
+
lineWidth: 12,
|
|
100
|
+
lineDash: null
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
_chart.annotation().arc({
|
|
104
|
+
start: [0, 0.95],
|
|
105
|
+
end: [data[0].value, 0.95],
|
|
106
|
+
style: {
|
|
107
|
+
stroke: color,
|
|
108
|
+
lineWidth: 12,
|
|
109
|
+
lineDash: null
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
_chart.annotation().text({
|
|
113
|
+
position: ['50%', '85%'],
|
|
114
|
+
content: title,
|
|
115
|
+
style: {
|
|
116
|
+
fontSize: 12,
|
|
117
|
+
fill: this.theme === 'dark' ? 'rgba(255, 255, 255, 0.43)' : 'rgba(0, 0, 0, 0.43)',
|
|
118
|
+
textAlign: 'center'
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
_chart.annotation().text({
|
|
122
|
+
position: ['50%', '90%'],
|
|
123
|
+
content: `${val} %`,
|
|
124
|
+
style: {
|
|
125
|
+
fontSize: 20,
|
|
126
|
+
fill: this.theme === 'dark' ? 'rgba(255, 255, 255, 0.85)' : 'rgba(0, 0, 0, 0.85)',
|
|
127
|
+
textAlign: 'center'
|
|
128
|
+
},
|
|
129
|
+
offsetY: 15
|
|
130
|
+
});
|
|
131
|
+
_chart.changeData(data);
|
|
132
|
+
}
|
|
133
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2GaugeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
134
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.4", type: G2GaugeComponent, selector: "g2-gauge", inputs: { title: "title", height: "height", color: "color", bgColor: "bgColor", format: "format", percent: "percent", padding: "padding" }, host: { properties: { "class.g2-gauge": "true" } }, exportAs: ["g2Gauge"], usesInheritance: true, ngImport: i0, template: `<nz-skeleton *ngIf="!loaded"></nz-skeleton>`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.NzSkeletonComponent, selector: "nz-skeleton", inputs: ["nzActive", "nzLoading", "nzRound", "nzTitle", "nzAvatar", "nzParagraph"], exportAs: ["nzSkeleton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
135
|
+
}
|
|
136
|
+
__decorate([
|
|
137
|
+
InputNumber()
|
|
138
|
+
], G2GaugeComponent.prototype, "height", void 0);
|
|
139
|
+
__decorate([
|
|
140
|
+
InputNumber()
|
|
141
|
+
], G2GaugeComponent.prototype, "percent", void 0);
|
|
142
|
+
export { G2GaugeComponent };
|
|
143
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2GaugeComponent, decorators: [{
|
|
144
|
+
type: Component,
|
|
145
|
+
args: [{
|
|
146
|
+
selector: 'g2-gauge',
|
|
147
|
+
exportAs: 'g2Gauge',
|
|
148
|
+
template: `<nz-skeleton *ngIf="!loaded"></nz-skeleton>`,
|
|
149
|
+
host: {
|
|
150
|
+
'[class.g2-gauge]': 'true'
|
|
151
|
+
},
|
|
152
|
+
preserveWhitespaces: false,
|
|
153
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
154
|
+
encapsulation: ViewEncapsulation.None
|
|
155
|
+
}]
|
|
156
|
+
}], propDecorators: { title: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], height: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], color: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], bgColor: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], format: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], percent: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], padding: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}] } });
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gauge.component.js","sourceRoot":"","sources":["../../../../../packages/chart/gauge/gauge.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from '@angular/core';\n\nimport type { Chart } from '@antv/g2';\n\nimport { G2BaseComponent } from '@delon/chart/core';\nimport { InputNumber, NumberInput } from '@delon/util/decorator';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\n\n@Component({\n  selector: 'g2-gauge',\n  exportAs: 'g2Gauge',\n  template: `<nz-skeleton *ngIf=\"!loaded\"></nz-skeleton>`,\n  host: {\n    '[class.g2-gauge]': 'true'\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class G2GaugeComponent extends G2BaseComponent {\n  static ngAcceptInputType_height: NumberInput;\n  static ngAcceptInputType_percent: NumberInput;\n\n  // #region fields\n\n  @Input() title?: string;\n  @Input() @InputNumber() height?: number;\n  @Input() color = '#2f9cff';\n  @Input() bgColor?: string; // = '#f0f2f5';\n  @Input() format?: (text: string, item: NzSafeAny, index: number) => string;\n  @Input() @InputNumber() percent?: number;\n  @Input() padding: number | number[] | 'auto' = [10, 10, 30, 10];\n\n  // #endregion\n\n  install(): void {\n    // 自定义Shape 部分\n    this.winG2.registerShape('point', 'pointer', {\n      draw(cfg: NzSafeAny, container: NzSafeAny) {\n        const group = container.addGroup({});\n        // 获取极坐标系下画布中心点\n        const center = (this as NzSafeAny).parsePoint({ x: 0, y: 0 });\n        // 绘制指针\n        group.addShape('line', {\n          attrs: {\n            x1: center.x,\n            y1: center.y,\n            x2: cfg.x,\n            y2: cfg.y,\n            stroke: cfg.color,\n            lineWidth: 2.5,\n            lineCap: 'round'\n          }\n        });\n        group.addShape('circle', {\n          attrs: {\n            x: center.x,\n            y: center.y,\n            r: 5.75,\n            stroke: cfg.color,\n            lineWidth: 2,\n            fill: '#fff'\n          }\n        });\n        return group;\n      }\n    });\n\n    const { el, height, padding, format, theme } = this;\n\n    const chart: Chart = (this._chart = new this.winG2.Chart({\n      container: el.nativeElement,\n      autoFit: true,\n      height,\n      padding,\n      theme\n    }));\n    chart.legend(false);\n    chart.animate(false);\n    chart.tooltip(false);\n    chart.coordinate('polar', {\n      startAngle: (-9 / 8) * Math.PI,\n      endAngle: (1 / 8) * Math.PI,\n      radius: 0.75\n    });\n    chart.scale('value', {\n      min: 0,\n      max: 100,\n      nice: true,\n      tickCount: 6\n    });\n    chart.axis('1', false);\n    chart.axis('value', {\n      line: null,\n      label: {\n        offset: -14,\n        formatter: format\n      },\n      tickLine: null,\n      grid: null\n    });\n    chart.point().position('value*1').shape('pointer');\n\n    this.ready.next(chart);\n\n    this.changeData();\n\n    chart.render();\n  }\n\n  changeData(): void {\n    const { _chart, percent, color, bgColor, title } = this;\n    if (!_chart) return;\n\n    const data = [{ name: title, value: percent }];\n    const val = data[0].value;\n    _chart.annotation().clear(true);\n    _chart.geometries[0].color(color);\n    // 绘制仪表盘背景\n    _chart.annotation().arc({\n      top: false,\n      start: [0, 0.95],\n      end: [100, 0.95],\n      style: {\n        stroke: bgColor,\n        lineWidth: 12,\n        lineDash: null\n      }\n    });\n    _chart.annotation().arc({\n      start: [0, 0.95],\n      end: [data[0].value!, 0.95],\n      style: {\n        stroke: color,\n        lineWidth: 12,\n        lineDash: null\n      }\n    });\n\n    _chart.annotation().text({\n      position: ['50%', '85%'],\n      content: title,\n      style: {\n        fontSize: 12,\n        fill: this.theme === 'dark' ? 'rgba(255, 255, 255, 0.43)' : 'rgba(0, 0, 0, 0.43)',\n        textAlign: 'center'\n      }\n    });\n    _chart.annotation().text({\n      position: ['50%', '90%'],\n      content: `${val} %`,\n      style: {\n        fontSize: 20,\n        fill: this.theme === 'dark' ? 'rgba(255, 255, 255, 0.85)' : 'rgba(0, 0, 0, 0.85)',\n        textAlign: 'center'\n      },\n      offsetY: 15\n    });\n\n    _chart.changeData(data);\n  }\n}\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { NzSkeletonModule } from 'ng-zorro-antd/skeleton';
|
|
4
|
+
import { G2GaugeComponent } from './gauge.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const COMPONENTS = [G2GaugeComponent];
|
|
7
|
+
class G2GaugeModule {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2GaugeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
9
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.4", ngImport: i0, type: G2GaugeModule, declarations: [G2GaugeComponent], imports: [CommonModule, NzSkeletonModule], exports: [G2GaugeComponent] }); }
|
|
10
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2GaugeModule, imports: [CommonModule, NzSkeletonModule] }); }
|
|
11
|
+
}
|
|
12
|
+
export { G2GaugeModule };
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.4", ngImport: i0, type: G2GaugeModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: [CommonModule, NzSkeletonModule],
|
|
17
|
+
declarations: COMPONENTS,
|
|
18
|
+
exports: COMPONENTS
|
|
19
|
+
}]
|
|
20
|
+
}] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2F1Z2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY2hhcnQvZ2F1Z2UvZ2F1Z2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTFELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUVyRCxNQUFNLFVBQVUsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUM7QUFFdEMsTUFLYSxhQUFhOzhHQUFiLGFBQWE7K0dBQWIsYUFBYSxpQkFQTixnQkFBZ0IsYUFHeEIsWUFBWSxFQUFFLGdCQUFnQixhQUh0QixnQkFBZ0I7K0dBT3ZCLGFBQWEsWUFKZCxZQUFZLEVBQUUsZ0JBQWdCOztTQUk3QixhQUFhOzJGQUFiLGFBQWE7a0JBTHpCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGdCQUFnQixDQUFDO29CQUN6QyxZQUFZLEVBQUUsVUFBVTtvQkFDeEIsT0FBTyxFQUFFLFVBQVU7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE56U2tlbGV0b25Nb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL3NrZWxldG9uJztcblxuaW1wb3J0IHsgRzJHYXVnZUNvbXBvbmVudCB9IGZyb20gJy4vZ2F1Z2UuY29tcG9uZW50JztcblxuY29uc3QgQ09NUE9ORU5UUyA9IFtHMkdhdWdlQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTnpTa2VsZXRvbk1vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogQ09NUE9ORU5UUyxcbiAgZXhwb3J0czogQ09NUE9ORU5UU1xufSlcbmV4cG9ydCBjbGFzcyBHMkdhdWdlTW9kdWxlIHt9XG4iXX0=
|