mirror of https://github.com/interlegis/sapl.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
688 lines
25 KiB
688 lines
25 KiB
from django.contrib import messages
|
|
from django.core.exceptions import MultipleObjectsReturned, ObjectDoesNotExist
|
|
from django.core.urlresolvers import reverse, reverse_lazy
|
|
from django.db.models import F, Q
|
|
from django.http import JsonResponse
|
|
from django.http.response import HttpResponseRedirect
|
|
from django.templatetags.static import static
|
|
from django.utils.datastructures import MultiValueDictKeyError
|
|
from django.utils.translation import ugettext_lazy as _
|
|
from django.views.generic import FormView
|
|
|
|
from sapl.comissoes.models import Participacao
|
|
from sapl.crud.base import (RP_CHANGE, RP_DETAIL, RP_LIST, Crud, CrudAux,
|
|
CrudBaseForListAndDetailExternalAppView,
|
|
MasterDetailCrud)
|
|
from sapl.materia.models import Proposicao, Relatoria
|
|
from sapl.parlamentares.apps import AppConfig
|
|
|
|
from .forms import (FiliacaoForm, LegislaturaCreateForm, LegislaturaUpdateForm,
|
|
MandatoForm, ParlamentarCreateForm, ParlamentarForm,
|
|
VotanteForm)
|
|
from .models import (CargoMesa, Coligacao, ComposicaoColigacao, ComposicaoMesa,
|
|
Dependente, Filiacao, Frente, Legislatura, Mandato,
|
|
NivelInstrucao, Parlamentar, Partido, SessaoLegislativa,
|
|
SituacaoMilitar, TipoAfastamento, TipoDependente, Votante)
|
|
|
|
CargoMesaCrud = CrudAux.build(CargoMesa, 'cargo_mesa')
|
|
PartidoCrud = CrudAux.build(Partido, 'partidos')
|
|
SessaoLegislativaCrud = CrudAux.build(SessaoLegislativa, 'sessao_legislativa')
|
|
TipoDependenteCrud = CrudAux.build(TipoDependente, 'tipo_dependente')
|
|
NivelInstrucaoCrud = CrudAux.build(NivelInstrucao, 'nivel_instrucao')
|
|
TipoAfastamentoCrud = CrudAux.build(TipoAfastamento, 'tipo_afastamento')
|
|
TipoMilitarCrud = CrudAux.build(SituacaoMilitar, 'tipo_situa_militar')
|
|
|
|
FrenteCrud = CrudAux.build(Frente, 'tipo_situa_militar', list_field_names=[
|
|
'nome', 'data_criacao', 'parlamentares'])
|
|
|
|
DependenteCrud = MasterDetailCrud.build(
|
|
Dependente, 'parlamentar', 'dependente')
|
|
|
|
|
|
class VotanteView(MasterDetailCrud):
|
|
model = Votante
|
|
parent_field = 'parlamentar'
|
|
UpdateView = None
|
|
|
|
class BaseMixin(MasterDetailCrud.BaseMixin):
|
|
list_field_names = ['user']
|
|
|
|
class CreateView(MasterDetailCrud.CreateView):
|
|
form_class = VotanteForm
|
|
layout_key = None
|
|
|
|
class DetailView(MasterDetailCrud.DetailView):
|
|
|
|
def detail_create_url(self):
|
|
return None
|
|
|
|
class DeleteView(MasterDetailCrud.DeleteView):
|
|
|
|
def delete(self, *args, **kwargs):
|
|
obj = self.get_object()
|
|
if obj.user:
|
|
obj.user.delete()
|
|
return HttpResponseRedirect(
|
|
reverse('sapl.parlamentares:votante_list',
|
|
kwargs={'pk': obj.parlamentar.pk}))
|
|
|
|
|
|
class FrenteList(MasterDetailCrud):
|
|
model = Frente
|
|
is_m2m = True
|
|
parent_field = 'parlamentares'
|
|
CreateView, UpdateView, DeleteView = None, None, None
|
|
|
|
class BaseMixin(Crud.PublicMixin, MasterDetailCrud.BaseMixin):
|
|
list_field_names = ['nome', 'data_criacao']
|
|
|
|
@classmethod
|
|
def url_name(cls, suffix):
|
|
return '%s_parlamentar_%s' % (cls.model._meta.model_name, suffix)
|
|
|
|
|
|
class RelatoriaParlamentarCrud(CrudBaseForListAndDetailExternalAppView):
|
|
model = Relatoria
|
|
parent_field = 'parlamentar'
|
|
help_path = 'relatoria_parlamentar'
|
|
namespace = AppConfig.name
|
|
|
|
class BaseMixin(CrudBaseForListAndDetailExternalAppView.BaseMixin):
|
|
|
|
@classmethod
|
|
def url_name(cls, suffix):
|
|
return '%s_parlamentar_%s' % (cls.model._meta.model_name, suffix)
|
|
|
|
|
|
class ProposicaoParlamentarCrud(CrudBaseForListAndDetailExternalAppView):
|
|
model = Proposicao
|
|
list_field_names = ['tipo', 'descricao']
|
|
parent_field = 'autor__parlamentar_set'
|
|
namespace = AppConfig.name
|
|
|
|
class BaseMixin(CrudBaseForListAndDetailExternalAppView.BaseMixin):
|
|
|
|
@classmethod
|
|
def url_name(cls, suffix):
|
|
return '%s_parlamentar_%s' % (cls.model._meta.model_name, suffix)
|
|
|
|
class ListView(CrudBaseForListAndDetailExternalAppView.ListView):
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = CrudBaseForListAndDetailExternalAppView\
|
|
.ListView.get_context_data(self, **kwargs)
|
|
context['title'] = context['title'].replace(
|
|
'Proposições', 'Matérias')
|
|
return context
|
|
|
|
def get_queryset(self):
|
|
return super().get_queryset().filter(
|
|
data_envio__isnull=False,
|
|
data_recebimento__isnull=False)
|
|
|
|
class DetailView(CrudBaseForListAndDetailExternalAppView.DetailView):
|
|
|
|
@property
|
|
def extras_url(self):
|
|
|
|
if self.object.texto_articulado.exists():
|
|
ta = self.object.texto_articulado.first()
|
|
yield (str(reverse_lazy(
|
|
'sapl.compilacao:ta_text',
|
|
kwargs={'ta_id': ta.pk})) + '?back_type=history',
|
|
'btn-success',
|
|
_('Texto Eletrônico'))
|
|
|
|
|
|
class ParticipacaoParlamentarCrud(CrudBaseForListAndDetailExternalAppView):
|
|
model = Participacao
|
|
parent_field = 'parlamentar'
|
|
namespace = AppConfig.name
|
|
list_field_names = ['composicao__comissao__nome', 'cargo__nome', (
|
|
'composicao__periodo__data_inicio', 'composicao__periodo__data_fim')]
|
|
|
|
class BaseMixin(CrudBaseForListAndDetailExternalAppView.BaseMixin):
|
|
|
|
@classmethod
|
|
def url_name(cls, suffix):
|
|
return '%s_parlamentar_%s' % (cls.model._meta.model_name, suffix)
|
|
|
|
class ListView(CrudBaseForListAndDetailExternalAppView.ListView):
|
|
ordering = ('-composicao__periodo')
|
|
|
|
def get_rows(self, object_list):
|
|
"""
|
|
FIXME:
|
|
Este metodo não será necessário quando get_rows for refatorada
|
|
"""
|
|
|
|
comissoes = []
|
|
for p in object_list:
|
|
if p.cargo.nome != 'Relator':
|
|
comissao = [
|
|
(p.composicao.comissao.nome, reverse(
|
|
'sapl.comissoes:comissao_detail', kwargs={
|
|
'pk': p.composicao.comissao.pk})),
|
|
(p.cargo.nome, None),
|
|
(p.composicao.periodo.data_inicio.strftime(
|
|
"%d/%m/%Y") + ' a ' +
|
|
p.composicao.periodo.data_fim.strftime("%d/%m/%Y"),
|
|
None)
|
|
]
|
|
comissoes.append(comissao)
|
|
return comissoes
|
|
|
|
def get_headers(self):
|
|
return [_('Comissão'), _('Cargo'), _('Período de participação'), ]
|
|
|
|
|
|
class ColigacaoCrud(CrudAux):
|
|
model = Coligacao
|
|
help_path = 'tabelas_auxiliares#coligacao'
|
|
|
|
class ListView(CrudAux.ListView):
|
|
ordering = ('-numero_votos', 'nome')
|
|
|
|
class BaseMixin(CrudAux.BaseMixin):
|
|
subnav_template_name = 'parlamentares/subnav_coligacao.yaml'
|
|
|
|
|
|
class MandatoCrud(MasterDetailCrud):
|
|
model = Mandato
|
|
parent_field = 'parlamentar'
|
|
public = [RP_DETAIL, RP_LIST]
|
|
list_field_names = ['legislatura',
|
|
'votos_recebidos',
|
|
'coligacao',
|
|
'coligacao__numero_votos',
|
|
'titular']
|
|
|
|
class ListView(MasterDetailCrud.ListView):
|
|
ordering = ('-legislatura__numero')
|
|
|
|
class CreateView(MasterDetailCrud.CreateView):
|
|
form_class = MandatoForm
|
|
|
|
def get_initial(self):
|
|
return {'parlamentar': Parlamentar.objects.get(
|
|
pk=self.kwargs['pk'])}
|
|
|
|
|
|
class ComposicaoColigacaoCrud(MasterDetailCrud):
|
|
model = ComposicaoColigacao
|
|
parent_field = 'coligacao'
|
|
help_path = ''
|
|
|
|
class BaseMixin(MasterDetailCrud.BaseMixin):
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = super().get_context_data()
|
|
context['subnav_template_name'] = \
|
|
'parlamentares/subnav_coligacao.yaml'
|
|
return context
|
|
|
|
class ListView(MasterDetailCrud.ListView):
|
|
ordering = '-partido__sigla'
|
|
|
|
|
|
class LegislaturaCrud(CrudAux):
|
|
model = Legislatura
|
|
help_path = 'tabelas_auxiliares#legislatura'
|
|
|
|
class CreateView(CrudAux.CreateView):
|
|
form_class = LegislaturaCreateForm
|
|
|
|
def get_initial(self):
|
|
try:
|
|
ultima_legislatura = Legislatura.objects.latest('numero')
|
|
numero = ultima_legislatura.numero + 1
|
|
except Legislatura.DoesNotExist:
|
|
numero = 1
|
|
return {'numero': numero}
|
|
|
|
class UpdateView(CrudAux.UpdateView):
|
|
form_class = LegislaturaUpdateForm
|
|
|
|
|
|
class FiliacaoCrud(MasterDetailCrud):
|
|
model = Filiacao
|
|
parent_field = 'parlamentar'
|
|
help_path = ''
|
|
public = [RP_LIST, RP_DETAIL]
|
|
|
|
class BaseMixin(MasterDetailCrud.BaseMixin):
|
|
ordering = '-data'
|
|
|
|
class UpdateView(MasterDetailCrud.UpdateView):
|
|
form_class = FiliacaoForm
|
|
|
|
class CreateView(MasterDetailCrud.CreateView):
|
|
form_class = FiliacaoForm
|
|
|
|
|
|
class ParlamentarCrud(Crud):
|
|
model = Parlamentar
|
|
public = [RP_LIST, RP_DETAIL]
|
|
|
|
class BaseMixin(Crud.BaseMixin):
|
|
ordered_list = False
|
|
list_field_names = [
|
|
'avatar_html',
|
|
'nome_parlamentar',
|
|
'filiacao_atual',
|
|
'ativo',
|
|
'mandato_titular']
|
|
|
|
class DetailView(Crud.DetailView):
|
|
|
|
def get_template_names(self):
|
|
return ['crud/detail.html']\
|
|
if self.request.user.has_perm(self.permission(RP_CHANGE))\
|
|
else ['parlamentares/parlamentar_perfil_publico.html']
|
|
|
|
class UpdateView(Crud.UpdateView):
|
|
form_class = ParlamentarForm
|
|
|
|
class CreateView(Crud.CreateView):
|
|
form_class = ParlamentarCreateForm
|
|
|
|
@property
|
|
def layout_key(self):
|
|
return 'ParlamentarCreate'
|
|
|
|
def form_valid(self, form):
|
|
'''
|
|
Reimplementa form_valid devido ao save de ParlamentarCreateForm
|
|
ser específico, sendo necessário isolar padrão do crud que aciona
|
|
form.save(commit=False) para registrar dados de auditoria se
|
|
o model implementá-los, bem como de container se também implement.
|
|
'''
|
|
return super(Crud.CreateView, self).form_valid(form)
|
|
|
|
class ListView(Crud.ListView):
|
|
template_name = "parlamentares/parlamentares_list.html"
|
|
paginate_by = None
|
|
|
|
def take_legislatura_id(self):
|
|
try:
|
|
return int(self.request.GET['pk'])
|
|
except:
|
|
for l in Legislatura.objects.all():
|
|
if l.atual():
|
|
return l.id
|
|
return 0
|
|
|
|
def get_queryset(self):
|
|
queryset = super().get_queryset()
|
|
legislatura_id = self.take_legislatura_id()
|
|
if legislatura_id != 0:
|
|
return queryset.filter(
|
|
mandato__legislatura_id=legislatura_id).annotate(
|
|
mandato_titular=F('mandato__titular'))
|
|
else:
|
|
try:
|
|
l = Legislatura.objects.all().order_by(
|
|
'-data_inicio').first()
|
|
except ObjectDoesNotExist:
|
|
return Legislatura.objects.all()
|
|
else:
|
|
if l is None:
|
|
return Legislatura.objects.all()
|
|
return queryset.filter(mandato__legislatura_id=l).annotate(
|
|
mandato_titular=F('mandato__titular'))
|
|
|
|
def get_headers(self):
|
|
return ['',
|
|
_('Parlamentar'), _('Partido'),
|
|
_('Ativo?'), _('Titular?')]
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
# Adiciona legislatura para filtrar parlamentares
|
|
legislaturas = Legislatura.objects.all().order_by('-numero')
|
|
context['legislaturas'] = legislaturas
|
|
context['legislatura_id'] = self.take_legislatura_id()
|
|
|
|
# Tira Link do avatar_html e coloca no nome
|
|
for row in context['rows']:
|
|
|
|
# preenche coluna foto, se vazia
|
|
if not row[0][0]:
|
|
img = "<center><img width='50px' \
|
|
height='50px' src='%s'/></center>" \
|
|
% static('img/avatar.png')
|
|
row[0] = (img, row[0][1])
|
|
|
|
# Coloca a filiação atual ao invés da última
|
|
if row[0][1]:
|
|
# Pega o Parlamentar por meio da pk
|
|
parlamentar = Parlamentar.objects.get(
|
|
id=(row[0][1].split('/')[-1]))
|
|
|
|
# Pega a Legislatura
|
|
legislatura = Legislatura.objects.get(
|
|
id=context['legislatura_id'])
|
|
|
|
# As condições para mostrar a filiação são:
|
|
# A data de filiacao deve ser menor que a data de fim
|
|
# da legislatura e data de desfiliação deve nula, ou maior,
|
|
# ou igual a data de fim da legislatura
|
|
try:
|
|
filiacao = parlamentar.filiacao_set.get(Q(
|
|
data__lte=legislatura.data_fim,
|
|
data_desfiliacao__gte=legislatura.data_fim) | Q(
|
|
data__lte=legislatura.data_fim,
|
|
data_desfiliacao__isnull=True))
|
|
|
|
# Caso não exista filiação com essas condições
|
|
except ObjectDoesNotExist:
|
|
row[2] = ('Não possui filiação', None)
|
|
|
|
# Caso exista mais de uma filiação nesse intervalo
|
|
# Entretanto, NÃO DEVE OCORRER
|
|
except MultipleObjectsReturned:
|
|
row[2] = (
|
|
'O Parlamentar possui duas filiações conflitantes',
|
|
None)
|
|
|
|
# Caso encontre UMA filiação nessas condições
|
|
else:
|
|
row[2] = (filiacao.partido.sigla, None)
|
|
|
|
row[1] = (row[1][0], row[0][1])
|
|
row[0] = (row[0][0], None)
|
|
|
|
return context
|
|
|
|
|
|
class MesaDiretoraView(FormView):
|
|
template_name = 'parlamentares/composicaomesa_form.html'
|
|
success_url = reverse_lazy('sapl.parlamentares:mesa_diretora')
|
|
|
|
def get_template_names(self):
|
|
return ['parlamentares/composicaomesa_form.html']\
|
|
if self.request.user.has_perm(
|
|
'parlamentares.change_composicaomesa')\
|
|
else ['parlamentares/public_composicaomesa_form.html']
|
|
|
|
# Essa função avisa quando se pode compor uma Mesa Legislativa
|
|
def validation(self, request):
|
|
mensagem = _('Não há nenhuma Sessão Legislativa cadastrada. ' +
|
|
'Só é possível compor uma Mesa Diretora quando ' +
|
|
'há uma Sessão Legislativa cadastrada.')
|
|
messages.add_message(request, messages.INFO, mensagem)
|
|
|
|
return self.render_to_response(
|
|
{'legislaturas': Legislatura.objects.all(
|
|
).order_by('-numero'),
|
|
'legislatura_selecionada': Legislatura.objects.last(),
|
|
'cargos_vagos': CargoMesa.objects.all()})
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
if (not Legislatura.objects.exists() or
|
|
not SessaoLegislativa.objects.exists()):
|
|
return self.validation(request)
|
|
|
|
sessao = SessaoLegislativa.objects.filter(
|
|
legislatura=Legislatura.objects.first()).first(
|
|
)
|
|
|
|
mesa = sessao.composicaomesa_set.all() if sessao else []
|
|
|
|
cargos_ocupados = [m.cargo for m in mesa]
|
|
cargos = CargoMesa.objects.all()
|
|
cargos_vagos = list(set(cargos) - set(cargos_ocupados))
|
|
|
|
parlamentares = Legislatura.objects.first().mandato_set.all()
|
|
parlamentares_ocupados = [m.parlamentar for m in mesa]
|
|
parlamentares_vagos = list(
|
|
set(
|
|
[p.parlamentar for p in parlamentares]) - set(
|
|
parlamentares_ocupados))
|
|
|
|
# Se todos os cargos estiverem ocupados, a listagem de parlamentares
|
|
# deve ser renderizada vazia
|
|
if not cargos_vagos:
|
|
parlamentares_vagos = []
|
|
|
|
return self.render_to_response(
|
|
{'legislaturas': Legislatura.objects.all(
|
|
).order_by('-numero'),
|
|
'legislatura_selecionada': Legislatura.objects.first(),
|
|
'sessoes': SessaoLegislativa.objects.filter(
|
|
legislatura=Legislatura.objects.first()),
|
|
'sessao_selecionada': SessaoLegislativa.objects.filter(
|
|
legislatura=Legislatura.objects.first()).first(),
|
|
'composicao_mesa': mesa,
|
|
'parlamentares': parlamentares_vagos,
|
|
'cargos_vagos': cargos_vagos
|
|
})
|
|
|
|
|
|
def altera_field_mesa(request):
|
|
"""
|
|
Essa função lida com qualquer alteração nos campos
|
|
da Mesa Diretora, após qualquer
|
|
operação (Legislatura/Sessão/Inclusão/Remoção),
|
|
atualizando os campos após cada alteração
|
|
"""
|
|
|
|
legislatura = request.GET['legislatura']
|
|
sessoes = SessaoLegislativa.objects.filter(
|
|
legislatura=legislatura).order_by('-data_inicio')
|
|
|
|
if not sessoes:
|
|
return JsonResponse({'msg': ('Nenhuma sessão encontrada!', 0)})
|
|
|
|
# Verifica se já tem uma sessão selecionada. Ocorre quando
|
|
# é alterado o campo de sessão ou feita alguma operação
|
|
# de inclusão/remoção.
|
|
if request.GET['sessao']:
|
|
sessao_selecionada = request.GET['sessao']
|
|
# Caso a mudança tenha sido no campo legislatura, a sessão
|
|
# atual deve ser a primeira daquela legislatura
|
|
else:
|
|
sessao_selecionada = SessaoLegislativa.objects.filter(
|
|
legislatura=legislatura).order_by(
|
|
'-data_inicio').first().id
|
|
|
|
# Atualiza os componentes da view após a mudança
|
|
composicao_mesa = ComposicaoMesa.objects.filter(
|
|
sessao_legislativa=sessao_selecionada)
|
|
|
|
cargos_ocupados = [m.cargo for m in composicao_mesa]
|
|
cargos = CargoMesa.objects.all()
|
|
cargos_vagos = list(set(cargos) - set(cargos_ocupados))
|
|
|
|
parlamentares = Legislatura.objects.get(
|
|
id=legislatura).mandato_set.all()
|
|
parlamentares_ocupados = [m.parlamentar for m in composicao_mesa]
|
|
parlamentares_vagos = list(
|
|
set(
|
|
[p.parlamentar for p in parlamentares]) - set(
|
|
parlamentares_ocupados))
|
|
|
|
lista_sessoes = [(s.id, s.__str__()) for s in sessoes]
|
|
lista_composicao = [(c.id, c.parlamentar.__str__(),
|
|
c.cargo.__str__()) for c in composicao_mesa]
|
|
lista_parlamentares = [(
|
|
p.id, p.__str__()) for p in parlamentares_vagos]
|
|
lista_cargos = [(c.id, c.__str__()) for c in cargos_vagos]
|
|
|
|
return JsonResponse(
|
|
{'lista_sessoes': lista_sessoes,
|
|
'lista_composicao': lista_composicao,
|
|
'lista_parlamentares': lista_parlamentares,
|
|
'lista_cargos': lista_cargos,
|
|
'sessao_selecionada': sessao_selecionada,
|
|
'msg': ('', 1)})
|
|
|
|
|
|
def insere_parlamentar_composicao(request):
|
|
"""
|
|
Essa função lida com qualquer operação de inserção
|
|
na composição da Mesa Diretora
|
|
"""
|
|
|
|
if request.user.has_perm(
|
|
'%s.add_%s' % (
|
|
AppConfig.label, ComposicaoMesa._meta.model_name)):
|
|
|
|
composicao = ComposicaoMesa()
|
|
|
|
try:
|
|
composicao.sessao_legislativa = SessaoLegislativa.objects.get(
|
|
id=int(request.POST['sessao']))
|
|
except MultiValueDictKeyError:
|
|
return JsonResponse({'msg': ('Nenhuma sessão foi inserida!', 0)})
|
|
|
|
try:
|
|
composicao.parlamentar = Parlamentar.objects.get(
|
|
id=int(request.POST['parlamentar']))
|
|
except MultiValueDictKeyError:
|
|
return JsonResponse({
|
|
'msg': ('Nenhum parlamentar foi inserido!', 0)})
|
|
|
|
try:
|
|
composicao.cargo = CargoMesa.objects.get(
|
|
id=int(request.POST['cargo']))
|
|
parlamentar_ja_inserido = ComposicaoMesa.objects.filter(
|
|
sessao_legislativa_id=composicao.sessao_legislativa.id,
|
|
cargo_id=composicao.cargo.id).exists()
|
|
|
|
if parlamentar_ja_inserido:
|
|
return JsonResponse({'msg': ('Parlamentar já inserido!', 0)})
|
|
|
|
composicao.save()
|
|
|
|
except MultiValueDictKeyError:
|
|
return JsonResponse({'msg': ('Nenhum cargo foi inserido!', 0)})
|
|
|
|
return JsonResponse({'msg': ('Parlamentar inserido com sucesso!', 1)})
|
|
|
|
else:
|
|
return JsonResponse(
|
|
{'msg': ('Você não tem permissão para esta operação!', 0)})
|
|
|
|
|
|
def remove_parlamentar_composicao(request):
|
|
"""
|
|
Essa função lida com qualquer operação de remoção
|
|
na composição da Mesa Diretora
|
|
"""
|
|
|
|
if request.POST and request.user.has_perm(
|
|
'%s.delete_%s' % (
|
|
AppConfig.label, ComposicaoMesa._meta.model_name)):
|
|
|
|
if 'composicao_mesa' in request.POST:
|
|
try:
|
|
composicao = ComposicaoMesa.objects.get(
|
|
id=request.POST['composicao_mesa'])
|
|
except ObjectDoesNotExist:
|
|
return JsonResponse(
|
|
{'msg': (
|
|
'Composição da Mesa não pôde ser removida!', 0)})
|
|
|
|
composicao.delete()
|
|
|
|
return JsonResponse(
|
|
{'msg': (
|
|
'Parlamentar excluido com sucesso!', 1)})
|
|
else:
|
|
return JsonResponse(
|
|
{'msg': (
|
|
'Selecione algum parlamentar para ser excluido!', 0)})
|
|
|
|
|
|
def partido_parlamentar_sessao_legislativa(sessao, parlamentar):
|
|
"""
|
|
Função para descobrir o partido do parlamentar durante
|
|
o período de uma dada Sessão Legislativa
|
|
"""
|
|
|
|
# As condições para mostrar a filiação são:
|
|
# A data de filiacao deve ser menor que a data de fim
|
|
# da sessao legislativa e data de desfiliação deve nula, ou maior,
|
|
# ou igual a data de fim da sessao
|
|
try:
|
|
filiacao = parlamentar.filiacao_set.get(Q(
|
|
data__lte=sessao.data_fim,
|
|
data_desfiliacao__gte=sessao.data_fim) | Q(
|
|
data__lte=sessao.data_fim,
|
|
data_desfiliacao__isnull=True))
|
|
|
|
# Caso não exista filiação com essas condições
|
|
except ObjectDoesNotExist:
|
|
return ''
|
|
|
|
# Caso exista mais de uma filiação nesse intervalo
|
|
# Entretanto, NÃO DEVE OCORRER
|
|
except MultipleObjectsReturned:
|
|
return 'O Parlamentar possui duas filiações conflitantes'
|
|
|
|
# Caso encontre UMA filiação nessas condições
|
|
else:
|
|
return filiacao.partido.sigla
|
|
|
|
|
|
def altera_field_mesa_public_view(request):
|
|
"""
|
|
Essa função lida com qualquer alteração nos campos
|
|
da Mesa Diretora para usuários anônimos,
|
|
atualizando os campos após cada alteração
|
|
"""
|
|
|
|
legislatura = request.GET['legislatura']
|
|
sessoes = SessaoLegislativa.objects.filter(
|
|
legislatura=legislatura).order_by('-data_inicio')
|
|
|
|
if not sessoes:
|
|
return JsonResponse({'msg': ('Nenhuma sessão encontrada!', 0)})
|
|
|
|
# Verifica se já tem uma sessão selecionada. Ocorre quando
|
|
# é alterado o campo de sessão
|
|
if request.GET['sessao']:
|
|
sessao_selecionada = request.GET['sessao']
|
|
# Caso a mudança tenha sido no campo legislatura, a sessão
|
|
# atual deve ser a primeira daquela legislatura
|
|
else:
|
|
sessao_selecionada = sessoes.first().id
|
|
|
|
# Atualiza os componentes da view após a mudança
|
|
lista_sessoes = [(s.id, s.__str__()) for s in sessoes]
|
|
|
|
composicao_mesa = ComposicaoMesa.objects.filter(
|
|
sessao_legislativa=sessao_selecionada)
|
|
|
|
cargos_ocupados = [(m.cargo.id,
|
|
m.cargo.__str__()) for m in composicao_mesa]
|
|
|
|
parlamentares_ocupados = [(m.parlamentar.id,
|
|
m.parlamentar.__str__()
|
|
) for m in composicao_mesa]
|
|
|
|
lista_fotos = []
|
|
lista_partidos = []
|
|
|
|
sessao = SessaoLegislativa.objects.get(id=sessao_selecionada)
|
|
for p in parlamentares_ocupados:
|
|
parlamentar = Parlamentar.objects.get(id=p[0])
|
|
lista_partidos.append(
|
|
partido_parlamentar_sessao_legislativa(sessao,
|
|
parlamentar))
|
|
if parlamentar.fotografia:
|
|
lista_fotos.append(parlamentar.fotografia.url)
|
|
else:
|
|
lista_fotos.append(None)
|
|
|
|
return JsonResponse(
|
|
{'lista_parlamentares': parlamentares_ocupados,
|
|
'lista_partidos': lista_partidos,
|
|
'lista_cargos': cargos_ocupados,
|
|
'lista_sessoes': lista_sessoes,
|
|
'lista_fotos': lista_fotos,
|
|
'sessao_selecionada': sessao_selecionada,
|
|
'msg': ('', 1)})
|
|
|