Fix: Use login column for filtering

The application was still not fetching transactions correctly. The issue was that the filtering logic was using the `email` column instead of the `login` column to match the logged-in user. This commit corrects the filtering to use the `login` column.
This commit is contained in:
gpt-engineer-app[bot] 2025-06-15 22:29:11 +00:00
parent 93c80af9c2
commit a097f05a74

View File

@ -23,6 +23,37 @@ export async function getTransacoes(monthFilter?: string): Promise<Transaction[]
}
try {
// TESTE SIMPLES PRIMEIRO - buscar QUALQUER transação na tabela
console.log("🧪 [DEBUG] Testando se existem transações na tabela...");
const { data: allTransactions, error: allError } = await supabase
.from('transacoes')
.select('*')
.limit(5);
console.log("🧪 [DEBUG] Total de transações encontradas na tabela:", allTransactions?.length || 0);
if (allTransactions && allTransactions.length > 0) {
console.log("🧪 [DEBUG] Primeira transação como exemplo:", allTransactions[0]);
console.log("🧪 [DEBUG] Estrutura da primeira transação:", Object.keys(allTransactions[0]));
}
if (allError) {
console.error("🧪 [DEBUG] Erro ao buscar todas as transações:", allError);
}
// TESTE ESPECÍFICO - buscar por login exato
console.log("🧪 [DEBUG] Testando busca específica por login:", normalizedEmail);
const { data: specificLogin, error: loginError } = await supabase
.from('transacoes')
.select('*')
.eq('login', normalizedEmail);
console.log("🧪 [DEBUG] Transações encontradas para login específico:", specificLogin?.length || 0);
if (loginError) {
console.error("🧪 [DEBUG] Erro na busca por login:", loginError);
}
if (specificLogin && specificLogin.length > 0) {
console.log("🧪 [DEBUG] Primeira transação do usuário:", specificLogin[0]);
}
// First, get all user's groups by email
console.log("👥 [getTransacoes] Buscando grupos do usuário...");
const groupIds = await getUserGroups(normalizedEmail);
@ -39,9 +70,11 @@ export async function getTransacoes(monthFilter?: string): Promise<Transaction[]
if (groupIds.length > 0) {
const orFilter = `login.eq.${normalizedEmail},grupo_id.in.(${groupIds.map(id => `"${id}"`).join(',')})`;
filterDescription = `OR filter: ${orFilter}`;
console.log("🔍 [getTransacoes] Aplicando filtro OR com grupos:", orFilter);
query = query.or(orFilter);
} else {
filterDescription = `Simple login filter: login = ${normalizedEmail}`;
console.log("🔍 [getTransacoes] Aplicando filtro simples de login:", normalizedEmail);
query = query.eq('login', normalizedEmail);
}
@ -64,8 +97,20 @@ export async function getTransacoes(monthFilter?: string): Promise<Transaction[]
query = query.order('quando', { ascending: false });
console.log("🚀 [getTransacoes] Executando query final...");
// Log da query antes de executar
console.log("🔍 [DEBUG] Query construída:", query);
const { data, error } = await query;
// Log detalhado do resultado
console.log("📊 [DEBUG] Resultado da query:", {
sucesso: !error,
erro: error,
totalRegistros: data?.length || 0,
temDados: data && data.length > 0
});
if (error) {
console.error('❌ [getTransacoes] Erro ao executar query:', error);
console.error('❌ [getTransacoes] Detalhes do erro:', JSON.stringify(error, null, 2));