Browse Source

Implementa o campo de ordenacao igual ao SAPL 2.5

pull/282/head
Eduardo Calil 9 years ago
parent
commit
a132d5b506
  1. 57
      materia/forms.py
  2. 13
      materia/views.py

57
materia/forms.py

@ -6,6 +6,7 @@ from django.core.exceptions import ValidationError
from django.db.models import Max from django.db.models import Max
from django.forms import ModelForm from django.forms import ModelForm
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from django.utils.text import capfirst
from django_filters import FilterSet from django_filters import FilterSet
import crispy_layout_mixin import crispy_layout_mixin
@ -28,6 +29,11 @@ def em_tramitacao():
(False, 'Não')] (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): class ProposicaoForm(ModelForm):
tipo_materia = forms.ModelChoiceField( tipo_materia = forms.ModelChoiceField(
@ -690,24 +696,37 @@ class MateriaLegislativaPesquisaFields(FilterSet):
lookup_expr='icontains', lookup_expr='icontains',
help_text="") help_text="")
ORDER_BY_FIELD = "'numero', 'ano'"
class Meta: class Meta:
models = MateriaLegislativa models = MateriaLegislativa
fields = {'tipo',
'ano', order_by = (
'numero_protocolo', ('', 'Selecione'),
'data_apresentacao', ('dataC', 'Data, Tipo, Ano, Numero - Ordem Crescente'),
'data_publicacao', ('dataD', 'Data, Tipo, Ano, Numero - Ordem Decrescente'),
'em_tramitacao', ('tipoC', 'Tipo, Ano, Numero, Data - Ordem Crescente'),
'ementa', ('tipoD', 'Tipo, Ano, Numero, Data - Ordem Decrescente')
'autoria__autor__id', )
'relatoria__parlamentar_id',
'tramitacao__unidade_tramitacao_destino', # def get_ordering_field(self, choices):
'tramitacao__status', # super(
'autoria__autor__tipo', # MateriaLegislativaPesquisaFields, self).get_ordering_field(choices)
'autoria__partido', # return forms.ChoiceField(label=_('Ordenação'),
'local_origem_externa'} # 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): def __init__(self, *args, **kwargs):
super(MateriaLegislativaPesquisaFields, self).__init__(*args, **kwargs) super(MateriaLegislativaPesquisaFields, self).__init__(*args, **kwargs)
@ -741,7 +760,9 @@ class MateriaLegislativaPesquisaFields(FilterSet):
('tramitacao__status', 6)]) ('tramitacao__status', 6)])
row9 = crispy_layout_mixin.to_row( row9 = crispy_layout_mixin.to_row(
[('em_tramitacao', 6), [('em_tramitacao', 6),
('ementa', 6)]) ('o', 6)])
row10 = crispy_layout_mixin.to_row(
[('ementa', 12)])
self.form.helper = FormHelper() self.form.helper = FormHelper()
self.form.helper.form_method = 'GET' self.form.helper.form_method = 'GET'
@ -750,7 +771,7 @@ class MateriaLegislativaPesquisaFields(FilterSet):
row1, row2, row3, row4, row1, row2, row3, row4,
HTML(sapl.utils.autor_label), HTML(sapl.utils.autor_label),
HTML(sapl.utils.autor_modal), HTML(sapl.utils.autor_modal),
row5, row6, row7, row8, row9, row5, row6, row7, row8, row9, row10,
form_actions(save_label='Pesquisar')) form_actions(save_label='Pesquisar'))
) )

13
materia/views.py

@ -1201,14 +1201,6 @@ class MateriaLegislativaPesquisaView(FilterView):
filterset_class = MateriaLegislativaPesquisaFields filterset_class = MateriaLegislativaPesquisaFields
paginate_by = 10 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): def get_context_data(self, **kwargs):
context = super(MateriaLegislativaPesquisaView, context = super(MateriaLegislativaPesquisaView,
self).get_context_data(**kwargs) self).get_context_data(**kwargs)
@ -1218,6 +1210,7 @@ class MateriaLegislativaPesquisaView(FilterView):
context['page_range'] = make_pagination( context['page_range'] = make_pagination(
page_obj.number, paginator.num_pages) page_obj.number, paginator.num_pages)
return context return context
def get(self, request, *args, **kwargs): def get(self, request, *args, **kwargs):
@ -1233,7 +1226,7 @@ class MateriaLegislativaPesquisaView(FilterView):
lista = filtra_tramitacao_destino_and_status(status_tramitacao, lista = filtra_tramitacao_destino_and_status(status_tramitacao,
unidade_destino) unidade_destino)
self.object_list = self.filterset.qs.filter( self.object_list = self.filterset.qs.filter(
id__in=lista).distinct().order_by id__in=lista).distinct()
elif status_tramitacao: elif status_tramitacao:
lista = filtra_tramitacao_status(status_tramitacao) lista = filtra_tramitacao_status(status_tramitacao)
@ -1261,6 +1254,8 @@ class MateriaLegislativaPesquisaView(FilterView):
numero_res=len(self.object_list) numero_res=len(self.object_list)
) )
self.filterset.form.fields['o'].label = _('Ordenação')
return self.render_to_response(context) return self.render_to_response(context)

Loading…
Cancel
Save