@visionaris-bruno/vs-echarts 1.0.1 → 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
- /** Configuración visual agnóstica */
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['chartConfig'] || changes['palette'] || changes['colorResolver'] || changes['valueFormatter']) {
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", chartConfig: "chartConfig", palette: "palette", colorResolver: "colorResolver", valueFormatter: "valueFormatter" }, outputs: { chartClick: "chartClick" }, viewQueries: [{ propertyName: "chartContainer", first: true, predicate: ["chartContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0 });
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
- }], chartConfig: [{
212
+ }], optionsOverrides: [{
129
213
  type: Input
130
214
  }], palette: [{
131
215
  type: Input
@@ -214,7 +298,7 @@ function getXAxisOptions(overrides) {
214
298
  triggerEvent: true,
215
299
  axisLabel: {
216
300
  rotate: autoRotate,
217
- interval: 'auto',
301
+ interval: 0,
218
302
  color: EChartsTokens.axisColor,
219
303
  fontSize: EChartsTokens.fontSize
220
304
  },
@@ -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(chartConfig) {
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, chartConfig) {
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(chartConfig);
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.chartConfig);
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%}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-family:Roboto,sans-serif;text-align:center;padding:2rem}\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"] }] });
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%}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-family:Roboto,sans-serif;text-align:center;padding:2rem}\n"] }]
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, chartConfig) {
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(chartConfig);
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.setupInteractions();
866
+ this.setupAdditionalInteractions();
713
867
  }
714
868
  onInputChanges(changes) {
715
869
  if (changes['data']) {
716
- this.selectedSectorIndex = null;
870
+ this.selectedCategoryIndex = null;
717
871
  this.selectedSeriesIndex = null;
718
872
  this.currentLegendSelected = null;
719
873
  }
720
874
  super.onInputChanges(changes);
721
875
  }
722
- setupInteractions() {
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.toggleSectorSelection(xIndex);
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.chartConfig);
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.selectedSectorIndex !== null && baseOptions.series) {
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.selectedSectorIndex;
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%}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-family:Roboto,sans-serif;text-align:center;padding:2rem}\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"] }] });
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%}.empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-family:Roboto,sans-serif;text-align:center;padding:2rem}\n"] }]
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: 'auto',\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
- * IEChartConfiguration
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
- interface IEChartConfiguration {
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, chartConfig: IEChartConfiguration): EChartsOption;
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(chartConfig?: IEChartConfiguration): EChartsOption;
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
- /** Configuración visual agnóstica */
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; }; "chartConfig": { "alias": "chartConfig"; "required": false; }; "palette": { "alias": "palette"; "required": false; }; "colorResolver": { "alias": "colorResolver"; "required": false; }; "valueFormatter": { "alias": "valueFormatter"; "required": false; }; }, { "chartClick": "chartClick"; }, never, never, true, never>;
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, chartConfig: IEChartConfiguration): EChartsOption;
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, chartConfig: IEChartConfiguration): EChartsOption;
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 setupInteractions;
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
- export { BaseEchartsComponent, EchartsRingComponent, EchartsVerticalBandsComponent, initializeEcharts, provideVSEcharts };
235
- export type { EChartClickType, EChartColorResolver, EChartValueFormatter, IEChartConfiguration, IEChartData, IEChartSeries };
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 };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visionaris-bruno/vs-echarts",
3
- "version": "1.0.1",
3
+ "version": "2.0.0",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^20.3.0",
6
6
  "@angular/core": "^20.3.0",