Browse Source

Exibição e inclusão/exclusão da presença dos parlamentares na Sessão Plenária e Ordem do Dia

pull/1173/head
cristian-longhi 9 years ago
parent
commit
2b4920fea0
  1. 24
      sapl/sessao/views.py
  2. 55
      sapl/templates/sessao/presenca.html
  3. 55
      sapl/templates/sessao/presenca_ordemdia.html

24
sapl/sessao/views.py

@ -30,7 +30,7 @@ from sapl.materia.models import (Autoria, DocumentoAcessorio,
from sapl.materia.views import MateriaLegislativaPesquisaView from sapl.materia.views import MateriaLegislativaPesquisaView
from sapl.norma.models import NormaJuridica from sapl.norma.models import NormaJuridica
from sapl.parlamentares.models import (Filiacao, Legislatura, Parlamentar, from sapl.parlamentares.models import (Filiacao, Legislatura, Parlamentar,
SessaoLegislativa) SessaoLegislativa, Mandato)
from sapl.sessao.apps import AppConfig from sapl.sessao.apps import AppConfig
from sapl.sessao.forms import ExpedienteMateriaForm, OrdemDiaForm from sapl.sessao.forms import ExpedienteMateriaForm, OrdemDiaForm
@ -561,7 +561,12 @@ class PresencaMixin:
) )
presentes = [p.parlamentar for p in presencas] presentes = [p.parlamentar for p in presencas]
for parlamentar in Parlamentar.objects.filter(ativo=True): mandato = Mandato.objects.filter(
legislatura_id=self.object.legislatura_id)
mandato_parlamentar = [p.parlamentar for p in mandato]
for parlamentar in mandato_parlamentar:
if parlamentar in presentes: if parlamentar in presentes:
yield (parlamentar, True) yield (parlamentar, True)
else: else:
@ -575,7 +580,12 @@ class PresencaMixin:
) )
presentes = [p.parlamentar for p in presencas] presentes = [p.parlamentar for p in presencas]
for parlamentar in Parlamentar.objects.filter(ativo=True): mandato = Mandato.objects.filter(
legislatura_id=self.object.legislatura_id)
mandato_parlamentar = [p.parlamentar for p in mandato]
for parlamentar in mandato_parlamentar:
if parlamentar in presentes: if parlamentar in presentes:
yield (parlamentar, True) yield (parlamentar, True)
else: else:
@ -605,13 +615,13 @@ class PresencaView(FormMixin, PresencaMixin, DetailView):
sessao_plenaria_id=self.object.id) sessao_plenaria_id=self.object.id)
# Id dos parlamentares presentes # Id dos parlamentares presentes
marcados = request.POST.getlist('presenca') marcados = request.POST.getlist('presenca_ativos') + request.POST.getlist('presenca_inativos')
# Deletar os que foram desmarcadors # Deletar os que foram desmarcadors
deletar = set(set(presentes_banco) - set(marcados)) deletar = set(set(presentes_banco) - set(marcados))
for d in deletar: for d in deletar:
SessaoPlenariaPresenca.objects.filter( SessaoPlenariaPresenca.objects.filter(
parlamentar_id=d.parlamentar_id).delete() parlamentar_id=d.parlamentar_id, sessao_plenaria_id=self.object.id).delete()
for p in marcados: for p in marcados:
sessao = SessaoPlenariaPresenca() sessao = SessaoPlenariaPresenca()
@ -713,13 +723,13 @@ class PresencaOrdemDiaView(FormMixin, PresencaMixin, DetailView):
sessao_plenaria_id=pk) sessao_plenaria_id=pk)
# Id dos parlamentares presentes # Id dos parlamentares presentes
marcados = request.POST.getlist('presenca') marcados = request.POST.getlist('presenca_ativos') + request.POST.getlist('presenca_inativos')
# Deletar os que foram desmarcadors # Deletar os que foram desmarcadors
deletar = set(set(presentes_banco) - set(marcados)) deletar = set(set(presentes_banco) - set(marcados))
for d in deletar: for d in deletar:
PresencaOrdemDia.objects.filter( PresencaOrdemDia.objects.filter(
parlamentar_id=d.parlamentar_id).delete() parlamentar_id=d.parlamentar_id, sessao_plenaria_id=self.object.id).delete()
for p in marcados: for p in marcados:
ordem = PresencaOrdemDia() ordem = PresencaOrdemDia()

55
sapl/templates/sessao/presenca.html

@ -17,17 +17,37 @@
</label> </label>
</div> </div>
</div> </div>
<br />
<div class="controls"> <br />
{% for parlamentar, check in view.get_presencas %} <div class="controls">
<div class="checkbox"> <div class="checkbox">
<label for="id_presenca_{{forloop.counter}}"> <label for="id_ativos">
<input type="checkbox" id="id_presenca_{{forloop.counter}}" name="presenca" value="{{ parlamentar.id }}" {% if check %} checked {% endif %}/> <input type="checkbox" name="ativos" id="id_ativos" onchange="escondeInativos()" checked /> Exibir somente parlamentares ativos
{{ parlamentar.nome_parlamentar }} / {{ parlamentar.filiacao_atual }} </label>
</label> </div>
</div> </div>
{% endfor %}
</div> <br />
<div class="controls">
{% for parlamentar, check in view.get_presencas %}
{% if parlamentar.ativo %}
<div class="checkbox">
<label for="id_presenca_{{forloop.counter}}">
<input type="checkbox" id="id_presenca_{{forloop.counter}}" name="presenca_ativos" value="{{ parlamentar.id }}" {% if check %} checked {% endif %}/>
{{ parlamentar.nome_parlamentar }} / {{ parlamentar.filiacao_atual }}
</label>
</div>
{% else %}
<div class="checkbox inativos" style="display:none;">
<label for="id_presenca_{{forloop.counter}}">
<input type="checkbox" id="id_presenca_{{forloop.counter}}" name="presenca_inativos" value="{{ parlamentar.id }}" {% if check %} checked {% endif %}/>
{{ parlamentar.nome_parlamentar }} / {{ parlamentar.filiacao_atual }}
</label>
</div>
{% endif %}
{% endfor %}
</div>
<br /> <br />
<input type="submit" value="Salvar" class="btn btn-primary" /> <input type="submit" value="Salvar" class="btn btn-primary" />
@ -55,10 +75,21 @@
{% block extra_js %} {% block extra_js %}
<script language="JavaScript"> <script language="JavaScript">
function checkAll(event) { function checkAll(event) {
$('[name=presenca]').each(function() { $('[name=presenca_ativos]').each(function() {
$(this).prop('checked', event.target.checked ? 'checked': null); $(this).prop('checked', event.target.checked ? 'checked': null);
$(this).trigger('click'); $(this).trigger('click');
}); });
if (($('[name=ativos]').is(':checked')) == false) {
$('[name=presenca_inativos]').each(function() {
$(this).prop('checked', event.target.checked ? 'checked': null);
$(this).trigger('click');
});
}
} }
function escondeInativos() {
$(".inativos").toggle();
}
</script> </script>
{% endblock %} {% endblock %}

55
sapl/templates/sessao/presenca_ordemdia.html

@ -17,19 +17,39 @@
</label> </label>
</div> </div>
</div> </div>
<br>
<br />
<div class="controls"> <div class="controls">
{% for parlamentar, check in view.get_presencas_ordem %}
<div class="checkbox"> <div class="checkbox">
<label for="id_presenca_{{forloop.counter}}"> <label for="id_ativos">
<input type="checkbox" id="id_presenca_{{forloop.counter}}" name="presenca" value="{{ parlamentar.id }}" {% if check %} checked {% endif %}/> <input type="checkbox" name="ativos" id="id_ativos" onchange="escondeInativos()" checked /> Exibir somente parlamentares ativos
{{ parlamentar.nome_parlamentar }} / {{ parlamentar.filiacao_atual }} </label>
</label>
</div> </div>
{% endfor %}
</div> </div>
<br />
<div class="controls">
{% for parlamentar, check in view.get_presencas_ordem %}
{% if parlamentar.ativo %}
<div class="checkbox">
<label for="id_presenca_{{forloop.counter}}">
<input type="checkbox" id="id_presenca_{{forloop.counter}}" name="presenca_ativos" value="{{ parlamentar.id }}" {% if check %} checked {% endif %}/>
{{ parlamentar.nome_parlamentar }} / {{ parlamentar.filiacao_atual }}
</label>
</div>
{% else %}
<div class="checkbox inativos" style="display:none;">
<label for="id_presenca_{{forloop.counter}}">
<input type="checkbox" id="id_presenca_{{forloop.counter}}" name="presenca_inativos" value="{{ parlamentar.id }}" {% if check %} checked {% endif %}/>
{{ parlamentar.nome_parlamentar }} / {{ parlamentar.filiacao_atual }}
</label>
</div>
{% endif %}
{% endfor %}
</div>
<br /> <br />
<input type="submit" value="Salvar" class="btn btn-primary" /> <input type="submit" value="Salvar" class="btn btn-primary" />
</form> </form>
@ -56,10 +76,21 @@
{% block extra_js %} {% block extra_js %}
<script language="JavaScript"> <script language="JavaScript">
function checkAll(event) { function checkAll(event) {
$('[name=presenca]').each(function() { $('[name=presenca_ativos]').each(function() {
$(this).prop('checked', event.target.checked ? 'checked': null); $(this).prop('checked', event.target.checked ? 'checked': null);
$(this).trigger('click'); $(this).trigger('click');
}); });
} if (($('[name=ativos]').is(':checked')) == false) {
$('[name=presenca_inativos]').each(function() {
$(this).prop('checked', event.target.checked ? 'checked': null);
$(this).trigger('click');
});
}
}
function escondeInativos() {
$(".inativos").toggle();
}
</script> </script>
{% endblock %} {% endblock %}

Loading…
Cancel
Save