Browse Source

Refatora Mesa Diretora para Usuário Anônimo (#1078)

pull/1000/merge
eduardocalil 8 years ago
committed by Edward
parent
commit
e84733ccc3
  1. 1
      .gitignore
  2. 4
      sapl/parlamentares/urls.py
  3. 99
      sapl/parlamentares/views.py
  4. 1
      sapl/settings.py
  5. 3
      sapl/templates/parlamentares/composicaomesa_form.html
  6. 89
      sapl/templates/parlamentares/public_composicaomesa_form.html

1
.gitignore

@ -93,5 +93,6 @@ bower
bower_components bower_components
media media
whoosh/ whoosh/
solr-4.10.2/
postgres-data/ postgres-data/
data/ data/

4
sapl/parlamentares/urls.py

@ -1,6 +1,7 @@
from django.conf.urls import include, url from django.conf.urls import include, url
from sapl.parlamentares.views import (altera_field_mesa, from sapl.parlamentares.views import (altera_field_mesa,
altera_field_mesa_public_view,
CargoMesaCrud, ColigacaoCrud, CargoMesaCrud, ColigacaoCrud,
ComposicaoColigacaoCrud, DependenteCrud, ComposicaoColigacaoCrud, DependenteCrud,
FiliacaoCrud, FrenteCrud, FrenteList, FiliacaoCrud, FrenteCrud, FrenteList,
@ -59,6 +60,9 @@ urlpatterns = [
url(r'^mesa-diretora/altera-field-mesa/$', url(r'^mesa-diretora/altera-field-mesa/$',
altera_field_mesa, name='altera_field_mesa'), altera_field_mesa, name='altera_field_mesa'),
url(r'^mesa-diretora/altera-field-mesa-public-view/$',
altera_field_mesa_public_view, name='altera_field_mesa_public_view'),
url(r'^mesa-diretora/insere-parlamentar-composicao/$', url(r'^mesa-diretora/insere-parlamentar-composicao/$',
insere_parlamentar_composicao, name='insere_parlamentar_composicao'), insere_parlamentar_composicao, name='insere_parlamentar_composicao'),

99
sapl/parlamentares/views.py

@ -373,11 +373,9 @@ class ParlamentarCrud(Crud):
# Caso exista mais de uma filiação nesse intervalo # Caso exista mais de uma filiação nesse intervalo
# Entretanto, NÃO DEVE OCORRER # Entretanto, NÃO DEVE OCORRER
except MultipleObjectsReturned: except MultipleObjectsReturned:
filiacao = parlamentar.filiacao_set.filter(Q( row[2] = (
data__lte=legislatura.data_fim, 'O Parlamentar possui duas filiações conflitantes',
data_desfiliacao__gte=legislatura.data_fim) | Q( None)
data__lte=legislatura.data_fim,
data_desfiliacao__isnull=True)).last()
# Caso encontre UMA filiação nessas condições # Caso encontre UMA filiação nessas condições
else: else:
@ -588,3 +586,94 @@ def remove_parlamentar_composicao(request):
return JsonResponse( return JsonResponse(
{'msg': ( {'msg': (
'Selecione algum parlamentar para ser excluido!', 0)}) '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)})

1
sapl/settings.py

@ -208,6 +208,7 @@ LOCALE_PATHS = (
# Static files (CSS, JavaScript, Images) # Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.8/howto/static-files/ # https://docs.djangoproject.com/en/1.8/howto/static-files/
STATIC_URL = '/static/' STATIC_URL = '/static/'
STATIC_ROOT = PROJECT_DIR.child("collected_static") STATIC_ROOT = PROJECT_DIR.child("collected_static")
STATICFILES_DIRS = (BASE_DIR.child("static"),) STATICFILES_DIRS = (BASE_DIR.child("static"),)

3
sapl/templates/parlamentares/composicaomesa_form.html

@ -158,8 +158,7 @@
// Atualiza os campos após alguma operação de mudança da Legislatura/Sessao ou // Atualiza os campos após alguma operação de mudança da Legislatura/Sessao ou
// Inserção/Remoção // Inserção/Remoção
function altera_field(id_legislatura, id_sessao=null, msg=null){ function altera_field(id_legislatura, id_sessao=null, msg=null){
// Pega o novo valor do campo que foi modificado (Sessao/Legislatura) ou utiliza // Pega o novo valor dos campos modificados
// o valor da Legislatura, por conveniência, quando há alguma inserção ou remoção
var sessao_value = id_sessao var sessao_value = id_sessao
var legislatura_value = id_legislatura var legislatura_value = id_legislatura

89
sapl/templates/parlamentares/public_composicaomesa_form.html

@ -10,7 +10,7 @@
<div class="row"> <div class="row">
<div class="col-md-6"> <div class="col-md-6">
<label>Escolha uma Legislatura</label> <label>Escolha uma Legislatura</label>
<select name="legislatura" class="form-control" onChange="form.submit();"> <select name="legislatura" id="id_legislatura" class="form-control">
{% for l in legislaturas %} {% for l in legislaturas %}
<option value="{{l.id}}" {% if l == legislatura_selecionada %} selected {% endif %}> <option value="{{l.id}}" {% if l == legislatura_selecionada %} selected {% endif %}>
{{l}} {{l}}
@ -20,7 +20,7 @@
</div> </div>
<div class="col-md-6"> <div class="col-md-6">
<label>Escolha uma Sessão Legislativa</label> <label>Escolha uma Sessão Legislativa</label>
<select name="sessao" class="form-control" onChange="form.submit();"> <select name="sessao" id="id_sessao_legislativa" class="form-control">
{% for s in sessoes %} {% for s in sessoes %}
<option value="{{s.id}}" {% if s == sessao_selecionada %} selected {% endif %}> <option value="{{s.id}}" {% if s == sessao_selecionada %} selected {% endif %}>
{{s}} {{s}}
@ -33,7 +33,7 @@
<br /> <br />
<fieldset class="form-group"> <fieldset class="form-group">
<legend>Composição da Mesa Diretora</legend> <legend>Composição da Mesa Diretora</legend>
<table class="table table-striped table-hover table-link-ordering"> <table id="tabela-composicao" class="table table-striped table-hover table-link-ordering">
<thead> <thead>
<tr> <tr>
<th></th> <th></th>
@ -46,7 +46,7 @@
{% for p in composicao_mesa %} {% for p in composicao_mesa %}
<tr> <tr>
{% if p.parlamentar.fotografia %} {% if p.parlamentar.fotografia %}
<td><img class="img-responsive" height="60" width="60" src="{{ p.parlamentar.fotografia.url }}"></td> <td><img class="img-responsive" height="30" width="30" src="{{ p.parlamentar.fotografia.url }}"></td>
{% else %} {% else %}
<td></td> <td></td>
{% endif %} {% endif %}
@ -60,3 +60,84 @@
</fieldset> </fieldset>
</form> </form>
{% endblock detail_content %} {% endblock detail_content %}
{% block extra_js %}
<script language="Javascript">
//##############################################################
//# USEFUL FUNCTIONS #
//##############################################################
function retorna_imagem(url){
if (url != null){
image_component = '<img class="img-responsive" height="30" width="30" src="' + url + '">'
return image_component
}
else{
return ''
}
}
//##############################################################
//# EVENT HANDLERS #
//##############################################################
function altera_field(id_legislatura, id_sessao=null){
// Pega o novo valor do campo que foi modificado (Sessao/Legislatura)
var sessao_value = id_sessao
var legislatura_value = id_legislatura
// Limpa o campo que será atualizado
$("#id_sessao_legislativa option").remove();
$("#tabela-composicao tbody").empty();
$.get("/mesa-diretora/altera-field-mesa-public-view",
{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_parlamentares = data['lista_parlamentares'];
lista_cargos = data['lista_cargos'];
lista_fotos = data['lista_fotos']
lista_partidos = data['lista_partidos']
// Atualiza a listagem de sessões
for (i = 0; i < lista_sessoes.length; i++) {
$('#id_sessao_legislativa').append('<option value="' + lista_sessoes[i][0] + '">' + lista_sessoes[i][1] + '</option>');
}
// Atualiza a tabela de composição
for (i = 0; i < lista_parlamentares.length; i++) {
$("#tabela-composicao tbody").append('<tr> <td>' + retorna_imagem(lista_fotos[i]) +'</td> <td><a href="/parlamentar/' + lista_parlamentares[i][0] + '">' + lista_parlamentares[i][1] + '</a></td> <td>' + lista_partidos[i] + '</td> <td>'+ lista_cargos[i][1] + '</td> </tr>');
}
// 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'])
});
}
//#############################################################
//# 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);
});
</script>
{% endblock %}
Loading…
Cancel
Save