Browse Source

"conserta" horário de verão (#3040)

* "conserta" horário de verão

* Endereçando as reviews
pull/2996/head
Edward 5 years ago
committed by Edward Ribeiro
parent
commit
17fa5e2038
  1. 10
      sapl/painel/views.py
  2. 78
      sapl/templates/painel/index.html

10
sapl/painel/views.py

@ -353,12 +353,15 @@ def painel_view(request, pk):
'resultado': True, 'resultado': True,
'materia': True 'materia': True
} }
now = timezone.localtime(timezone.now())
utc_offset = now.utcoffset().total_seconds() / 60
context = {'head_title': str(_('Painel Plenário')), context = {'head_title': str(_('Painel Plenário')),
'sessao_id': pk, 'sessao_id': pk,
'cronometros': Cronometro.objects.filter(ativo=True).order_by('ordenacao'), 'cronometros': Cronometro.objects.filter(ativo=True).order_by('ordenacao'),
'painel_config': PainelConfig.objects.first(), 'painel_config': PainelConfig.objects.first(),
'casa': CasaLegislativa.objects.last(), 'casa': CasaLegislativa.objects.last(),
'exibicao': exibicao 'exibicao': exibicao,
'utc_offset': utc_offset,
} }
return render(request, 'painel/index.html', context) return render(request, 'painel/index.html', context)
@ -375,12 +378,15 @@ def painel_parcial_view(request, pk, opcoes):
'resultado': bit_is_set(opcoes, 3), 'resultado': bit_is_set(opcoes, 3),
'materia': bit_is_set(opcoes, 4) 'materia': bit_is_set(opcoes, 4)
} }
now = timezone.localtime(timezone.now())
utc_offset = now.utcoffset().total_seconds() / 60
context = {'head_title': str(_('Painel Plenário')), context = {'head_title': str(_('Painel Plenário')),
'sessao_id': pk, 'sessao_id': pk,
'cronometros': Cronometro.objects.filter(ativo=True).order_by('ordenacao'), 'cronometros': Cronometro.objects.filter(ativo=True).order_by('ordenacao'),
'painel_config': PainelConfig.objects.first(), 'painel_config': PainelConfig.objects.first(),
'casa': CasaLegislativa.objects.last(), 'casa': CasaLegislativa.objects.last(),
'exibicao': exibicao 'exibicao': exibicao,
'utc_offset': utc_offset,
} }
return render(request, 'painel/index.html', context) return render(request, 'painel/index.html', context)

78
sapl/templates/painel/index.html

@ -135,27 +135,40 @@
{% endblock webpack_loader_chunks_js %} {% endblock webpack_loader_chunks_js %}
<script type="text/javascript"> <script type="text/javascript">
var d = new Date(); $(document).ready(function() {
var n = d.toLocaleDateString();
document.getElementById("date").innerHTML = n; // As constantes decisões sobre a existência ou não do horário de verão,
// assim como que data de início e termino do mesmo, fizeram com que fosse necessário
// substituir a chamada a Date() por um esquema mais elaborado, onde se
// recupera o offset do UTC (-3 GMT, no caso de Brasília) e seta-se
// manualmente. Esta informação vem do servidor, desta forma não ficamos
// na dependência da atualização de browser, pois tanto o Date() em JS
// quanto as libs python (django.utils.timezone, datetime, pytz, etc)
// lêem do tzdata, que precisa ser atualizado toda vez que o governo
// brasileiro modifica alguma coisa relacionada ao horário de verão.
// Recuperando essa informação do servidor só teremos que atualizar as
// libs tzdata (Linux) e pytz (Python) uma vez. Além disso, o uso da
// biblioteca moment.js é recomendada, pois ela trata data e hora
// melhor que o Date() do JS.
$("#date").append(moment().format("DD/MM/YY"));
var offset = parseFloat({{ utc_offset }});
//TODO: replace by a fancy jQuery clock
function checkTime(i) { function checkTime(i) {
if (i<10) {i = "0" + i}; // add zero in front of numbers < 10 if (i<10) {i = "0" + i}; // add zero in front of numbers < 10
return i; return i;
} }
function startTime() { function startTime() {
var today=new Date(); var today = moment.utc().utcOffset(offset).format("HH:mm:ss");
var h=today.getHours(); $("#relogio").text(today)
var m=today.getMinutes();
var s=today.getSeconds();
m = checkTime(m);
s = checkTime(s);
$("#relogio").text(h+":"+m+":"+s)
var t = setTimeout(function(){ var t = setTimeout(function(){
startTime() startTime()
}, 500); }, 500);
} }
startTime();
function show_voto(voto) { function show_voto(voto) {
if (voto == "Sim"){ if (voto == "Sim"){
@ -167,6 +180,46 @@
return voto return voto
} }
var audioAlertFinish = document.getElementById("audio");
$('#cronometro_discurso').runner({
autostart: false,
countdown: true,
startAt: {{ 'discurso'|cronometro_to_seconds }} * 1000,
stopAt: 0,
milliseconds: false,
format: function(value) {
let h = Math.floor((value/1000) / 3600);
h = checkTime(h);
let m = Math.floor((value/1000) % 3600 / 60);
m = checkTime(m);
let s = Math.floor((value/1000) % 3600 % 60);
s = checkTime(s);
return h.toString() + ":" + m.toString() + ":" + s.toString();
}
}).on('runnerFinish', function(eventObject, info){
audioAlertFinish.play();
});
$('#cronometro_aparte').runner({
autostart: false,
countdown: true,
startAt: {{ 'aparte'|cronometro_to_seconds }} * 1000,
stopAt: 0,
milliseconds: false,
format: function(value) {
let h = Math.floor((value/1000) / 3600);
h = checkTime(h);
let m = Math.floor((value/1000) % 3600 / 60);
m = checkTime(m);
let s = Math.floor((value/1000) % 3600 % 60);
s = checkTime(s);
return h.toString() + ":" + m.toString() + ":" + s.toString();
}
}).on('runnerFinish', function(eventObject, info){
audioAlertFinish.play();
});
function playAudioNumVezes(audio, times, ended) { function playAudioNumVezes(audio, times, ended) {
if (times <= 0) { if (times <= 0) {
return; return;
@ -431,14 +484,9 @@
} else{ } else{
$("#observacao_materia").text(''); $("#observacao_materia").text('');
} }
<<<<<<< HEAD
if (data['tipo_resultado'] && data['status_painel']){
if(data['tipo_votacao'] != 'Leitura'){
=======
if (data['tipo_resultado'] && data['status_painel'] == true){ if (data['tipo_resultado'] && data['status_painel'] == true){
if(data['tipo_votacao'] != 'Leitura' && !data['sessao_finalizada'] && !data["sessao_solene"]){ if(data['tipo_votacao'] != 'Leitura' && !data['sessao_finalizada'] && !data["sessao_solene"]){
>>>>>>> 8b4c0879... HOT-FIX: Corrige comportamento do painel quando a sessão está finalizada
$("#resultado_votacao").css("color", "#45919D"); $("#resultado_votacao").css("color", "#45919D");
$("#mat_em_votacao").text("Matéria em Votação"); $("#mat_em_votacao").text("Matéria em Votação");
$("#resultado_votacao_div").show(); $("#resultado_votacao_div").show();

Loading…
Cancel
Save