diff --git a/sapl/sessao/migrations/0045_auto_20190809_1319.py b/sapl/sessao/migrations/0045_auto_20190809_1319.py new file mode 100644 index 000000000..2254340a2 --- /dev/null +++ b/sapl/sessao/migrations/0045_auto_20190809_1319.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- +# Generated by Django 1.11.20 on 2019-08-09 16:19 +from __future__ import unicode_literals + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('sessao', '0044_merge_20190802_1117'), + ] + + operations = [ + migrations.AlterModelOptions( + name='tipoexpediente', + options={'ordering': ['ordenacao'], 'verbose_name': 'Tipo de Expediente', 'verbose_name_plural': 'Tipos de Expediente'}, + ), + migrations.AddField( + model_name='tipoexpediente', + name='ordenacao', + field=models.PositiveIntegerField(blank=True, null=True, verbose_name='Ordenação'), + ), + ] diff --git a/sapl/sessao/migrations/0046_auto_20190809_1319.py b/sapl/sessao/migrations/0046_auto_20190809_1319.py new file mode 100644 index 000000000..925c8df08 --- /dev/null +++ b/sapl/sessao/migrations/0046_auto_20190809_1319.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- +# Generated by Django 1.11.20 on 2019-08-09 16:19 +from __future__ import unicode_literals + +from django.db import migrations + + +def migra_ordenacao_tipos(apps, schema_editor): + TipoExpediente = apps.get_model('sessao', 'TipoExpediente') + + for i,tipo in enumerate(TipoExpediente.objects.all().order_by('nome')): + tipo.ordenacao=i+1 + tipo.save() + + +class Migration(migrations.Migration): + + dependencies = [ + ('sessao', '0045_auto_20190809_1319'), + ] + + operations = [ + migrations.RunPython(migra_ordenacao_tipos) + ] diff --git a/sapl/sessao/models.py b/sapl/sessao/models.py index e6016895f..20b83e921 100644 --- a/sapl/sessao/models.py +++ b/sapl/sessao/models.py @@ -295,11 +295,15 @@ class ExpedienteMateria(AbstractOrdemDia): @reversion.register() class TipoExpediente(models.Model): nome = models.CharField(max_length=100, verbose_name=_('Tipo')) + ordenacao = models.PositiveIntegerField( + blank=True, + null=True, + verbose_name=_("Ordenação")) class Meta: verbose_name = _('Tipo de Expediente') verbose_name_plural = _('Tipos de Expediente') - ordering = ['nome'] + ordering = ['ordenacao'] def __str__(self): return self.nome diff --git a/sapl/sessao/views.py b/sapl/sessao/views.py index 9560c66e1..efc553faa 100755 --- a/sapl/sessao/views.py +++ b/sapl/sessao/views.py @@ -2076,16 +2076,13 @@ class ExpedienteView(FormMixin, DetailView): def get(self, request, *args, **kwargs): self.object = self.get_object() context = self.get_context_data(object=self.object) - tipos = TipoExpediente.objects.all().order_by('nome') + tipos = TipoExpediente.objects.all().order_by('ordenacao', 'nome') expedientes_sessao = ExpedienteSessao.objects.filter( - sessao_plenaria_id=self.object.id).order_by('tipo__nome') + sessao_plenaria_id=self.object.id).order_by('tipo__ordenacao', 'tipo__nome') - expedientes_salvos = [] - for e in expedientes_sessao: - expedientes_salvos.append(e.tipo) + expedientes_salvos = [e.tipo.id for e in expedientes_sessao] - tipos_null = list(set(tipos) - set(expedientes_salvos)) - tipos_null.sort(key=lambda x: x.nome) + tipos_null = TipoExpediente.objects.all().exclude(id__in=expedientes_salvos).order_by('ordenacao', 'nome') expedientes = [] for e, t in zip(expedientes_sessao, tipos): diff --git a/sapl/templates/sessao/layouts.yaml b/sapl/templates/sessao/layouts.yaml index 661a65554..8e8c3916a 100644 --- a/sapl/templates/sessao/layouts.yaml +++ b/sapl/templates/sessao/layouts.yaml @@ -27,7 +27,7 @@ TipoResultadoVotacao: TipoExpediente: {% trans 'Tipo de Expediente' %}: - - nome + - nome ordenacao RegistroVotacao: {% trans 'Votação Simbólica' %}: