Browse Source

fix rebase

pull/2895/head
ricardocanela 6 years ago
parent
commit
630766cadc
  1. 19
      sapl/base/forms.py
  2. 37
      sapl/base/views.py
  3. 24
      sapl/relatorios/views.py
  4. 81
      sapl/templates/relatorios/relatorio_historico_tramitacao_adm.html
  5. 2
      sapl/templates/relatorios/relatorio_normas_vigencia.html

19
sapl/base/forms.py

@ -1664,6 +1664,8 @@ class PartidoForm(FileFieldCheckMixin, ModelForm):
class RelatorioHistoricoTramitacaoAdmFilterSet(django_filters.FilterSet):
o = AnoNumeroOrderingFilter(help_text='')
@property
def qs(self):
parent = super(RelatorioHistoricoTramitacaoAdmFilterSet, self).qs
@ -1694,12 +1696,27 @@ class RelatorioHistoricoTramitacaoAdmFilterSet(django_filters.FilterSet):
[('tipo', 6),
('tramitacaoadministrativo__status', 6)])
buttons = FormActions(
*[
HTML('''
<div class="form-check">
<input name="relatorio" type="checkbox" class="form-check-input" id="relatorio">
<label class="form-check-label" for="relatorio">Gerar relatório PDF</label>
</div>
''')
],
Submit('pesquisar', _('Pesquisar'), css_class='float-right',
onclick='return true;'),
css_class='form-group row justify-content-between'
,
)
self.form.helper = SaplFormHelper()
self.form.helper.form_method = 'GET'
self.form.helper.layout = Layout(
Fieldset(_(''),
row1, row2, row3,
form_actions(label='Pesquisar'))
buttons, )
)

37
sapl/base/views.py

@ -33,7 +33,7 @@ from sapl.relatorios.views import (relatorio_materia_em_tramitacao, relatorio_ma
relatorio_materia_por_ano_autor, relatorio_presenca_sessao,
relatorio_historico_tramitacao, relatorio_fim_prazo_tramitacao,
relatorio_atas, relatorio_audiencia, relatorio_normas_mes,
relatorio_normas_vigencia)
relatorio_normas_vigencia, relatorio_historico_tramitacao_adm)
from sapl import settings
from sapl.audiencia.models import AudienciaPublica, TipoAudienciaPublica
@ -2432,7 +2432,6 @@ class RelatorioHistoricoTramitacaoAdmView(FilterView):
return context
class RelatorioNormasPorAutorView(FilterView):
model = NormaJuridica
filterset_class = RelatorioNormasPorAutorFilterSet
@ -2479,3 +2478,37 @@ class RelatorioNormasPorAutorView(FilterView):
' - ' + self.request.GET['data_1'])
return context
def get(self, request, *args, **kwargs):
super(RelatorioNormasPorAutorView, self).get(request)
# Se a pesquisa estiver quebrando com a paginação
# Olhe esta função abaixo
# Provavelmente você criou um novo campo no Form/FilterSet
# Então a ordem da URL está diferente
data = self.filterset.data
if data and data.get('tipo') is not None:
url = "&" + str(self.request.environ['QUERY_STRING'])
if url.startswith("&page"):
ponto_comeco = url.find('tipo=') - 1
url = url[ponto_comeco:]
else:
url = ''
self.filterset.form.fields['o'].label = _('Ordenação')
# é usada essa verificação anônima para quando os documentos administrativos
# estão no modo ostensivo, mas podem existir documentos administrativos
# restritos
length = self.object_list.count()
is_relatorio = request.GET.get('relatorio', None)
self.paginate_by = None if is_relatorio else self.paginate_by
context = self.get_context_data(filter=self.filterset,
filter_url=url,
numero_res=length
)
context['show_results'] = show_results_filter_set(
self.request.GET.copy())
if is_relatorio:
return relatorio_historico_tramitacao_adm(request, context)
else:
return self.render_to_response(context)

24
sapl/relatorios/views.py

