diff --git a/sapl/relatorios/urls.py b/sapl/relatorios/urls.py index de1733549..5a863fbc9 100644 --- a/sapl/relatorios/urls.py +++ b/sapl/relatorios/urls.py @@ -27,8 +27,8 @@ urlpatterns = [ relatorio_protocolo, name='relatorio_protocolo'), url(r'^relatorios/(?P\d+)/(?P\d+)/etiqueta-protocolo$', relatorio_etiqueta_protocolo, name='relatorio_etiqueta_protocolo'), - url(r'^relatorios/pauta-sessao/(?P\d+)/$', - relatorio_pauta_sessao, name='relatorio_pauta_sessao'), + # url(r'^relatorios/pauta-sessao/(?P\d+)/$', + # relatorio_pauta_sessao, name='relatorio_pauta_sessao'), url(r'^relatorios/(?P\d+)/resumo_ata$', resumo_ata_pdf, name='resumo_ata_pdf'), url(r'^relatorios/(?P\d+)/sessao-plenaria-pdf$', diff --git a/sapl/relatorios/views.py b/sapl/relatorios/views.py index 8a899f3fd..02c7d3317 100755 --- a/sapl/relatorios/views.py +++ b/sapl/relatorios/views.py @@ -1363,8 +1363,7 @@ def relatorio_normas_por_autor(obj, request, context): def relatorio_pauta_sessao_weasy(obj, request, context): sessao = context['object'] - info = "Pauta da {} ({} - {}) Legislatura".format(sessao, sessao.legislatura.data_inicio.year, - sessao.legislatura.data_fim.year) + info = f"Pauta da {sessao} ({sessao.legislatura.data_inicio.year} - {sessao.legislatura.data_fim.year}) Legislatura" return cria_relatorio(request, context, 'relatorios/relatorio_pauta_sessao.html', info) diff --git a/sapl/sessao/views.py b/sapl/sessao/views.py index dc3226f77..d98aec3bf 100755 --- a/sapl/sessao/views.py +++ b/sapl/sessao/views.py @@ -30,7 +30,7 @@ from sapl.crud.base import (RP_DETAIL, RP_LIST, Crud, CrudAux, PermissionRequiredForAppCrudMixin, make_pagination) from sapl.materia.forms import filtra_tramitacao_status from sapl.materia.models import (Autoria, TipoMateriaLegislativa, - Tramitacao) + Tramitacao, MateriaEmTramitacao, Numeracao) from sapl.materia.views import MateriaLegislativaPesquisaView from sapl.painel.models import Cronometro, PainelConfig from sapl.parlamentares.models import (Filiacao, Legislatura, Mandato, @@ -3430,38 +3430,21 @@ class PautaSessaoDetailView(DetailView): # ===================================================================== # Identificação Básica abertura = self.object.data_inicio.strftime('%d/%m/%Y') - if self.object.data_fim: - encerramento = self.object.data_fim.strftime('%d/%m/%Y') - else: - encerramento = "" - + encerramento = self.object.data_fim.strftime('%d/%m/%Y') if self.object.data_fim else "" hora_inicio = self.object.hora_inicio hora_fim = self.object.hora_fim - context.update({'basica': [ - _('Tipo de Sessão: %(tipo)s') % {'tipo': self.object.tipo}, - _('Abertura: %(abertura)s - %(hora_inicio)s') % { - 'abertura': abertura, 'hora_inicio': hora_inicio}, - _('Encerramento: %(encerramento)s - %(hora_fim)s') % { - 'encerramento': encerramento, 'hora_fim': hora_fim}, - ]}) + context.update({ + 'basica': [ + _(f'Tipo de Sessão: {self.object.tipo}'), + _(f'Abertura: {abertura} - {hora_inicio}'), + _(f'Encerramento: {encerramento} - {hora_fim}') + ] + }) # ===================================================================== # Matérias Expediente - materias = ExpedienteMateria.objects.filter( - sessao_plenaria_id=self.object.id) - materias_expediente = [] - for m in materias: - ementa = m.materia.ementa - titulo = m.materia - numero = m.numero_ordem - - ultima_tramitacao = m.materia.tramitacao_set.last() - - situacao = ultima_tramitacao.status if ultima_tramitacao else None - - if situacao is None: - situacao = _("Não informada") + for m in ExpedienteMateria.objects.select_related("materia").filter(sessao_plenaria_id=self.object.id): rv = m.registrovotacao_set.all() if rv: resultado = rv[0].tipo_resultado_votacao.nome @@ -3470,60 +3453,45 @@ class PautaSessaoDetailView(DetailView): resultado = _('Matéria não votada') resultado_observacao = _(' ') - autoria = Autoria.objects.filter(materia_id=m.materia_id) - autor = [str(x.autor) for x in autoria] - - mat = {'id': m.materia_id, - 'ementa': ementa, - 'observacao': m.observacao, - 'titulo': titulo, - 'numero': numero, - 'resultado': resultado, - 'resultado_observacao': resultado_observacao, - 'situacao': situacao, - 'autor': autor - } - materias_expediente.append(mat) + ultima_tramitacao = m.materia.tramitacao_set.last() + numeracao = Numeracao.objects.filter(materia=m.materia).first() + + materias_expediente.append({ + 'id': m.materia_id, + 'ementa': m.materia.ementa, + 'observacao': m.observacao, + 'titulo': m.materia, + 'numero': m.numero_ordem, + 'resultado': resultado, + 'resultado_observacao': resultado_observacao, + 'situacao': ultima_tramitacao.status if ultima_tramitacao else _("Não informada"), + 'processo': f'{str(numeracao.numero_materia)}/{str(numeracao.ano_materia)}' if numeracao else '-', + 'autor': [str(x.autor) for x in Autoria.objects.select_related("autor").filter(materia_id=m.materia_id)] + }) context.update({'materia_expediente': materias_expediente}) # ===================================================================== # Expedientes - expediente = ExpedienteSessao.objects.filter( - sessao_plenaria_id=self.object.id).order_by('tipo__ordenacao') - expedientes = [] - for e in expediente: + for e in ExpedienteSessao.objects.select_related("tipo").filter(sessao_plenaria_id=self.object.id)\ + .order_by('tipo__ordenacao'): conteudo = e.conteudo from sapl.relatorios.views import is_empty if not is_empty(conteudo): tipo = e.tipo conteudo = sub(' ', ' ', conteudo) - ex = {'tipo': tipo, 'conteudo': conteudo} - expedientes.append(ex) + expedientes.append({'tipo': tipo, 'conteudo': conteudo}) context.update({'expedientes': expedientes}) # ===================================================================== # Orador Expediente - oradores = OradorExpediente.objects.filter( - sessao_plenaria_id=self.object.id).order_by('numero_ordem') - context.update({'oradores': oradores}) + context.update({ + 'oradores': OradorExpediente.objects.filter(sessao_plenaria_id=self.object.id).order_by('numero_ordem') + }) # ===================================================================== # Matérias Ordem do Dia - ordem = OrdemDia.objects.filter( - sessao_plenaria_id=self.object.id) - materias_ordem = [] - for o in ordem: - ementa = o.materia.ementa - titulo = o.materia - numero = o.numero_ordem - - ultima_tramitacao = o.materia.tramitacao_set.last() - - situacao = ultima_tramitacao.status if ultima_tramitacao else None - - if situacao is None: - situacao = _("Não informada") + for o in OrdemDia.objects.select_related("materia").filter(sessao_plenaria_id=self.object.id): # Verificar resultado rv = o.registrovotacao_set.all() if rv: @@ -3533,29 +3501,29 @@ class PautaSessaoDetailView(DetailView): resultado = _('Matéria não votada') resultado_observacao = _(' ') - autoria = Autoria.objects.filter( - materia_id=o.materia_id) - autor = [str(x.autor) for x in autoria] - - mat = {'id': o.materia_id, - 'ementa': ementa, - 'observacao': o.observacao, - 'titulo': titulo, - 'numero': numero, - 'resultado': resultado, - 'resultado_observacao': resultado_observacao, - 'situacao': situacao, - 'autor': autor - } - materias_ordem.append(mat) - - context.update({'materias_ordem': materias_ordem}) - context.update({'subnav_template_name': 'sessao/pauta_subnav.yaml'}) + ultima_tramitacao = o.materia.tramitacao_set.last() + numeracao = Numeracao.objects.filter(materia=m.materia).first() + + materias_ordem.append({ + 'id': o.materia_id, + 'ementa': o.materia.ementa, + 'observacao': o.observacao, + 'titulo': o.materia, + 'numero': o.numero_ordem, + 'resultado': resultado, + 'resultado_observacao': resultado_observacao, + 'situacao': ultima_tramitacao.status if ultima_tramitacao else _("Não informada"), + 'processo': f'{str(numeracao.numero_materia)}/{str(numeracao.ano_materia)}' if numeracao else '-', + 'autor': [str(x.autor) for x in Autoria.objects.select_related("autor").filter(materia_id=o.materia_id)] + }) - is_pdf = True if request.build_absolute_uri().split( - '/')[-1] == 'pdf' else False + context.update({ + 'materias_ordem': materias_ordem, + 'subnav_template_name': 'sessao/pauta_subnav.yaml' + }) - if is_pdf: + # Verifica se é um PDF + if request.build_absolute_uri().split('/')[-1] == 'pdf': return relatorio_pauta_sessao_weasy(self, request, context) else: return self.render_to_response(context) diff --git a/sapl/templates/relatorios/relatorio_pauta_sessao.html b/sapl/templates/relatorios/relatorio_pauta_sessao.html index 8cc6f9fd9..e4b180e5c 100644 --- a/sapl/templates/relatorios/relatorio_pauta_sessao.html +++ b/sapl/templates/relatorios/relatorio_pauta_sessao.html @@ -16,34 +16,42 @@

