Browse Source

Fix #1012 bug mesa diretora (#1022)

* Inicia o bug fix

* Refatora funcionalidades de inserção e remoção

* Lança os possíveis erros para o usuário na tela

* Otimiza o codigo
pull/1070/head
eduardocalil 8 years ago
committed by Edward
parent
commit
a7ed403bc0
  1. 17
      sapl/parlamentares/urls.py
  2. 235
      sapl/parlamentares/views.py
  3. 17
      sapl/static/js/app.js
  4. 371
      sapl/templates/parlamentares/composicaomesa_form.html

17
sapl/parlamentares/urls.py

@ -1,14 +1,18 @@
from django.conf.urls import include, url from django.conf.urls import include, url
from sapl.parlamentares.views import (CargoMesaCrud, ColigacaoCrud, from sapl.parlamentares.views import (altera_field_mesa,
CargoMesaCrud, ColigacaoCrud,
ComposicaoColigacaoCrud, DependenteCrud, ComposicaoColigacaoCrud, DependenteCrud,
FiliacaoCrud, FrenteCrud, FrenteList, FiliacaoCrud, FrenteCrud, FrenteList,
LegislaturaCrud, MandatoCrud, LegislaturaCrud,
insere_parlamentar_composicao,
MandatoCrud,
MesaDiretoraView, NivelInstrucaoCrud, MesaDiretoraView, NivelInstrucaoCrud,
ParlamentarCrud, ParlamentarCrud,
ParticipacaoParlamentarCrud, PartidoCrud, ParticipacaoParlamentarCrud, PartidoCrud,
ProposicaoParlamentarCrud, ProposicaoParlamentarCrud,
RelatoriaParlamentarCrud, RelatoriaParlamentarCrud,
remove_parlamentar_composicao,
SessaoLegislativaCrud, SessaoLegislativaCrud,
TipoAfastamentoCrud, TipoDependenteCrud, TipoAfastamentoCrud, TipoDependenteCrud,
TipoMilitarCrud, VotanteView) TipoMilitarCrud, VotanteView)
@ -51,4 +55,13 @@ urlpatterns = [
url(r'^mesa-diretora/$', url(r'^mesa-diretora/$',
MesaDiretoraView.as_view(), name='mesa_diretora'), MesaDiretoraView.as_view(), name='mesa_diretora'),
url(r'^mesa-diretora/altera-field-mesa/$',
altera_field_mesa, name='altera_field_mesa'),
url(r'^mesa-diretora/insere-parlamentar-composicao/$',
insere_parlamentar_composicao, name='insere_parlamentar_composicao'),
url(r'^mesa-diretora/remove-parlamentar-composicao/$',
remove_parlamentar_composicao, name='remove_parlamentar_composicao'),
] ]

235
sapl/parlamentares/views.py

