Browse Source

Fixes #1819 - Verifica se data de designação superior a data de desligamento (#1821)

pull/1822/head
Edward 7 years ago
committed by Edward Ribeiro
parent
commit
bc10c637d5
  1. 39
      sapl/comissoes/forms.py

39
sapl/comissoes/forms.py

@ -65,8 +65,9 @@ class ParticipacaoCreateForm(forms.ModelForm):
parlamentares = Mandato.objects.filter(qs, parlamentares = Mandato.objects.filter(qs,
parlamentar__ativo=True parlamentar__ativo=True
).prefetch_related('parlamentar').\ ).prefetch_related('parlamentar').\
values_list('parlamentar', values_list('parlamentar',
flat=True).distinct() flat=True
).distinct()
qs = Parlamentar.objects.filter(id__in=parlamentares).distinct().\ qs = Parlamentar.objects.filter(id__in=parlamentares).distinct().\
exclude(id__in=id_part) exclude(id__in=id_part)
@ -86,12 +87,21 @@ class ParticipacaoCreateForm(forms.ModelForm):
if not self.is_valid(): if not self.is_valid():
return cleaned_data return cleaned_data
data_designacao = cleaned_data['data_designacao']
data_desligamento = cleaned_data['data_desligamento']
if data_desligamento and \
data_designacao > data_desligamento:
raise ValidationError(_('Data de designação não pode ser superior '
'à data de desligamento'))
composicao = Composicao.objects.get(id=self.initial['parent_pk']) composicao = Composicao.objects.get(id=self.initial['parent_pk'])
cargos_unicos = [c.cargo.nome for c in composicao.participacao_set.filter(cargo__unico=True)] cargos_unicos = [c.cargo.nome for c in composicao.participacao_set.filter(cargo__unico=True)]
if cleaned_data['cargo'].nome in cargos_unicos: if cleaned_data['cargo'].nome in cargos_unicos:
msg = _('Este cargo é único para esta Comissão.') msg = _('Este cargo é único para esta Comissão.')
raise ValidationError(msg) raise ValidationError(msg)
return cleaned_data
def create_participacao(self): def create_participacao(self):
@ -154,6 +164,31 @@ class ParticipacaoEditForm(forms.ModelForm):
id=self.initial['parlamentar']).nome_parlamentar id=self.initial['parlamentar']).nome_parlamentar
self.fields['nome_parlamentar'].widget.attrs['disabled'] = 'disabled' self.fields['nome_parlamentar'].widget.attrs['disabled'] = 'disabled'
def clean(self):
cleaned_data = super(ParticipacaoEditForm, self).clean()
if not self.is_valid():
return cleaned_data
data_designacao = cleaned_data['data_designacao']
data_desligamento = cleaned_data['data_desligamento']
if data_desligamento and \
data_designacao > data_desligamento:
raise ValidationError(_('Data de designação não pode ser superior '
'à data de desligamento'))
composicao_id = self.instance.composicao_id
composicao = Composicao.objects.get(id=composicao_id)
cargos_unicos = [c.cargo.nome for c in composicao.participacao_set.filter(cargo__unico=True)]
if cleaned_data['cargo'].nome in cargos_unicos:
msg = _('Este cargo é único para esta Comissão.')
raise ValidationError(msg)
return cleaned_data
class ComissaoForm(forms.ModelForm): class ComissaoForm(forms.ModelForm):

Loading…
Cancel
Save