Browse Source

Refatora PautaSessaoDetailView - Matérias do Expediente

pull/3286/head
João Rodrigues 4 years ago
parent
commit
16ae10603b
  1. 45
      sapl/sessao/views.py

45
sapl/sessao/views.py

@ -50,7 +50,7 @@ from .models import (Bancada, CargoBancada, CargoMesa,
SessaoPlenaria, SessaoPlenariaPresenca, TipoExpediente, SessaoPlenaria, SessaoPlenariaPresenca, TipoExpediente,
TipoResultadoVotacao, TipoSessaoPlenaria, VotoParlamentar, TipoRetiradaPauta, TipoResultadoVotacao, TipoSessaoPlenaria, VotoParlamentar, TipoRetiradaPauta,
RetiradaPauta, TipoJustificativa, JustificativaAusencia, OradorOrdemDia, RetiradaPauta, TipoJustificativa, JustificativaAusencia, OradorOrdemDia,
ORDENACAO_RESUMO, RegistroLeitura) ORDENACAO_RESUMO, RegistroLeitura, ExpedientePautaSessao)
TipoSessaoCrud = CrudAux.build(TipoSessaoPlenaria, 'tipo_sessao_plenaria') TipoSessaoCrud = CrudAux.build(TipoSessaoPlenaria, 'tipo_sessao_plenaria')
@ -3583,32 +3583,27 @@ class PautaSessaoDetailView(DetailView):
# ===================================================================== # =====================================================================
# Matérias Expediente # Matérias Expediente
materias_expediente = [] materias_expediente = []
for m in ExpedienteMateria.objects \ for e in ExpedientePautaSessao.objects.select_related("materia").filter(
.prefetch_related('registrovotacao_set') \ sessao_plenaria_id=self.object.id
.select_related("materia", "materia__tipo") \ ).order_by('expediente__numero_ordem'):
.filter(sessao_plenaria_id=self.object.id):
rv = m.registrovotacao_set.first() processo = f'{str(e.numeracao.numero_materia)}/{str(e.numeracao.ano_materia)}' if e.numeracao else '-'
if rv:
resultado = rv.tipo_resultado_votacao.nome autores = e.autores if e.autores else [
resultado_observacao = rv.observacao str(a.autor) for a in e.materia.autoria_set.select_related('autor').all()
else: ]
resultado = _('Matéria não votada')
resultado_observacao = _(' ')
ultima_tramitacao = m.materia.tramitacao_set.order_by('-data_tramitacao', '-id').first()
numeracao = m.materia.numeracao_set.first()
materias_expediente.append({ materias_expediente.append({
'id': m.materia_id, 'id': e.materia_id,
'ementa': m.materia.ementa, 'ementa': e.materia.ementa,
'observacao': m.observacao, 'observacao': e.expediente.observacao,
'titulo': m.materia, 'titulo': e.materia,
'numero': m.numero_ordem, 'numero': e.expediente.numero_ordem,
'resultado': resultado, 'resultado': '', # Não é utilizado
'resultado_observacao': resultado_observacao, 'resultado_observacao': '', # Não é utilizado
'situacao': ultima_tramitacao.status if ultima_tramitacao else _("Não informada"), 'situacao': e.tramitacao.status if e.tramitacao else _('Não informada'),
'processo': f'{str(numeracao.numero_materia)}/{str(numeracao.ano_materia)}' if numeracao else '-', 'processo': processo,
'autor': [str(x.autor) for x in m.materia.autoria_set.select_related('autor').all()] 'autor': e.autores
}) })
context.update({'materia_expediente': materias_expediente}) context.update({'materia_expediente': materias_expediente})
# ===================================================================== # =====================================================================

Loading…
Cancel
Save