@visionaris-bruno/vs-echarts 1.0.2 → 2.0.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.
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { provideEchartsCore, NgxEchartsDirective } from 'ngx-echarts';
|
|
2
2
|
import * as echarts from 'echarts/core';
|
|
3
|
-
import { BarChart, PieChart } from 'echarts/charts';
|
|
3
|
+
import { BarChart, PieChart, LineChart } from 'echarts/charts';
|
|
4
4
|
import { TitleComponent, TooltipComponent, GridComponent, LegendComponent, GraphicComponent, ToolboxComponent } from 'echarts/components';
|
|
5
5
|
import { CanvasRenderer } from 'echarts/renderers';
|
|
6
6
|
import * as i0 from '@angular/core';
|
|
@@ -20,13 +20,14 @@ function initializeEcharts() {
|
|
|
20
20
|
echarts.use([
|
|
21
21
|
BarChart,
|
|
22
22
|
PieChart,
|
|
23
|
+
LineChart,
|
|
23
24
|
TitleComponent,
|
|
24
25
|
TooltipComponent,
|
|
25
26
|
GridComponent,
|
|
26
27
|
LegendComponent,
|
|
27
28
|
CanvasRenderer,
|
|
28
29
|
GraphicComponent,
|
|
29
|
-
ToolboxComponent
|
|
30
|
+
ToolboxComponent,
|
|
30
31
|
]);
|
|
31
32
|
initialized = true;
|
|
32
33
|
}
|
|
@@ -38,6 +39,13 @@ function provideVSEcharts() {
|
|
|
38
39
|
initializeEcharts();
|
|
39
40
|
return provideEchartsCore({ echarts });
|
|
40
41
|
}
|
|
42
|
+
function defaultOptionsOverrides() {
|
|
43
|
+
return {
|
|
44
|
+
line: {
|
|
45
|
+
series: {},
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
}
|
|
41
49
|
|
|
42
50
|
/**
|
|
43
51
|
* BaseEchartsComponent
|
|
@@ -51,8 +59,7 @@ class BaseEchartsComponent {
|
|
|
51
59
|
chartContainer;
|
|
52
60
|
/** Datos normalizados para graficar */
|
|
53
61
|
data = { categories: [], series: [] };
|
|
54
|
-
|
|
55
|
-
chartConfig = {};
|
|
62
|
+
optionsOverrides = defaultOptionsOverrides();
|
|
56
63
|
/** Paleta de colores básica */
|
|
57
64
|
palette;
|
|
58
65
|
/** Resolver de colores dinámico (Callback) */
|
|
@@ -71,6 +78,10 @@ class BaseEchartsComponent {
|
|
|
71
78
|
});
|
|
72
79
|
}
|
|
73
80
|
chartInstance;
|
|
81
|
+
currentLegendSelected = null;
|
|
82
|
+
/** Estado de selección para filtros cruzados */
|
|
83
|
+
selectedCategoryIndex = null;
|
|
84
|
+
selectedSeriesIndex = null;
|
|
74
85
|
ngOnChanges(changes) {
|
|
75
86
|
this.onInputChanges(changes);
|
|
76
87
|
}
|
|
@@ -83,8 +94,81 @@ class BaseEchartsComponent {
|
|
|
83
94
|
*/
|
|
84
95
|
onChartInit(instance) {
|
|
85
96
|
this.chartInstance = instance;
|
|
97
|
+
this.setupBaseInteractions();
|
|
86
98
|
this.updateChartOptions();
|
|
87
99
|
}
|
|
100
|
+
/**
|
|
101
|
+
* Configura interacciones base como el clic en el fondo para limpiar selección.
|
|
102
|
+
*/
|
|
103
|
+
setupBaseInteractions() {
|
|
104
|
+
if (!this.chartInstance)
|
|
105
|
+
return;
|
|
106
|
+
const zr = this.chartInstance.getZr();
|
|
107
|
+
zr.on('click', (params) => {
|
|
108
|
+
if (!params.target) {
|
|
109
|
+
this.clearSelection();
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
onChartClick(event) {
|
|
114
|
+
if (event.componentType === 'series') {
|
|
115
|
+
const index = event.dataIndex;
|
|
116
|
+
const seriesIndex = event.seriesIndex;
|
|
117
|
+
if (index !== undefined && index >= 0) {
|
|
118
|
+
this.handleSelection(index, seriesIndex);
|
|
119
|
+
// Emit standardized payload for cross-filtering
|
|
120
|
+
this.chartClick.emit({
|
|
121
|
+
type: 'cross-filter',
|
|
122
|
+
data: {
|
|
123
|
+
category: event.name,
|
|
124
|
+
serie: event.seriesName,
|
|
125
|
+
value: event.value
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Maneja la lógica de alternancia de selección.
|
|
133
|
+
*/
|
|
134
|
+
handleSelection(dataIndex, seriesIndex) {
|
|
135
|
+
const isSamePoint = this.selectedCategoryIndex === dataIndex && this.selectedSeriesIndex === seriesIndex;
|
|
136
|
+
if (isSamePoint) {
|
|
137
|
+
this.clearSelection();
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
this.selectedCategoryIndex = dataIndex;
|
|
141
|
+
this.selectedSeriesIndex = seriesIndex;
|
|
142
|
+
this.updateChartOptions();
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Limpia el estado de selección actual.
|
|
147
|
+
*/
|
|
148
|
+
clearSelection() {
|
|
149
|
+
this.selectedCategoryIndex = null;
|
|
150
|
+
this.selectedSeriesIndex = null;
|
|
151
|
+
this.updateChartOptions();
|
|
152
|
+
}
|
|
153
|
+
dispatchAction(type, d) {
|
|
154
|
+
if (this.chartInstance == undefined)
|
|
155
|
+
return;
|
|
156
|
+
const { seriesIndex = [], dataIndex = [], } = d;
|
|
157
|
+
this.chartInstance.dispatchAction({
|
|
158
|
+
type,
|
|
159
|
+
seriesIndex,
|
|
160
|
+
dataIndex,
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Maneja clics en la leyenda para persistir filtros.
|
|
165
|
+
*/
|
|
166
|
+
onLegendSelectChanged(event) {
|
|
167
|
+
if (event && event.selected) {
|
|
168
|
+
this.currentLegendSelected = event.selected;
|
|
169
|
+
this.updateChartOptions();
|
|
170
|
+
}
|
|
171
|
+
}
|
|
88
172
|
updateOptions(options) {
|
|
89
173
|
this.chartOptions = { ...options };
|
|
90
174
|
this.chartInstance?.setOption(options, { notMerge: true });
|
|
@@ -96,7 +180,7 @@ class BaseEchartsComponent {
|
|
|
96
180
|
* el comportamiento base (detectar inputs relevantes y actualizar el chart).
|
|
97
181
|
*/
|
|
98
182
|
onInputChanges(changes) {
|
|
99
|
-
if (changes['data'] || changes['
|
|
183
|
+
if (changes['data'] || changes['optionsOverrides'] || changes['palette'] || changes['colorResolver'] || changes['valueFormatter']) {
|
|
100
184
|
this.updateChartOptions();
|
|
101
185
|
}
|
|
102
186
|
}
|
|
@@ -113,7 +197,7 @@ class BaseEchartsComponent {
|
|
|
113
197
|
this.chartInstance?.resize();
|
|
114
198
|
}
|
|
115
199
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: BaseEchartsComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
116
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.19", type: BaseEchartsComponent, isStandalone: true, inputs: { data: "data",
|
|
200
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.19", type: BaseEchartsComponent, isStandalone: true, inputs: { data: "data", optionsOverrides: "optionsOverrides", palette: "palette", colorResolver: "colorResolver", valueFormatter: "valueFormatter" }, outputs: { chartClick: "chartClick" }, viewQueries: [{ propertyName: "chartContainer", first: true, predicate: ["chartContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0 });
|
|
117
201
|
}
|
|
118
202
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: BaseEchartsComponent, decorators: [{
|
|
119
203
|
type: Directive,
|
|
@@ -125,7 +209,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImpo
|
|
|
125
209
|
args: ['chartContainer', { static: true }]
|
|
126
210
|
}], data: [{
|
|
127
211
|
type: Input
|
|
128
|
-
}],
|
|
212
|
+
}], optionsOverrides: [{
|
|
129
213
|
type: Input
|
|
130
214
|
}], palette: [{
|
|
131
215
|
type: Input
|
|
@@ -283,6 +367,79 @@ function getTooltipOptions(overrides) {
|
|
|
283
367
|
};
|
|
284
368
|
return { ...defaults, ...overrides };
|
|
285
369
|
}
|
|
370
|
+
/**
|
|
371
|
+
* Applies a visual selection effect to line-based series.
|
|
372
|
+
* Highlights the selected series and point, and dims everything else.
|
|
373
|
+
*
|
|
374
|
+
* @param series The series array to modify
|
|
375
|
+
* @param selectedCategoryIndex Index of the selected category
|
|
376
|
+
* @param selectedSeriesIndex Index of the selected series
|
|
377
|
+
* @returns Modified series array
|
|
378
|
+
*/
|
|
379
|
+
function applyLineSelectionStyle(series, selectedCategoryIndex, selectedSeriesIndex) {
|
|
380
|
+
if (selectedCategoryIndex === null || !series)
|
|
381
|
+
return series;
|
|
382
|
+
return series.map((s, sIdx) => {
|
|
383
|
+
const isSelectedSeries = sIdx === selectedSeriesIndex;
|
|
384
|
+
// Serie seleccionada: Línea con opacidad 1 para que destaque la tendencia.
|
|
385
|
+
// Serie NO seleccionada: Opacidad 0.20 para atenuar fuertemente.
|
|
386
|
+
const seriesOpacity = isSelectedSeries ? 1 : 0.20;
|
|
387
|
+
return {
|
|
388
|
+
...s,
|
|
389
|
+
emphasis: {
|
|
390
|
+
disabled: true // Deshabilitar el énfasis (hover) cuando hay una selección activa
|
|
391
|
+
},
|
|
392
|
+
itemStyle: {
|
|
393
|
+
...s.itemStyle,
|
|
394
|
+
opacity: seriesOpacity
|
|
395
|
+
},
|
|
396
|
+
lineStyle: {
|
|
397
|
+
...s.lineStyle,
|
|
398
|
+
opacity: seriesOpacity
|
|
399
|
+
},
|
|
400
|
+
...(s.areaStyle ? {
|
|
401
|
+
areaStyle: {
|
|
402
|
+
...s.areaStyle,
|
|
403
|
+
opacity: isSelectedSeries ? 0.6 : 0.1
|
|
404
|
+
}
|
|
405
|
+
} : {}),
|
|
406
|
+
// Personalizamos los puntos individualmente
|
|
407
|
+
data: (s.data || []).map((val, idx) => {
|
|
408
|
+
const isSelectedPoint = isSelectedSeries && idx === selectedCategoryIndex;
|
|
409
|
+
const isOtherPointInSelectedSeries = isSelectedSeries && idx !== selectedCategoryIndex;
|
|
410
|
+
const originalPoint = (val && typeof val === 'object') ? val : { value: val };
|
|
411
|
+
if (isSelectedPoint) {
|
|
412
|
+
return {
|
|
413
|
+
...originalPoint,
|
|
414
|
+
z: 10, // Asegurar que el punto seleccionado esté por encima de los demás
|
|
415
|
+
itemStyle: {
|
|
416
|
+
...originalPoint.itemStyle,
|
|
417
|
+
opacity: 1,
|
|
418
|
+
borderWidth: 2,
|
|
419
|
+
borderColor: '#fff',
|
|
420
|
+
shadowBlur: 10,
|
|
421
|
+
shadowColor: 'rgba(0,0,0,0.5)'
|
|
422
|
+
},
|
|
423
|
+
symbolSize: 12
|
|
424
|
+
};
|
|
425
|
+
}
|
|
426
|
+
else if (isOtherPointInSelectedSeries) {
|
|
427
|
+
// Puntos de la serie seleccionada que NO son el clicado: un poco más pequeños y traslúcidos
|
|
428
|
+
return {
|
|
429
|
+
...originalPoint,
|
|
430
|
+
itemStyle: {
|
|
431
|
+
...originalPoint.itemStyle,
|
|
432
|
+
opacity: 0.5
|
|
433
|
+
},
|
|
434
|
+
symbolSize: 6
|
|
435
|
+
};
|
|
436
|
+
}
|
|
437
|
+
// Puntos de otras series o por defecto
|
|
438
|
+
return val;
|
|
439
|
+
})
|
|
440
|
+
};
|
|
441
|
+
});
|
|
442
|
+
}
|
|
286
443
|
|
|
287
444
|
/**
|
|
288
445
|
* BaseEchartBuilder
|
|
@@ -295,6 +452,7 @@ function getTooltipOptions(overrides) {
|
|
|
295
452
|
class BaseEchartBuilder {
|
|
296
453
|
valueFormatter = (value) => value.toLocaleString();
|
|
297
454
|
palette = [];
|
|
455
|
+
// TODO: Hay que implementar un valor por defecto.
|
|
298
456
|
colorResolver;
|
|
299
457
|
constructor() { }
|
|
300
458
|
/**
|
|
@@ -327,7 +485,7 @@ class BaseEchartBuilder {
|
|
|
327
485
|
* TODO: particionar en configuraciones concretas con sus
|
|
328
486
|
* respectivos overrides.
|
|
329
487
|
*/
|
|
330
|
-
getCommonOptions(
|
|
488
|
+
getCommonOptions(overrides) {
|
|
331
489
|
const common = {
|
|
332
490
|
backgroundColor: 'transparent',
|
|
333
491
|
textStyle: {
|
|
@@ -360,7 +518,7 @@ class BaseEchartBuilder {
|
|
|
360
518
|
* @see {@link vs-echarts/docs/charts/ring-patterns.md}
|
|
361
519
|
*/
|
|
362
520
|
class RingBuilder extends BaseEchartBuilder {
|
|
363
|
-
build(data,
|
|
521
|
+
build(data, overrides) {
|
|
364
522
|
if (!data || !data.series.length)
|
|
365
523
|
return {};
|
|
366
524
|
const totalRings = data.series.length; // Cada serie es un anillo
|
|
@@ -420,7 +578,7 @@ class RingBuilder extends BaseEchartBuilder {
|
|
|
420
578
|
}
|
|
421
579
|
return seriesOption;
|
|
422
580
|
});
|
|
423
|
-
const common = this.getCommonOptions(
|
|
581
|
+
const common = this.getCommonOptions(overrides);
|
|
424
582
|
return {
|
|
425
583
|
...common,
|
|
426
584
|
tooltip: {
|
|
@@ -468,7 +626,6 @@ class EchartsRingComponent extends BaseEchartsComponent {
|
|
|
468
626
|
lastSelectedSeriesIndex = null;
|
|
469
627
|
lastSelectedDataIndex = null;
|
|
470
628
|
selectedPercent = null;
|
|
471
|
-
currentLegendSelected = null;
|
|
472
629
|
currentGraphicText = '';
|
|
473
630
|
builder;
|
|
474
631
|
constructor() {
|
|
@@ -568,7 +725,7 @@ class EchartsRingComponent extends BaseEchartsComponent {
|
|
|
568
725
|
if (this.colorResolver)
|
|
569
726
|
this.builder.setColorResolver(this.colorResolver);
|
|
570
727
|
// 2. Obtenemos las bases del chart usando el builder
|
|
571
|
-
let options = this.builder.build(this.data, this.
|
|
728
|
+
let options = this.builder.build(this.data, this.optionsOverrides);
|
|
572
729
|
// 3. Persistencia de GRAPHIC (KPI central)
|
|
573
730
|
if (options.graphic && Array.isArray(options.graphic)) {
|
|
574
731
|
const graphic = options.graphic[0];
|
|
@@ -600,14 +757,14 @@ class EchartsRingComponent extends BaseEchartsComponent {
|
|
|
600
757
|
this.triggerUpdate(options);
|
|
601
758
|
}
|
|
602
759
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: EchartsRingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
603
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.19", type: EchartsRingComponent, isStandalone: true, selector: "vs-echarts-ring", providers: [provideVSEcharts()], usesInheritance: true, ngImport: i0, template: "<div class=\"echarts-container\">\n <div class=\"ring-chart\" \n echarts \n [options]=\"chartOptions\" \n [autoResize]=\"true\" \n (chartInit)=\"onChartInit($event)\" \n (chartClick)=\"onChartClick($event)\" \n (chartMouseOver)=\"onChartMouseOver($event)\" \n (chartMouseOut)=\"onChartMouseOut($event)\" \n (chartLegendSelectChanged)=\"onLegendSelectChanged($event)\"\n ></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.ring-chart{width:100%;height:100%}
|
|
760
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.19", type: EchartsRingComponent, isStandalone: true, selector: "vs-echarts-ring", providers: [provideVSEcharts()], usesInheritance: true, ngImport: i0, template: "<div class=\"echarts-container\">\n <div class=\"ring-chart\" \n echarts \n [options]=\"chartOptions\" \n [autoResize]=\"true\" \n (chartInit)=\"onChartInit($event)\" \n (chartClick)=\"onChartClick($event)\" \n (chartMouseOver)=\"onChartMouseOver($event)\" \n (chartMouseOut)=\"onChartMouseOut($event)\" \n (chartLegendSelectChanged)=\"onLegendSelectChanged($event)\"\n ></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.ring-chart{width:100%;height:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: NgxEchartsDirective, selector: "echarts, [echarts]", inputs: ["options", "theme", "initOpts", "merge", "autoResize", "loading", "loadingType", "loadingOpts"], outputs: ["chartInit", "optionsError", "chartClick", "chartDblClick", "chartMouseDown", "chartMouseMove", "chartMouseUp", "chartMouseOver", "chartMouseOut", "chartGlobalOut", "chartContextMenu", "chartHighlight", "chartDownplay", "chartSelectChanged", "chartLegendSelectChanged", "chartLegendSelected", "chartLegendUnselected", "chartLegendLegendSelectAll", "chartLegendLegendInverseSelect", "chartLegendScroll", "chartDataZoom", "chartDataRangeSelected", "chartGraphRoam", "chartGeoRoam", "chartTreeRoam", "chartTimelineChanged", "chartTimelinePlayChanged", "chartRestore", "chartDataViewChanged", "chartMagicTypeChanged", "chartGeoSelectChanged", "chartGeoSelected", "chartGeoUnselected", "chartAxisAreaSelected", "chartBrush", "chartBrushEnd", "chartBrushSelected", "chartGlobalCursorTaken", "chartRendered", "chartFinished"], exportAs: ["echarts"] }] });
|
|
604
761
|
}
|
|
605
762
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: EchartsRingComponent, decorators: [{
|
|
606
763
|
type: Component,
|
|
607
764
|
args: [{ selector: 'vs-echarts-ring', standalone: true, imports: [
|
|
608
765
|
CommonModule,
|
|
609
766
|
NgxEchartsDirective,
|
|
610
|
-
], providers: [provideVSEcharts()], template: "<div class=\"echarts-container\">\n <div class=\"ring-chart\" \n echarts \n [options]=\"chartOptions\" \n [autoResize]=\"true\" \n (chartInit)=\"onChartInit($event)\" \n (chartClick)=\"onChartClick($event)\" \n (chartMouseOver)=\"onChartMouseOver($event)\" \n (chartMouseOut)=\"onChartMouseOut($event)\" \n (chartLegendSelectChanged)=\"onLegendSelectChanged($event)\"\n ></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.ring-chart{width:100%;height:100%}
|
|
767
|
+
], providers: [provideVSEcharts()], template: "<div class=\"echarts-container\">\n <div class=\"ring-chart\" \n echarts \n [options]=\"chartOptions\" \n [autoResize]=\"true\" \n (chartInit)=\"onChartInit($event)\" \n (chartClick)=\"onChartClick($event)\" \n (chartMouseOver)=\"onChartMouseOver($event)\" \n (chartMouseOut)=\"onChartMouseOut($event)\" \n (chartLegendSelectChanged)=\"onLegendSelectChanged($event)\"\n ></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.ring-chart{width:100%;height:100%}\n"] }]
|
|
611
768
|
}], ctorParameters: () => [] });
|
|
612
769
|
|
|
613
770
|
/**
|
|
@@ -620,7 +777,7 @@ class VerticalBandsBuilder extends BaseEchartBuilder {
|
|
|
620
777
|
constructor() {
|
|
621
778
|
super();
|
|
622
779
|
}
|
|
623
|
-
build(data,
|
|
780
|
+
build(data, overrides) {
|
|
624
781
|
if (!data || !data.series.length)
|
|
625
782
|
return {};
|
|
626
783
|
const series = data.series.map((s) => {
|
|
@@ -667,7 +824,7 @@ class VerticalBandsBuilder extends BaseEchartBuilder {
|
|
|
667
824
|
}
|
|
668
825
|
return seriesOption;
|
|
669
826
|
});
|
|
670
|
-
const common = this.getCommonOptions(
|
|
827
|
+
const common = this.getCommonOptions(overrides);
|
|
671
828
|
return {
|
|
672
829
|
...common,
|
|
673
830
|
tooltip: {
|
|
@@ -699,9 +856,6 @@ class VerticalBandsBuilder extends BaseEchartBuilder {
|
|
|
699
856
|
* @see {@link vs-echarts/docs/charts/vertical-bands-patterns.md}
|
|
700
857
|
*/
|
|
701
858
|
class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
702
|
-
selectedSectorIndex = null;
|
|
703
|
-
selectedSeriesIndex = null;
|
|
704
|
-
currentLegendSelected = null;
|
|
705
859
|
builder;
|
|
706
860
|
constructor() {
|
|
707
861
|
super();
|
|
@@ -709,30 +863,29 @@ class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
|
709
863
|
}
|
|
710
864
|
onChartInit(instance) {
|
|
711
865
|
super.onChartInit(instance);
|
|
712
|
-
this.
|
|
866
|
+
this.setupAdditionalInteractions();
|
|
713
867
|
}
|
|
714
868
|
onInputChanges(changes) {
|
|
715
869
|
if (changes['data']) {
|
|
716
|
-
this.
|
|
870
|
+
this.selectedCategoryIndex = null;
|
|
717
871
|
this.selectedSeriesIndex = null;
|
|
718
872
|
this.currentLegendSelected = null;
|
|
719
873
|
}
|
|
720
874
|
super.onInputChanges(changes);
|
|
721
875
|
}
|
|
722
|
-
|
|
876
|
+
setupAdditionalInteractions() {
|
|
723
877
|
if (!this.chartInstance)
|
|
724
878
|
return;
|
|
725
|
-
// 1. ZRender click for background "sectors"
|
|
879
|
+
// 1. ZRender click for background "sectors" (Specific to bands)
|
|
726
880
|
const zr = this.chartInstance.getZr();
|
|
727
881
|
zr.on('click', (params) => {
|
|
728
882
|
if (!params.target) {
|
|
729
883
|
const pointInPixel = [params.offsetX, params.offsetY];
|
|
730
884
|
if (this.chartInstance.containPixel('grid', pointInPixel)) {
|
|
731
|
-
// Fix TS2352: convertFromPixel return type cast
|
|
732
885
|
const xIndexResult = this.chartInstance.convertFromPixel({ xAxisIndex: 0 }, pointInPixel);
|
|
733
886
|
const xIndex = Array.isArray(xIndexResult) ? xIndexResult[0] : xIndexResult;
|
|
734
887
|
if (typeof xIndex === 'number' && xIndex >= 0) {
|
|
735
|
-
this.
|
|
888
|
+
this.handleSelection(xIndex, -1); // Use -1 or null to indicate sector selection without specific series
|
|
736
889
|
}
|
|
737
890
|
}
|
|
738
891
|
}
|
|
@@ -747,21 +900,8 @@ class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
|
747
900
|
this.clearHighlight();
|
|
748
901
|
});
|
|
749
902
|
}
|
|
750
|
-
toggleSectorSelection(index, seriesIndex = null) {
|
|
751
|
-
const isSameBar = this.selectedSectorIndex === index && this.selectedSeriesIndex === seriesIndex;
|
|
752
|
-
if (isSameBar) {
|
|
753
|
-
this.selectedSectorIndex = null;
|
|
754
|
-
this.selectedSeriesIndex = null;
|
|
755
|
-
}
|
|
756
|
-
else {
|
|
757
|
-
this.selectedSectorIndex = index;
|
|
758
|
-
this.selectedSeriesIndex = seriesIndex;
|
|
759
|
-
}
|
|
760
|
-
// Refresh options to apply selection logic
|
|
761
|
-
this.updateChartOptions();
|
|
762
|
-
}
|
|
763
903
|
highlightSector(index) {
|
|
764
|
-
if (!this.chartInstance)
|
|
904
|
+
if (!this.chartInstance || this.selectedCategoryIndex !== null)
|
|
765
905
|
return;
|
|
766
906
|
const seriesCount = Array.isArray(this.chartOptions.series) ? this.chartOptions.series.length : 0;
|
|
767
907
|
this.chartInstance.dispatchAction({
|
|
@@ -779,28 +919,6 @@ class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
|
779
919
|
seriesIndex: Array.from({ length: seriesCount }, (_, i) => i)
|
|
780
920
|
});
|
|
781
921
|
}
|
|
782
|
-
onChartClick(event) {
|
|
783
|
-
// 3. ECharts click only for bars (to avoid unwanted axis filtering)
|
|
784
|
-
if (event.componentType === 'series') {
|
|
785
|
-
const index = event.dataIndex;
|
|
786
|
-
if (index !== undefined && index >= 0) {
|
|
787
|
-
let seriesIndex = null;
|
|
788
|
-
if (event.componentType === 'series') {
|
|
789
|
-
seriesIndex = event.seriesIndex;
|
|
790
|
-
}
|
|
791
|
-
this.toggleSectorSelection(index, seriesIndex);
|
|
792
|
-
// Emit standardized payload for cross-filtering
|
|
793
|
-
this.chartClick.emit({
|
|
794
|
-
type: 'cross-filter',
|
|
795
|
-
data: {
|
|
796
|
-
category: event.name,
|
|
797
|
-
serie: event.seriesName,
|
|
798
|
-
value: event.value
|
|
799
|
-
}
|
|
800
|
-
});
|
|
801
|
-
}
|
|
802
|
-
}
|
|
803
|
-
}
|
|
804
922
|
/**
|
|
805
923
|
* Maneja clics en la leyenda para persistir filtros.
|
|
806
924
|
*/
|
|
@@ -823,20 +941,23 @@ class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
|
823
941
|
if (this.colorResolver)
|
|
824
942
|
this.builder.setColorResolver(this.colorResolver);
|
|
825
943
|
// 2. Obtenemos las bases del chart usando el builder
|
|
826
|
-
let baseOptions = this.builder.build(this.data, this.
|
|
944
|
+
let baseOptions = this.builder.build(this.data, this.optionsOverrides);
|
|
827
945
|
// 3. Re-apply legend selection state if exists
|
|
828
946
|
if (this.currentLegendSelected && baseOptions.legend) {
|
|
829
947
|
baseOptions.legend.selected = { ...this.currentLegendSelected };
|
|
830
948
|
}
|
|
831
949
|
// 4. Apply persistent selection style if a sector is selected
|
|
832
|
-
if (this.
|
|
950
|
+
if (this.selectedCategoryIndex !== null && baseOptions.series) {
|
|
833
951
|
const seriesArray = baseOptions.series;
|
|
834
952
|
baseOptions.series = seriesArray.map((s, sIdx) => {
|
|
835
953
|
if (s.type === 'bar' && Array.isArray(s.data)) {
|
|
836
954
|
return {
|
|
837
955
|
...s,
|
|
956
|
+
emphasis: {
|
|
957
|
+
disabled: true
|
|
958
|
+
},
|
|
838
959
|
data: s.data.map((val, idx) => {
|
|
839
|
-
const isSelected = idx === this.
|
|
960
|
+
const isSelected = idx === this.selectedCategoryIndex;
|
|
840
961
|
const isBarSelected = isSelected && sIdx === this.selectedSeriesIndex;
|
|
841
962
|
const itemVal = (val && typeof val === 'object' && val.value !== undefined) ? val.value : val;
|
|
842
963
|
return {
|
|
@@ -855,16 +976,165 @@ class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
|
855
976
|
this.triggerUpdate(baseOptions);
|
|
856
977
|
}
|
|
857
978
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: EchartsVerticalBandsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
858
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.19", type: EchartsVerticalBandsComponent, isStandalone: true, selector: "vs-echarts-vertical-bands", providers: [provideVSEcharts()], usesInheritance: true, ngImport: i0, template: "<div class=\"echarts-container\">\n <div echarts [options]=\"chartOptions\" [autoResize]=\"true\" (chartInit)=\"onChartInit($event)\" (chartClick)=\"onChartClick($event)\" (legendSelectChanged)=\"onLegendSelectChanged($event)\" class=\"demo-chart\"></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.demo-chart{width:100%;height:100%}
|
|
979
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.19", type: EchartsVerticalBandsComponent, isStandalone: true, selector: "vs-echarts-vertical-bands", providers: [provideVSEcharts()], usesInheritance: true, ngImport: i0, template: "<div class=\"echarts-container\">\n <div echarts [options]=\"chartOptions\" [autoResize]=\"true\" (chartInit)=\"onChartInit($event)\" (chartClick)=\"onChartClick($event)\" (legendSelectChanged)=\"onLegendSelectChanged($event)\" class=\"demo-chart\"></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.demo-chart{width:100%;height:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: NgxEchartsDirective, selector: "echarts, [echarts]", inputs: ["options", "theme", "initOpts", "merge", "autoResize", "loading", "loadingType", "loadingOpts"], outputs: ["chartInit", "optionsError", "chartClick", "chartDblClick", "chartMouseDown", "chartMouseMove", "chartMouseUp", "chartMouseOver", "chartMouseOut", "chartGlobalOut", "chartContextMenu", "chartHighlight", "chartDownplay", "chartSelectChanged", "chartLegendSelectChanged", "chartLegendSelected", "chartLegendUnselected", "chartLegendLegendSelectAll", "chartLegendLegendInverseSelect", "chartLegendScroll", "chartDataZoom", "chartDataRangeSelected", "chartGraphRoam", "chartGeoRoam", "chartTreeRoam", "chartTimelineChanged", "chartTimelinePlayChanged", "chartRestore", "chartDataViewChanged", "chartMagicTypeChanged", "chartGeoSelectChanged", "chartGeoSelected", "chartGeoUnselected", "chartAxisAreaSelected", "chartBrush", "chartBrushEnd", "chartBrushSelected", "chartGlobalCursorTaken", "chartRendered", "chartFinished"], exportAs: ["echarts"] }] });
|
|
859
980
|
}
|
|
860
981
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: EchartsVerticalBandsComponent, decorators: [{
|
|
861
982
|
type: Component,
|
|
862
983
|
args: [{ selector: 'vs-echarts-vertical-bands', standalone: true, imports: [
|
|
863
984
|
CommonModule,
|
|
864
985
|
NgxEchartsDirective,
|
|
865
|
-
], providers: [provideVSEcharts()], template: "<div class=\"echarts-container\">\n <div echarts [options]=\"chartOptions\" [autoResize]=\"true\" (chartInit)=\"onChartInit($event)\" (chartClick)=\"onChartClick($event)\" (legendSelectChanged)=\"onLegendSelectChanged($event)\" class=\"demo-chart\"></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.demo-chart{width:100%;height:100%}
|
|
986
|
+
], providers: [provideVSEcharts()], template: "<div class=\"echarts-container\">\n <div echarts [options]=\"chartOptions\" [autoResize]=\"true\" (chartInit)=\"onChartInit($event)\" (chartClick)=\"onChartClick($event)\" (legendSelectChanged)=\"onLegendSelectChanged($event)\" class=\"demo-chart\"></div>\n</div>\n", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}.demo-chart{width:100%;height:100%}\n"] }]
|
|
987
|
+
}], ctorParameters: () => [] });
|
|
988
|
+
|
|
989
|
+
class LineBuilder extends BaseEchartBuilder {
|
|
990
|
+
constructor() {
|
|
991
|
+
super();
|
|
992
|
+
}
|
|
993
|
+
build(data, overrides) {
|
|
994
|
+
if (!data || !data.series.length)
|
|
995
|
+
return {};
|
|
996
|
+
const { areaStyle = undefined, stack = undefined, } = overrides.line.series;
|
|
997
|
+
const series = data.series.map((s) => {
|
|
998
|
+
const seriesOption = {
|
|
999
|
+
name: s.name,
|
|
1000
|
+
type: 'line',
|
|
1001
|
+
animation: true,
|
|
1002
|
+
animationDuration: 1000,
|
|
1003
|
+
animationEasing: 'cubicOut',
|
|
1004
|
+
data: s.data,
|
|
1005
|
+
smooth: true, //curva
|
|
1006
|
+
smoothMonotone: 'x',
|
|
1007
|
+
symbolSize: 6,
|
|
1008
|
+
itemStyle: {
|
|
1009
|
+
shadowColor: 'rgba(0, 0, 0, 0.2)',
|
|
1010
|
+
shadowBlur: 5,
|
|
1011
|
+
shadowOffsetY: 2,
|
|
1012
|
+
},
|
|
1013
|
+
lineStyle: {
|
|
1014
|
+
width: 2,
|
|
1015
|
+
shadowColor: 'rgba(0, 0, 0, 0.2)',
|
|
1016
|
+
shadowBlur: 8,
|
|
1017
|
+
shadowOffsetY: 6,
|
|
1018
|
+
cap: 'round',
|
|
1019
|
+
join: 'round',
|
|
1020
|
+
},
|
|
1021
|
+
emphasis: {
|
|
1022
|
+
focus: 'none',
|
|
1023
|
+
itemStyle: {
|
|
1024
|
+
borderWidth: 2,
|
|
1025
|
+
shadowBlur: 10,
|
|
1026
|
+
},
|
|
1027
|
+
lineStyle: {
|
|
1028
|
+
width: 4,
|
|
1029
|
+
shadowBlur: 12,
|
|
1030
|
+
}
|
|
1031
|
+
},
|
|
1032
|
+
areaStyle,
|
|
1033
|
+
stack,
|
|
1034
|
+
};
|
|
1035
|
+
// Inyectar el resolver de color si existe
|
|
1036
|
+
if (this.colorResolver && seriesOption.itemStyle != undefined) {
|
|
1037
|
+
seriesOption.itemStyle.color = this.colorResolver;
|
|
1038
|
+
}
|
|
1039
|
+
return seriesOption;
|
|
1040
|
+
});
|
|
1041
|
+
const common = this.getCommonOptions(overrides);
|
|
1042
|
+
return {
|
|
1043
|
+
...common,
|
|
1044
|
+
tooltip: {
|
|
1045
|
+
...getTooltipOptions({ trigger: 'axis' }),
|
|
1046
|
+
formatter: (params) => {
|
|
1047
|
+
let html = `<b>${params[0].name}</b><br/>`;
|
|
1048
|
+
params.forEach((p) => {
|
|
1049
|
+
const seriesObj = data.series[p.seriesIndex];
|
|
1050
|
+
const key = seriesObj.originalKey || (data.categoryKeys ? data.categoryKeys[p.dataIndex] : String(p.dataIndex));
|
|
1051
|
+
const valFormatted = this.formatCellValue(p.value, key);
|
|
1052
|
+
html += `${p.marker} ${p.seriesName}: <b>${valFormatted}</b><br/>`;
|
|
1053
|
+
});
|
|
1054
|
+
return html;
|
|
1055
|
+
}
|
|
1056
|
+
},
|
|
1057
|
+
legend: getLegendOptions(),
|
|
1058
|
+
xAxis: getXAxisOptions({ data: data.categories }),
|
|
1059
|
+
yAxis: getYAxisOptions(),
|
|
1060
|
+
series: series
|
|
1061
|
+
};
|
|
1062
|
+
}
|
|
1063
|
+
}
|
|
1064
|
+
|
|
1065
|
+
class EchartsLineComponent extends BaseEchartsComponent {
|
|
1066
|
+
builder;
|
|
1067
|
+
constructor() {
|
|
1068
|
+
super();
|
|
1069
|
+
this.builder = new LineBuilder();
|
|
1070
|
+
}
|
|
1071
|
+
onInputChanges(changes) {
|
|
1072
|
+
if (changes['data']) {
|
|
1073
|
+
this.selectedCategoryIndex = null;
|
|
1074
|
+
this.selectedSeriesIndex = null;
|
|
1075
|
+
this.currentLegendSelected = null;
|
|
1076
|
+
}
|
|
1077
|
+
super.onInputChanges(changes);
|
|
1078
|
+
}
|
|
1079
|
+
updateChartOptions() {
|
|
1080
|
+
if (!this.chartInstance)
|
|
1081
|
+
return;
|
|
1082
|
+
if (!this.data)
|
|
1083
|
+
return;
|
|
1084
|
+
// 1. Configuramos el builder (Formateadores, Colores, etc se manejan en la base)
|
|
1085
|
+
if (this.valueFormatter)
|
|
1086
|
+
this.builder.setValueFormatter(this.valueFormatter);
|
|
1087
|
+
if (this.palette)
|
|
1088
|
+
this.builder.setPalette(this.palette);
|
|
1089
|
+
if (this.colorResolver)
|
|
1090
|
+
this.builder.setColorResolver(this.colorResolver);
|
|
1091
|
+
// 2. Obtenemos las bases del chart usando el builder
|
|
1092
|
+
let baseOptions = this.builder.build(this.data, this.optionsOverrides);
|
|
1093
|
+
// 3. Re-apply legend selection state if exists
|
|
1094
|
+
if (this.currentLegendSelected && baseOptions.legend) {
|
|
1095
|
+
baseOptions.legend.selected = { ...this.currentLegendSelected };
|
|
1096
|
+
}
|
|
1097
|
+
// 4. Apply persistent selection style if a point is selected
|
|
1098
|
+
if (this.selectedCategoryIndex !== null && baseOptions.series) {
|
|
1099
|
+
baseOptions.series = applyLineSelectionStyle(baseOptions.series, this.selectedCategoryIndex, this.selectedSeriesIndex);
|
|
1100
|
+
}
|
|
1101
|
+
this.triggerUpdate(baseOptions);
|
|
1102
|
+
}
|
|
1103
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: EchartsLineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
1104
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.19", type: EchartsLineComponent, isStandalone: true, selector: "vs-echarts-line", providers: [provideVSEcharts()], usesInheritance: true, ngImport: i0, template: "<div class=\"echarts-container\">\n <div\n echarts\n [options]=\"chartOptions\"\n [autoResize]=\"true\"\n (chartInit)=\"onChartInit($event)\"\n (chartClick)=\"onChartClick($event)\"\n (legendSelectChanged)=\"onLegendSelectChanged($event)\"\n style=\"width: 100%; height: 100%;\"\n ></div>\n</div>", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: NgxEchartsDirective, selector: "echarts, [echarts]", inputs: ["options", "theme", "initOpts", "merge", "autoResize", "loading", "loadingType", "loadingOpts"], outputs: ["chartInit", "optionsError", "chartClick", "chartDblClick", "chartMouseDown", "chartMouseMove", "chartMouseUp", "chartMouseOver", "chartMouseOut", "chartGlobalOut", "chartContextMenu", "chartHighlight", "chartDownplay", "chartSelectChanged", "chartLegendSelectChanged", "chartLegendSelected", "chartLegendUnselected", "chartLegendLegendSelectAll", "chartLegendLegendInverseSelect", "chartLegendScroll", "chartDataZoom", "chartDataRangeSelected", "chartGraphRoam", "chartGeoRoam", "chartTreeRoam", "chartTimelineChanged", "chartTimelinePlayChanged", "chartRestore", "chartDataViewChanged", "chartMagicTypeChanged", "chartGeoSelectChanged", "chartGeoSelected", "chartGeoUnselected", "chartAxisAreaSelected", "chartBrush", "chartBrushEnd", "chartBrushSelected", "chartGlobalCursorTaken", "chartRendered", "chartFinished"], exportAs: ["echarts"] }] });
|
|
1105
|
+
}
|
|
1106
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImport: i0, type: EchartsLineComponent, decorators: [{
|
|
1107
|
+
type: Component,
|
|
1108
|
+
args: [{ selector: 'vs-echarts-line', standalone: true, imports: [
|
|
1109
|
+
CommonModule,
|
|
1110
|
+
NgxEchartsDirective,
|
|
1111
|
+
], providers: [provideVSEcharts()], template: "<div class=\"echarts-container\">\n <div\n echarts\n [options]=\"chartOptions\"\n [autoResize]=\"true\"\n (chartInit)=\"onChartInit($event)\"\n (chartClick)=\"onChartClick($event)\"\n (legendSelectChanged)=\"onLegendSelectChanged($event)\"\n style=\"width: 100%; height: 100%;\"\n ></div>\n</div>", styles: [".echarts-container{width:100%;height:100%;position:relative;background-color:#fff;border-radius:8px}\n"] }]
|
|
866
1112
|
}], ctorParameters: () => [] });
|
|
867
1113
|
|
|
1114
|
+
// Interfaces de Inputs de Base EChart Component //
|
|
1115
|
+
|
|
1116
|
+
const areaStyle = {};
|
|
1117
|
+
function getLineOverridesTemplate() {
|
|
1118
|
+
return {
|
|
1119
|
+
series: {}
|
|
1120
|
+
};
|
|
1121
|
+
}
|
|
1122
|
+
function getAreaOverridesTemplate() {
|
|
1123
|
+
return {
|
|
1124
|
+
series: {
|
|
1125
|
+
areaStyle,
|
|
1126
|
+
}
|
|
1127
|
+
};
|
|
1128
|
+
}
|
|
1129
|
+
function getAreaStackOverridesTemplate() {
|
|
1130
|
+
return {
|
|
1131
|
+
series: {
|
|
1132
|
+
areaStyle,
|
|
1133
|
+
stack: 'total',
|
|
1134
|
+
}
|
|
1135
|
+
};
|
|
1136
|
+
}
|
|
1137
|
+
|
|
868
1138
|
/*
|
|
869
1139
|
* Public API Surface of echarts
|
|
870
1140
|
*/
|
|
@@ -873,5 +1143,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.19", ngImpo
|
|
|
873
1143
|
* Generated bundle index. Do not edit.
|
|
874
1144
|
*/
|
|
875
1145
|
|
|
876
|
-
export { BaseEchartsComponent, EchartsRingComponent, EchartsVerticalBandsComponent, initializeEcharts, provideVSEcharts };
|
|
1146
|
+
export { BaseEchartsComponent, EchartsLineComponent, EchartsRingComponent, EchartsVerticalBandsComponent, defaultOptionsOverrides, getAreaOverridesTemplate, getAreaStackOverridesTemplate, getLineOverridesTemplate, initializeEcharts, provideVSEcharts };
|
|
877
1147
|
//# sourceMappingURL=visionaris-bruno-vs-echarts.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"visionaris-bruno-vs-echarts.mjs","sources":["../../../projects/vs-echarts/src/lib/vs-echarts.config.ts","../../../projects/vs-echarts/src/lib/base-echart.component.ts","../../../projects/vs-echarts/src/lib/echarts-options.ts","../../../projects/vs-echarts/src/lib/builders/base-echart.builder.ts","../../../projects/vs-echarts/src/lib/builders/ring.builder.ts","../../../projects/vs-echarts/src/lib/charts/echarts-ring/echarts-ring.component.ts","../../../projects/vs-echarts/src/lib/charts/echarts-ring/echarts-ring.component.html","../../../projects/vs-echarts/src/lib/builders/vertical-bands.builder.ts","../../../projects/vs-echarts/src/lib/charts/echarts-vertical-bands/echarts-vertical-bands.component.ts","../../../projects/vs-echarts/src/lib/charts/echarts-vertical-bands/echarts-vertical-bands.component.html","../../../projects/vs-echarts/src/public-api.ts","../../../projects/vs-echarts/src/visionaris-bruno-vs-echarts.ts"],"sourcesContent":["import { provideEchartsCore } from 'ngx-echarts';\nimport * as echarts from 'echarts/core';\nimport { BarChart, PieChart } from 'echarts/charts';\nimport {\n TitleComponent,\n TooltipComponent,\n GridComponent,\n LegendComponent,\n GraphicComponent,\n ToolboxComponent\n} from 'echarts/components';\nimport { CanvasRenderer } from 'echarts/renderers';\n\n/**\n * Inicialización centralizada de ECharts para evitar duplicación y efectos secundarios \n * no controlados en componentes standalone.\n */\nlet initialized = false;\n\nexport function initializeEcharts() {\n if (initialized) return;\n \n echarts.use([\n BarChart,\n PieChart,\n TitleComponent,\n TooltipComponent,\n GridComponent,\n LegendComponent,\n CanvasRenderer,\n GraphicComponent,\n ToolboxComponent\n ]);\n \n initialized = true;\n}\n\n/**\n * Provee la configuración de ECharts para ngx-echarts.\n * Llama automáticamente a la inicialización de módulos.\n */\nexport function provideVSEcharts() {\n initializeEcharts();\n return provideEchartsCore({ echarts });\n}\n","import { Input, OnChanges, SimpleChanges, ViewChild, ElementRef, Output, EventEmitter, OnDestroy, Directive } from '@angular/core';\nimport { ReplaySubject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport type * as echarts from 'echarts';\n\nimport { IEChartData, EChartValueFormatter, EChartColorResolver, IEChartConfiguration } from './echarts-data.interfaces';\nimport { EChartClickType } from './echarts.interfaces';\nimport { BaseEchartBuilder } from './builders/base-echart.builder';\n\n@Directive({\n standalone: true\n})\n/**\n * BaseEchartsComponent\n * \n * Clase base para componentes especialistas de ECharts.\n * Gestiona el ciclo de vida, redimensionado dinámico y debouncing de actualizaciones.\n * \n * @see {@link vs-echarts/docs/internal-architecture.md}\n */\nexport abstract class BaseEchartsComponent implements OnChanges, OnDestroy {\n @ViewChild('chartContainer', { static: true }) chartContainer!: ElementRef;\n \n /** Datos normalizados para graficar */\n @Input() data: IEChartData = { categories: [], series: [] };\n \n /** Configuración visual agnóstica */\n @Input() chartConfig: IEChartConfiguration = {};\n\n /** Paleta de colores básica */\n @Input() palette?: string[];\n\n /** Resolver de colores dinámico (Callback) */\n @Input() colorResolver?: EChartColorResolver;\n\n /** Formateador de valores para etiquetas y tooltips */\n @Input() valueFormatter?: EChartValueFormatter;\n \n @Output() chartClick = new EventEmitter<{type: EChartClickType, data: any}>();\n\n /** Opciones configuradas para ngx-echarts */\n public chartOptions: any = {};\n\n /** Subject para debouncing de actualizaciones. ReplaySubject asegura no perder el primer renderizado. */\n private updateSubject = new ReplaySubject<echarts.EChartsOption>(1);\n private updateSubscription?: Subscription;\n\n constructor() {\n this.updateSubscription = this.updateSubject.pipe(\n debounceTime(150)\n ).subscribe(options => {\n this.updateOptions(options);\n });\n }\n\n protected chartInstance?: echarts.ECharts;\n protected abstract builder: BaseEchartBuilder;\n\n ngOnChanges(changes: SimpleChanges) {\n this.onInputChanges(changes);\n }\n\n ngOnDestroy() {\n this.updateSubscription?.unsubscribe();\n this.chartInstance?.dispose();\n }\n\n /**\n * Captura la instancia de echarts (usado por ngx-echarts)\n */\n onChartInit(instance: any) {\n this.chartInstance = instance;\n this.updateChartOptions();\n }\n\n private updateOptions(options: echarts.EChartsOption) {\n this.chartOptions = { ...options };\n this.chartInstance?.setOption(options, { notMerge: true });\n }\n\n /**\n * Hook de template method invocado por `ngOnChanges`.\n * Las subclases lo sobreescriben para añadir lógica propia\n * y deben llamar a `super.onInputChanges(changes)` para preservar\n * el comportamiento base (detectar inputs relevantes y actualizar el chart).\n */\n protected onInputChanges(changes: SimpleChanges): void {\n if (changes['data'] || changes['chartConfig'] || changes['palette'] || changes['colorResolver'] || changes['valueFormatter']) {\n this.updateChartOptions();\n }\n }\n\n protected abstract updateChartOptions(): void;\n \n /**\n * Gatilla actualización en ngx-echarts\n */\n protected triggerUpdate(options: echarts.EChartsOption) {\n this.updateSubject.next(options);\n }\n\n /**\n * Método público para forzar el redimensionado desde el padre\n */\n public resize() {\n this.chartInstance?.resize();\n }\n}\n","/**\n * ECharts Options Standard Library\n * \n * Biblioteca de fragmentos de configuración y tokens de diseño para asegurar \n * una estética cohesiva en todos los gráficos de Visionaris.\n * \n * @see {@link VisionarisFrontEnd/docs/technical/echarts-architecture.md}\n */\n\n// Pre-cached native formatter for performance in axis ticks\nexport const compactFormatter = new Intl.NumberFormat('es-AR', {\n notation: 'compact',\n compactDisplay: 'short',\n maximumFractionDigits: 1\n});\n\n/**\n * Formats a value using native browser SI suffixes (k, M, B).\n */\nexport function formatAxisValue(value: number): string {\n return compactFormatter.format(value);\n}\n\n/**\n * Global Design Tokens for ECharts\n */\nconst EChartsTokens = {\n fontFamily: \"'Inter', 'Roboto', sans-serif\",\n fontSize: 11,\n axisColor: '#666',\n lineColor: '#ddd',\n primaryColor: '#08B1D5',\n tooltipBg: 'rgba(255, 255, 255, 0.95)',\n defaultPalette: ['#08B1D5', '#2C3E50', '#F39C12', '#E74C3C', '#27AE60', '#8E44AD', '#3498DB', '#16A085', '#D35400', '#2980B9']\n};\n\n/**\n * Exposes the default Visionaris palette for internal fallbacks.\n */\nexport function getDefaultPalette(): string[] {\n return [...EChartsTokens.defaultPalette];\n}\n\n/**\n * Common legend configuration with scroll to prevent \"cannibalization\".\n * Atomic Pattern: Provides the scrollable container with Visionaris styling.\n */\nexport function getLegendOptions(overrides?: any): any {\n const defaults = {\n show: true,\n type: 'scroll',\n orient: 'horizontal',\n bottom: 0,\n left: 'center',\n height: 60,\n textStyle: {\n color: '#333',\n fontSize: EChartsTokens.fontSize,\n fontFamily: EChartsTokens.fontFamily\n },\n pageButtonPosition: 'end',\n pageIconColor: EChartsTokens.primaryColor,\n pageIconInactiveColor: '#ccc',\n pageIconSize: 12,\n pageTextStyle: {\n color: '#666'\n }\n };\n\n return { ...defaults, ...overrides };\n}\n\n/**\n * Common XAxis configuration for category-based charts.\n * Atomic Pattern: Handles category mapping and adaptive label rotation.\n */\nexport function getXAxisOptions(overrides?: any): any {\n const categories = overrides?.data || [];\n const autoRotate = categories.length > 10 ? 45 : 0;\n\n const defaults = {\n type: 'category',\n triggerEvent: true,\n axisLabel: {\n rotate: autoRotate,\n interval: 0, \n color: EChartsTokens.axisColor,\n fontSize: EChartsTokens.fontSize\n },\n axisLine: {\n lineStyle: {\n color: EChartsTokens.lineColor\n }\n }\n };\n\n // Deep merge for axisLabel if provided\n const result = { ...defaults, ...overrides };\n if (overrides?.axisLabel) {\n result.axisLabel = { ...defaults.axisLabel, ...overrides.axisLabel };\n }\n\n return result;\n}\n\n/**\n * Common YAxis configuration for value-based charts.\n * Atomic Pattern: Standardizes value formatting and grid lines.\n */\nexport function getYAxisOptions(overrides?: any): any {\n const defaults = {\n type: 'value',\n splitLine: { \n show: true,\n lineStyle: { \n type: 'dashed',\n color: '#f0f0f0'\n } \n },\n axisLabel: {\n formatter: (value: number) => formatAxisValue(value),\n color: EChartsTokens.axisColor,\n fontSize: EChartsTokens.fontSize\n }\n };\n\n const result = { ...defaults, ...overrides };\n if (overrides?.splitLine) {\n result.splitLine = { ...defaults.splitLine, ...overrides.splitLine };\n }\n\n return result;\n}\n\n/**\n * Common Tooltip configuration.\n * Atomic Pattern: Enforces consistent glassmorphism and pointer styles.\n */\nexport function getTooltipOptions(overrides?: any): any {\n const trigger = overrides?.trigger || 'axis';\n const isAxis = trigger === 'axis';\n\n const defaults = {\n show: true,\n trigger: trigger,\n backgroundColor: EChartsTokens.tooltipBg,\n borderColor: '#eee',\n borderWidth: 1,\n textStyle: {\n color: '#333',\n fontSize: 12\n },\n extraCssText: 'box-shadow: 0 0 10px rgba(0,0,0,0.1); border-radius: 8px;',\n ...(isAxis ? {\n axisPointer: {\n type: 'shadow'\n }\n } : {})\n };\n\n return { ...defaults, ...overrides };\n}\n","import { EChartsOption } from 'echarts';\nimport { IEChartData, EChartValueFormatter, EChartColorResolver, IEChartConfiguration } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-options';\n\n/**\n * BaseEchartBuilder\n * \n * Clase base para la construcción de opciones de ECharts.\n * Implementa lógica compartida de paletas y opciones comunes.\n * \n * @see {@link vs-echarts/docs/internal-architecture.md}\n */\nexport abstract class BaseEchartBuilder {\n \n protected valueFormatter: EChartValueFormatter = (value: number) => value.toLocaleString();\n protected palette: string[] = [];\n protected colorResolver?: EChartColorResolver;\n\n constructor() {}\n\n /**\n * Permite inyectar un formateador de valores externo.\n */\n public setValueFormatter(formatter: EChartValueFormatter): void {\n if (formatter) {\n this.valueFormatter = formatter;\n }\n }\n\n /**\n * Permite inyectar una paleta de colores básica.\n */\n public setPalette(palette: string[]): void {\n if (palette) {\n this.palette = palette;\n }\n }\n\n /**\n * Permite inyectar un resolver de colores dinámico.\n */\n public setColorResolver(resolver: EChartColorResolver): void {\n if (resolver) {\n this.colorResolver = resolver;\n }\n }\n\n /**\n * Método principal para construir el objeto EChartsOption.\n */\n abstract build(\n data: IEChartData,\n chartConfig: IEChartConfiguration\n ): EChartsOption;\n\n /**\n * Retorna configuraciones comunes para todos los gráficos.\n * \n * TODO: particionar en configuraciones concretas con sus \n * respectivos overrides.\n */\n protected getCommonOptions(chartConfig?: IEChartConfiguration): EChartsOption {\n const common: EChartsOption = {\n backgroundColor: 'transparent',\n textStyle: {\n fontFamily: \"'Inter', 'Roboto', 'Open Sans', sans-serif\"\n },\n grid: {\n left: '3%',\n right: '4%',\n bottom: '15%',\n top: '20px',\n containLabel: true\n }\n };\n\n // Aplicar paleta global: Prioridad Palette Inyectada > Default Visionaris\n common.color = (this.palette && this.palette.length > 0) ? this.palette : EChartsOptions.getDefaultPalette();\n\n return common;\n }\n\n /**\n * Formatea un valor utilizando el callback inyectado.\n */\n protected formatCellValue(value: number, key: string): string {\n return this.valueFormatter(value, key);\n }\n}\n","import { EChartsOption } from 'echarts';\nimport { BaseEchartBuilder } from './base-echart.builder';\nimport { IEChartData, IEChartConfiguration } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-options';\n\n/**\n * RingBuilder\n * \n * Especializado en construir opciones para gráficos de tipo Ring (Donas concéntricas).\n * @see {@link vs-echarts/docs/charts/ring-patterns.md}\n */\nexport class RingBuilder extends BaseEchartBuilder {\n \n build(\n data: IEChartData,\n chartConfig: IEChartConfiguration\n ): EChartsOption {\n if (!data || !data.series.length) return {};\n\n const totalRings = data.series.length; // Cada serie es un anillo\n \n // Configuración dinámica de radios y márgenes\n const margin = totalRings > 1 ? Math.max(0.5, 2.5 - (totalRings * 0.1)) : 0;\n const minInnerRadius = totalRings === 1 ? 45 : (totalRings > 5 ? Math.max(15, 40 - (totalRings * 1.2)) : 40);\n const maxOuterRadius = totalRings === 1 ? 72 : (totalRings > 5 ? Math.min(90, 72 + (totalRings * 0.5)) : 72);\n\n const availableSpan = maxOuterRadius - minInnerRadius - (margin * (totalRings - 1));\n const thickness = availableSpan / totalRings;\n\n const borderRadius = totalRings === 1 ? 10 : Math.max(2, Math.min(10, thickness * 0.8));\n const borderWidth = totalRings === 1 ? 2 : Math.max(0.5, Math.min(2, thickness * 0.15));\n\n const series = data.series.map((s, ringIndex) => {\n const inner = minInnerRadius + (ringIndex * (thickness + margin));\n const outer = inner + thickness;\n\n const pieData = data.categories.map((catName, catIndex) => ({\n name: catName,\n value: s.data[catIndex],\n originalMeassureKey: s.originalKey || (data.categoryKeys ? data.categoryKeys[catIndex] : '')\n }));\n\n const seriesOption: any = {\n name: s.name,\n type: 'pie' as const,\n radius: [`${inner}%`, `${outer}%`],\n center: ['50%', '50%'],\n avoidLabelOverlap: true,\n minAngle: 3,\n selectedMode: 'single' as const,\n selectedOffset: 4,\n itemStyle: {\n borderRadius: borderRadius,\n borderColor: '#fff',\n borderWidth: borderWidth\n },\n label: { show: false },\n emphasis: { \n scale: true,\n scaleSize: 2,\n itemStyle: {\n borderColor: '#fff',\n borderWidth: borderWidth\n }\n },\n select: {\n itemStyle: {\n borderColor: '#fff',\n borderWidth: borderWidth\n }\n },\n animationType: 'scale',\n animationEasing: 'elasticOut',\n data: pieData,\n id: `ring_${ringIndex}`\n };\n\n // Inyectar el resolver de color si existe\n if (this.colorResolver) {\n seriesOption.itemStyle.color = this.colorResolver;\n }\n\n return seriesOption;\n });\n\n const common = this.getCommonOptions(chartConfig);\n\n return {\n ...common,\n tooltip: {\n ...EChartsOptions.getTooltipOptions({ trigger: 'item' }),\n formatter: (params: any) => {\n const key = (params.data as any).originalMeassureKey || '';\n const valFormatted = this.formatCellValue(params.value as number, key);\n const seriesHeader = totalRings > 1 ? `<b>${params.seriesName}</b><br/>` : '';\n return `${seriesHeader}${params.name}<br/>${params.marker} <b>${valFormatted}</b> (${params.percent}%)`;\n }\n },\n legend: EChartsOptions.getLegendOptions(),\n graphic: [{\n id: 'center-kpi',\n type: 'text' as const,\n left: 'center',\n top: 'middle',\n z: 100,\n transition: ['style'],\n style: {\n text: '',\n fontSize: 22,\n fontWeight: 'bold',\n fill: '#333',\n stroke: '#fff',\n lineWidth: 1,\n paintOrder: 'stroke',\n textAlign: 'center',\n textVerticalAlign: 'middle',\n opacity: 0\n } as any\n } as any],\n series: series as any,\n };\n }\n}\n","import { Component, SimpleChanges } from '@angular/core';\nimport { BaseEchartsComponent } from '../../base-echart.component';\nimport { RingBuilder } from '../../builders/ring.builder';\nimport { NgxEchartsDirective } from 'ngx-echarts';\nimport { CommonModule } from '@angular/common';\nimport { provideVSEcharts } from '../../vs-echarts.config';\n\n/**\n * EchartsRingComponent\n * \n * Especialista en visualización de tipo Ring. Soporta multi-medidas y KPI central.\n * @see {@link vs-echarts/docs/charts/ring-patterns.md}\n */\n@Component({\n selector: 'vs-echarts-ring',\n standalone: true,\n imports: [\n CommonModule,\n NgxEchartsDirective,\n ],\n templateUrl: './echarts-ring.component.html',\n styleUrls: ['./echarts-ring.component.scss'],\n providers: [provideVSEcharts()]\n})\nexport class EchartsRingComponent extends BaseEchartsComponent {\n \n private lastSelectedSeriesIndex: number | null = null;\n private lastSelectedDataIndex: number | null = null;\n private selectedPercent: string | null = null;\n private currentLegendSelected: any = null;\n private currentGraphicText: string = '';\n \n protected override builder: RingBuilder;\n\n constructor() {\n super();\n this.builder = new RingBuilder();\n }\n\n protected override onInputChanges(changes: SimpleChanges): void {\n // Reset selection only if data changed\n if (changes['data']) {\n this.lastSelectedSeriesIndex = null;\n this.lastSelectedDataIndex = null;\n this.selectedPercent = null;\n this.currentLegendSelected = null;\n this.currentGraphicText = '';\n }\n super.onInputChanges(changes);\n }\n\n /**\n * Maneja clics en los sectores del ring.\n * Soporta múltiples series (anillos) y actualiza el KPI central.\n */\n onChartClick(event: any): void {\n if (this.chartInstance && event && event.dataIndex !== undefined) {\n const isSameSelection = \n event.seriesIndex === this.lastSelectedSeriesIndex && \n event.dataIndex === this.lastSelectedDataIndex;\n\n if (isSameSelection) {\n // Toggle OFF\n this.lastSelectedSeriesIndex = null;\n this.lastSelectedDataIndex = null;\n this.selectedPercent = null;\n this.setGraphicText('');\n \n this.chartInstance.dispatchAction({\n type: 'unselect',\n seriesIndex: event.seriesIndex,\n dataIndex: event.dataIndex\n });\n } else {\n // SELECT\n this.lastSelectedSeriesIndex = event.seriesIndex;\n this.lastSelectedDataIndex = event.dataIndex;\n this.selectedPercent = (event.percent !== undefined) ? event.percent + '%' : '';\n this.setGraphicText(this.selectedPercent);\n }\n\n this.chartClick.emit({\n type: 'cross-filter',\n data: {\n category: event.name,\n serie: event.seriesName,\n value: event.value\n }\n });\n }\n }\n\n onChartMouseOver(event: any): void {\n if (this.selectedPercent === null && event && event.percent !== undefined) {\n this.setGraphicText(event.percent + '%');\n }\n }\n\n onChartMouseOut(event: any): void {\n if (this.selectedPercent === null) {\n this.setGraphicText('');\n }\n }\n\n /**\n * Captura los cambios en la selección de la leyenda para persistirlos.\n */\n onLegendSelectChanged(event: any): void {\n if (event && event.selected) {\n this.currentLegendSelected = event.selected;\n \n // Resetear la selección actual al cambiar el contexto de la leyenda\n this.lastSelectedSeriesIndex = null;\n this.lastSelectedDataIndex = null;\n this.selectedPercent = null;\n this.currentGraphicText = '';\n \n this.updateChartOptions();\n }\n }\n\n /**\n * Actualiza el texto del Graphic central y persiste la selección en el modelo de opciones.\n */\n private setGraphicText(text: string): void {\n this.currentGraphicText = text;\n this.updateChartOptions();\n }\n\n protected updateChartOptions(): void {\n if (!this.chartInstance) return;\n if (!this.data) return;\n \n // 1. Configuramos el builder (Formateadores, Colores, etc se manejan en la base)\n // Pero aquí necesitamos llamar a super o duplicar la lógica de inyección de inputs\n if (this.valueFormatter) this.builder.setValueFormatter(this.valueFormatter);\n if (this.palette) this.builder.setPalette(this.palette);\n if (this.colorResolver) this.builder.setColorResolver(this.colorResolver);\n\n // 2. Obtenemos las bases del chart usando el builder\n let options = this.builder.build(\n this.data, \n this.chartConfig\n );\n\n // 3. Persistencia de GRAPHIC (KPI central)\n if (options.graphic && Array.isArray(options.graphic)) {\n const graphic = (options.graphic as any)[0];\n if (graphic && graphic.style) {\n graphic.style.text = this.currentGraphicText;\n graphic.style.opacity = this.currentGraphicText ? 1 : 0;\n }\n }\n\n // 4. Persistencia de SELECCIÓN (sector elevado)\n if (options.series && Array.isArray(options.series)) {\n options.series.forEach((s: any, sIdx: number) => {\n if (s.data && Array.isArray(s.data)) {\n s.data.forEach((item: any, dIdx: number) => {\n if (typeof item === 'object') {\n item.selected = (sIdx === this.lastSelectedSeriesIndex && dIdx === this.lastSelectedDataIndex);\n }\n });\n }\n });\n }\n\n // 5. Persistencia de LEYENDA (filtros de usuario)\n if (this.currentLegendSelected && options.legend) {\n options.legend = {\n ...(options.legend as any),\n selected: { ...this.currentLegendSelected }\n };\n }\n\n // Gatillar actualización en ngx-echarts\n this.triggerUpdate(options);\n }\n}\n","<div class=\"echarts-container\">\n <div class=\"ring-chart\" \n echarts \n [options]=\"chartOptions\" \n [autoResize]=\"true\" \n (chartInit)=\"onChartInit($event)\" \n (chartClick)=\"onChartClick($event)\" \n (chartMouseOver)=\"onChartMouseOver($event)\" \n (chartMouseOut)=\"onChartMouseOut($event)\" \n (chartLegendSelectChanged)=\"onLegendSelectChanged($event)\"\n ></div>\n</div>\n","import { EChartsOption } from 'echarts';\nimport { BaseEchartBuilder } from './base-echart.builder';\nimport { IEChartData, IEChartConfiguration } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-options';\n\n/**\n * VerticalBandsBuilder\n * \n * Especializado en construir opciones para gráficos de barras verticales.\n * @see {@link vs-echarts/docs/charts/vertical-bands-patterns.md}\n */\nexport class VerticalBandsBuilder extends BaseEchartBuilder {\n \n constructor() {\n super();\n }\n\n build(\n data: IEChartData,\n chartConfig: IEChartConfiguration\n ): EChartsOption {\n if (!data || !data.series.length) return {};\n\n const series = data.series.map((s) => {\n const seriesOption: any = {\n name: s.name,\n type: 'bar',\n barMaxWidth: 50,\n barGap: '15%',\n barCategoryGap: '35%',\n animation: true,\n animationDuration: 1000,\n animationEasing: 'cubicOut',\n itemStyle: {\n borderRadius: [4, 4, 0, 0]\n },\n data: s.data,\n emphasis: {\n focus: 'none'\n },\n blur: {\n itemStyle: {\n opacity: 0.2\n }\n },\n select: {\n itemStyle: {\n opacity: 1,\n shadowBlur: 10,\n shadowColor: 'rgba(0,0,0,0.3)'\n }\n },\n label: {\n show: false,\n position: 'top',\n formatter: (params: any) => {\n const key = s.originalKey || (data.categoryKeys ? data.categoryKeys[params.dataIndex] : String(params.dataIndex));\n return this.formatCellValue(params.value as number, key);\n }\n }\n };\n\n // Inyectar el resolver de color si existe\n if (this.colorResolver) {\n seriesOption.itemStyle.color = this.colorResolver;\n }\n\n return seriesOption;\n });\n\n const common = this.getCommonOptions(chartConfig);\n\n return {\n ...common,\n tooltip: {\n ...EChartsOptions.getTooltipOptions({ trigger: 'axis' }),\n formatter: (params: any) => {\n let html = `<b>${params[0].name}</b><br/>`;\n params.forEach((p: any) => {\n const seriesObj = data.series[p.seriesIndex];\n const key = seriesObj.originalKey || (data.categoryKeys ? data.categoryKeys[p.dataIndex] : String(p.dataIndex));\n const valFormatted = this.formatCellValue(p.value, key);\n html += `${p.marker} ${p.seriesName}: <b>${valFormatted}</b><br/>`;\n });\n return html;\n }\n },\n legend: EChartsOptions.getLegendOptions(),\n xAxis: EChartsOptions.getXAxisOptions({ data: data.categories }),\n yAxis: EChartsOptions.getYAxisOptions(),\n series: series as any\n };\n }\n}\n","import { Component, EventEmitter, Output, SimpleChanges } from '@angular/core';\nimport { BaseEchartsComponent } from '../../base-echart.component';\nimport { VerticalBandsBuilder } from '../../builders/vertical-bands.builder';\nimport { NgxEchartsDirective } from 'ngx-echarts';\nimport { CommonModule } from '@angular/common';\nimport { provideVSEcharts } from '../../vs-echarts.config';\n\n/**\n * EchartsVerticalBandsComponent\n * \n * Especialista en visualización de bandas/barras verticales. \n * Implementa patrones de interacción ZRender y resaltado de grupos.\n * @see {@link vs-echarts/docs/charts/vertical-bands-patterns.md}\n */\n@Component({\n selector: 'vs-echarts-vertical-bands',\n standalone: true,\n imports: [\n CommonModule,\n NgxEchartsDirective,\n ],\n templateUrl: './echarts-vertical-bands.component.html',\n styleUrls: ['./echarts-vertical-bands.component.scss'],\n providers: [provideVSEcharts()]\n})\nexport class EchartsVerticalBandsComponent extends BaseEchartsComponent {\n \n selectedSectorIndex: number | null = null;\n selectedSeriesIndex: number | null = null;\n private currentLegendSelected: any = null;\n \n protected override builder: VerticalBandsBuilder;\n\n constructor() {\n super();\n this.builder = new VerticalBandsBuilder();\n }\n\n override onChartInit(instance: any): void {\n super.onChartInit(instance);\n this.setupInteractions();\n }\n\n protected override onInputChanges(changes: SimpleChanges): void {\n if (changes['data']) {\n this.selectedSectorIndex = null;\n this.selectedSeriesIndex = null;\n this.currentLegendSelected = null;\n }\n super.onInputChanges(changes);\n }\n\n private setupInteractions(): void {\n if (!this.chartInstance) return;\n\n // 1. ZRender click for background \"sectors\"\n const zr = this.chartInstance.getZr();\n zr.on('click', (params: any) => {\n if (!params.target) {\n const pointInPixel = [params.offsetX, params.offsetY];\n if (this.chartInstance!.containPixel('grid', pointInPixel)) {\n // Fix TS2352: convertFromPixel return type cast\n const xIndexResult = this.chartInstance!.convertFromPixel({ xAxisIndex: 0 }, pointInPixel);\n const xIndex = Array.isArray(xIndexResult) ? xIndexResult[0] : xIndexResult;\n \n if (typeof xIndex === 'number' && xIndex >= 0) {\n this.toggleSectorSelection(xIndex);\n }\n }\n }\n });\n\n // 2. Mouseover for Group Highlighting\n this.chartInstance.on('mouseover', (params: any) => {\n if (params.dataIndex !== undefined) {\n this.highlightSector(params.dataIndex);\n }\n });\n\n this.chartInstance.on('mouseout', () => {\n this.clearHighlight();\n });\n }\n\n private toggleSectorSelection(index: number, seriesIndex: number | null = null): void {\n const isSameBar = this.selectedSectorIndex === index && this.selectedSeriesIndex === seriesIndex;\n\n if (isSameBar) {\n this.selectedSectorIndex = null;\n this.selectedSeriesIndex = null;\n } else {\n this.selectedSectorIndex = index;\n this.selectedSeriesIndex = seriesIndex;\n }\n \n // Refresh options to apply selection logic\n this.updateChartOptions();\n }\n\n private highlightSector(index: number): void {\n if (!this.chartInstance) return;\n const seriesCount = Array.isArray(this.chartOptions.series) ? this.chartOptions.series.length : 0;\n this.chartInstance.dispatchAction({\n type: 'highlight',\n seriesIndex: Array.from({length: seriesCount}, (_, i) => i),\n dataIndex: index\n });\n }\n\n private clearHighlight(): void {\n if (!this.chartInstance) return;\n const seriesCount = Array.isArray(this.chartOptions.series) ? this.chartOptions.series.length : 0;\n this.chartInstance.dispatchAction({\n type: 'downplay',\n seriesIndex: Array.from({length: seriesCount}, (_, i) => i)\n });\n }\n\n onChartClick(event: any): void {\n // 3. ECharts click only for bars (to avoid unwanted axis filtering)\n if (event.componentType === 'series') {\n const index = event.dataIndex;\n\n if (index !== undefined && index >= 0) {\n let seriesIndex: number | null = null;\n if (event.componentType === 'series') {\n seriesIndex = event.seriesIndex;\n }\n this.toggleSectorSelection(index, seriesIndex);\n \n // Emit standardized payload for cross-filtering\n this.chartClick.emit({\n type: 'cross-filter',\n data: {\n category: event.name,\n serie: event.seriesName,\n value: event.value\n }\n });\n }\n }\n }\n\n /**\n * Maneja clics en la leyenda para persistir filtros.\n */\n onLegendSelectChanged(event: any): void {\n if (event && event.selected) {\n this.currentLegendSelected = event.selected;\n this.updateChartOptions();\n }\n }\n\n protected updateChartOptions(): void {\n if (!this.chartInstance) return;\n if (!this.data) return;\n\n // 1. Configuramos el builder (Formateadores, Colores, etc se manejan en la base)\n if (this.valueFormatter) this.builder.setValueFormatter(this.valueFormatter);\n if (this.palette) this.builder.setPalette(this.palette);\n if (this.colorResolver) this.builder.setColorResolver(this.colorResolver);\n\n // 2. Obtenemos las bases del chart usando el builder\n let baseOptions = this.builder.build(\n this.data, \n this.chartConfig\n );\n\n // 3. Re-apply legend selection state if exists\n if (this.currentLegendSelected && baseOptions.legend) {\n (baseOptions.legend as any).selected = { ...this.currentLegendSelected };\n }\n\n // 4. Apply persistent selection style if a sector is selected\n if (this.selectedSectorIndex !== null && baseOptions.series) {\n const seriesArray = baseOptions.series as any[];\n baseOptions.series = seriesArray.map((s, sIdx) => {\n if (s.type === 'bar' && Array.isArray(s.data)) {\n return {\n ...s,\n data: s.data.map((val: any, idx: number) => {\n const isSelected = idx === this.selectedSectorIndex;\n const isBarSelected = isSelected && sIdx === this.selectedSeriesIndex;\n \n const itemVal = (val && typeof val === 'object' && val.value !== undefined) ? val.value : val;\n \n return {\n value: itemVal,\n itemStyle: {\n opacity: isSelected ? (isBarSelected ? 1 : 0.5) : 0.15,\n borderWidth: 0\n }\n };\n })\n };\n }\n return s;\n });\n }\n\n this.triggerUpdate(baseOptions)\n }\n}\n","<div class=\"echarts-container\">\n <div echarts [options]=\"chartOptions\" [autoResize]=\"true\" (chartInit)=\"onChartInit($event)\" (chartClick)=\"onChartClick($event)\" (legendSelectChanged)=\"onLegendSelectChanged($event)\" class=\"demo-chart\"></div>\n</div>\n","/*\n * Public API Surface of echarts\n */\n\nexport * from './lib/vs-echarts.config';\nexport * from './lib/charts/echarts-ring/echarts-ring.component';\nexport * from './lib/charts/echarts-vertical-bands/echarts-vertical-bands.component';\nexport * from './lib/base-echart.component';\nexport * from './lib/echarts-data.interfaces';\nexport * from './lib/echarts.interfaces';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["EChartsOptions.getDefaultPalette","EChartsOptions.getTooltipOptions","EChartsOptions.getLegendOptions","EChartsOptions.getXAxisOptions","EChartsOptions.getYAxisOptions"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"visionaris-bruno-vs-echarts.mjs","sources":["../../../projects/vs-echarts/src/lib/vs-echarts.config.ts","../../../projects/vs-echarts/src/lib/base-echart.component.ts","../../../projects/vs-echarts/src/lib/echarts-utils.ts","../../../projects/vs-echarts/src/lib/builders/base.builder.ts","../../../projects/vs-echarts/src/lib/builders/ring.builder.ts","../../../projects/vs-echarts/src/lib/charts/echarts-ring/echarts-ring.ts","../../../projects/vs-echarts/src/lib/charts/echarts-ring/echarts-ring.html","../../../projects/vs-echarts/src/lib/builders/vertical-bands.builder.ts","../../../projects/vs-echarts/src/lib/charts/echarts-vertical-bands/echarts-vertical-bands.ts","../../../projects/vs-echarts/src/lib/charts/echarts-vertical-bands/echarts-vertical-bands.html","../../../projects/vs-echarts/src/lib/builders/line.builder.ts","../../../projects/vs-echarts/src/lib/charts/echarts-line/echarts-line.ts","../../../projects/vs-echarts/src/lib/charts/echarts-line/echarts-line.html","../../../projects/vs-echarts/src/lib/echarts-data.interfaces.ts","../../../projects/vs-echarts/src/lib/presets-overrides-options-templates.ts","../../../projects/vs-echarts/src/public-api.ts","../../../projects/vs-echarts/src/visionaris-bruno-vs-echarts.ts"],"sourcesContent":["import { provideEchartsCore } from 'ngx-echarts';\nimport * as echarts from 'echarts/core';\nimport { BarChart, LineChart, PieChart } from 'echarts/charts';\nimport {\n TitleComponent,\n TooltipComponent,\n GridComponent,\n LegendComponent,\n GraphicComponent,\n ToolboxComponent\n} from 'echarts/components';\nimport { CanvasRenderer } from 'echarts/renderers';\nimport { IEChartOptionsOverrides } from './echarts-data.interfaces';\n\n/**\n * Inicialización centralizada de ECharts para evitar duplicación y efectos secundarios \n * no controlados en componentes standalone.\n */\nlet initialized = false;\n\nexport function initializeEcharts() {\n if (initialized) return;\n \n echarts.use([\n BarChart,\n PieChart,\n LineChart,\n TitleComponent,\n TooltipComponent,\n GridComponent,\n LegendComponent,\n CanvasRenderer,\n GraphicComponent,\n ToolboxComponent,\n ]);\n \n initialized = true;\n}\n\n/**\n * Provee la configuración de ECharts para ngx-echarts.\n * Llama automáticamente a la inicialización de módulos.\n */\nexport function provideVSEcharts() {\n initializeEcharts();\n return provideEchartsCore({ echarts });\n}\n\nexport function defaultOptionsOverrides(): IEChartOptionsOverrides {\n return {\n line: {\n series: {\n },\n },\n }\n}","import { Input, OnChanges, SimpleChanges, ViewChild, ElementRef, Output, EventEmitter, OnDestroy, Directive } from '@angular/core';\nimport { ReplaySubject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport type * as echarts from 'echarts';\n\nimport { IEChartData, EChartValueFormatter, EChartColorResolver, IEChartOptionsOverrides } from './echarts-data.interfaces';\nimport { EChartClickType } from './echarts.interfaces';\nimport { BaseEchartBuilder } from './builders/base.builder';\nimport { defaultOptionsOverrides } from './vs-echarts.config';\n\n@Directive({\n standalone: true\n})\n/**\n * BaseEchartsComponent\n * \n * Clase base para componentes especialistas de ECharts.\n * Gestiona el ciclo de vida, redimensionado dinámico y debouncing de actualizaciones.\n * \n * @see {@link vs-echarts/docs/internal-architecture.md}\n */\nexport abstract class BaseEchartsComponent implements OnChanges, OnDestroy {\n @ViewChild('chartContainer', { static: true }) chartContainer!: ElementRef;\n \n /** Datos normalizados para graficar */\n @Input() data: IEChartData = { categories: [], series: [] };\n \n @Input() optionsOverrides: IEChartOptionsOverrides = defaultOptionsOverrides();\n\n /** Paleta de colores básica */\n @Input() palette?: string[];\n\n /** Resolver de colores dinámico (Callback) */\n @Input() colorResolver?: EChartColorResolver;\n\n /** Formateador de valores para etiquetas y tooltips */\n @Input() valueFormatter?: EChartValueFormatter;\n \n @Output() chartClick = new EventEmitter<{type: EChartClickType, data: any}>(); \n\n /** Opciones configuradas para ngx-echarts */\n public chartOptions: any = {};\n\n /** Subject para debouncing de actualizaciones. ReplaySubject asegura no perder el primer renderizado. */\n private updateSubject = new ReplaySubject<echarts.EChartsOption>(1);\n private updateSubscription?: Subscription;\n\n constructor() {\n this.updateSubscription = this.updateSubject.pipe(\n debounceTime(150)\n ).subscribe(options => {\n this.updateOptions(options);\n });\n }\n\n protected chartInstance?: echarts.ECharts;\n protected abstract builder: BaseEchartBuilder;\n protected currentLegendSelected: any = null;\n\n /** Estado de selección para filtros cruzados */\n protected selectedCategoryIndex: number | null = null;\n protected selectedSeriesIndex: number | null = null;\n\n ngOnChanges(changes: SimpleChanges) {\n this.onInputChanges(changes);\n }\n\n ngOnDestroy() {\n this.updateSubscription?.unsubscribe();\n this.chartInstance?.dispose();\n }\n\n /**\n * Captura la instancia de echarts (usado por ngx-echarts)\n */\n onChartInit(instance: any) {\n this.chartInstance = instance;\n this.setupBaseInteractions();\n this.updateChartOptions();\n }\n\n /**\n * Configura interacciones base como el clic en el fondo para limpiar selección.\n */\n private setupBaseInteractions(): void {\n if (!this.chartInstance) return;\n const zr = this.chartInstance.getZr();\n zr.on('click', (params: any) => {\n if (!params.target) {\n this.clearSelection();\n }\n });\n }\n\n onChartClick(event: any): void {\n if (event.componentType === 'series') {\n const index = event.dataIndex;\n const seriesIndex = event.seriesIndex;\n\n if (index !== undefined && index >= 0) {\n this.handleSelection(index, seriesIndex);\n\n // Emit standardized payload for cross-filtering\n this.chartClick.emit({\n type: 'cross-filter',\n data: {\n category: event.name,\n serie: event.seriesName,\n value: event.value\n }\n });\n }\n }\n }\n\n /**\n * Maneja la lógica de alternancia de selección.\n */\n protected handleSelection(dataIndex: number, seriesIndex: number): void {\n const isSamePoint = this.selectedCategoryIndex === dataIndex && this.selectedSeriesIndex === seriesIndex;\n \n if (isSamePoint) {\n this.clearSelection();\n } else {\n this.selectedCategoryIndex = dataIndex;\n this.selectedSeriesIndex = seriesIndex;\n this.updateChartOptions();\n }\n }\n\n /**\n * Limpia el estado de selección actual.\n */\n protected clearSelection(): void {\n this.selectedCategoryIndex = null;\n this.selectedSeriesIndex = null;\n this.updateChartOptions();\n }\n \n dispatchAction(type: string, d: { seriesIndex?: number[], dataIndex?: number[] }) {\n if (this.chartInstance == undefined) return;\n \n const {\n seriesIndex = [],\n dataIndex = [],\n } = d;\n\n this.chartInstance.dispatchAction({\n type,\n seriesIndex,\n dataIndex,\n });\n }\n\n /**\n * Maneja clics en la leyenda para persistir filtros.\n */\n onLegendSelectChanged(event: any): void {\n if (event && event.selected) {\n this.currentLegendSelected = event.selected;\n this.updateChartOptions();\n }\n }\n\n private updateOptions(options: echarts.EChartsOption) {\n this.chartOptions = { ...options };\n this.chartInstance?.setOption(options, { notMerge: true });\n }\n\n /**\n * Hook de template method invocado por `ngOnChanges`.\n * Las subclases lo sobreescriben para añadir lógica propia\n * y deben llamar a `super.onInputChanges(changes)` para preservar\n * el comportamiento base (detectar inputs relevantes y actualizar el chart).\n */\n protected onInputChanges(changes: SimpleChanges): void {\n if (changes['data'] || changes['optionsOverrides'] || changes['palette'] || changes['colorResolver'] || changes['valueFormatter']) {\n this.updateChartOptions();\n }\n }\n\n protected abstract updateChartOptions(): void;\n \n /**\n * Gatilla actualización en ngx-echarts\n */\n protected triggerUpdate(options: echarts.EChartsOption) {\n this.updateSubject.next(options);\n }\n\n /**\n * Método público para forzar el redimensionado desde el padre\n */\n public resize() {\n this.chartInstance?.resize();\n }\n}\n","/**\n * ECharts Options Standard Library\n * \n * Biblioteca de fragmentos de configuración y tokens de diseño para asegurar \n * una estética cohesiva en todos los gráficos de Visionaris.\n * \n * @see {@link VisionarisFrontEnd/docs/technical/echarts-architecture.md}\n */\n\nimport { LineSeriesOption } from \"echarts\";\n\n// Pre-cached native formatter for performance in axis ticks\nexport const compactFormatter = new Intl.NumberFormat('es-AR', {\n notation: 'compact',\n compactDisplay: 'short',\n maximumFractionDigits: 1\n});\n\n/**\n * Formats a value using native browser SI suffixes (k, M, B).\n */\nexport function formatAxisValue(value: number): string {\n return compactFormatter.format(value);\n}\n\n/**\n * Global Design Tokens for ECharts\n */\nconst EChartsTokens = {\n fontFamily: \"'Inter', 'Roboto', sans-serif\",\n fontSize: 11,\n axisColor: '#666',\n lineColor: '#ddd',\n primaryColor: '#08B1D5',\n tooltipBg: 'rgba(255, 255, 255, 0.95)',\n defaultPalette: ['#08B1D5', '#2C3E50', '#F39C12', '#E74C3C', '#27AE60', '#8E44AD', '#3498DB', '#16A085', '#D35400', '#2980B9']\n};\n\n/**\n * Exposes the default Visionaris palette for internal fallbacks.\n */\nexport function getDefaultPalette(): string[] {\n return [...EChartsTokens.defaultPalette];\n}\n\n/**\n * Common legend configuration with scroll to prevent \"cannibalization\".\n * Atomic Pattern: Provides the scrollable container with Visionaris styling.\n */\nexport function getLegendOptions(overrides?: any): any {\n const defaults = {\n show: true,\n type: 'scroll',\n orient: 'horizontal',\n bottom: 0,\n left: 'center',\n height: 60,\n textStyle: {\n color: '#333',\n fontSize: EChartsTokens.fontSize,\n fontFamily: EChartsTokens.fontFamily\n },\n pageButtonPosition: 'end',\n pageIconColor: EChartsTokens.primaryColor,\n pageIconInactiveColor: '#ccc',\n pageIconSize: 12,\n pageTextStyle: {\n color: '#666'\n }\n };\n\n return { ...defaults, ...overrides };\n}\n\n/**\n * Common XAxis configuration for category-based charts.\n * Atomic Pattern: Handles category mapping and adaptive label rotation.\n */\nexport function getXAxisOptions(overrides?: any): any {\n const categories = overrides?.data || [];\n const autoRotate = categories.length > 10 ? 45 : 0;\n\n const defaults = {\n type: 'category',\n triggerEvent: true,\n axisLabel: {\n rotate: autoRotate,\n interval: 0, \n color: EChartsTokens.axisColor,\n fontSize: EChartsTokens.fontSize\n },\n axisLine: {\n lineStyle: {\n color: EChartsTokens.lineColor\n }\n }\n };\n\n // Deep merge for axisLabel if provided\n const result = { ...defaults, ...overrides };\n if (overrides?.axisLabel) {\n result.axisLabel = { ...defaults.axisLabel, ...overrides.axisLabel };\n }\n\n return result;\n}\n\n/**\n * Common YAxis configuration for value-based charts.\n * Atomic Pattern: Standardizes value formatting and grid lines.\n */\nexport function getYAxisOptions(overrides?: any): any {\n const defaults = {\n type: 'value',\n splitLine: { \n show: true,\n lineStyle: { \n type: 'dashed',\n color: '#f0f0f0'\n } \n },\n axisLabel: {\n formatter: (value: number) => formatAxisValue(value),\n color: EChartsTokens.axisColor,\n fontSize: EChartsTokens.fontSize\n }\n };\n\n const result = { ...defaults, ...overrides };\n if (overrides?.splitLine) {\n result.splitLine = { ...defaults.splitLine, ...overrides.splitLine };\n }\n\n return result;\n}\n\n/**\n * Common Tooltip configuration.\n * Atomic Pattern: Enforces consistent glassmorphism and pointer styles.\n */\nexport function getTooltipOptions(overrides?: any): any {\n const trigger = overrides?.trigger || 'axis';\n const isAxis = trigger === 'axis';\n\n const defaults = {\n show: true,\n trigger: trigger,\n backgroundColor: EChartsTokens.tooltipBg,\n borderColor: '#eee',\n borderWidth: 1,\n textStyle: {\n color: '#333',\n fontSize: 12\n },\n extraCssText: 'box-shadow: 0 0 10px rgba(0,0,0,0.1); border-radius: 8px;',\n ...(isAxis ? {\n axisPointer: {\n type: 'shadow'\n }\n } : {})\n };\n\n return { ...defaults, ...overrides };\n}\n\n/**\n * Applies a visual selection effect to line-based series.\n * Highlights the selected series and point, and dims everything else.\n * \n * @param series The series array to modify\n * @param selectedCategoryIndex Index of the selected category\n * @param selectedSeriesIndex Index of the selected series\n * @returns Modified series array\n */\nexport function applyLineSelectionStyle(\n series: LineSeriesOption[],\n selectedCategoryIndex: number | null,\n selectedSeriesIndex: number | null\n): LineSeriesOption[] {\n if (selectedCategoryIndex === null || !series) return series;\n\n return series.map((s, sIdx) => {\n const isSelectedSeries = sIdx === selectedSeriesIndex;\n\n // Serie seleccionada: Línea con opacidad 1 para que destaque la tendencia.\n // Serie NO seleccionada: Opacidad 0.20 para atenuar fuertemente.\n const seriesOpacity = isSelectedSeries ? 1 : 0.20;\n \n return {\n ...s,\n emphasis: {\n disabled: true // Deshabilitar el énfasis (hover) cuando hay una selección activa\n },\n itemStyle: {\n ...s.itemStyle,\n opacity: seriesOpacity\n },\n lineStyle: {\n ...s.lineStyle,\n opacity: seriesOpacity\n },\n ...(s.areaStyle ? {\n areaStyle: {\n ...s.areaStyle,\n opacity: isSelectedSeries ? 0.6 : 0.1\n }\n } : {}),\n // Personalizamos los puntos individualmente\n data: (s.data || []).map((val: any, idx: number) => {\n const isSelectedPoint = isSelectedSeries && idx === selectedCategoryIndex;\n const isOtherPointInSelectedSeries = isSelectedSeries && idx !== selectedCategoryIndex;\n \n const originalPoint = (val && typeof val === 'object') ? val : { value: val };\n \n if (isSelectedPoint) {\n return {\n ...originalPoint,\n z: 10, // Asegurar que el punto seleccionado esté por encima de los demás\n itemStyle: {\n ...originalPoint.itemStyle,\n opacity: 1,\n borderWidth: 2,\n borderColor: '#fff',\n shadowBlur: 10,\n shadowColor: 'rgba(0,0,0,0.5)'\n },\n symbolSize: 12\n };\n } else if (isOtherPointInSelectedSeries) {\n // Puntos de la serie seleccionada que NO son el clicado: un poco más pequeños y traslúcidos\n return {\n ...originalPoint,\n itemStyle: {\n ...originalPoint.itemStyle,\n opacity: 0.5\n },\n symbolSize: 6\n };\n }\n \n // Puntos de otras series o por defecto\n return val;\n })\n };\n });\n}\n","import { EChartsOption } from 'echarts';\nimport { IEChartData, EChartValueFormatter, EChartColorResolver, IEChartOptionsOverrides } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-utils';\n\n/**\n * BaseEchartBuilder\n * \n * Clase base para la construcción de opciones de ECharts.\n * Implementa lógica compartida de paletas y opciones comunes.\n * \n * @see {@link vs-echarts/docs/internal-architecture.md}\n */\nexport abstract class BaseEchartBuilder {\n \n protected valueFormatter: EChartValueFormatter = (value: number) => value.toLocaleString();\n protected palette: string[] = [];\n // TODO: Hay que implementar un valor por defecto.\n protected colorResolver?: EChartColorResolver;\n\n constructor() {}\n\n /**\n * Permite inyectar un formateador de valores externo.\n */\n public setValueFormatter(formatter: EChartValueFormatter): void {\n if (formatter) {\n this.valueFormatter = formatter;\n }\n }\n\n /**\n * Permite inyectar una paleta de colores básica.\n */\n public setPalette(palette: string[]): void {\n if (palette) {\n this.palette = palette;\n }\n }\n\n /**\n * Permite inyectar un resolver de colores dinámico.\n */\n public setColorResolver(resolver: EChartColorResolver): void {\n if (resolver) {\n this.colorResolver = resolver;\n }\n }\n\n /**\n * Método principal para construir el objeto EChartsOption.\n */\n abstract build(\n data: IEChartData,\n overrides: IEChartOptionsOverrides\n ): EChartsOption;\n\n /**\n * Retorna configuraciones comunes para todos los gráficos.\n * \n * TODO: particionar en configuraciones concretas con sus \n * respectivos overrides.\n */\n protected getCommonOptions(overrides?: IEChartOptionsOverrides): EChartsOption {\n const common: EChartsOption = {\n backgroundColor: 'transparent',\n textStyle: {\n fontFamily: \"'Inter', 'Roboto', 'Open Sans', sans-serif\"\n },\n grid: {\n left: '3%',\n right: '4%',\n bottom: '15%',\n top: '20px',\n containLabel: true\n }\n };\n\n // Aplicar paleta global: Prioridad Palette Inyectada > Default Visionaris\n common.color = (this.palette && this.palette.length > 0) ? this.palette : EChartsOptions.getDefaultPalette();\n\n return common;\n }\n\n /**\n * Formatea un valor utilizando el callback inyectado.\n */\n protected formatCellValue(value: number, key: string): string {\n return this.valueFormatter(value, key);\n }\n}\n","import { EChartsOption } from 'echarts';\nimport { BaseEchartBuilder } from './base.builder';\nimport { IEChartData, IEChartOptionsOverrides } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-utils';\n\n/**\n * RingBuilder\n * \n * Especializado en construir opciones para gráficos de tipo Ring (Donas concéntricas).\n * @see {@link vs-echarts/docs/charts/ring-patterns.md}\n */\nexport class RingBuilder extends BaseEchartBuilder {\n \n build(\n data: IEChartData,\n overrides: IEChartOptionsOverrides\n ): EChartsOption {\n if (!data || !data.series.length) return {};\n\n const totalRings = data.series.length; // Cada serie es un anillo\n \n // Configuración dinámica de radios y márgenes\n const margin = totalRings > 1 ? Math.max(0.5, 2.5 - (totalRings * 0.1)) : 0;\n const minInnerRadius = totalRings === 1 ? 45 : (totalRings > 5 ? Math.max(15, 40 - (totalRings * 1.2)) : 40);\n const maxOuterRadius = totalRings === 1 ? 72 : (totalRings > 5 ? Math.min(90, 72 + (totalRings * 0.5)) : 72);\n\n const availableSpan = maxOuterRadius - minInnerRadius - (margin * (totalRings - 1));\n const thickness = availableSpan / totalRings;\n\n const borderRadius = totalRings === 1 ? 10 : Math.max(2, Math.min(10, thickness * 0.8));\n const borderWidth = totalRings === 1 ? 2 : Math.max(0.5, Math.min(2, thickness * 0.15));\n\n const series = data.series.map((s, ringIndex) => {\n const inner = minInnerRadius + (ringIndex * (thickness + margin));\n const outer = inner + thickness;\n\n const pieData = data.categories.map((catName, catIndex) => ({\n name: catName,\n value: s.data[catIndex],\n originalMeassureKey: s.originalKey || (data.categoryKeys ? data.categoryKeys[catIndex] : '')\n }));\n\n const seriesOption: any = {\n name: s.name,\n type: 'pie' as const,\n radius: [`${inner}%`, `${outer}%`],\n center: ['50%', '50%'],\n avoidLabelOverlap: true,\n minAngle: 3,\n selectedMode: 'single' as const,\n selectedOffset: 4,\n itemStyle: {\n borderRadius: borderRadius,\n borderColor: '#fff',\n borderWidth: borderWidth\n },\n label: { show: false },\n emphasis: { \n scale: true,\n scaleSize: 2,\n itemStyle: {\n borderColor: '#fff',\n borderWidth: borderWidth\n }\n },\n select: {\n itemStyle: {\n borderColor: '#fff',\n borderWidth: borderWidth\n }\n },\n animationType: 'scale',\n animationEasing: 'elasticOut',\n data: pieData,\n id: `ring_${ringIndex}`\n };\n\n // Inyectar el resolver de color si existe\n if (this.colorResolver) {\n seriesOption.itemStyle.color = this.colorResolver;\n }\n\n return seriesOption;\n });\n\n const common = this.getCommonOptions(overrides);\n\n return {\n ...common,\n tooltip: {\n ...EChartsOptions.getTooltipOptions({ trigger: 'item' }),\n formatter: (params: any) => {\n const key = (params.data as any).originalMeassureKey || '';\n const valFormatted = this.formatCellValue(params.value as number, key);\n const seriesHeader = totalRings > 1 ? `<b>${params.seriesName}</b><br/>` : '';\n return `${seriesHeader}${params.name}<br/>${params.marker} <b>${valFormatted}</b> (${params.percent}%)`;\n }\n },\n legend: EChartsOptions.getLegendOptions(),\n graphic: [{\n id: 'center-kpi',\n type: 'text' as const,\n left: 'center',\n top: 'middle',\n z: 100,\n transition: ['style'],\n style: {\n text: '',\n fontSize: 22,\n fontWeight: 'bold',\n fill: '#333',\n stroke: '#fff',\n lineWidth: 1,\n paintOrder: 'stroke',\n textAlign: 'center',\n textVerticalAlign: 'middle',\n opacity: 0\n } as any\n } as any],\n series: series as any,\n };\n }\n}\n","import { Component, SimpleChanges } from '@angular/core';\nimport { BaseEchartsComponent } from '../../base-echart.component';\nimport { RingBuilder } from '../../builders/ring.builder';\nimport { NgxEchartsDirective } from 'ngx-echarts';\nimport { CommonModule } from '@angular/common';\nimport { provideVSEcharts } from '../../vs-echarts.config';\n\n/**\n * EchartsRingComponent\n * \n * Especialista en visualización de tipo Ring. Soporta multi-medidas y KPI central.\n * @see {@link vs-echarts/docs/charts/ring-patterns.md}\n */\n@Component({\n selector: 'vs-echarts-ring',\n standalone: true,\n imports: [\n CommonModule,\n NgxEchartsDirective,\n ],\n templateUrl: './echarts-ring.html',\n styleUrls: ['./echarts-ring.scss'],\n providers: [provideVSEcharts()]\n})\nexport class EchartsRingComponent extends BaseEchartsComponent {\n \n private lastSelectedSeriesIndex: number | null = null;\n private lastSelectedDataIndex: number | null = null;\n private selectedPercent: string | null = null;\n\n private currentGraphicText: string = '';\n \n protected override builder: RingBuilder;\n\n constructor() {\n super();\n this.builder = new RingBuilder();\n }\n\n protected override onInputChanges(changes: SimpleChanges): void {\n // Reset selection only if data changed\n if (changes['data']) {\n this.lastSelectedSeriesIndex = null;\n this.lastSelectedDataIndex = null;\n this.selectedPercent = null;\n this.currentLegendSelected = null;\n this.currentGraphicText = '';\n }\n super.onInputChanges(changes);\n }\n\n /**\n * Maneja clics en los sectores del ring.\n * Soporta múltiples series (anillos) y actualiza el KPI central.\n */\n override onChartClick(event: any): void {\n if (this.chartInstance && event && event.dataIndex !== undefined) {\n const isSameSelection = \n event.seriesIndex === this.lastSelectedSeriesIndex && \n event.dataIndex === this.lastSelectedDataIndex;\n\n if (isSameSelection) {\n // Toggle OFF\n this.lastSelectedSeriesIndex = null;\n this.lastSelectedDataIndex = null;\n this.selectedPercent = null;\n this.setGraphicText('');\n \n this.chartInstance.dispatchAction({\n type: 'unselect',\n seriesIndex: event.seriesIndex,\n dataIndex: event.dataIndex\n });\n } else {\n // SELECT\n this.lastSelectedSeriesIndex = event.seriesIndex;\n this.lastSelectedDataIndex = event.dataIndex;\n this.selectedPercent = (event.percent !== undefined) ? event.percent + '%' : '';\n this.setGraphicText(this.selectedPercent);\n }\n\n this.chartClick.emit({\n type: 'cross-filter',\n data: {\n category: event.name,\n serie: event.seriesName,\n value: event.value\n }\n });\n }\n }\n\n onChartMouseOver(event: any): void {\n if (this.selectedPercent === null && event && event.percent !== undefined) {\n this.setGraphicText(event.percent + '%');\n }\n }\n\n onChartMouseOut(event: any): void {\n if (this.selectedPercent === null) {\n this.setGraphicText('');\n }\n }\n\n /**\n * Captura los cambios en la selección de la leyenda para persistirlos.\n */\n override onLegendSelectChanged(event: any): void {\n if (event && event.selected) {\n this.currentLegendSelected = event.selected;\n \n // Resetear la selección actual al cambiar el contexto de la leyenda\n this.lastSelectedSeriesIndex = null;\n this.lastSelectedDataIndex = null;\n this.selectedPercent = null;\n this.currentGraphicText = '';\n \n this.updateChartOptions();\n }\n }\n\n /**\n * Actualiza el texto del Graphic central y persiste la selección en el modelo de opciones.\n */\n private setGraphicText(text: string): void {\n this.currentGraphicText = text;\n this.updateChartOptions();\n }\n\n protected updateChartOptions(): void {\n if (!this.chartInstance) return;\n if (!this.data) return;\n \n // 1. Configuramos el builder (Formateadores, Colores, etc se manejan en la base)\n // Pero aquí necesitamos llamar a super o duplicar la lógica de inyección de inputs\n if (this.valueFormatter) this.builder.setValueFormatter(this.valueFormatter);\n if (this.palette) this.builder.setPalette(this.palette);\n if (this.colorResolver) this.builder.setColorResolver(this.colorResolver);\n\n // 2. Obtenemos las bases del chart usando el builder\n let options = this.builder.build(\n this.data, \n this.optionsOverrides\n );\n\n // 3. Persistencia de GRAPHIC (KPI central)\n if (options.graphic && Array.isArray(options.graphic)) {\n const graphic = (options.graphic as any)[0];\n if (graphic && graphic.style) {\n graphic.style.text = this.currentGraphicText;\n graphic.style.opacity = this.currentGraphicText ? 1 : 0;\n }\n }\n\n // 4. Persistencia de SELECCIÓN (sector elevado)\n if (options.series && Array.isArray(options.series)) {\n options.series.forEach((s: any, sIdx: number) => {\n if (s.data && Array.isArray(s.data)) {\n s.data.forEach((item: any, dIdx: number) => {\n if (typeof item === 'object') {\n item.selected = (sIdx === this.lastSelectedSeriesIndex && dIdx === this.lastSelectedDataIndex);\n }\n });\n }\n });\n }\n\n // 5. Persistencia de LEYENDA (filtros de usuario)\n if (this.currentLegendSelected && options.legend) {\n options.legend = {\n ...(options.legend as any),\n selected: { ...this.currentLegendSelected }\n };\n }\n\n // Gatillar actualización en ngx-echarts\n this.triggerUpdate(options);\n }\n}\n","<div class=\"echarts-container\">\n <div class=\"ring-chart\" \n echarts \n [options]=\"chartOptions\" \n [autoResize]=\"true\" \n (chartInit)=\"onChartInit($event)\" \n (chartClick)=\"onChartClick($event)\" \n (chartMouseOver)=\"onChartMouseOver($event)\" \n (chartMouseOut)=\"onChartMouseOut($event)\" \n (chartLegendSelectChanged)=\"onLegendSelectChanged($event)\"\n ></div>\n</div>\n","import { EChartsOption } from 'echarts';\nimport { BaseEchartBuilder } from './base.builder';\nimport { IEChartData, IEChartOptionsOverrides } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-utils';\n\n/**\n * VerticalBandsBuilder\n * \n * Especializado en construir opciones para gráficos de barras verticales.\n * @see {@link vs-echarts/docs/charts/vertical-bands-patterns.md}\n */\nexport class VerticalBandsBuilder extends BaseEchartBuilder {\n \n constructor() {\n super();\n }\n\n build(\n data: IEChartData,\n overrides: IEChartOptionsOverrides\n ): EChartsOption {\n if (!data || !data.series.length) return {};\n\n const series = data.series.map((s) => {\n const seriesOption: any = {\n name: s.name,\n type: 'bar',\n barMaxWidth: 50,\n barGap: '15%',\n barCategoryGap: '35%',\n animation: true,\n animationDuration: 1000,\n animationEasing: 'cubicOut',\n itemStyle: {\n borderRadius: [4, 4, 0, 0]\n },\n data: s.data,\n emphasis: {\n focus: 'none'\n },\n blur: {\n itemStyle: {\n opacity: 0.2\n }\n },\n select: {\n itemStyle: {\n opacity: 1,\n shadowBlur: 10,\n shadowColor: 'rgba(0,0,0,0.3)'\n }\n },\n label: {\n show: false,\n position: 'top',\n formatter: (params: any) => {\n const key = s.originalKey || (data.categoryKeys ? data.categoryKeys[params.dataIndex] : String(params.dataIndex));\n return this.formatCellValue(params.value as number, key);\n }\n }\n };\n\n // Inyectar el resolver de color si existe\n if (this.colorResolver) {\n seriesOption.itemStyle.color = this.colorResolver;\n }\n\n return seriesOption;\n });\n\n const common = this.getCommonOptions(overrides);\n\n return {\n ...common,\n tooltip: {\n ...EChartsOptions.getTooltipOptions({ trigger: 'axis' }),\n formatter: (params: any) => {\n let html = `<b>${params[0].name}</b><br/>`;\n params.forEach((p: any) => {\n const seriesObj = data.series[p.seriesIndex];\n const key = seriesObj.originalKey || (data.categoryKeys ? data.categoryKeys[p.dataIndex] : String(p.dataIndex));\n const valFormatted = this.formatCellValue(p.value, key);\n html += `${p.marker} ${p.seriesName}: <b>${valFormatted}</b><br/>`;\n });\n return html;\n }\n },\n legend: EChartsOptions.getLegendOptions(),\n xAxis: EChartsOptions.getXAxisOptions({ data: data.categories }),\n yAxis: EChartsOptions.getYAxisOptions(),\n series: series as any\n };\n }\n}\n","import { Component, EventEmitter, Output, SimpleChanges } from '@angular/core';\nimport { BaseEchartsComponent } from '../../base-echart.component';\nimport { VerticalBandsBuilder } from '../../builders/vertical-bands.builder';\nimport { NgxEchartsDirective } from 'ngx-echarts';\nimport { CommonModule } from '@angular/common';\nimport { provideVSEcharts } from '../../vs-echarts.config';\n\n/**\n * EchartsVerticalBandsComponent\n * \n * Especialista en visualización de bandas/barras verticales. \n * Implementa patrones de interacción ZRender y resaltado de grupos.\n * @see {@link vs-echarts/docs/charts/vertical-bands-patterns.md}\n */\n@Component({\n selector: 'vs-echarts-vertical-bands',\n standalone: true,\n imports: [\n CommonModule,\n NgxEchartsDirective,\n ],\n templateUrl: './echarts-vertical-bands.html',\n styleUrls: ['./echarts-vertical-bands.scss'],\n providers: [provideVSEcharts()]\n})\nexport class EchartsVerticalBandsComponent extends BaseEchartsComponent {\n \n protected override builder: VerticalBandsBuilder;\n\n constructor() {\n super();\n this.builder = new VerticalBandsBuilder();\n }\n\n override onChartInit(instance: any): void {\n super.onChartInit(instance);\n this.setupAdditionalInteractions();\n }\n\n protected override onInputChanges(changes: SimpleChanges): void {\n if (changes['data']) {\n this.selectedCategoryIndex = null;\n this.selectedSeriesIndex = null;\n this.currentLegendSelected = null;\n }\n super.onInputChanges(changes);\n }\n\n private setupAdditionalInteractions(): void {\n if (!this.chartInstance) return;\n\n // 1. ZRender click for background \"sectors\" (Specific to bands)\n const zr = this.chartInstance.getZr();\n zr.on('click', (params: any) => {\n if (!params.target) {\n const pointInPixel = [params.offsetX, params.offsetY];\n if (this.chartInstance!.containPixel('grid', pointInPixel)) {\n const xIndexResult = this.chartInstance!.convertFromPixel({ xAxisIndex: 0 }, pointInPixel);\n const xIndex = Array.isArray(xIndexResult) ? xIndexResult[0] : xIndexResult;\n \n if (typeof xIndex === 'number' && xIndex >= 0) {\n this.handleSelection(xIndex, -1); // Use -1 or null to indicate sector selection without specific series\n }\n }\n }\n });\n\n // 2. Mouseover for Group Highlighting\n this.chartInstance.on('mouseover', (params: any) => {\n if (params.dataIndex !== undefined) {\n this.highlightSector(params.dataIndex);\n }\n });\n\n this.chartInstance.on('mouseout', () => {\n this.clearHighlight();\n });\n }\n\n private highlightSector(index: number): void {\n if (!this.chartInstance || this.selectedCategoryIndex !== null) return;\n const seriesCount = Array.isArray(this.chartOptions.series) ? this.chartOptions.series.length : 0;\n this.chartInstance.dispatchAction({\n type: 'highlight',\n seriesIndex: Array.from({length: seriesCount}, (_, i) => i),\n dataIndex: index\n });\n }\n\n private clearHighlight(): void {\n if (!this.chartInstance) return;\n const seriesCount = Array.isArray(this.chartOptions.series) ? this.chartOptions.series.length : 0;\n this.chartInstance.dispatchAction({\n type: 'downplay',\n seriesIndex: Array.from({length: seriesCount}, (_, i) => i)\n });\n }\n\n /**\n * Maneja clics en la leyenda para persistir filtros.\n */\n override onLegendSelectChanged(event: any): void {\n if (event && event.selected) {\n this.currentLegendSelected = event.selected;\n this.updateChartOptions();\n }\n }\n\n protected updateChartOptions(): void {\n if (!this.chartInstance) return;\n if (!this.data) return;\n\n // 1. Configuramos el builder (Formateadores, Colores, etc se manejan en la base)\n if (this.valueFormatter) this.builder.setValueFormatter(this.valueFormatter);\n if (this.palette) this.builder.setPalette(this.palette);\n if (this.colorResolver) this.builder.setColorResolver(this.colorResolver);\n\n // 2. Obtenemos las bases del chart usando el builder\n let baseOptions = this.builder.build(\n this.data, \n this.optionsOverrides\n );\n\n // 3. Re-apply legend selection state if exists\n if (this.currentLegendSelected && baseOptions.legend) {\n (baseOptions.legend as any).selected = { ...this.currentLegendSelected };\n }\n\n // 4. Apply persistent selection style if a sector is selected\n if (this.selectedCategoryIndex !== null && baseOptions.series) {\n const seriesArray = baseOptions.series as any[];\n baseOptions.series = seriesArray.map((s, sIdx) => {\n if (s.type === 'bar' && Array.isArray(s.data)) {\n return {\n ...s,\n emphasis: {\n disabled: true\n },\n data: s.data.map((val: any, idx: number) => {\n const isSelected = idx === this.selectedCategoryIndex;\n const isBarSelected = isSelected && sIdx === this.selectedSeriesIndex;\n \n const itemVal = (val && typeof val === 'object' && val.value !== undefined) ? val.value : val;\n \n return {\n value: itemVal,\n itemStyle: {\n opacity: isSelected ? (isBarSelected ? 1 : 0.5) : 0.15,\n borderWidth: 0\n }\n };\n })\n };\n }\n return s;\n });\n }\n\n this.triggerUpdate(baseOptions)\n }\n}\n","<div class=\"echarts-container\">\n <div echarts [options]=\"chartOptions\" [autoResize]=\"true\" (chartInit)=\"onChartInit($event)\" (chartClick)=\"onChartClick($event)\" (legendSelectChanged)=\"onLegendSelectChanged($event)\" class=\"demo-chart\"></div>\n</div>\n","import { EChartsOption, LineSeriesOption } from 'echarts';\nimport { BaseEchartBuilder } from './base.builder';\nimport { IEChartData, IEChartOptionsOverrides } from '../echarts-data.interfaces';\nimport * as EChartsOptions from '../echarts-utils';\n\n\nexport class LineBuilder extends BaseEchartBuilder {\n \n constructor() {\n super();\n }\n\n build(\n data: IEChartData,\n overrides: IEChartOptionsOverrides\n ): EChartsOption {\n if (!data || !data.series.length) return {};\n\n const { \n areaStyle = undefined,\n stack = undefined,\n } = overrides.line.series;\n\n const series = data.series.map((s) => {\n const seriesOption: LineSeriesOption = {\n name: s.name,\n type: 'line',\n animation: true,\n animationDuration: 1000,\n animationEasing: 'cubicOut',\n data: s.data,\n smooth: true, //curva\n smoothMonotone: 'x',\n symbolSize: 6,\n itemStyle: {\n shadowColor: 'rgba(0, 0, 0, 0.2)',\n shadowBlur: 5,\n shadowOffsetY: 2,\n },\n lineStyle: {\n width: 2,\n shadowColor: 'rgba(0, 0, 0, 0.2)',\n shadowBlur: 8,\n shadowOffsetY: 6,\n cap: 'round',\n join: 'round',\n },\n emphasis: {\n focus: 'none',\n itemStyle: {\n borderWidth: 2,\n shadowBlur: 10,\n },\n lineStyle: {\n width: 4,\n shadowBlur: 12,\n }\n },\n areaStyle,\n stack,\n };\n\n // Inyectar el resolver de color si existe\n if (this.colorResolver && seriesOption.itemStyle != undefined) {\n seriesOption.itemStyle.color = this.colorResolver;\n }\n\n return seriesOption;\n });\n\n const common = this.getCommonOptions(overrides);\n\n return {\n ...common,\n tooltip: {\n ...EChartsOptions.getTooltipOptions({ trigger: 'axis' }),\n formatter: (params: any) => {\n let html = `<b>${params[0].name}</b><br/>`;\n params.forEach((p: any) => {\n const seriesObj = data.series[p.seriesIndex];\n const key = seriesObj.originalKey || (data.categoryKeys ? data.categoryKeys[p.dataIndex] : String(p.dataIndex));\n const valFormatted = this.formatCellValue(p.value, key);\n html += `${p.marker} ${p.seriesName}: <b>${valFormatted}</b><br/>`;\n });\n return html;\n }\n },\n legend: EChartsOptions.getLegendOptions(),\n xAxis: EChartsOptions.getXAxisOptions({ data: data.categories }),\n yAxis: EChartsOptions.getYAxisOptions(),\n series: series as any\n };\n }\n}\n","import { Component, SimpleChanges } from '@angular/core';\nimport { provideVSEcharts } from '../../vs-echarts.config';\nimport { NgxEchartsDirective } from 'ngx-echarts';\nimport { CommonModule } from '@angular/common';\nimport { BaseEchartsComponent } from '../../base-echart.component';\nimport { LineBuilder } from '../../builders/line.builder';\nimport * as EChartsOptions from '../../echarts-utils';\n\n@Component({\n selector: 'vs-echarts-line',\n templateUrl: './echarts-line.html',\n styleUrl: './echarts-line.scss',\n standalone: true,\n imports: [\n CommonModule,\n NgxEchartsDirective,\n ],\n providers: [provideVSEcharts()]\n})\nexport class EchartsLineComponent extends BaseEchartsComponent {\n \n protected override builder: LineBuilder;\n\n constructor(){\n super();\n this.builder = new LineBuilder();\n }\n\n protected override onInputChanges(changes: SimpleChanges): void {\n if (changes['data']) {\n this.selectedCategoryIndex = null;\n this.selectedSeriesIndex = null;\n this.currentLegendSelected = null;\n }\n super.onInputChanges(changes);\n }\n\n protected updateChartOptions(): void {\n if (!this.chartInstance) return;\n if (!this.data) return;\n\n // 1. Configuramos el builder (Formateadores, Colores, etc se manejan en la base)\n if (this.valueFormatter) this.builder.setValueFormatter(this.valueFormatter);\n if (this.palette) this.builder.setPalette(this.palette);\n if (this.colorResolver) this.builder.setColorResolver(this.colorResolver);\n\n // 2. Obtenemos las bases del chart usando el builder\n let baseOptions = this.builder.build(\n this.data,\n this.optionsOverrides\n );\n\n // 3. Re-apply legend selection state if exists\n if (this.currentLegendSelected && baseOptions.legend) {\n (baseOptions.legend as any).selected = { ...this.currentLegendSelected };\n }\n\n // 4. Apply persistent selection style if a point is selected\n if (this.selectedCategoryIndex !== null && baseOptions.series) {\n baseOptions.series = EChartsOptions.applyLineSelectionStyle(\n baseOptions.series as any[],\n this.selectedCategoryIndex,\n this.selectedSeriesIndex\n );\n }\n\n this.triggerUpdate(baseOptions)\n }\n}\n","<div class=\"echarts-container\">\n <div\n echarts\n [options]=\"chartOptions\"\n [autoResize]=\"true\"\n (chartInit)=\"onChartInit($event)\"\n (chartClick)=\"onChartClick($event)\"\n (legendSelectChanged)=\"onLegendSelectChanged($event)\"\n style=\"width: 100%; height: 100%;\"\n ></div>\n</div>","// Interfaces de Inputs de Base EChart Component // \n\nimport { Axis, LineSeriesOption } from \"echarts\";\n\n/**\n * IEChartSeries\n * \n * Estructura de datos para una serie de ECharts.\n */\nexport interface IEChartSeries {\n name: string;\n data: number[];\n originalKey?: string; // Clave técnica original (ej. medida o dimensión)\n}\n\n/**\n * IEChartData\n * \n * Interfaz unificada para el paso de datos a componentes de ECharts.\n * Desacoplada de IDataFrame de Visionaris.\n */\nexport interface IEChartData {\n categories: string[];\n categoryKeys?: string[]; // Claves técnicas de las categorías (ej. medidas en layout 'row')\n series: IEChartSeries[];\n}\n\n/**\n * EChartValueFormatter\n * \n * Callback para formatear los valores numéricos de las celdas/series.\n */\nexport type EChartValueFormatter = (value: number, key: string) => string;\n\n/**\n * EChartColorResolver\n * \n * Callback para determinar el color de un elemento gráfico basado en sus parámetros.\n */\nexport type EChartColorResolver = (params: any) => string;\n\nexport interface IEChartOptionsOverrides {\n // commons //\n\n // end //\n // concrete options //\n\n /** line options overrides */\n line: {\n series: LineSeriesOption,\n }\n \n // end //\n}","import { IEChartOptionsOverrides } from \"./echarts-data.interfaces\";\n\n \nconst areaStyle = {\n};\n\nexport function getLineOverridesTemplate(): IEChartOptionsOverrides[\"line\"] {\n return {\n series: {\n }\n }\n}\n\nexport function getAreaOverridesTemplate(): IEChartOptionsOverrides[\"line\"] {\n return {\n series: {\n areaStyle,\n }\n }\n}\n\nexport function getAreaStackOverridesTemplate(): IEChartOptionsOverrides[\"line\"] {\n return {\n series: {\n areaStyle,\n stack: 'total',\n }\n }\n}","/*\n * Public API Surface of echarts\n */\n\nexport * from './lib/vs-echarts.config';\nexport * from './lib/charts/echarts-ring/echarts-ring';\nexport * from './lib/charts/echarts-vertical-bands/echarts-vertical-bands';\nexport * from './lib/charts/echarts-line/echarts-line';\nexport * from './lib/base-echart.component';\nexport * from './lib/echarts-data.interfaces';\nexport * from './lib/echarts.interfaces';\nexport * from './lib/presets-overrides-options-templates';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["EChartsOptions.getDefaultPalette","EChartsOptions.getTooltipOptions","EChartsOptions.getLegendOptions","EChartsOptions.getXAxisOptions","EChartsOptions.getYAxisOptions","EChartsOptions.applyLineSelectionStyle"],"mappings":"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"}
|
package/index.d.ts
CHANGED
|
@@ -1,14 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { OnChanges, OnDestroy, ElementRef, EventEmitter, SimpleChanges } from '@angular/core';
|
|
3
3
|
import * as echarts from 'echarts';
|
|
4
|
-
import { EChartsOption } from 'echarts';
|
|
5
|
-
|
|
6
|
-
declare function initializeEcharts(): void;
|
|
7
|
-
/**
|
|
8
|
-
* Provee la configuración de ECharts para ngx-echarts.
|
|
9
|
-
* Llama automáticamente a la inicialización de módulos.
|
|
10
|
-
*/
|
|
11
|
-
declare function provideVSEcharts(): i0.Provider;
|
|
4
|
+
import { LineSeriesOption, EChartsOption } from 'echarts';
|
|
12
5
|
|
|
13
6
|
/**
|
|
14
7
|
* IEChartSeries
|
|
@@ -43,13 +36,20 @@ type EChartValueFormatter = (value: number, key: string) => string;
|
|
|
43
36
|
* Callback para determinar el color de un elemento gráfico basado en sus parámetros.
|
|
44
37
|
*/
|
|
45
38
|
type EChartColorResolver = (params: any) => string;
|
|
39
|
+
interface IEChartOptionsOverrides {
|
|
40
|
+
/** line options overrides */
|
|
41
|
+
line: {
|
|
42
|
+
series: LineSeriesOption;
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
declare function initializeEcharts(): void;
|
|
46
47
|
/**
|
|
47
|
-
*
|
|
48
|
-
*
|
|
49
|
-
* Interfaz agnóstica para la configuración visual básica de ECharts.
|
|
48
|
+
* Provee la configuración de ECharts para ngx-echarts.
|
|
49
|
+
* Llama automáticamente a la inicialización de módulos.
|
|
50
50
|
*/
|
|
51
|
-
|
|
52
|
-
|
|
51
|
+
declare function provideVSEcharts(): i0.Provider;
|
|
52
|
+
declare function defaultOptionsOverrides(): IEChartOptionsOverrides;
|
|
53
53
|
|
|
54
54
|
type EChartClickType = 'cross-filter';
|
|
55
55
|
|
|
@@ -81,14 +81,14 @@ declare abstract class BaseEchartBuilder {
|
|
|
81
81
|
/**
|
|
82
82
|
* Método principal para construir el objeto EChartsOption.
|
|
83
83
|
*/
|
|
84
|
-
abstract build(data: IEChartData,
|
|
84
|
+
abstract build(data: IEChartData, overrides: IEChartOptionsOverrides): EChartsOption;
|
|
85
85
|
/**
|
|
86
86
|
* Retorna configuraciones comunes para todos los gráficos.
|
|
87
87
|
*
|
|
88
88
|
* TODO: particionar en configuraciones concretas con sus
|
|
89
89
|
* respectivos overrides.
|
|
90
90
|
*/
|
|
91
|
-
protected getCommonOptions(
|
|
91
|
+
protected getCommonOptions(overrides?: IEChartOptionsOverrides): EChartsOption;
|
|
92
92
|
/**
|
|
93
93
|
* Formatea un valor utilizando el callback inyectado.
|
|
94
94
|
*/
|
|
@@ -99,8 +99,7 @@ declare abstract class BaseEchartsComponent implements OnChanges, OnDestroy {
|
|
|
99
99
|
chartContainer: ElementRef;
|
|
100
100
|
/** Datos normalizados para graficar */
|
|
101
101
|
data: IEChartData;
|
|
102
|
-
|
|
103
|
-
chartConfig: IEChartConfiguration;
|
|
102
|
+
optionsOverrides: IEChartOptionsOverrides;
|
|
104
103
|
/** Paleta de colores básica */
|
|
105
104
|
palette?: string[];
|
|
106
105
|
/** Resolver de colores dinámico (Callback) */
|
|
@@ -119,12 +118,37 @@ declare abstract class BaseEchartsComponent implements OnChanges, OnDestroy {
|
|
|
119
118
|
constructor();
|
|
120
119
|
protected chartInstance?: echarts.ECharts;
|
|
121
120
|
protected abstract builder: BaseEchartBuilder;
|
|
121
|
+
protected currentLegendSelected: any;
|
|
122
|
+
/** Estado de selección para filtros cruzados */
|
|
123
|
+
protected selectedCategoryIndex: number | null;
|
|
124
|
+
protected selectedSeriesIndex: number | null;
|
|
122
125
|
ngOnChanges(changes: SimpleChanges): void;
|
|
123
126
|
ngOnDestroy(): void;
|
|
124
127
|
/**
|
|
125
128
|
* Captura la instancia de echarts (usado por ngx-echarts)
|
|
126
129
|
*/
|
|
127
130
|
onChartInit(instance: any): void;
|
|
131
|
+
/**
|
|
132
|
+
* Configura interacciones base como el clic en el fondo para limpiar selección.
|
|
133
|
+
*/
|
|
134
|
+
private setupBaseInteractions;
|
|
135
|
+
onChartClick(event: any): void;
|
|
136
|
+
/**
|
|
137
|
+
* Maneja la lógica de alternancia de selección.
|
|
138
|
+
*/
|
|
139
|
+
protected handleSelection(dataIndex: number, seriesIndex: number): void;
|
|
140
|
+
/**
|
|
141
|
+
* Limpia el estado de selección actual.
|
|
142
|
+
*/
|
|
143
|
+
protected clearSelection(): void;
|
|
144
|
+
dispatchAction(type: string, d: {
|
|
145
|
+
seriesIndex?: number[];
|
|
146
|
+
dataIndex?: number[];
|
|
147
|
+
}): void;
|
|
148
|
+
/**
|
|
149
|
+
* Maneja clics en la leyenda para persistir filtros.
|
|
150
|
+
*/
|
|
151
|
+
onLegendSelectChanged(event: any): void;
|
|
128
152
|
private updateOptions;
|
|
129
153
|
/**
|
|
130
154
|
* Hook de template method invocado por `ngOnChanges`.
|
|
@@ -143,7 +167,7 @@ declare abstract class BaseEchartsComponent implements OnChanges, OnDestroy {
|
|
|
143
167
|
*/
|
|
144
168
|
resize(): void;
|
|
145
169
|
static ɵfac: i0.ɵɵFactoryDeclaration<BaseEchartsComponent, never>;
|
|
146
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<BaseEchartsComponent, never, never, { "data": { "alias": "data"; "required": false; }; "
|
|
170
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<BaseEchartsComponent, never, never, { "data": { "alias": "data"; "required": false; }; "optionsOverrides": { "alias": "optionsOverrides"; "required": false; }; "palette": { "alias": "palette"; "required": false; }; "colorResolver": { "alias": "colorResolver"; "required": false; }; "valueFormatter": { "alias": "valueFormatter"; "required": false; }; }, { "chartClick": "chartClick"; }, never, never, true, never>;
|
|
147
171
|
}
|
|
148
172
|
|
|
149
173
|
/**
|
|
@@ -153,7 +177,7 @@ declare abstract class BaseEchartsComponent implements OnChanges, OnDestroy {
|
|
|
153
177
|
* @see {@link vs-echarts/docs/charts/ring-patterns.md}
|
|
154
178
|
*/
|
|
155
179
|
declare class RingBuilder extends BaseEchartBuilder {
|
|
156
|
-
build(data: IEChartData,
|
|
180
|
+
build(data: IEChartData, overrides: IEChartOptionsOverrides): EChartsOption;
|
|
157
181
|
}
|
|
158
182
|
|
|
159
183
|
/**
|
|
@@ -166,7 +190,6 @@ declare class EchartsRingComponent extends BaseEchartsComponent {
|
|
|
166
190
|
private lastSelectedSeriesIndex;
|
|
167
191
|
private lastSelectedDataIndex;
|
|
168
192
|
private selectedPercent;
|
|
169
|
-
private currentLegendSelected;
|
|
170
193
|
private currentGraphicText;
|
|
171
194
|
protected builder: RingBuilder;
|
|
172
195
|
constructor();
|
|
@@ -199,7 +222,7 @@ declare class EchartsRingComponent extends BaseEchartsComponent {
|
|
|
199
222
|
*/
|
|
200
223
|
declare class VerticalBandsBuilder extends BaseEchartBuilder {
|
|
201
224
|
constructor();
|
|
202
|
-
build(data: IEChartData,
|
|
225
|
+
build(data: IEChartData, overrides: IEChartOptionsOverrides): EChartsOption;
|
|
203
226
|
}
|
|
204
227
|
|
|
205
228
|
/**
|
|
@@ -210,18 +233,13 @@ declare class VerticalBandsBuilder extends BaseEchartBuilder {
|
|
|
210
233
|
* @see {@link vs-echarts/docs/charts/vertical-bands-patterns.md}
|
|
211
234
|
*/
|
|
212
235
|
declare class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
213
|
-
selectedSectorIndex: number | null;
|
|
214
|
-
selectedSeriesIndex: number | null;
|
|
215
|
-
private currentLegendSelected;
|
|
216
236
|
protected builder: VerticalBandsBuilder;
|
|
217
237
|
constructor();
|
|
218
238
|
onChartInit(instance: any): void;
|
|
219
239
|
protected onInputChanges(changes: SimpleChanges): void;
|
|
220
|
-
private
|
|
221
|
-
private toggleSectorSelection;
|
|
240
|
+
private setupAdditionalInteractions;
|
|
222
241
|
private highlightSector;
|
|
223
242
|
private clearHighlight;
|
|
224
|
-
onChartClick(event: any): void;
|
|
225
243
|
/**
|
|
226
244
|
* Maneja clics en la leyenda para persistir filtros.
|
|
227
245
|
*/
|
|
@@ -231,5 +249,23 @@ declare class EchartsVerticalBandsComponent extends BaseEchartsComponent {
|
|
|
231
249
|
static ɵcmp: i0.ɵɵComponentDeclaration<EchartsVerticalBandsComponent, "vs-echarts-vertical-bands", never, {}, {}, never, never, true, never>;
|
|
232
250
|
}
|
|
233
251
|
|
|
234
|
-
|
|
235
|
-
|
|
252
|
+
declare class LineBuilder extends BaseEchartBuilder {
|
|
253
|
+
constructor();
|
|
254
|
+
build(data: IEChartData, overrides: IEChartOptionsOverrides): EChartsOption;
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
declare class EchartsLineComponent extends BaseEchartsComponent {
|
|
258
|
+
protected builder: LineBuilder;
|
|
259
|
+
constructor();
|
|
260
|
+
protected onInputChanges(changes: SimpleChanges): void;
|
|
261
|
+
protected updateChartOptions(): void;
|
|
262
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<EchartsLineComponent, never>;
|
|
263
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EchartsLineComponent, "vs-echarts-line", never, {}, {}, never, never, true, never>;
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
declare function getLineOverridesTemplate(): IEChartOptionsOverrides["line"];
|
|
267
|
+
declare function getAreaOverridesTemplate(): IEChartOptionsOverrides["line"];
|
|
268
|
+
declare function getAreaStackOverridesTemplate(): IEChartOptionsOverrides["line"];
|
|
269
|
+
|
|
270
|
+
export { BaseEchartsComponent, EchartsLineComponent, EchartsRingComponent, EchartsVerticalBandsComponent, defaultOptionsOverrides, getAreaOverridesTemplate, getAreaStackOverridesTemplate, getLineOverridesTemplate, initializeEcharts, provideVSEcharts };
|
|
271
|
+
export type { EChartClickType, EChartColorResolver, EChartValueFormatter, IEChartData, IEChartOptionsOverrides, IEChartSeries };
|