|
@ -14,7 +14,7 @@ from sapl.base.models import Autor, TipoAutor |
|
|
from sapl.crispy_layout_mixin import form_actions, SaplFormHelper, to_row |
|
|
from sapl.crispy_layout_mixin import form_actions, SaplFormHelper, to_row |
|
|
from sapl.materia.forms import choice_anos_com_materias |
|
|
from sapl.materia.forms import choice_anos_com_materias |
|
|
from sapl.materia.models import (MateriaLegislativa, |
|
|
from sapl.materia.models import (MateriaLegislativa, |
|
|
TipoMateriaLegislativa) |
|
|
TipoMateriaLegislativa, Orgao) |
|
|
from sapl.utils import (ANO_CHOICES, choice_anos_com_normas, |
|
|
from sapl.utils import (ANO_CHOICES, choice_anos_com_normas, |
|
|
FileFieldCheckMixin, FilterOverridesMetaMixin, |
|
|
FileFieldCheckMixin, FilterOverridesMetaMixin, |
|
|
NormaPesquisaOrderingFilter, RangeWidgetOverride, |
|
|
NormaPesquisaOrderingFilter, RangeWidgetOverride, |
|
@ -338,6 +338,12 @@ class AnexoNormaJuridicaForm(FileFieldCheckMixin, ModelForm): |
|
|
|
|
|
|
|
|
class NormaRelacionadaForm(ModelForm): |
|
|
class NormaRelacionadaForm(ModelForm): |
|
|
|
|
|
|
|
|
|
|
|
orgao = forms.ModelChoiceField( |
|
|
|
|
|
label='Órgão', |
|
|
|
|
|
required=False, |
|
|
|
|
|
queryset=Orgao.objects.all(), |
|
|
|
|
|
empty_label='----------', |
|
|
|
|
|
) |
|
|
tipo = forms.ModelChoiceField( |
|
|
tipo = forms.ModelChoiceField( |
|
|
label='Tipo', |
|
|
label='Tipo', |
|
|
required=True, |
|
|
required=True, |
|
@ -354,7 +360,7 @@ class NormaRelacionadaForm(ModelForm): |
|
|
|
|
|
|
|
|
class Meta: |
|
|
class Meta: |
|
|
model = NormaRelacionada |
|
|
model = NormaRelacionada |
|
|
fields = ['tipo', 'numero', 'ano', 'ementa', 'tipo_vinculo'] |
|
|
fields = ['orgao', 'tipo', 'numero', 'ano', 'ementa', 'tipo_vinculo'] |
|
|
|
|
|
|
|
|
def __init__(self, *args, **kwargs): |
|
|
def __init__(self, *args, **kwargs): |
|
|
super(NormaRelacionadaForm, self).__init__(*args, **kwargs) |
|
|
super(NormaRelacionadaForm, self).__init__(*args, **kwargs) |
|
@ -367,20 +373,21 @@ class NormaRelacionadaForm(ModelForm): |
|
|
cleaned_data = self.cleaned_data |
|
|
cleaned_data = self.cleaned_data |
|
|
|
|
|
|
|
|
try: |
|
|
try: |
|
|
self.logger.debug("Tentando obter objeto NormaJuridica com numero={}, ano={}, tipo={}.".format( |
|
|
self.logger.debug("Tentando obter objeto NormaJuridica com numero={}, ano={}, tipo={}, orgao={}.".format( |
|
|
cleaned_data['numero'], cleaned_data['ano'], cleaned_data['tipo'])) |
|
|
cleaned_data['numero'], cleaned_data['ano'], cleaned_data['tipo'], cleaned_data['orgao'])) |
|
|
norma_relacionada = NormaJuridica.objects.get( |
|
|
norma_relacionada = NormaJuridica.objects.get( |
|
|
numero=cleaned_data['numero'], |
|
|
numero=cleaned_data['numero'], |
|
|
ano=cleaned_data['ano'], |
|
|
ano=cleaned_data['ano'], |
|
|
tipo=cleaned_data['tipo']) |
|
|
tipo=cleaned_data['tipo'], |
|
|
|
|
|
orgao=cleaned_data['orgao']) |
|
|
except ObjectDoesNotExist: |
|
|
except ObjectDoesNotExist: |
|
|
self.logger.info("NormaJuridica com numero={}, ano={}, tipo={} não existe.".format( |
|
|
self.logger.info("NormaJuridica com numero={}, ano={}, tipo={}, orgao={} não existe.".format( |
|
|
cleaned_data['numero'], cleaned_data['ano'], cleaned_data['tipo'])) |
|
|
cleaned_data['numero'], cleaned_data['ano'], cleaned_data['tipo'], cleaned_data['orgao'])) |
|
|
msg = _('A norma a ser relacionada não existe.') |
|
|
msg = _('A norma a ser relacionada não existe.') |
|
|
raise ValidationError(msg) |
|
|
raise ValidationError(msg) |
|
|
else: |
|
|
else: |
|
|
self.logger.info("NormaJuridica com numero={}, ano={}, tipo={} obtida com sucesso.".format( |
|
|
self.logger.info("NormaJuridica com numero={}, ano={}, tipo={} , orgao={} obtida com sucesso.".format( |
|
|
cleaned_data['numero'], cleaned_data['ano'], cleaned_data['tipo'])) |
|
|
cleaned_data['numero'], cleaned_data['ano'], cleaned_data['tipo'], cleaned_data['orgao'])) |
|
|
cleaned_data['norma_relacionada'] = norma_relacionada |
|
|
cleaned_data['norma_relacionada'] = norma_relacionada |
|
|
|
|
|
|
|
|
return cleaned_data |
|
|
return cleaned_data |
|
|