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.
99 lines
2.5 KiB
SQL
99 lines
2.5 KiB
SQL
-- name: CreateCadastroFot :one
|
|
INSERT INTO cadastro_fot (
|
|
fot, empresa_id, curso_id, ano_formatura_id, instituicao, cidade, estado, observacoes, gastos_captacao, pre_venda
|
|
) VALUES (
|
|
$1, $2, $3, $4, $5, $6, $7, $8, $9, $10
|
|
) RETURNING *;
|
|
|
|
-- name: ListCadastroFot :many
|
|
SELECT
|
|
c.*,
|
|
e.nome as empresa_nome,
|
|
cur.nome as curso_nome,
|
|
a.ano_semestre as ano_formatura_label
|
|
FROM cadastro_fot c
|
|
JOIN empresas e ON c.empresa_id = e.id
|
|
JOIN cursos cur ON c.curso_id = cur.id
|
|
JOIN anos_formaturas a ON c.ano_formatura_id = a.id
|
|
ORDER BY c.fot DESC;
|
|
|
|
-- name: ListCadastroFotByEmpresa :many
|
|
SELECT
|
|
c.*,
|
|
e.nome as empresa_nome,
|
|
cur.nome as curso_nome,
|
|
a.ano_semestre as ano_formatura_label
|
|
FROM cadastro_fot c
|
|
JOIN empresas e ON c.empresa_id = e.id
|
|
JOIN cursos cur ON c.curso_id = cur.id
|
|
JOIN anos_formaturas a ON c.ano_formatura_id = a.id
|
|
WHERE c.empresa_id = $1
|
|
ORDER BY c.fot DESC;
|
|
|
|
-- name: GetCadastroFotByID :one
|
|
SELECT
|
|
c.*,
|
|
e.nome as empresa_nome,
|
|
cur.nome as curso_nome,
|
|
a.ano_semestre as ano_formatura_label
|
|
FROM cadastro_fot c
|
|
JOIN empresas e ON c.empresa_id = e.id
|
|
JOIN cursos cur ON c.curso_id = cur.id
|
|
JOIN anos_formaturas a ON c.ano_formatura_id = a.id
|
|
WHERE c.id = $1;
|
|
|
|
-- name: GetCadastroFotByFOT :one
|
|
SELECT * FROM cadastro_fot WHERE fot = $1;
|
|
|
|
-- name: UpdateCadastroFot :one
|
|
UPDATE cadastro_fot SET
|
|
fot = $2,
|
|
empresa_id = $3,
|
|
curso_id = $4,
|
|
ano_formatura_id = $5,
|
|
instituicao = $6,
|
|
cidade = $7,
|
|
estado = $8,
|
|
observacoes = $9,
|
|
gastos_captacao = $10,
|
|
pre_venda = $11,
|
|
updated_at = CURRENT_TIMESTAMP
|
|
WHERE id = $1
|
|
RETURNING *;
|
|
|
|
-- name: DeleteCadastroFot :exec
|
|
DELETE FROM cadastro_fot WHERE id = $1;
|
|
|
|
-- name: GetCadastroFotByFotJoin :one
|
|
SELECT
|
|
c.*,
|
|
e.nome as empresa_nome,
|
|
cur.nome as curso_nome,
|
|
a.ano_semestre as ano_formatura_label
|
|
FROM cadastro_fot c
|
|
JOIN empresas e ON c.empresa_id = e.id
|
|
JOIN cursos cur ON c.curso_id = cur.id
|
|
JOIN anos_formaturas a ON c.ano_formatura_id = a.id
|
|
WHERE c.fot = $1;
|
|
|
|
-- name: UpdateCadastroFotGastos :exec
|
|
UPDATE cadastro_fot SET
|
|
gastos_captacao = $2,
|
|
updated_at = CURRENT_TIMESTAMP
|
|
WHERE id = $1;
|
|
|
|
-- name: SearchFot :many
|
|
SELECT
|
|
c.*,
|
|
e.nome as empresa_nome,
|
|
cur.nome as curso_nome,
|
|
a.ano_semestre as ano_formatura_label
|
|
FROM cadastro_fot c
|
|
JOIN empresas e ON c.empresa_id = e.id
|
|
JOIN cursos cur ON c.curso_id = cur.id
|
|
JOIN anos_formaturas a ON c.ano_formatura_id = a.id
|
|
WHERE CAST(c.fot AS TEXT) ILIKE '%' || $1 || '%'
|
|
ORDER BY c.fot ASC
|
|
LIMIT 10;
|
|
|
|
|