fix: correção da ordenação por CODGRUPO
This commit is contained in:
parent
6ce426222e
commit
64d4397847
|
|
@ -474,7 +474,7 @@ export default function Teste() {
|
|||
entidadeFiltro,
|
||||
diretoIndiretoFiltro,
|
||||
centroCustoFiltro,
|
||||
codigoContaFiltro,
|
||||
codigoContaFiltro,
|
||||
tipoLinha: row.type,
|
||||
rowData: {
|
||||
entidade: row.entidade,
|
||||
|
|
@ -563,9 +563,9 @@ export default function Teste() {
|
|||
const newExpanded = new Set(prev);
|
||||
if (newExpanded.has(entidade)) {
|
||||
newExpanded.delete(entidade);
|
||||
} else {
|
||||
} else {
|
||||
newExpanded.add(entidade);
|
||||
}
|
||||
}
|
||||
return newExpanded;
|
||||
});
|
||||
}, []);
|
||||
|
|
@ -587,9 +587,9 @@ export default function Teste() {
|
|||
const newExpanded = new Set(prev);
|
||||
if (newExpanded.has(chave)) {
|
||||
newExpanded.delete(chave);
|
||||
} else {
|
||||
} else {
|
||||
newExpanded.add(chave);
|
||||
}
|
||||
}
|
||||
return newExpanded;
|
||||
});
|
||||
}, []);
|
||||
|
|
@ -775,23 +775,41 @@ export default function Teste() {
|
|||
const rows: HierarchicalRow[] = [];
|
||||
|
||||
// Nova hierarquia: [entidade, direto/indireto, cc, conta]
|
||||
// Agrupar por entidade
|
||||
const entidades = data.reduce((acc, item) => {
|
||||
// Agrupar primeiro por CODGRUPO, depois por entidade
|
||||
const gruposPorCodigo = data.reduce((acc, item) => {
|
||||
const codgrupo = item.codgrupo || "";
|
||||
if (!codgrupo) return acc;
|
||||
if (!acc[codgrupo]) {
|
||||
acc[codgrupo] = {};
|
||||
}
|
||||
const entidade = item.entidades || "";
|
||||
if (!entidade) return acc;
|
||||
if (!acc[entidade]) {
|
||||
acc[entidade] = [];
|
||||
if (!acc[codgrupo][entidade]) {
|
||||
acc[codgrupo][entidade] = [];
|
||||
}
|
||||
acc[entidade].push(item);
|
||||
acc[codgrupo][entidade].push(item);
|
||||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
}, {} as Record<string, Record<string, DREItem[]>>);
|
||||
|
||||
// Ordenar entidades alfabeticamente
|
||||
const sortedEntidades = Object.entries(entidades).sort(([entA], [entB]) =>
|
||||
entA.localeCompare(entB)
|
||||
);
|
||||
// Ordenar por CODGRUPO (numericamente), depois por entidade (alfabeticamente)
|
||||
const sortedGrupos = Object.entries(gruposPorCodigo).sort(([codA], [codB]) => {
|
||||
// Ordenar numericamente por CODGRUPO
|
||||
const numA = parseInt(codA) || 0;
|
||||
const numB = parseInt(codB) || 0;
|
||||
if (numA !== numB) {
|
||||
return numA - numB;
|
||||
}
|
||||
// Se não for numérico, ordenar alfabeticamente
|
||||
return codA.localeCompare(codB);
|
||||
});
|
||||
|
||||
sortedEntidades.forEach(([entidade, items]) => {
|
||||
sortedGrupos.forEach(([codgrupo, entidades]) => {
|
||||
// Ordenar entidades dentro do grupo alfabeticamente
|
||||
const sortedEntidades = Object.entries(entidades).sort(([entA], [entB]) =>
|
||||
entA.localeCompare(entB)
|
||||
);
|
||||
|
||||
sortedEntidades.forEach(([entidade, items]) => {
|
||||
const totalEntidade = items.reduce((sum, item) => sum + parseFloat(item.valor), 0);
|
||||
const valoresEntidadePorMes = calcularValoresPorMes(items);
|
||||
|
||||
|
|
@ -819,8 +837,8 @@ export default function Teste() {
|
|||
acc[subgrupo] = [];
|
||||
}
|
||||
acc[subgrupo].push(item);
|
||||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
|
||||
// Ordenar: DIRETO primeiro, depois INDIRETO
|
||||
const sortedDiretoIndireto = Object.entries(diretoIndireto).sort(([a], [b]) => {
|
||||
|
|
@ -833,9 +851,9 @@ export default function Teste() {
|
|||
|
||||
sortedDiretoIndireto.forEach(([diretoIndireto, diretoIndiretoItems]) => {
|
||||
const totalDiretoIndireto = diretoIndiretoItems.reduce(
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
0
|
||||
);
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
0
|
||||
);
|
||||
const valoresDiretoIndiretoPorMes = calcularValoresPorMes(diretoIndiretoItems);
|
||||
|
||||
// Verificar se direto/indireto contém faturamento líquido
|
||||
|
|
@ -843,9 +861,9 @@ export default function Teste() {
|
|||
const codgrupoParaCalculoDI = temFaturamentoLiquidoDI ? "00" : "";
|
||||
|
||||
// Linha direto/indireto (Level 1) - sempre expandida
|
||||
rows.push({
|
||||
rows.push({
|
||||
type: "direto_indireto",
|
||||
level: 1,
|
||||
level: 1,
|
||||
entidade,
|
||||
direto_indireto: diretoIndireto,
|
||||
total: totalDiretoIndireto,
|
||||
|
|
@ -863,27 +881,27 @@ export default function Teste() {
|
|||
acc[centro] = [];
|
||||
}
|
||||
acc[centro].push(item);
|
||||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
|
||||
// Ordenar centros de custo por CODIGOCENTROCUSTO
|
||||
const sortedCentros = Object.entries(centros).sort(([centroA, itemsA], [centroB, itemsB]) => {
|
||||
const codigoA = itemsA[0]?.codigo_centro_custo || "";
|
||||
const codigoB = itemsB[0]?.codigo_centro_custo || "";
|
||||
// Ordenar centros de custo por CODIGOCENTROCUSTO
|
||||
const sortedCentros = Object.entries(centros).sort(([centroA, itemsA], [centroB, itemsB]) => {
|
||||
const codigoA = itemsA[0]?.codigo_centro_custo || "";
|
||||
const codigoB = itemsB[0]?.codigo_centro_custo || "";
|
||||
if (codigoA && codigoB) {
|
||||
return codigoA.localeCompare(codigoB);
|
||||
}
|
||||
if (codigoA && !codigoB) return -1;
|
||||
if (!codigoA && codigoB) return 1;
|
||||
return centroA.localeCompare(centroB);
|
||||
});
|
||||
});
|
||||
|
||||
sortedCentros.forEach(([centro, centroItems]) => {
|
||||
const totalCentro = centroItems.reduce(
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
0
|
||||
);
|
||||
const valoresCentroPorMes = calcularValoresPorMes(centroItems);
|
||||
sortedCentros.forEach(([centro, centroItems]) => {
|
||||
const totalCentro = centroItems.reduce(
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
0
|
||||
);
|
||||
const valoresCentroPorMes = calcularValoresPorMes(centroItems);
|
||||
|
||||
// Verificar se centro de custo contém faturamento líquido
|
||||
const temFaturamentoLiquidoCC = centroItems.some(item => item.codgrupo === "00");
|
||||
|
|
@ -953,8 +971,9 @@ export default function Teste() {
|
|||
percentuaisPorMes: calcularPercentuaisPorMes(valoresContaPorMes, codgrupoParaCalculoConta),
|
||||
percentualTotal: calcularPercentualTotal(totalConta, codgrupoParaCalculoConta),
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
|
@ -983,7 +1002,7 @@ export default function Teste() {
|
|||
|
||||
setExpandedEntidades(new Set(todasEntidades));
|
||||
setExpandedDiretoIndireto(new Set(todosDiretoIndireto));
|
||||
setExpandedCentros(new Set(todosCentros));
|
||||
setExpandedCentros(new Set(todosCentros));
|
||||
|
||||
setIsAllExpanded(true);
|
||||
});
|
||||
|
|
@ -1577,23 +1596,41 @@ export default function Teste() {
|
|||
const rows: HierarchicalRow[] = [];
|
||||
|
||||
// Nova hierarquia: [entidade, direto/indireto, cc, conta]
|
||||
// Agrupar por entidade
|
||||
const entidades = data.reduce((acc, item) => {
|
||||
// Agrupar primeiro por CODGRUPO, depois por entidade
|
||||
const gruposPorCodigo = data.reduce((acc, item) => {
|
||||
const codgrupo = item.codgrupo || "";
|
||||
if (!codgrupo) return acc;
|
||||
if (!acc[codgrupo]) {
|
||||
acc[codgrupo] = {};
|
||||
}
|
||||
const entidade = item.entidades || "";
|
||||
if (!entidade) return acc;
|
||||
if (!acc[entidade]) {
|
||||
acc[entidade] = [];
|
||||
if (!acc[codgrupo][entidade]) {
|
||||
acc[codgrupo][entidade] = [];
|
||||
}
|
||||
acc[entidade].push(item);
|
||||
acc[codgrupo][entidade].push(item);
|
||||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
}, {} as Record<string, Record<string, DREItem[]>>);
|
||||
|
||||
// Ordenar entidades alfabeticamente
|
||||
const sortedEntidades = Object.entries(entidades).sort(([entA], [entB]) =>
|
||||
entA.localeCompare(entB)
|
||||
);
|
||||
// Ordenar por CODGRUPO (numericamente), depois por entidade (alfabeticamente)
|
||||
const sortedGrupos = Object.entries(gruposPorCodigo).sort(([codA], [codB]) => {
|
||||
// Ordenar numericamente por CODGRUPO
|
||||
const numA = parseInt(codA) || 0;
|
||||
const numB = parseInt(codB) || 0;
|
||||
if (numA !== numB) {
|
||||
return numA - numB;
|
||||
}
|
||||
// Se não for numérico, ordenar alfabeticamente
|
||||
return codA.localeCompare(codB);
|
||||
});
|
||||
|
||||
sortedEntidades.forEach(([entidade, items]) => {
|
||||
sortedGrupos.forEach(([codgrupo, entidades]) => {
|
||||
// Ordenar entidades dentro do grupo alfabeticamente
|
||||
const sortedEntidades = Object.entries(entidades).sort(([entA], [entB]) =>
|
||||
entA.localeCompare(entB)
|
||||
);
|
||||
|
||||
sortedEntidades.forEach(([entidade, items]) => {
|
||||
// Calcular total da entidade
|
||||
const totalEntidade = items.reduce(
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
|
|
@ -1675,44 +1712,44 @@ export default function Teste() {
|
|||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
|
||||
// Ordenar centros de custo por CODIGOCENTROCUSTO
|
||||
const sortedCentros = Object.entries(centros).sort(([centroA, itemsA], [centroB, itemsB]) => {
|
||||
const codigoA = itemsA[0]?.codigo_centro_custo || "";
|
||||
const codigoB = itemsB[0]?.codigo_centro_custo || "";
|
||||
|
||||
if (codigoA && codigoB) {
|
||||
return codigoA.localeCompare(codigoB);
|
||||
}
|
||||
|
||||
if (codigoA && !codigoB) return -1;
|
||||
if (!codigoA && codigoB) return 1;
|
||||
|
||||
return centroA.localeCompare(centroB);
|
||||
});
|
||||
// Ordenar centros de custo por CODIGOCENTROCUSTO
|
||||
const sortedCentros = Object.entries(centros).sort(([centroA, itemsA], [centroB, itemsB]) => {
|
||||
const codigoA = itemsA[0]?.codigo_centro_custo || "";
|
||||
const codigoB = itemsB[0]?.codigo_centro_custo || "";
|
||||
|
||||
if (codigoA && codigoB) {
|
||||
return codigoA.localeCompare(codigoB);
|
||||
}
|
||||
|
||||
if (codigoA && !codigoB) return -1;
|
||||
if (!codigoA && codigoB) return 1;
|
||||
|
||||
return centroA.localeCompare(centroB);
|
||||
});
|
||||
|
||||
sortedCentros.forEach(([centro, centroItems]) => {
|
||||
const totalCentro = centroItems.reduce(
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
0
|
||||
);
|
||||
sortedCentros.forEach(([centro, centroItems]) => {
|
||||
const totalCentro = centroItems.reduce(
|
||||
(sum, item) => sum + parseFloat(item.valor),
|
||||
0
|
||||
);
|
||||
const valoresCentroPorMes = calcularValoresPorMes(centroItems);
|
||||
|
||||
// Verificar se centro de custo contém faturamento líquido
|
||||
const temFaturamentoLiquidoCC = centroItems.some(item => item.codgrupo === "00");
|
||||
const codgrupoParaCalculoCC = temFaturamentoLiquidoCC ? "00" : "";
|
||||
|
||||
// Linha do centro de custo (Level 2)
|
||||
// Linha do centro de custo (Level 2)
|
||||
const chaveCentro = `${entidade}-${diretoIndireto}-${centro}`;
|
||||
rows.push({
|
||||
type: "centro_custo",
|
||||
level: 2,
|
||||
rows.push({
|
||||
type: "centro_custo",
|
||||
level: 2,
|
||||
entidade,
|
||||
direto_indireto: diretoIndireto,
|
||||
centro_custo: centro,
|
||||
codigo_centro_custo: centroItems[0].codigo_centro_custo,
|
||||
total: totalCentro,
|
||||
centro_custo: centro,
|
||||
codigo_centro_custo: centroItems[0].codigo_centro_custo,
|
||||
total: totalCentro,
|
||||
isExpanded: expandedCentros.has(chaveCentro),
|
||||
valoresPorMes: valoresCentroPorMes,
|
||||
valoresPorMes: valoresCentroPorMes,
|
||||
percentuaisPorMes: calcularPercentuaisPorMes(valoresCentroPorMes, codgrupoParaCalculoCC),
|
||||
percentualTotal: calcularPercentualTotal(totalCentro, codgrupoParaCalculoCC),
|
||||
});
|
||||
|
|
@ -1729,19 +1766,19 @@ export default function Teste() {
|
|||
return acc;
|
||||
}, {} as Record<string, DREItem[]>);
|
||||
|
||||
// Ordenar contas por CODCONTA
|
||||
const sortedContas = Object.entries(contas).sort(([contaA, itemsA], [contaB, itemsB]) => {
|
||||
const codcontaA = itemsA[0]?.codigo_conta || 0;
|
||||
const codcontaB = itemsB[0]?.codigo_conta || 0;
|
||||
|
||||
if (codcontaA && codcontaB) {
|
||||
return codcontaA - codcontaB;
|
||||
}
|
||||
|
||||
if (codcontaA && !codcontaB) return -1;
|
||||
if (!codcontaA && codcontaB) return 1;
|
||||
|
||||
return contaA.localeCompare(contaB);
|
||||
// Ordenar contas por CODCONTA
|
||||
const sortedContas = Object.entries(contas).sort(([contaA, itemsA], [contaB, itemsB]) => {
|
||||
const codcontaA = itemsA[0]?.codigo_conta || 0;
|
||||
const codcontaB = itemsB[0]?.codigo_conta || 0;
|
||||
|
||||
if (codcontaA && codcontaB) {
|
||||
return codcontaA - codcontaB;
|
||||
}
|
||||
|
||||
if (codcontaA && !codcontaB) return -1;
|
||||
if (!codcontaA && codcontaB) return 1;
|
||||
|
||||
return contaA.localeCompare(contaB);
|
||||
});
|
||||
|
||||
sortedContas.forEach(([conta, contaItems]) => {
|
||||
|
|
@ -1757,7 +1794,7 @@ export default function Teste() {
|
|||
|
||||
// Linha da conta (Level 3)
|
||||
rows.push({
|
||||
type: "conta",
|
||||
type: "conta",
|
||||
level: 3,
|
||||
entidade,
|
||||
direto_indireto: diretoIndireto,
|
||||
|
|
@ -1774,8 +1811,9 @@ export default function Teste() {
|
|||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
return rows;
|
||||
|
|
@ -1873,13 +1911,13 @@ export default function Teste() {
|
|||
<div className="flex items-center gap-2 whitespace-nowrap">
|
||||
<button
|
||||
onClick={() => toggleDiretoIndireto(`${row.entidade}-${row.direto_indireto}`)}
|
||||
className="p-2 hover:bg-blue-100 rounded-lg transition-all duration-150 ease-in-out flex items-center justify-center w-8 h-8 flex-shrink-0 transform hover:scale-105"
|
||||
>
|
||||
{row.isExpanded ? (
|
||||
<ChevronDown className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
) : (
|
||||
<ChevronRight className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
)}
|
||||
className="p-2 hover:bg-blue-100 rounded-lg transition-all duration-150 ease-in-out flex items-center justify-center w-8 h-8 flex-shrink-0 transform hover:scale-105"
|
||||
>
|
||||
{row.isExpanded ? (
|
||||
<ChevronDown className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
) : (
|
||||
<ChevronRight className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
)}
|
||||
</button>
|
||||
<button
|
||||
onClick={() => handleRowClick(row)}
|
||||
|
|
@ -1898,19 +1936,19 @@ export default function Teste() {
|
|||
<div className="flex items-center gap-2 whitespace-nowrap">
|
||||
<button
|
||||
onClick={() => toggleCentro(`${row.entidade}-${row.direto_indireto}-${row.centro_custo}`)}
|
||||
className="p-2 hover:bg-blue-100 rounded-lg transition-all duration-150 ease-in-out flex items-center justify-center w-8 h-8 flex-shrink-0 transform hover:scale-105"
|
||||
>
|
||||
{row.isExpanded ? (
|
||||
<ChevronDown className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
) : (
|
||||
<ChevronRight className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
)}
|
||||
className="p-2 hover:bg-blue-100 rounded-lg transition-all duration-150 ease-in-out flex items-center justify-center w-8 h-8 flex-shrink-0 transform hover:scale-105"
|
||||
>
|
||||
{row.isExpanded ? (
|
||||
<ChevronDown className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
) : (
|
||||
<ChevronRight className="w-4 h-4 text-blue-600 transition-transform duration-150" />
|
||||
)}
|
||||
</button>
|
||||
<button
|
||||
onClick={() => handleRowClick(row)}
|
||||
className="flex-1 text-left hover:bg-blue-50/50 p-2 rounded-lg cursor-pointer transition-all duration-200 truncate"
|
||||
>
|
||||
<div className="flex items-center gap-2">
|
||||
<div className="flex items-center gap-2">
|
||||
<span className="font-medium text-gray-700">
|
||||
{row.codigo_centro_custo
|
||||
? `${row.centro_custo} - ${row.codigo_centro_custo}`
|
||||
|
|
|
|||
Loading…
Reference in New Issue