@ -1618,6 +1618,30 @@ def relatorio_normas_vigencia(request, context):
return response
def relatorio_historico_tramitacao_adm(request, context):
base_url = request.build_absolute_uri()
casa = CasaLegislativa.objects.first()
rodape = ' '.join(get_rodape(casa))
context.update({'data': dt.today().strftime('%d/%m/%Y')})
context.update({'rodape': rodape})
header_context = {"casa": casa, 'logotipo': casa.logotipo, 'MEDIA_URL': MEDIA_URL}
html_template = render_to_string('relatorios/relatorio_historico_tramitacao_adm.html', context)
html_header = render_to_string('relatorios/header_ata.html', header_context)
pdf_file = make_pdf(base_url=base_url, main_template=html_template, header_template=html_header)
response = HttpResponse(content_type='application/pdf;')
response['Content-Disposition'] = 'inline; filename=relatorio.pdf'
response['Content-Transfer-Encoding'] = 'binary'
response.write(pdf_file)
return response
def relatorio_sessao_plenaria_pdf(request, pk):
base_url=request.build_absolute_uri()
logger = logging.getLogger(__name__)

81
sapl/templates/relatorios/relatorio_historico_tramitacao_adm.html

@ -0,0 +1,81 @@
{% load i18n %}
{% load common_tags %}
{% load static %}
<head>
<style>
@page{
margin-top: 4.5cm;
size: A4 portrait;
@bottom-right {
content: "Página" counter(page);
height: 3cm;
font-size: 8pt;
}
@bottom-center {
border-top: 1px solid black;
font-size: 8pt;
height: 1cm;
content: "{{rodape|safe}}";
font-style:italic;
}
@bottom-left {
content: "{{data}}";
height: 3cm;
font-size: 8pt;
}
@top-center {
content: string(title);
}
header {
width: 0;
height: 0;
visibility: hidden;
string-set: title content();
}
}
</style>
<link rel="stylesheet" href="{% static '/sapl/css/relatorio.css'%}">
</head>
<body>
<h2>Histórico de Tramitações de Documento Administrativo</h2>
<b>PARÂMETROS DE PESQUISA:<br /></b>
&emsp;Período: {{ data_tramitacao }} <br />
&emsp;Tipo de documento: {{ tipo }}<br />
&emsp;Status atual: {{ tramitacaoadministrativo__status }}<br />
&emsp;Local de origem: {{ tramitacaoadministrativo__unidade_tramitacao_local }}<br />
&emsp;Local de destino: {{ tramitacaoadministrativo__unidade_tramitacao_destino }}<br /><br /><br />
{% if object_list %}
{% if object_list|length == 1 %}
<tr><td><h3 style="text-align: left;">Foi encontrado 1 documento com esses parâmetros.</h3></td></tr><br><br>
{% else %}
<tr><td><h3 style="text-align: left;">Foram encontrados {{object_list|length}} documentos com esses parâmetros.</h3></td></tr><br><br>
{% endif %}
<table class="table table-bordered table-hover">
<thead class="thead-default" >
<tr class="active">
<th>Documento</th>
<th>Ementa</th>
</tr>
</thead>
<tbody>
{% for documento in object_list %}
<tr>
<td>
{{documento.tipo.descricao}} - {{documento.tipo.sigla}} {{documento.numero}}/{{documento.ano}}
</td>
<td>{{documento.ementa}}<br>{{documento.observacao}}</td>
</tr>
{% endfor %}
</tbody>
</table>
{% else %}
<tr><td><h3 style="text-align: left;">Nenhum documento encontrado com esses parâmetros.</h3></td></tr><br><br>
{% endif %}
</body>

2
sapl/templates/relatorios/relatorio_normas_vigencia.html

@ -43,7 +43,7 @@
</head>
<body>
<h2>Fim de Prazo de Tramitações</h2>
<h2>Normas por vigência</h2>
<b>PARÂMETROS DE PESQUISA:<br /></b>
&emsp;Ano: {{ ano }} <br />

Loading…
Cancel
Save