bdpformulas 1.0.78 → 1.0.80
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.
|
@@ -62,5 +62,6 @@ const RUBROS_VALOR_PADRE = {
|
|
|
62
62
|
[balance_1.EEFFConsolidadoRubroEnum.UtilidadNetaEjercicio]: balance_1.EEFFConsolidadoRubroEnum.TotalIngresos
|
|
63
63
|
};
|
|
64
64
|
function getRubroIdValorPadre(rubroPadreId, rubroId) {
|
|
65
|
+
//@ts-ignore
|
|
65
66
|
return RUBROS_VALOR_PADRE[rubroPadreId] ?? RUBROS_VALOR_PADRE[rubroId];
|
|
66
67
|
}
|
|
@@ -5,6 +5,7 @@ export default class DeudasStrategy implements Strategy {
|
|
|
5
5
|
cleanNumber: (data: any) => number;
|
|
6
6
|
calcularDeuda(params: any): void;
|
|
7
7
|
calcularDeudaFilaPorcentaje(params: any): void;
|
|
8
|
+
calcularDeudaGridLinea(params: any): void;
|
|
8
9
|
sumarizador(params: any): any;
|
|
9
10
|
execute(data: any): any;
|
|
10
11
|
}
|
|
@@ -41,6 +41,32 @@ class DeudasStrategy {
|
|
|
41
41
|
i++;
|
|
42
42
|
} while (this.data.Deudas.find((item) => item.RubroId == params.rubro1 && item.Secuencia == i));
|
|
43
43
|
}
|
|
44
|
+
calcularDeudaGridLinea(params) {
|
|
45
|
+
let i = 1;
|
|
46
|
+
do {
|
|
47
|
+
let rows1 = this.data.Deudas.filter((item) => item.RubroId == params.rubro1 && item.Secuencia == i);
|
|
48
|
+
let row2 = this.data.Deudas.find((item) => item.RubroId == params.rubro2 && item.Secuencia == i);
|
|
49
|
+
let row3 = this.data.Deudas.find((item) => item.RubroId == params.rubro3 && item.Secuencia == i);
|
|
50
|
+
//sumarizando
|
|
51
|
+
let row1 = rows1.reduce((sum, item) => {
|
|
52
|
+
if (!sum)
|
|
53
|
+
sum = { ...item };
|
|
54
|
+
else {
|
|
55
|
+
for (let i = 1; i <= this.data.CantidadProyeccion; i++) {
|
|
56
|
+
sum[`Monto${i}`] = this.cleanNumber(sum[`Monto${i}`]) + this.cleanNumber(item[`Monto${i}`]);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return sum;
|
|
60
|
+
}, null);
|
|
61
|
+
for (let j = 1; j <= this.data.CantidadProyeccion; j++) {
|
|
62
|
+
if (row3[`Monto${j}`] == 0) {
|
|
63
|
+
row3[`Monto${j}`] = (this.cleanNumber(row1[`Monto${j}`]) * this.cleanNumber(row2[`Monto${j}`]) / 100);
|
|
64
|
+
row3[`Monto${j}`] = Math.round(row3[`Monto${j}`] * 100) / 100;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
i++;
|
|
68
|
+
} while (this.data.Deudas.find((item) => item.RubroId == params.rubro1 && item.Secuencia == i));
|
|
69
|
+
}
|
|
44
70
|
sumarizador(params) {
|
|
45
71
|
let destino = this.data.Deudas.find((item) => item.RubroId == params.rubro2);
|
|
46
72
|
this.data.Deudas.filter((item) => item.RubroId == params.rubro1).reduce((sum, item) => {
|
|
@@ -63,6 +89,9 @@ class DeudasStrategy {
|
|
|
63
89
|
this.sumarizador({ rubro1: 'ACT_DEU_10002', rubro2: 'ACT_DEU_10200' });
|
|
64
90
|
this.sumarizador({ rubro1: 'ACT_DEU_10003', rubro2: 'ACT_DEU_10300' });
|
|
65
91
|
this.calcularDeuda({ rubro1: 'ACT_DEU_20001', rubro2: 'ACT_DEU_20002', rubro3: 'ACT_DEU_20003' });
|
|
92
|
+
this.sumarizador({ rubro1: 'ACT_DEU_20001', rubro2: 'ACT_DEU_20100' });
|
|
93
|
+
this.sumarizador({ rubro1: 'ACT_DEU_20002', rubro2: 'ACT_DEU_20200' });
|
|
94
|
+
this.sumarizador({ rubro1: 'ACT_DEU_20003', rubro2: 'ACT_DEU_20300' });
|
|
66
95
|
this.calcularDeuda({ rubro1: 'ACT_DEU_30001', rubro2: 'ACT_DEU_30002', rubro3: 'ACT_DEU_30003' });
|
|
67
96
|
this.sumarizador({ rubro1: 'ACT_DEU_30001', rubro2: 'ACT_DEU_30100' });
|
|
68
97
|
this.sumarizador({ rubro1: 'ACT_DEU_30002', rubro2: 'ACT_DEU_30200' });
|
|
@@ -71,7 +100,8 @@ class DeudasStrategy {
|
|
|
71
100
|
this.sumarizador({ rubro1: 'ACT_DEU_40001', rubro2: 'ACT_DEU_40100' });
|
|
72
101
|
this.sumarizador({ rubro1: 'ACT_DEU_40002', rubro2: 'ACT_DEU_40200' });
|
|
73
102
|
this.sumarizador({ rubro1: 'ACT_DEU_40003', rubro2: 'ACT_DEU_40300' });
|
|
74
|
-
this.
|
|
103
|
+
this.calcularDeuda({ rubro1: 'ACT_DEU_41001', rubro2: 'ACT_DEU_41002', rubro3: 'ACT_DEU_41003' });
|
|
104
|
+
this.calcularDeudaGridLinea({ rubro1: 'ACT_DEU_50001', rubro2: 'ACT_DEU_50002', rubro3: 'ACT_DEU_50003' });
|
|
75
105
|
this.calcularDeudaFilaPorcentaje({ rubro1: 'ACT_DEU_60001', rubro2: 'ACT_DEU_60002', rubro3: 'ACT_DEU_60003' });
|
|
76
106
|
return this.data.Deudas;
|
|
77
107
|
}
|
|
@@ -25,7 +25,7 @@ const calcularComportamiento = (conceptosCalc, comportamiento) => {
|
|
|
25
25
|
Orden: (0, Constantes_1.getOrden)(item.RubroId)
|
|
26
26
|
});
|
|
27
27
|
}
|
|
28
|
-
acc.get(key)[`C-${item.Correlativo}`] = parseFloat(item.Monto);
|
|
28
|
+
acc.get(key)[`C-${item.Correlativo}`] = parseFloat(!item.Monto ? 0 : item.Monto);
|
|
29
29
|
acc.get(key)[`Desc-${item.Correlativo}`] = item.CorrelativoDesc;
|
|
30
30
|
acc.get(key).Total += parseFloat(item.Monto);
|
|
31
31
|
return acc;
|
|
@@ -56,7 +56,8 @@ const calcularCostos = (comportamientoCalc) => {
|
|
|
56
56
|
acc.get(item.RubroId)[key] = 0;
|
|
57
57
|
if (!Object.keys(acc.get(TOTAL)).includes(key))
|
|
58
58
|
acc.get(TOTAL)[key] = 0;
|
|
59
|
-
|
|
59
|
+
let costo = item[key] * item.CostoCampanna / 100;
|
|
60
|
+
costo = !costo ? 0 : costo;
|
|
60
61
|
acc.get(item.RubroId).Total += costo;
|
|
61
62
|
acc.get(item.RubroId)[key] += costo;
|
|
62
63
|
acc.get(TOTAL)[key] += costo;
|