forked from git.gladyson/openmonetis
Adiciona sistema completo de preferências de usuário: - Cria tabela userPreferences no schema com campos disableMagnetlines, periodMonthsBefore e periodMonthsAfter - Implementa página de Ajustes com abas (Preferências, Alterar nome, Senha, E-mail, Deletar conta) - Adiciona componente PreferencesForm para configuração de magnetlines e períodos de exibição - Propaga periodPreferences para todos os componentes de lançamentos e calendário Refatora sistema de changelog: - Remove implementação anterior baseada em JSON estático - Adiciona nova página de changelog dinâmica em app/(dashboard)/changelog - Adiciona componente changelog-list.tsx - Remove arquivos obsoletos (changelog-notification, actions, data, utils, scripts) Adiciona controle de saldo inicial em contas: - Novo campo excludeInitialBalanceFromIncome em contas - Permite excluir saldo inicial do cálculo de receitas - Atualiza queries de lançamentos para respeitar esta configuração Melhorias adicionais: - Adiciona componente ui/accordion.tsx do shadcn/ui - Refatora formatPeriodLabel para displayPeriod centralizado - Propaga estabelecimentos para componentes de lançamentos - Remove variável DB_PROVIDER obsoleta do .env.example e documentação - Adiciona 6 migrações de banco de dados (0003-0008)
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
import { lancamentos, contas, pagadores, cartoes, categorias } from "@/db/schema";
|
|
import { INITIAL_BALANCE_NOTE } from "@/lib/accounts/constants";
|
|
import { db } from "@/lib/db";
|
|
import { and, desc, eq, isNull, ne, or, type SQL } from "drizzle-orm";
|
|
|
|
export async function fetchLancamentos(filters: SQL[]) {
|
|
const lancamentoRows = await db
|
|
.select({
|
|
lancamento: lancamentos,
|
|
pagador: pagadores,
|
|
conta: contas,
|
|
cartao: cartoes,
|
|
categoria: categorias,
|
|
})
|
|
.from(lancamentos)
|
|
.leftJoin(pagadores, eq(lancamentos.pagadorId, pagadores.id))
|
|
.leftJoin(contas, eq(lancamentos.contaId, contas.id))
|
|
.leftJoin(cartoes, eq(lancamentos.cartaoId, cartoes.id))
|
|
.leftJoin(categorias, eq(lancamentos.categoriaId, categorias.id))
|
|
.where(
|
|
and(
|
|
...filters,
|
|
// Excluir saldos iniciais de contas que têm excludeInitialBalanceFromIncome = true
|
|
or(
|
|
ne(lancamentos.note, INITIAL_BALANCE_NOTE),
|
|
isNull(contas.excludeInitialBalanceFromIncome),
|
|
eq(contas.excludeInitialBalanceFromIncome, false)
|
|
)
|
|
)
|
|
)
|
|
.orderBy(desc(lancamentos.purchaseDate), desc(lancamentos.createdAt));
|
|
|
|
// Transformar resultado para o formato esperado
|
|
return lancamentoRows.map((row) => ({
|
|
...row.lancamento,
|
|
pagador: row.pagador,
|
|
conta: row.conta,
|
|
cartao: row.cartao,
|
|
categoria: row.categoria,
|
|
}));
|
|
}
|