CREATE PROCEDURE [dbo].[sp_conEstadoResultadoResumido_Excel]
(
 @mes        INT =12, 
 @periodo    INT =2021, 
 @unegocio   INT =0,
 @acumulado  BIT =0
 )

 as
 
DECLARE @tablaAcumulado TABLE ( cuenta varchar(50), EERR varchar(50), descripcionEERR varchar(300), saldoAcumulado decimal(18,4))

INSERT INTO @tablaAcumulado
SELECT ISNULL(C2.cuenta,'') AS cuenta, 
		ISNULL(ConPlanEstadoResultados.cuenta,'') AS EERR,
		ISNULL(ConPlanEstadoResultados.descripcion,'') AS descripcion,
		(sum(ISNULL(haber,0))-sum(ISNULL(debe,0))) as saldoAcumulado 
FROM conComprobantes AS C2
		inner join conPlanCuentas on C2.periodo=conPlanCuentas.periodo
											AND C2.cuenta=conPlanCuentas.cuenta
		INNER JOIN ConPlanEstadoResultados ON conPlanCuentas.periodo=ConPlanEstadoResultados.periodo 
									AND conPlanCuentas.estadoResul=ConPlanEstadoResultados.cuenta
WHERE C2.periodo= @periodo
		AND (mes BETWEEN 1 AND @mes OR @mes = 0)
		AND (uni_negocio=@unegocio OR @unegocio=-1)
GROUP BY 	C2.cuenta,
			ConPlanEstadoResultados.cuenta,
			ConPlanEstadoResultados.descripcion


DECLARE @tablaMes TABLE ( cuenta varchar(50), EERR varchar(50), descripcion varchar(300), saldoMes decimal(18,4))

INSERT INTO @tablaMes
SELECT C2.cuenta, 
		ConPlanEstadoResultados.cuenta AS EERR,
		ConPlanEstadoResultados.descripcion,
		(sum(ISNULL(haber,0))-sum(ISNULL(debe,0))) as saldoMES
FROM conComprobantes AS C2
		inner join conPlanCuentas on C2.periodo=conPlanCuentas.periodo
											AND C2.cuenta=conPlanCuentas.cuenta
		INNER JOIN ConPlanEstadoResultados ON conPlanCuentas.periodo=ConPlanEstadoResultados.periodo 
									AND conPlanCuentas.estadoResul=ConPlanEstadoResultados.cuenta
WHERE C2.periodo= @periodo
		AND (mes = @mes )
		AND (uni_negocio=@unegocio OR @unegocio=-1)
GROUP BY 	C2.cuenta,
			ConPlanEstadoResultados.cuenta,
			ConPlanEstadoResultados.descripcion

SELECT  ISNULL(A.EERR,'') AS EERR,
		ISNULL(A.descripcionEERR,'') AS descripcionEERR,
		SUM(ISNULL(M.saldoMes,0)) AS saldoMes,
		SUM(ISNULL(A.saldoAcumulado,0)) as saldoAcumulado
INTO #A
FROM @tablaAcumulado AS A
		LEFT OUTER JOIN @tablaMes AS M ON A.cuenta = M.cuenta
GROUP BY  A.EERR, A.descripcionEERR

IF @acumulado = 1
	BEGIN
		SELECT	ISNULL(ConPlanEstadoResultados.cuenta + ' - ' + ConPlanEstadoResultados.descripcion,'') AS cuentaER,
				--#A.EERR + ' - ' + #A.descripcionEERR as EERR,
				CONVERT(VARCHAR(50), conTotalesEERR.codigo) + ' - ' + conTotalesEERR.descripcion AS codTipoTotal,
				ISNULL(#A.saldoMes,0) AS saldoMes,
				ISNULL(#A.saldoAcumulado,0) as saldoAcumulado
		FROM ConPlanEstadoResultados
		LEFT JOIN #A ON ConPlanEstadoResultados.cuenta = #A.EERR		
		LEFT JOIN conTotalesEERR on ConPlanEstadoResultados.tipoTotal = conTotalesEERR.codigo
		WHERE periodo = @periodo
		AND ConPlanEstadoResultados.subclase > 0
	END
ELSE
	BEGIN
		SELECT	ISNULL(ConPlanEstadoResultados.cuenta + ' - ' + ConPlanEstadoResultados.descripcion,'') AS cuentaER,
				--#A.EERR + ' - ' + #A.descripcionEERR as EERR,
				CONVERT(VARCHAR(50), conTotalesEERR.codigo) + ' - ' + conTotalesEERR.descripcion AS codTipoTotal,
				ISNULL(#A.saldoMes,0) AS saldoMes
		FROM ConPlanEstadoResultados
		LEFT JOIN #A ON ConPlanEstadoResultados.cuenta = #A.EERR		
		LEFT JOIN conTotalesEERR on ConPlanEstadoResultados.tipoTotal = conTotalesEERR.codigo
		WHERE periodo = @periodo
		AND ConPlanEstadoResultados.subclase > 0
END