@ -2,6 +2,7 @@ from django.contrib import messages
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned
from django.core.urlresolvers import reverse, reverse_lazy from django.core.urlresolvers import reverse, reverse_lazy
from django.db.models import F, Q from django.db.models import F, Q
from django.http import JsonResponse
from django.http.response import HttpResponseRedirect from django.http.response import HttpResponseRedirect
from django.utils.datastructures import MultiValueDictKeyError from django.utils.datastructures import MultiValueDictKeyError
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
@ -434,6 +435,11 @@ class MesaDiretoraView(FormView):
[p.parlamentar for p in parlamentares]) - set( [p.parlamentar for p in parlamentares]) - set(
parlamentares_ocupados)) 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( return self.render_to_response(
{'legislaturas': Legislatura.objects.all( {'legislaturas': Legislatura.objects.all(
).order_by('-numero'), ).order_by('-numero'),
@ -447,107 +453,138 @@ class MesaDiretoraView(FormView):
'cargos_vagos': cargos_vagos 'cargos_vagos': cargos_vagos
}) })
def existe_membro_mesa(self, sessao_plenaria, cargo):
return ComposicaoMesa.objects.filter(
sessao_legislativa_id=sessao_plenaria.id,
# parlamentar_id = integrante.parlamentar_id,
cargo_id=cargo.id
).exists()
def post(self, request, *args, **kwargs):
if (not Legislatura.objects.exists() or
not SessaoLegislativa.objects.exists()):
return self.validation(request)
if 'Incluir' in request.POST and 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:
messages.error(request, _(
'Nenhuma sessão foi inserida!'))
return self.get(request)
try:
composicao.parlamentar = Parlamentar.objects.get(
id=int(request.POST['parlamentar']))
except MultiValueDictKeyError:
messages.error(request, _(
'Nenhum parlamentar foi inserido!'))
return self.get(request)
try: def altera_field_mesa(request):
composicao.cargo = CargoMesa.objects.get( """
id=int(request.POST['cargo'])) Essa função lida com qualquer alteração nos campos
if self.existe_membro_mesa(composicao.sessao_legislativa, da Mesa Diretora, após qualquer
composicao.cargo): operação (Legislatura/Sessão/Inclusão/Remoção),
messages.error(request, _('Parlamentar já inserido!')) atualizando os campos após cada alteração
return self.get(request) """
composicao.save() legislatura = request.GET['legislatura']
except MultiValueDictKeyError: sessoes = SessaoLegislativa.objects.filter(
messages.error(request, _( legislatura=legislatura).order_by('-data_inicio')
'Nenhum cargo foi inserido!'))
return self.get(request) if not sessoes:
return JsonResponse({'msg': ('Nenhuma sessão encontrada!', 0)})
messages.success(request, _(
'Parlamentar adicionado com sucesso!')) # Verifica se já tem uma sessão selecionada. Ocorre quando
# é alterado o campo de sessão ou feita alguma operação
elif 'Excluir' in request.POST and request.user.has_perm( # de inclusão/remoção.
'%s.delete_%s' % ( if request.GET['sessao']:
AppConfig.label, ComposicaoMesa._meta.model_name)): 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: if 'composicao_mesa' in request.POST:
ids = request.POST['composicao_mesa'].split(':') try:
composicao = ComposicaoMesa.objects.get( composicao = ComposicaoMesa.objects.get(
sessao_legislativa_id=int(request.POST['sessao']), id=request.POST['composicao_mesa'])
parlamentar_id=int(ids[0]), except ObjectDoesNotExist:
cargo_id=int(ids[1]) return JsonResponse(
) {'msg': (
composicao.delete() 'Composição da Mesa não pôde ser removida!', 0)})
messages.success(request, _(
'Parlamentar excluido com sucesso!'))
else:
messages.error(request, _(
'Selecione um parlamentar para ser excluido!'))
mesa = ComposicaoMesa.objects.filter(
sessao_legislativa=request.POST['sessao'])
cargos_ocupados = [m.cargo for m in mesa]
cargos = CargoMesa.objects.all()
cargos_vagos = list(set(cargos) - set(cargos_ocupados))
parlamentares = Legislatura.objects.get(
id=int(request.POST['legislatura'])).mandato_set.all()
parlamentares_ocupados = [m.parlamentar for m in mesa]
parlamentares_vagos = list(
set(
[p.parlamentar for p in parlamentares]) - set(
parlamentares_ocupados))
sessao_sel = SessaoLegislativa.objects.get(
id=int(request.POST['sessao']))
if str(sessao_sel.legislatura_id) != request.POST['legislatura']: composicao.delete()
sessao_sel = SessaoLegislativa.objects.filter(
legislatura=Legislatura.objects.first()).first()
return self.render_to_response( return JsonResponse(
{'legislaturas': Legislatura.objects.all( {'msg': (
).order_by('-numero'), 'Parlamentar excluido com sucesso!', 1)})
'legislatura_selecionada': Legislatura.objects.get( else:
id=int(request.POST['legislatura'])), return JsonResponse(
'sessoes': SessaoLegislativa.objects.filter( {'msg': (
legislatura_id=int(request.POST['legislatura'])), 'Selecione algum parlamentar para ser excluido!', 0)})
'sessao_selecionada': sessao_sel,
'composicao_mesa': mesa,
'parlamentares': parlamentares_vagos,
'cargos_vagos': cargos_vagos
})

17
sapl/static/js/app.js

@ -217,3 +217,20 @@ $(document).ready(function(){
OptionalCustomFrontEnd(); OptionalCustomFrontEnd();
}); });
function getCookie(name) {
var cookieValue = null;
if (document.cookie && document.cookie !== '') {
var cookies = document.cookie.split(';');
for (var i = 0; i < cookies.length; i++) {
var cookie = jQuery.trim(cookies[i]);
// Does this cookie string begin with the name we want?
if (cookie.substring(0, name.length + 1) === (name + '=')) {
cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
break;
}
}
}
return cookieValue;
}

