@delon/chart 15.2.0 → 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.
Files changed (207) hide show
  1. package/bar/bar.component.d.ts +1 -1
  2. package/card/card.component.d.ts +1 -1
  3. package/chart-echarts/echarts.component.d.ts +1 -1
  4. package/core/g2.base.component.d.ts +1 -1
  5. package/custom/custom.component.d.ts +1 -1
  6. package/esm2022/bar/bar.component.mjs +144 -0
  7. package/esm2022/bar/bar.module.mjs +22 -0
  8. package/esm2022/card/card.component.mjs +56 -0
  9. package/esm2022/card/card.module.mjs +23 -0
  10. package/esm2022/chart-echarts/echarts.component.mjs +162 -0
  11. package/esm2022/chart-echarts/echarts.module.mjs +21 -0
  12. package/esm2022/chart-echarts/echarts.service.mjs +61 -0
  13. package/esm2022/core/g2.base.component.mjs +115 -0
  14. package/esm2022/core/g2.servicce.mjs +55 -0
  15. package/esm2022/custom/custom.component.mjs +70 -0
  16. package/esm2022/custom/custom.module.mjs +21 -0
  17. package/esm2022/gauge/gauge.component.mjs +171 -0
  18. package/esm2022/gauge/gauge.module.mjs +21 -0
  19. package/esm2022/mini-area/mini-area.component.mjs +135 -0
  20. package/esm2022/mini-area/mini-area.module.mjs +20 -0
  21. package/esm2022/mini-bar/mini-bar.component.mjs +102 -0
  22. package/esm2022/mini-bar/mini-bar.module.mjs +20 -0
  23. package/esm2022/mini-progress/mini-progress.component.mjs +47 -0
  24. package/esm2022/mini-progress/mini-progress.module.mjs +22 -0
  25. package/esm2022/number-info/number-info.component.mjs +46 -0
  26. package/esm2022/number-info/number-info.module.mjs +22 -0
  27. package/esm2022/pie/pie.component.mjs +223 -0
  28. package/esm2022/pie/pie.module.mjs +23 -0
  29. package/esm2022/radar/radar.component.mjs +150 -0
  30. package/esm2022/radar/radar.module.mjs +23 -0
  31. package/esm2022/single-bar/single-bar.component.mjs +128 -0
  32. package/esm2022/single-bar/single-bar.module.mjs +20 -0
  33. package/esm2022/tag-cloud/tag-cloud.component.mjs +163 -0
  34. package/esm2022/tag-cloud/tag-cloud.module.mjs +21 -0
  35. package/esm2022/timeline/timeline.component.mjs +206 -0
  36. package/esm2022/timeline/timeline.module.mjs +22 -0
  37. package/esm2022/trend/trend.component.mjs +53 -0
  38. package/esm2022/trend/trend.module.mjs +21 -0
  39. package/esm2022/water-wave/water-wave.component.mjs +221 -0
  40. package/esm2022/water-wave/water-wave.module.mjs +21 -0
  41. package/{fesm2020 → fesm2022}/bar.mjs +9 -9
  42. package/{fesm2020 → fesm2022}/bar.mjs.map +1 -1
  43. package/{fesm2015 → fesm2022}/card.mjs +7 -7
  44. package/{fesm2015 → fesm2022}/card.mjs.map +1 -1
  45. package/{fesm2020 → fesm2022}/chart-echarts.mjs +12 -12
  46. package/fesm2022/chart-echarts.mjs.map +1 -0
  47. package/{fesm2020 → fesm2022}/core.mjs +6 -6
  48. package/fesm2022/core.mjs.map +1 -0
  49. package/{fesm2015 → fesm2022}/custom.mjs +9 -9
  50. package/fesm2022/custom.mjs.map +1 -0
  51. package/{fesm2020 → fesm2022}/gauge.mjs +7 -7
  52. package/fesm2022/gauge.mjs.map +1 -0
  53. package/{fesm2020 → fesm2022}/mini-area.mjs +7 -7
  54. package/{fesm2020 → fesm2022}/mini-area.mjs.map +1 -1
  55. package/{fesm2020 → fesm2022}/mini-bar.mjs +7 -7
  56. package/{fesm2020 → fesm2022}/mini-bar.mjs.map +1 -1
  57. package/{fesm2020 → fesm2022}/mini-progress.mjs +7 -7
  58. package/{fesm2020 → fesm2022}/mini-progress.mjs.map +1 -1
  59. package/{fesm2020 → fesm2022}/number-info.mjs +7 -7
  60. package/{fesm2015 → fesm2022}/number-info.mjs.map +1 -1
  61. package/{fesm2020 → fesm2022}/pie.mjs +7 -7
  62. package/{fesm2020 → fesm2022}/pie.mjs.map +1 -1
  63. package/{fesm2020 → fesm2022}/radar.mjs +7 -7
  64. package/{fesm2020 → fesm2022}/radar.mjs.map +1 -1
  65. package/{fesm2020 → fesm2022}/single-bar.mjs +7 -7
  66. package/fesm2022/single-bar.mjs.map +1 -0
  67. package/{fesm2020 → fesm2022}/tag-cloud.mjs +7 -7
  68. package/{fesm2020 → fesm2022}/tag-cloud.mjs.map +1 -1
  69. package/{fesm2020 → fesm2022}/timeline.mjs +9 -9
  70. package/{fesm2020 → fesm2022}/timeline.mjs.map +1 -1
  71. package/{fesm2020 → fesm2022}/trend.mjs +9 -9
  72. package/fesm2022/trend.mjs.map +1 -0
  73. package/{fesm2020 → fesm2022}/water-wave.mjs +7 -7
  74. package/fesm2022/water-wave.mjs.map +1 -0
  75. package/gauge/gauge.component.d.ts +1 -1
  76. package/mini-area/mini-area.component.d.ts +1 -1
  77. package/mini-bar/mini-bar.component.d.ts +1 -1
  78. package/mini-progress/mini-progress.component.d.ts +1 -1
  79. package/number-info/number-info.component.d.ts +1 -1
  80. package/package.json +60 -100
  81. package/pie/pie.component.d.ts +1 -1
  82. package/radar/radar.component.d.ts +1 -1
  83. package/single-bar/single-bar.component.d.ts +1 -1
  84. package/tag-cloud/tag-cloud.component.d.ts +1 -1
  85. package/timeline/timeline.component.d.ts +1 -1
  86. package/trend/trend.component.d.ts +1 -1
  87. package/water-wave/water-wave.component.d.ts +1 -1
  88. package/esm2020/bar/bar.component.mjs +0 -143
  89. package/esm2020/bar/bar.module.mjs +0 -21
  90. package/esm2020/card/card.component.mjs +0 -55
  91. package/esm2020/card/card.module.mjs +0 -22
  92. package/esm2020/chart-echarts/echarts.component.mjs +0 -161
  93. package/esm2020/chart-echarts/echarts.module.mjs +0 -20
  94. package/esm2020/chart-echarts/echarts.service.mjs +0 -60
  95. package/esm2020/core/g2.base.component.mjs +0 -114
  96. package/esm2020/core/g2.servicce.mjs +0 -54
  97. package/esm2020/custom/custom.component.mjs +0 -69
  98. package/esm2020/custom/custom.module.mjs +0 -20
  99. package/esm2020/gauge/gauge.component.mjs +0 -170
  100. package/esm2020/gauge/gauge.module.mjs +0 -20
  101. package/esm2020/mini-area/mini-area.component.mjs +0 -134
  102. package/esm2020/mini-area/mini-area.module.mjs +0 -19
  103. package/esm2020/mini-bar/mini-bar.component.mjs +0 -101
  104. package/esm2020/mini-bar/mini-bar.module.mjs +0 -19
  105. package/esm2020/mini-progress/mini-progress.component.mjs +0 -46
  106. package/esm2020/mini-progress/mini-progress.module.mjs +0 -21
  107. package/esm2020/number-info/number-info.component.mjs +0 -45
  108. package/esm2020/number-info/number-info.module.mjs +0 -21
  109. package/esm2020/pie/pie.component.mjs +0 -222
  110. package/esm2020/pie/pie.module.mjs +0 -22
  111. package/esm2020/radar/radar.component.mjs +0 -149
  112. package/esm2020/radar/radar.module.mjs +0 -22
  113. package/esm2020/single-bar/single-bar.component.mjs +0 -127
  114. package/esm2020/single-bar/single-bar.module.mjs +0 -19
  115. package/esm2020/tag-cloud/tag-cloud.component.mjs +0 -162
  116. package/esm2020/tag-cloud/tag-cloud.module.mjs +0 -20
  117. package/esm2020/timeline/timeline.component.mjs +0 -205
  118. package/esm2020/timeline/timeline.module.mjs +0 -21
  119. package/esm2020/trend/trend.component.mjs +0 -52
  120. package/esm2020/trend/trend.module.mjs +0 -20
  121. package/esm2020/water-wave/water-wave.component.mjs +0 -220
  122. package/esm2020/water-wave/water-wave.module.mjs +0 -20
  123. package/fesm2015/bar.mjs +0 -168
  124. package/fesm2015/bar.mjs.map +0 -1
  125. package/fesm2015/chart-echarts.mjs +0 -241
  126. package/fesm2015/chart-echarts.mjs.map +0 -1
  127. package/fesm2015/core.mjs +0 -186
  128. package/fesm2015/core.mjs.map +0 -1
  129. package/fesm2015/custom.mjs.map +0 -1
  130. package/fesm2015/gauge.mjs +0 -194
  131. package/fesm2015/gauge.mjs.map +0 -1
  132. package/fesm2015/mini-area.mjs +0 -157
  133. package/fesm2015/mini-area.mjs.map +0 -1
  134. package/fesm2015/mini-bar.mjs +0 -124
  135. package/fesm2015/mini-bar.mjs.map +0 -1
  136. package/fesm2015/mini-progress.mjs +0 -71
  137. package/fesm2015/mini-progress.mjs.map +0 -1
  138. package/fesm2015/number-info.mjs +0 -70
  139. package/fesm2015/pie.mjs +0 -248
  140. package/fesm2015/pie.mjs.map +0 -1
  141. package/fesm2015/radar.mjs +0 -175
  142. package/fesm2015/radar.mjs.map +0 -1
  143. package/fesm2015/single-bar.mjs +0 -148
  144. package/fesm2015/single-bar.mjs.map +0 -1
  145. package/fesm2015/tag-cloud.mjs +0 -176
  146. package/fesm2015/tag-cloud.mjs.map +0 -1
  147. package/fesm2015/timeline.mjs +0 -228
  148. package/fesm2015/timeline.mjs.map +0 -1
  149. package/fesm2015/trend.mjs +0 -76
  150. package/fesm2015/trend.mjs.map +0 -1
  151. package/fesm2015/water-wave.mjs +0 -244
  152. package/fesm2015/water-wave.mjs.map +0 -1
  153. package/fesm2020/card.mjs +0 -81
  154. package/fesm2020/card.mjs.map +0 -1
  155. package/fesm2020/chart-echarts.mjs.map +0 -1
  156. package/fesm2020/chart.mjs +0 -7
  157. package/fesm2020/chart.mjs.map +0 -1
  158. package/fesm2020/core.mjs.map +0 -1
  159. package/fesm2020/custom.mjs +0 -93
  160. package/fesm2020/custom.mjs.map +0 -1
  161. package/fesm2020/gauge.mjs.map +0 -1
  162. package/fesm2020/number-info.mjs.map +0 -1
  163. package/fesm2020/single-bar.mjs.map +0 -1
  164. package/fesm2020/trend.mjs.map +0 -1
  165. package/fesm2020/water-wave.mjs.map +0 -1
  166. /package/{esm2020 → esm2022}/bar/bar.mjs +0 -0
  167. /package/{esm2020 → esm2022}/bar/public_api.mjs +0 -0
  168. /package/{esm2020 → esm2022}/card/card.mjs +0 -0
  169. /package/{esm2020 → esm2022}/card/public_api.mjs +0 -0
  170. /package/{esm2020 → esm2022}/chart-echarts/chart-echarts.mjs +0 -0
  171. /package/{esm2020 → esm2022}/chart-echarts/echarts.types.mjs +0 -0
  172. /package/{esm2020 → esm2022}/chart-echarts/public_api.mjs +0 -0
  173. /package/{esm2020 → esm2022}/chart.mjs +0 -0
  174. /package/{esm2020 → esm2022}/core/core.mjs +0 -0
  175. /package/{esm2020 → esm2022}/core/public_api.mjs +0 -0
  176. /package/{esm2020 → esm2022}/core/types/interaction.mjs +0 -0
  177. /package/{esm2020 → esm2022}/core/types/time.mjs +0 -0
  178. /package/{esm2020 → esm2022}/core/utils.mjs +0 -0
  179. /package/{esm2020 → esm2022}/custom/custom.mjs +0 -0
  180. /package/{esm2020 → esm2022}/custom/public_api.mjs +0 -0
  181. /package/{esm2020 → esm2022}/gauge/gauge.mjs +0 -0
  182. /package/{esm2020 → esm2022}/gauge/public_api.mjs +0 -0
  183. /package/{esm2020 → esm2022}/mini-area/mini-area.mjs +0 -0
  184. /package/{esm2020 → esm2022}/mini-area/public_api.mjs +0 -0
  185. /package/{esm2020 → esm2022}/mini-bar/mini-bar.mjs +0 -0
  186. /package/{esm2020 → esm2022}/mini-bar/public_api.mjs +0 -0
  187. /package/{esm2020 → esm2022}/mini-progress/mini-progress.mjs +0 -0
  188. /package/{esm2020 → esm2022}/mini-progress/public_api.mjs +0 -0
  189. /package/{esm2020 → esm2022}/number-info/number-info.mjs +0 -0
  190. /package/{esm2020 → esm2022}/number-info/public_api.mjs +0 -0
  191. /package/{esm2020 → esm2022}/pie/pie.mjs +0 -0
  192. /package/{esm2020 → esm2022}/pie/public_api.mjs +0 -0
  193. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  194. /package/{esm2020 → esm2022}/radar/public_api.mjs +0 -0
  195. /package/{esm2020 → esm2022}/radar/radar.mjs +0 -0
  196. /package/{esm2020 → esm2022}/single-bar/public_api.mjs +0 -0
  197. /package/{esm2020 → esm2022}/single-bar/single-bar.mjs +0 -0
  198. /package/{esm2020 → esm2022}/tag-cloud/public_api.mjs +0 -0
  199. /package/{esm2020 → esm2022}/tag-cloud/tag-cloud.mjs +0 -0
  200. /package/{esm2020 → esm2022}/timeline/public_api.mjs +0 -0
  201. /package/{esm2020 → esm2022}/timeline/timeline.mjs +0 -0
  202. /package/{esm2020 → esm2022}/trend/public_api.mjs +0 -0
  203. /package/{esm2020 → esm2022}/trend/trend.mjs +0 -0
  204. /package/{esm2020 → esm2022}/water-wave/public_api.mjs +0 -0
  205. /package/{esm2020 → esm2022}/water-wave/water-wave.mjs +0 -0
  206. /package/{fesm2015 → fesm2022}/chart.mjs +0 -0
  207. /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":"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","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=