Este commit introduz o módulo financeiro completo e refatora o sistema de profissionais para suportar múltiplas funções, corrigindo a contabilização e validação de equipes. Principais alterações: - **Módulo Financeiro:** - Criação da tabela `financial_transactions` e queries associadas. - Implementação do backend (Handler/Service) para gerenciar transações. - Nova página [Finance.tsx](cci:7://file:///c:/Projetos/photum/frontend/pages/Finance.tsx:0:0-0:0) com listagem, edição, filtros avançados e agrupamento por FOT. - Correção na busca de FOTs e formatação de datas. - **Gestão de Equipe e Profissionais:** - Refatoração para suportar múltiplas funções por profissional (Backend & Frontend). - Atualização do [Dashboard](cci:1://file:///c:/Projetos/photum/frontend/pages/Dashboard.tsx:31:0-1663:2) e [EventTable](cci:1://file:///c:/Projetos/photum/frontend/components/EventTable.tsx:28:0-659:2) para contabilizar corretamente profissionais (Fotografo, Cinegrafista, Recepcionista) verificando a lista de funções. - Implementação de validação de cota no aceite de convites (bloqueia se a equipe da função específica já estiver completa). - Ajuste visual nos indicadores de "Equipe Completa" e contadores de faltantes na listagem de eventos. - **Geral:** - Atualização da documentação Swagger. - Ajustes de tipagem e migrações de banco de dados.
41 lines
1.3 KiB
SQL
41 lines
1.3 KiB
SQL
-- name: CreateTransaction :one
|
|
INSERT INTO financial_transactions (
|
|
fot_id, data_cobranca, tipo_evento, tipo_servico, professional_name,
|
|
whatsapp, cpf, tabela_free, valor_free, valor_extra, descricao_extra,
|
|
total_pagar, data_pagamento, pgto_ok
|
|
) VALUES (
|
|
$1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14
|
|
) RETURNING *;
|
|
|
|
-- name: ListTransactionsByFot :many
|
|
SELECT * FROM financial_transactions
|
|
WHERE fot_id = $1
|
|
ORDER BY data_cobranca DESC;
|
|
|
|
-- name: ListTransactions :many
|
|
SELECT t.*, f.fot as fot_numero
|
|
FROM financial_transactions t
|
|
LEFT JOIN cadastro_fot f ON t.fot_id = f.id
|
|
ORDER BY t.data_cobranca DESC;
|
|
|
|
-- name: SumTotalByFot :one
|
|
SELECT COALESCE(SUM(total_pagar), 0)::NUMERIC
|
|
FROM financial_transactions
|
|
WHERE fot_id = $1;
|
|
|
|
-- name: UpdateTransaction :one
|
|
UPDATE financial_transactions SET
|
|
fot_id = $2, data_cobranca = $3, tipo_evento = $4, tipo_servico = $5,
|
|
professional_name = $6, whatsapp = $7, cpf = $8, tabela_free = $9,
|
|
valor_free = $10, valor_extra = $11, descricao_extra = $12,
|
|
total_pagar = $13, data_pagamento = $14, pgto_ok = $15,
|
|
atualizado_em = NOW()
|
|
WHERE id = $1
|
|
RETURNING *;
|
|
|
|
-- name: DeleteTransaction :exec
|
|
DELETE FROM financial_transactions WHERE id = $1;
|
|
|
|
-- name: GetTransaction :one
|
|
SELECT * FROM financial_transactions WHERE id = $1;
|
|
|