From 591cf4b44bd2f68584dc94426a2ef8b77fc3fc25 Mon Sep 17 00:00:00 2001 From: Cesar Augusto de Carvalho Date: Wed, 3 Jul 2019 13:39:01 -0300 Subject: [PATCH] =?UTF-8?q?Retira=20trava=20de=20ano=20e=20data=20de=20apr?= =?UTF-8?q?esenta=C3=A7=C3=A3o=20diferentes=20em=20Norma=20e=20Mat=C3=A9ri?= =?UTF-8?q?a=20(#2870)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Retira trava de ano e apresentacao diferentes em Norma e Materia * Adicina modal de aviso quando anos são diferentes --- sapl/materia/forms.py | 26 ---- sapl/norma/forms.py | 8 -- .../materia/materialegislativa_form.html | 114 ++++++++++++------ sapl/templates/norma/normajuridica_form.html | 48 ++++++++ 4 files changed, 128 insertions(+), 68 deletions(-) diff --git a/sapl/materia/forms.py b/sapl/materia/forms.py index ca4dc8c67..417352b1d 100644 --- a/sapl/materia/forms.py +++ b/sapl/materia/forms.py @@ -156,25 +156,6 @@ class MateriaSimplificadaForm(FileFieldCheckMixin, ModelForm): ) super(MateriaSimplificadaForm, self).__init__(*args, **kwargs) - def clean(self): - super(MateriaSimplificadaForm, self).clean() - - if not self.is_valid(): - return self.cleaned_data - - cleaned_data = self.cleaned_data - - data_apresentacao = cleaned_data['data_apresentacao'] - ano = cleaned_data['ano'] - - if data_apresentacao.year != ano: - self.logger.error("O ano da matéria ({}) é diferente" - " do ano na data de apresentação ({}).".format(ano, data_apresentacao.year)) - raise ValidationError("O ano da matéria não pode ser " - "diferente do ano na data de apresentação") - - return cleaned_data - class MateriaLegislativaForm(FileFieldCheckMixin, ModelForm): @@ -256,13 +237,6 @@ class MateriaLegislativaForm(FileFieldCheckMixin, ModelForm): raise ValidationError( _('Tipo do Protocolo deve ser o mesmo do Tipo Matéria')) - if data_apresentacao.year != ano: - self.logger.error("O ano da matéria ({}) é diferente " - "do ano na data de apresentação ({})." - .format(ano, data_apresentacao.year)) - raise ValidationError(_("O ano da matéria não pode ser " - "diferente do ano na data de apresentação")) - ano_origem_externa = cleaned_data['ano_origem_externa'] data_origem_externa = cleaned_data['data_origem_externa'] diff --git a/sapl/norma/forms.py b/sapl/norma/forms.py index 366b7d544..c01688611 100644 --- a/sapl/norma/forms.py +++ b/sapl/norma/forms.py @@ -189,14 +189,6 @@ class NormaJuridicaForm(FileFieldCheckMixin, ModelForm): else: cleaned_data['materia'] = None - ano = cleaned_data['ano'] - data = cleaned_data['data'] - - if data.year != ano: - self.logger.error("O ano da norma ({}) é diferente " - "do ano no campo data ({}).".format(ano, data.year)) - raise ValidationError("O ano da norma não pode ser " - "diferente do ano no campo data") return cleaned_data def clean_texto_integral(self): diff --git a/sapl/templates/materia/materialegislativa_form.html b/sapl/templates/materia/materialegislativa_form.html index bb435be91..24e322400 100644 --- a/sapl/templates/materia/materialegislativa_form.html +++ b/sapl/templates/materia/materialegislativa_form.html @@ -24,42 +24,88 @@ $("#id_tipo, #id_ano").change(recuperar_numero_ano); function compare(a, b) { - if (a.text < b.text) - return -1; - if (a.text > b.text) - return 1; - return 0; - } + if (a.text < b.text) + return -1; + if (a.text > b.text) + return 1; + return 0; + } + + var modal_estilos = 'display: block;' + +'width: 85%; max-width: 600px;' + +'background: #fff; padding: 15px;' + +'border-radius: 5px;' + +'-webkit-box-shadow: 0px 6px 14px -2px rgba(0,0,0,0.75);' + +'-moz-box-shadow: 0px 6px 14px -2px rgba(0,0,0,0.75);' + +'box-shadow: 0px 6px 14px -2px rgba(0,0,0,0.75);' + +'position: fixed;' + +'top: 50%; left: 50%;' + +'transform: translate(-50%,-50%);' + +'z-index: 99999999; text-align: center'; + + var fundo_modal_estilos = 'top: 0; right: 0;' + +'bottom: 0; left: 0; position: fixed;' + +'background-color: rgba(0, 0, 0, 0.6); z-index: 99999999;' + +'display: none;'; + + var meu_modal = '
' + +'
' + +'

Atenção! Ano de apresentação e ano da matéria são diferentes.


' + +'' + +'
'; + + function verifica_ano(){ + let ano = $("select#id_ano.select").val(); + let data_apresentacao = $("input#id_data_apresentacao.dateinput").val(); + let ano_apresentacao = data_apresentacao.substr(data_apresentacao.length - 4); + + if(ano && ano_apresentacao && ano_apresentacao != ano){ + $('#fundo_modal').fadeIn(); + } + } - $(document).ready(function() { - $("#id_tipo_autor").change(function() { - var tipo_selecionado = $("#id_tipo_autor").val(); - var autor_selecionado = $("#id_autor").val(); - $("#id_autor option").remove() - if (tipo_selecionado !== undefined && tipo_selecionado !== null) { - var json_data = { - tipo : tipo_selecionado, - data_relativa : $("#id_data_apresentacao").val() - } - $.getJSON("/api/autor/possiveis", json_data, function(data){ - if (data) { - var results = data.sort(compare); - if (results.length > 1) { - $("#id_autor").append(""); - } - $.each(results, function(idx, obj) { - $("#id_autor") - .append($("") - .attr("value", obj.value) - .text(obj.text)); - }); - $("#id_autor").val(autor_selecionado); - } - }); + $(document).ready(function() { + $("#id_tipo_autor").change(function() { + var tipo_selecionado = $("#id_tipo_autor").val(); + var autor_selecionado = $("#id_autor").val(); + $("#id_autor option").remove() + if (tipo_selecionado !== undefined && tipo_selecionado !== null) { + var json_data = { + tipo : tipo_selecionado, + data_relativa : $("#id_data_apresentacao").val() + } + $.getJSON("/api/autor/possiveis", json_data, function(data){ + if (data) { + var results = data.sort(compare); + if (results.length > 1) { + $("#id_autor").append(""); } - }); - $("#id_tipo_autor").trigger('change'); - }); + $.each(results, function(idx, obj) { + $("#id_autor") + .append($("") + .attr("value", obj.value) + .text(obj.text)); + }); + $("#id_autor").val(autor_selecionado); + } + }); + } + }); + $("#id_tipo_autor").trigger('change'); + + $("body").append(meu_modal); + + $("#fundo_modal, #close_model_btn").click(function(){ $("#fundo_modal").hide(); }); + $("#meu_modal").click(function(e){ e.stopPropagation(); }); + + $("select#id_ano.select.form-control").blur(function(){ + verifica_ano(); + }); + $("input#id_data_apresentacao.dateinput.form-control").blur(function(){ + verifica_ano(); + }); + }); {% endblock %} diff --git a/sapl/templates/norma/normajuridica_form.html b/sapl/templates/norma/normajuridica_form.html index 4c29fc98b..91531c4d1 100644 --- a/sapl/templates/norma/normajuridica_form.html +++ b/sapl/templates/norma/normajuridica_form.html @@ -57,6 +57,54 @@ numeroField.val(numero.replace(/^0+/, '')); } }); + + var modal_estilos = 'display: block;' + +'width: 85%; max-width: 600px;' + +'background: #fff; padding: 15px;' + +'border-radius: 5px;' + +'-webkit-box-shadow: 0px 6px 14px -2px rgba(0,0,0,0.75);' + +'-moz-box-shadow: 0px 6px 14px -2px rgba(0,0,0,0.75);' + +'box-shadow: 0px 6px 14px -2px rgba(0,0,0,0.75);' + +'position: fixed;' + +'top: 50%; left: 50%;' + +'transform: translate(-50%,-50%);' + +'z-index: 99999999; text-align: center'; + + var fundo_modal_estilos = 'top: 0; right: 0;' + +'bottom: 0; left: 0; position: fixed;' + +'background-color: rgba(0, 0, 0, 0.6); z-index: 99999999;' + +'display: none;'; + + var meu_modal = '
' + +'
' + +'

Atenção! Ano de apresentação e ano da norma são diferentes.


' + +'' + +'
'; + + function verifica_ano(){ + let ano = $("select#id_ano.select").val(); + let data_apresentacao = $("input#id_data.dateinput").val(); + let ano_apresentacao = data_apresentacao.substr(data_apresentacao.length - 4); + + if(ano && ano_apresentacao && ano_apresentacao != ano){ + $('#fundo_modal').fadeIn(); + } + } + + $(document).ready(function() { + $("body").append(meu_modal); + + $("#fundo_modal, #close_model_btn").click(function(){ $("#fundo_modal").hide(); }); + $("#meu_modal").click(function(e){ e.stopPropagation(); }); + + $("select#id_ano.select.form-control").blur(function(){ + verifica_ano(); + }); + $("input#id_data.dateinput.form-control").blur(function(){ + verifica_ano(); + }); + }); {% endblock %}