|
@ -10,6 +10,7 @@ from django.contrib.auth.forms import (AuthenticationForm, PasswordResetForm, |
|
|
from django.contrib.auth.models import Group, User |
|
|
from django.contrib.auth.models import Group, User |
|
|
from django.core.exceptions import ValidationError |
|
|
from django.core.exceptions import ValidationError |
|
|
from django.db import models, transaction |
|
|
from django.db import models, transaction |
|
|
|
|
|
from django.db.models import Q |
|
|
from django.forms import Form, ModelForm |
|
|
from django.forms import Form, ModelForm |
|
|
from django.utils.translation import ugettext_lazy as _ |
|
|
from django.utils.translation import ugettext_lazy as _ |
|
|
from django.utils.translation import string_concat |
|
|
from django.utils.translation import string_concat |
|
@ -170,6 +171,52 @@ class SessaoLegislativaForm(ModelForm): |
|
|
|
|
|
|
|
|
data_inicio = cleaned_data['data_inicio'] |
|
|
data_inicio = cleaned_data['data_inicio'] |
|
|
data_fim = cleaned_data['data_fim'] |
|
|
data_fim = cleaned_data['data_fim'] |
|
|
|
|
|
legislatura = cleaned_data['legislatura'] |
|
|
|
|
|
numero = cleaned_data['numero'] |
|
|
|
|
|
data_inicio_leg = legislatura.data_inicio |
|
|
|
|
|
data_fim_leg = legislatura.data_fim |
|
|
|
|
|
pk = self.initial['id'] |
|
|
|
|
|
|
|
|
|
|
|
# Querys para verificar se existem Sessões Legislativas no período selecionado no form |
|
|
|
|
|
# Caso onde a data_inicio e data_fim são iguais a de alguma sessão já criada |
|
|
|
|
|
primeiro_caso = Q(data_inicio=data_inicio, data_fim=data_fim) |
|
|
|
|
|
# Caso onde a data_inicio está entre o início e o fim de uma Sessão já existente |
|
|
|
|
|
segundo_caso = Q(data_inicio__lt=data_inicio, data_fim__range=(data_inicio, data_fim)) |
|
|
|
|
|
# Caso onde a data_fim está entre o início e o fim de uma Sessão já existente |
|
|
|
|
|
terceiro_caso = Q(data_inicio__range=(data_inicio, data_fim), data_fim__gt=data_fim) |
|
|
|
|
|
sessoes_existentes = SessaoLegislativa.objects.filter(primeiro_caso|segundo_caso|terceiro_caso).\ |
|
|
|
|
|
exclude(pk=pk) |
|
|
|
|
|
|
|
|
|
|
|
if sessoes_existentes: |
|
|
|
|
|
raise ValidationError('Já existe registrado uma Sessão Legislativa que coincide com a data ' |
|
|
|
|
|
'inserida, favor verificar as Sessões existentes antes de criar uma ' |
|
|
|
|
|
'nova Sessão Legislativa') |
|
|
|
|
|
|
|
|
|
|
|
sessoes_legislativas = SessaoLegislativa.objects.filter(legislatura=legislatura).exclude(pk=pk) |
|
|
|
|
|
|
|
|
|
|
|
if sessoes_legislativas: |
|
|
|
|
|
numeracoes = [n.numero for n in sessoes_legislativas] |
|
|
|
|
|
numeracoes = sorted(numeracoes) |
|
|
|
|
|
ult = max(numeracoes) |
|
|
|
|
|
|
|
|
|
|
|
else: |
|
|
|
|
|
ult = SessaoLegislativa.objects.latest('data_fim') |
|
|
|
|
|
ult = ult.numero |
|
|
|
|
|
|
|
|
|
|
|
if numero <= ult: |
|
|
|
|
|
raise ValidationError('O número da Sessão Legislativa não pode ser menor ou igual ' |
|
|
|
|
|
'que o de Sessões Legislativas passadas') |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if data_inicio < data_inicio_leg or \ |
|
|
|
|
|
data_inicio > data_fim_leg: |
|
|
|
|
|
raise ValidationError('A data de início da Sessão Legislativa deve estar compreendida ' |
|
|
|
|
|
'entre a data início e fim da Legislatura selecionada') |
|
|
|
|
|
|
|
|
|
|
|
if data_fim > data_fim_leg or \ |
|
|
|
|
|
data_fim < data_inicio_leg: |
|
|
|
|
|
raise ValidationError('A data de fim da Sessão Legislativa deve estar compreendida ' |
|
|
|
|
|
'entre a data início e fim da Legislatura selecionada') |
|
|
|
|
|
|
|
|
if data_inicio > data_fim: |
|
|
if data_inicio > data_fim: |
|
|
raise ValidationError('Data início não pode ser superior à data fim') |
|
|
raise ValidationError('Data início não pode ser superior à data fim') |
|
@ -182,6 +229,23 @@ class SessaoLegislativaForm(ModelForm): |
|
|
raise ValidationError('Data início de intervalo não pode ser ' |
|
|
raise ValidationError('Data início de intervalo não pode ser ' |
|
|
'superior à data fim de intervalo') |
|
|
'superior à data fim de intervalo') |
|
|
|
|
|
|
|
|
|
|
|
if data_inicio_intervalo: |
|
|
|
|
|
if data_inicio_intervalo < data_inicio or \ |
|
|
|
|
|
data_inicio_intervalo < data_inicio_leg or \ |
|
|
|
|
|
data_inicio_intervalo > data_fim or \ |
|
|
|
|
|
data_inicio_intervalo > data_inicio_leg: |
|
|
|
|
|
raise ValidationError('A data de início do intervalo deve estar compreendida entre ' |
|
|
|
|
|
'as datas de início e fim tanto da Legislatura quanto da ' |
|
|
|
|
|
'própria Sessão Legislativa') |
|
|
|
|
|
|
|
|
|
|
|
if data_fim_intervalo: |
|
|
|
|
|
if data_fim_intervalo > data_fim or \ |
|
|
|
|
|
data_fim_intervalo > data_fim_leg or \ |
|
|
|
|
|
data_fim_intervalo < data_inicio or \ |
|
|
|
|
|
data_fim_intervalo < data_inicio_leg: |
|
|
|
|
|
raise ValidationError('A data de fim do intervalo deve estar compreendida entre ' |
|
|
|
|
|
'as datas de início e fim tanto da Legislatura quanto da ' |
|
|
|
|
|
'própria Sessão Legislativa') |
|
|
return cleaned_data |
|
|
return cleaned_data |
|
|
|
|
|
|
|
|
|
|
|
|
|
|