From 6dd74de6b1ca7bfb3acc59baa02e9fad82852678 Mon Sep 17 00:00:00 2001 From: Eduardo Calil Date: Wed, 6 Apr 2016 12:58:25 -0300 Subject: [PATCH] Implementa o campo de ordenacao igual ao SAPL 2.5 --- materia/forms.py | 57 +++++++++++++++++++++++++++++++++--------------- materia/views.py | 13 ++++------- 2 files changed, 43 insertions(+), 27 deletions(-) diff --git a/materia/forms.py b/materia/forms.py index a1da19ed6..fc0c6cdff 100644 --- a/materia/forms.py +++ b/materia/forms.py @@ -6,6 +6,7 @@ from django.core.exceptions import ValidationError from django.db.models import Max from django.forms import ModelForm from django.utils.translation import ugettext_lazy as _ +from django.utils.text import capfirst from django_filters import FilterSet import crispy_layout_mixin @@ -28,6 +29,11 @@ def em_tramitacao(): (False, 'Não')] +def ordenacao(): + return [('data, tipo, ano, numero', 'Data, Tipo, Ano, Numero'), + ('tipo, ano, numero, data', 'Tipo, Ano, Numero, Data')] + + class ProposicaoForm(ModelForm): tipo_materia = forms.ModelChoiceField( @@ -679,24 +685,37 @@ class MateriaLegislativaPesquisaFields(FilterSet): lookup_expr='icontains', help_text="") - ORDER_BY_FIELD = "'numero', 'ano'" - class Meta: models = MateriaLegislativa - fields = {'tipo', - 'ano', - 'numero_protocolo', - 'data_apresentacao', - 'data_publicacao', - 'em_tramitacao', - 'ementa', - 'autoria__autor__id', - 'relatoria__parlamentar_id', - 'tramitacao__unidade_tramitacao_destino', - 'tramitacao__status', - 'autoria__autor__tipo', - 'autoria__partido', - 'local_origem_externa'} + + order_by = ( + ('', 'Selecione'), + ('dataC', 'Data, Tipo, Ano, Numero - Ordem Crescente'), + ('dataD', 'Data, Tipo, Ano, Numero - Ordem Decrescente'), + ('tipoC', 'Tipo, Ano, Numero, Data - Ordem Crescente'), + ('tipoD', 'Tipo, Ano, Numero, Data - Ordem Decrescente') + ) + + # def get_ordering_field(self, choices): + # super( + # MateriaLegislativaPesquisaFields, self).get_ordering_field(choices) + # return forms.ChoiceField(label=_('Ordenação'), + # required=False, + # choices=choices) + + def get_order_by(self, order_value): + if order_value == '': + return [] + elif order_value == 'dataC': + return ['data_apresentacao', 'tipo__sigla', 'ano', 'numero'] + elif order_value == 'dataD': + return ['-data_apresentacao', '-tipo__sigla', '-ano', '-numero'] + elif order_value == 'tipoC': + return ['tipo__sigla', 'ano', 'numero', 'data_apresentacao'] + else: + return ['-tipo__sigla', '-ano', '-numero', '-data_apresentacao'] + return super(MateriaLegislativaPesquisaFields, + self).get_order_by(order_value) def __init__(self, *args, **kwargs): super(MateriaLegislativaPesquisaFields, self).__init__(*args, **kwargs) @@ -730,7 +749,9 @@ class MateriaLegislativaPesquisaFields(FilterSet): ('tramitacao__status', 6)]) row9 = crispy_layout_mixin.to_row( [('em_tramitacao', 6), - ('ementa', 6)]) + ('o', 6)]) + row10 = crispy_layout_mixin.to_row( + [('ementa', 12)]) self.form.helper = FormHelper() self.form.helper.form_method = 'GET' @@ -739,7 +760,7 @@ class MateriaLegislativaPesquisaFields(FilterSet): row1, row2, row3, row4, HTML(sapl.utils.autor_label), HTML(sapl.utils.autor_modal), - row5, row6, row7, row8, row9, + row5, row6, row7, row8, row9, row10, form_actions(save_label='Pesquisar')) ) diff --git a/materia/views.py b/materia/views.py index d94acd7c5..b00389d28 100644 --- a/materia/views.py +++ b/materia/views.py @@ -1196,14 +1196,6 @@ class MateriaLegislativaPesquisaView(FilterView): filterset_class = MateriaLegislativaPesquisaFields paginate_by = 10 - # def get_filterset_kwargs(self, filterset_class): - # """ - # Returns the keyword arguments for instanciating the filterset. - # """ - # import ipdb; ipdb.set_trace() - # kwargs = {'data': self.request.GET or None} - # return kwargs - def get_context_data(self, **kwargs): context = super(MateriaLegislativaPesquisaView, self).get_context_data(**kwargs) @@ -1213,6 +1205,7 @@ class MateriaLegislativaPesquisaView(FilterView): context['page_range'] = make_pagination( page_obj.number, paginator.num_pages) + return context def get(self, request, *args, **kwargs): @@ -1228,7 +1221,7 @@ class MateriaLegislativaPesquisaView(FilterView): lista = filtra_tramitacao_destino_and_status(status_tramitacao, unidade_destino) self.object_list = self.filterset.qs.filter( - id__in=lista).distinct().order_by + id__in=lista).distinct() elif status_tramitacao: lista = filtra_tramitacao_status(status_tramitacao) @@ -1256,6 +1249,8 @@ class MateriaLegislativaPesquisaView(FilterView): numero_res=len(self.object_list) ) + self.filterset.form.fields['o'].label = _('Ordenação') + return self.render_to_response(context)