Matérias do Expediente

{% if materia_expediente %} - + {% if not object.finalizada %} {% endif %} {% for m in materia_expediente %} - - - - + + + + {% if not object.finalizada %} + + {% endif %} + {% endfor %} -
MatériaEmenta
MatériaEmentaSituação
- {{ m.numero }} - {{ m.titulo }}
- Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} -
- {{ m.ementa|safe }}
{{ m.observacao|linebreaksbr|safe }} -
+ {{ m.numero }} - {{ m.titulo }}
+ Processo: {{ m.processo }}
+ Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} +
+ {{ m.ementa|safe }}
{{ m.observacao|linebreaksbr|safe }} +
{{m.situacao|linebreaksbr|safe}}
+ {% else %} Não existem Matérias de Expediente para essa Sessão Plenária {% endif %}

Matérias da Ordem do Dia

{% if materias_ordem %} - + {% if not object.finalizada %} {% endif %} {% for m in materias_ordem %} - - - - + + + + {% if not object.finalizada %} + + {% endif %} + {% endfor %}
MatériaEmenta
MatériaEmentaSituação
- {{m.numero}} - {{m.titulo}}
- Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} -
{{m.ementa|safe}}
{{m.observacao|linebreaksbr|safe}}
+ {{m.numero}} - {{m.titulo}}
+ Processo: {{ m.processo }}
+ Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} +
{{m.ementa|safe}}
{{m.observacao|linebreaksbr|safe}}
{{m.situacao|linebreaksbr|safe}}
{% else %} diff --git a/sapl/templates/sessao/pauta_sessao_detail.html b/sapl/templates/sessao/pauta_sessao_detail.html index c35956f28..eb8f4411a 100644 --- a/sapl/templates/sessao/pauta_sessao_detail.html +++ b/sapl/templates/sessao/pauta_sessao_detail.html @@ -19,61 +19,67 @@
Expedientes - + {% for e in expedientes %} - - - + + + {% endfor %} - +
- {{e.tipo}}:

-
-

{{e.conteudo|safe}}

-
-
+ {{e.tipo}}:

+
+

{{e.conteudo|safe}}

+
+
Matérias do Expediente {% if materia_expediente %} - - {% for m in materia_expediente %} - - - + {% if not object.finalizada %} {% endif %} + {% for m in materia_expediente %} + + + + {% if not object.finalizada %} + + {% endif %} - {% endfor %} -
MatériaEmenta
- {{m.numero}} - - {{m.titulo}}
- Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} -
{{m.ementa|safe}}
{{m.observacao|linebreaksbr|safe}}
MatériaEmentaSituação
+ {{m.numero}} - + {{m.titulo}}
+ Processo: {{ m.processo }}
+ Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} +
{{m.ementa|safe}}
{{m.observacao|linebreaksbr|safe}}
{{m.situacao|linebreaksbr|safe}}
- {% else %} - Não existem Matérias de Expediente para essa Sessão Plenária - {% endif %} + {% endfor %} + + {% else %} + Não existem Matérias de Expediente para essa Sessão Plenária + {% endif %}
Matérias da Ordem do Dia {% if materias_ordem %} - + {% if not object.finalizada %} {% endif %} {% for m in materias_ordem %} - - - - + + + + {% if not object.finalizada %} + + {% endif %} + {% endfor %}
MatériaEmenta
MatériaEmentaSituação
- {{m.numero}} - - {{m.titulo}}
- Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} -
{{m.ementa|safe}}
{{m.observacao|linebreaksbr|safe}}
+ {{m.numero}} - + {{m.titulo}}
+ Processo: {{ m.processo }}
+ Autor{{ m.autor|length|pluralize:"es" }}: {{ m.autor|join:', ' }} +
{{m.ementa|safe}}
{{m.observacao|linebreaksbr|safe}}
{{m.situacao|linebreaksbr|safe}}
- {% else %} + {% else %} Não existem Matérias de Ordem do Dia para essa Sessão Plenária - {% endif %} + {% endif %}
{% endblock base_content %}