371
sapl/templates/parlamentares/composicaomesa_form.html

@ -8,82 +8,301 @@
<b>{{legislatura_selecionada}}</b> não possui nenhuma Sessão Legislativa cadastrada.<br /> <b>{{legislatura_selecionada}}</b> não possui nenhuma Sessão Legislativa cadastrada.<br />
Clique <a href="{% url 'sapl.parlamentares:sessaolegislativa_create' %}">aqui</a> para cadastrar uma nova. Clique <a href="{% url 'sapl.parlamentares:sessaolegislativa_create' %}">aqui</a> para cadastrar uma nova.
</div> </div>
{% else %} {% else %}
<form method="POST"> <div class="alert alert-danger alert-dismissible fade in" id="div-error" role="alert" style="display: none">
{% csrf_token %} <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<fieldset class="form-group"> <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
<legend>Escolha da Legislatura e da Sessão Legislativa</legend> </button>
<div class="row"> <b><span id="error-message"></span></b>
<div class="col-md-6"> </div>
<label>Escolha uma Legislatura</label>
<select name="legislatura" class="form-control" onChange="form.submit();"> <div class="alert alert-success alert-dismissible fade in" id="div-success" style="display: none" role="alert">
{% for l in legislaturas %} <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<option value="{{l.id}}" {% if l == legislatura_selecionada %} selected {% endif %}> <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
{{l}} </button>
</option> <b><span id="success-message"></span></b>
{% endfor %} </div>
</select>
</div> <fieldset class="form-group">
<div class="col-md-6"> <legend>Escolha da Legislatura e da Sessão Legislativa</legend>
<label>Escolha uma Sessão Legislativa</label> <div class="row">
<select name="sessao" class="form-control" onChange="form.submit();"> <div class="col-md-6">
{% for s in sessoes %} <label>Escolha uma Legislatura</label>
<option value="{{s.id}}" {% if s == sessao_selecionada %} selected {% endif %}> <select name="legislatura" id="id_legislatura" class="form-control">
{{s}} {% for l in legislaturas %}
</option> <option value="{{l.id}}" {% if l == legislatura_selecionada %} selected {% endif %}>
{% endfor %} {{l}}
</select> </option>
</div> {% endfor %}
</div> </select>
</fieldset> </div>
<br /> <div class="col-md-6">
<fieldset class="form-group"> <label>Escolha uma Sessão Legislativa</label>
<legend>Escolha da Composição da Mesa Diretora</legend> <select name="sessao" id="id_sessao_legislativa" class="form-control">
<div class="row"> {% for s in sessoes %}
<div class="col-md-4"> <option value="{{s.id}}" {% if s == sessao_selecionada %} selected {% endif %}>
<label>Composição da Mesa Diretora</label> {{s}}
<select multiple size="5" class="form-control" name="composicao_mesa"> </option>
{% for p in composicao_mesa %} {% endfor %}
<option value="{{p.parlamentar.id}}:{{p.cargo.id}}"> </select>
{{p.parlamentar}} || {{p.cargo}} </div>
</option> </div>
{% endfor %} </fieldset>
</select> <br />
</div> <fieldset class="form-group">
<legend>Escolha da Composição da Mesa Diretora</legend>
<div class="col-md-4" align="center"> <div class="row">
<br /><br /> <div class="col-md-4">
{% if cargos_vagos %} <label>Composição da Mesa Diretora</label>
{% if perms.parlamentares.add_cargomesa %} <select multiple size="5" class="form-control" id="id_composicao_mesa" name="composicao_mesa">
<input type="submit" name="Incluir" Value="Incluir" class="btn btn-primary" /> {% for p in composicao_mesa %}
{% endif %} <option value="{{p.id}}">
{% endif %} {{p.parlamentar}} || {{p.cargo}}
<br /> </option>
<br /> {% endfor %}
{% if perms.parlamentares.add_composicaomesa %} </select>
<input type="submit" name="Excluir" Value="Excluir" class="btn btn-danger" /> </div>
{% endif %}
</div> <div class="col-md-4" align="center">
<br /><br />
{% if cargos_vagos %} {% if perms.parlamentares.add_cargomesa %}
<div class="col-md-4"> <input type="submit" style="display: none" name="Incluir" id="id_incluir" Value="Incluir" class="btn btn-primary" />
<label>Parlamentare | Cargo</label> {% endif %}
<select class="form-control" name="parlamentar" id="parlamentar"> <br />
{% for p in parlamentares %} <br />
<option value="{{p.id}}">{{p.nome_completo}}</option> {% if perms.parlamentares.add_composicaomesa %}
{% endfor %} <input type="submit" style="display: none" name="Excluir" id="id_excluir" Value="Excluir" class="btn btn-danger" />
</select> {% endif %}
<br /> </div>
<select class="form-control" name="cargo" id="cargo">
{% for c in cargos_vagos %} <div class="col-md-4">
<option value="{{c.id}}">{{c}}</option> <label id='parlamentar-cargo-title' style="display: none">Parlamentar | Cargo</label>
{% endfor %} <select class="form-control" name="parlamentar" id="id_parlamentar" style="display: none">
</select> {% for p in parlamentares %}
</div> <option value="{{p.id}}">{{p.nome_completo}}</option>
{% endif %} {% endfor %}
</select>
</div> <br />
</fieldset> <select class="form-control" name="cargo" id="id_cargo" style="display: none">
</form> {% for c in cargos_vagos %}
<option value="{{c.id}}">{{c}}</option>
{% endfor %}
</select>
</div>
</div>
</fieldset>
{% endif %} {% endif %}
{% endblock detail_content %} {% endblock detail_content %}
{% block extra_js %}
<script language="Javascript">
//##############################################################
// Inicialização da View #
//##############################################################
// Se a composicao estiver completa, deve-se esconder o botão e os
// campos de inserção
$(document).ready(function(){
if($("#id_parlamentar").val() == null || $("#id_cargo").val() == null){
$("#id_parlamentar").hide();
$("#id_cargo").hide();
$("#parlamentar-cargo-title").hide();
$('#id_incluir').hide();
}
else{
$("#id_parlamentar").show();
$("#id_cargo").show();
$("#parlamentar-cargo-title").show();
$('#id_incluir').show();
}
// Se a composição estiver vazia, deve-se esconder
// de Excluir
if (!$("#id_composicao_mesa option").val()){
$("#id_excluir").hide()
}
else{
$("#id_excluir").show()
}
});
//##############################################################
//# EVENT HANDLERS #
//##############################################################
function errors_handler(msg){
if (msg == null){
$("#div-success").hide()
$("#div-error").hide()
$("#success-message").html('')
$("#error-message").html('')
}
else{
if (msg[1] == 0){
$("#div-error").show()
$("#error-message").html(msg[0])
}
else{
$("#div-success").show()
$("#success-message").html(msg[0])
}
}
}
// Atualiza os campos após alguma operação de mudança da Legislatura/Sessao ou
// Inserção/Remoção
function altera_field(id_legislatura, id_sessao=null, msg=null){
// Pega o novo valor do campo que foi modificado (Sessao/Legislatura) ou utiliza
// o valor da Legislatura, por conveniência, quando há alguma inserção ou remoção
var sessao_value = id_sessao
var legislatura_value = id_legislatura
// Limpa os campos que serão atualizados
$("#id_sessao_legislativa option").remove();
$("#id_composicao_mesa option").remove();
$("#id_parlamentar option").remove();
$("#id_cargo option").remove();
$.get("/mesa-diretora/altera-field-mesa",
{legislatura: legislatura_value, sessao: sessao_value},
function(data) {
// Caso não venha nenhum dado da requisição, retorna null
if ($.isEmptyObject(data)){
return null
}
lista_sessoes = data['lista_sessoes'];
lista_composicao = data['lista_composicao'];
lista_parlamentares = data['lista_parlamentares'];
lista_cargos = data['lista_cargos'];
// Atualiza a listagem dos campos
for (i = 0; i < lista_sessoes.length; i++) {
$('#id_sessao_legislativa').append('<option value="' + lista_sessoes[i][0] + '">' + lista_sessoes[i][1] + '</option>');
}
for (i = 0; i < lista_composicao.length; i++) {
$('#id_composicao_mesa').append('<option value="' + lista_composicao[i][0] + '">' + lista_composicao[i][1] + ' || ' + lista_composicao[i][2] + '</option>');
}
// Caso ainda tenha parlamentares/cargos a serem inseridos, preenche a listagem com
// os disponíveis e garante que as ferramentas de inserção estejam disponíveis
if (lista_parlamentares.length != 0 && lista_cargos.length != 0){
$('#id_incluir').show()
$('#id_cargo').show();
$('#id_parlamentar').show();
$("#parlamentar-cargo-title").show();
for (i = 0; i < lista_parlamentares.length; i++) {
$('#id_parlamentar').append('<option value="' + lista_parlamentares[i][0] + '">' + lista_parlamentares[i][1] + '</option>');
}
for (i = 0; i < lista_cargos.length; i++) {
$('#id_cargo').append('<option value="' + lista_cargos[i][0] + '">' + lista_cargos[i][1] + '</option>');
}
}
// Caso contrário, esconde do usuário essas opções
else{
$('#id_incluir').hide();
$('#id_cargo').hide();
$('#id_parlamentar').hide();
$("#parlamentar-cargo-title").hide();
}
// Garante que o botão de remoção aparecerá, caso tenha
// algum parlamentar na composição
if (lista_composicao.length != 0){
$("#id_excluir").show()
}
else{
$("#id_excluir").hide()
}
// Garante que a Sessão atual será a selecionada previamente e, no caso em que
// o campo modificado seja o de Legislatura, que a Sessão seja a última daquela
// legislatura
$("#id_sessao_legislativa").val(data['sessao_selecionada'])
// Caso haja algum erro que venha após a alteração da legislatura/sessao
// Essa mensagem de erro é prioridade
if (data['msg'][1] == 0){
msg = data['msg']
}
errors_handler(msg)
});
}
//#############################################################
//# EVENTS CATCH #
//#############################################################
$("#id_legislatura").change(function(){
legislatura = $("#id_legislatura").val();
altera_field(legislatura);
});
$("#id_sessao_legislativa").change(function(){
legislatura = $("#id_legislatura").val();
sessao = $("#id_sessao_legislativa").val();
altera_field(legislatura, sessao);
});
$('#id_incluir').click(function(){
$.ajax({
data: {sessao: $("#id_sessao_legislativa").val(),
parlamentar: $("#id_parlamentar").val(),
cargo: $("#id_cargo").val()},
type: 'POST',
url: "{% url 'sapl.parlamentares:insere_parlamentar_composicao' %}",
headers: {
'X-CSRFToken': getCookie('csrftoken')
},
success: function(data){
var msg = data['msg'];
legislatura = $("#id_legislatura").val();
sessao = $("#id_sessao_legislativa").val();
setTimeout(function(data){
// Atualiza os campos após a inserção
altera_field(legislatura, sessao, msg)
}, 500)
},
});
})
$('#id_excluir').click(function(){
// Pega o id do parlamentar que foi selecionado
selecionado = $("#id_composicao_mesa option:selected").val()
if (selecionado){
$.ajax({
data: {composicao_mesa: selecionado},
type: 'POST',
url: "{% url 'sapl.parlamentares:remove_parlamentar_composicao' %}",
headers: {
'X-CSRFToken': getCookie('csrftoken')
},
success: function(data){
var msg = data['msg'];
legislatura = $("#id_legislatura").val();
sessao = $("#id_sessao_legislativa").val();
setTimeout(function(data){
// Atualiza os campos após a remoção
altera_field(legislatura, sessao, msg)
}, 500)
},
});
}
});
</script>
{% endblock %}

Loading…
Cancel
Save