From 42c7c3396655aeb5ff26d22d258ccf3263a14dc2 Mon Sep 17 00:00:00 2001 From: Eduardo Calil Date: Thu, 11 Feb 2016 12:09:18 -0200 Subject: [PATCH] Corrige bug em relatoria de Materia sem tramitacao Fix 181 --- materia/views.py | 94 +++++++++++++++++++++++++++++------------------- 1 file changed, 58 insertions(+), 36 deletions(-) diff --git a/materia/views.py b/materia/views.py index 314defd43..15eb1a158 100644 --- a/materia/views.py +++ b/materia/views.py @@ -1336,31 +1336,42 @@ class RelatoriaView(FormMixin, GenericView): def post(self, request, *args, **kwargs): form = RelatoriaForm(request.POST) materia = MateriaLegislativa.objects.get(id=kwargs['pk']) - relatorias = Relatoria.objects.filter( - materia_id=kwargs['pk']).order_by('-data_designacao_relator') - localizacao = Tramitacao.objects.filter( - materia=materia).last() - comissao = Comissao.objects.get( - id=localizacao.unidade_tramitacao_destino_id) - - if form.is_valid(): - relatoria = form.save(commit=False) - relatoria.materia = materia - relatoria.comissao = comissao - relatoria.save() - return self.form_valid(form) - else: - - composicao = Composicao.objects.get(comissao=comissao) - parlamentares = composicao.participacao_set.all() + if not materia.tramitacao_set.all(): + msg = 'Adicione alguma Tramitação antes de adicionar uma Comissão!' + messages.add_message(request, messages.INFO, msg) return self.render_to_response( {'materialegislativa': materia, 'form': form, - 'relatorias': relatorias, - 'comissao': comissao, - 'tipo_fim_relatoria': TipoFimRelatoria.objects.all(), - 'parlamentares': parlamentares}) + 'tipo_fim_relatoria': TipoFimRelatoria.objects.all() + }) + else: + if form.is_valid(): + relatorias = Relatoria.objects.filter( + materia_id=kwargs['pk']).order_by( + '-data_designacao_relator') + localizacao = Tramitacao.objects.filter( + materia=materia).last() + comissao = Comissao.objects.get( + id=localizacao.unidade_tramitacao_destino_id) + + relatoria = form.save(commit=False) + relatoria.materia = materia + relatoria.comissao = comissao + relatoria.save() + return self.form_valid(form) + else: + + composicao = Composicao.objects.get(comissao=comissao) + parlamentares = composicao.participacao_set.all() + + return self.render_to_response( + {'materialegislativa': materia, + 'form': form, + 'relatorias': relatorias, + 'comissao': comissao, + 'tipo_fim_relatoria': TipoFimRelatoria.objects.all(), + 'parlamentares': parlamentares}) def get(self, request, *args, **kwargs): materia = MateriaLegislativa.objects.get(id=kwargs['pk']) @@ -1371,26 +1382,37 @@ class RelatoriaView(FormMixin, GenericView): localizacao = Tramitacao.objects.filter( materia=materia).last() - try: - comissao = Comissao.objects.get( - id=localizacao.unidade_tramitacao_destino_id) - except ObjectDoesNotExist: - msg = 'O local atual deve ser uma Comissão!' + if not materia.tramitacao_set.all(): + msg = 'Adicione alguma Tramitação antes de adicionar uma Comissão!' messages.add_message(request, messages.INFO, msg) - return self.render_to_response( - {'materialegislativa': materia, - 'form': form, - 'relatorias': relatorias}) - else: - composicao = Composicao.objects.filter(comissao=comissao).last() - parlamentares = composicao.participacao_set.all() return self.render_to_response( {'materialegislativa': materia, 'form': form, 'relatorias': relatorias, - 'comissao': comissao, - 'tipo_fim_relatoria': TipoFimRelatoria.objects.all(), - 'parlamentares': parlamentares}) + 'tipo_fim_relatoria': TipoFimRelatoria.objects.all() + }) + else: + try: + comissao = Comissao.objects.get( + id=localizacao.unidade_tramitacao_destino_id) + except ObjectDoesNotExist: + msg = 'O local atual deve ser uma Comissão!' + messages.add_message(request, messages.INFO, msg) + return self.render_to_response( + {'materialegislativa': materia, + 'form': form, + 'relatorias': relatorias}) + else: + composicao = Composicao.objects.filter( + comissao=comissao).last() + parlamentares = composicao.participacao_set.all() + return self.render_to_response( + {'materialegislativa': materia, + 'form': form, + 'relatorias': relatorias, + 'comissao': comissao, + 'tipo_fim_relatoria': TipoFimRelatoria.objects.all(), + 'parlamentares': parlamentares}) class TramitacaoForm(ModelForm):