Browse Source

Fix #2749 - Configurar cronômetro - tempo de disparo e com que antecedência (#2871)

* Fix #2828 - Adiciona tipo de cronômetro

* Corrige migrações

* Altera view do painel em Sessao

* Cronometros da tela de sessao funcionando

* Melhoria no Form de Cronometro

* Muda nome do cronometro da ordem

* Cria PainelConfig

* Adiciona opção de tempo de disparo previo

* Corrigido formato do cronometro

* Disparo prévio do cronômetro configurável

* Adiciona opção de duração do disparo

* Fix verbose name

* Remove migrations desnecessárias
pull/2770/head
Cesar Augusto de Carvalho 6 years ago
committed by Edward
parent
commit
ed93239c96
  1. 10
      sapl/painel/forms.py
  2. 48
      sapl/painel/migrations/0003_auto_20190603_1033.py~HEAD
  3. 25
      sapl/painel/migrations/0004_auto_20190603_1033.py~HEAD
  4. 25
      sapl/painel/migrations/0006_auto_20190612_1347.py
  5. 20
      sapl/painel/migrations/0007_painelconfig_tempo_disparo_termino.py
  6. 16
      sapl/painel/models.py
  7. 34
      sapl/templates/painel/index.html
  8. 2
      sapl/templates/painel/layouts.yaml
  9. 16
      sapl/templates/painel/painelconfig_form.html
  10. 38
      sapl/templates/sessao/painel.html

10
sapl/painel/forms.py

@ -18,4 +18,12 @@ class ConfiguracoesPainelForm(forms.ModelForm):
class Meta: class Meta:
model = PainelConfig model = PainelConfig
fields = ['cronometro_ordem'] fields = ['cronometro_ordem',
'disparo_cronometro',
'tempo_disparo_antecedencia',
'tempo_disparo_termino']
def __init__(self, *args, **kwargs):
super(ConfiguracoesPainelForm, self).__init__(*args, **kwargs)
self.fields['tempo_disparo_antecedencia'].widget.attrs['class'] = 'cronometro'
self.fields['tempo_disparo_termino'].widget.attrs['class'] = 'cronometro'

48
sapl/painel/migrations/0003_auto_20190603_1033.py~HEAD

@ -1,48 +0,0 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.20 on 2019-06-03 13:33
from __future__ import unicode_literals
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('painel', '0002_auto_20180523_1430'),
]
operations = [
migrations.AlterModelOptions(
name='cronometro',
options={'ordering': ['ordenacao'], 'verbose_name': 'Cronômetro', 'verbose_name_plural': 'Cronômetros'},
),
migrations.RemoveField(
model_name='cronometro',
name='data_cronometro',
),
migrations.AddField(
model_name='cronometro',
name='ativo',
field=models.BooleanField(choices=[(True, 'Sim'), (False, 'Não')], default=False, verbose_name='Ativo?'),
),
migrations.AddField(
model_name='cronometro',
name='duracao_cronometro',
field=models.DurationField(verbose_name='Duração do cronômetro'),
),
migrations.AddField(
model_name='cronometro',
name='ordenacao',
field=models.PositiveIntegerField(blank=True, null=True, verbose_name='Ordenação'),
),
migrations.AlterField(
model_name='cronometro',
name='status',
field=models.CharField(choices=[('I', 'Start'), ('R', 'Reset'), ('S', 'Stop'), ('C', 'Increment')], default='S', max_length=1, verbose_name='Status do cronômetro'),
),
migrations.AlterField(
model_name='cronometro',
name='tipo',
field=models.CharField(max_length=100, unique=True, verbose_name='Tipo Cronômetro'),
),
]

25
sapl/painel/migrations/0004_auto_20190603_1033.py~HEAD

@ -1,25 +0,0 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.20 on 2019-06-03 13:33
from __future__ import unicode_literals
from django.db import migrations
def create_default_cronometros(apps, schema_editor):
tipos_default = ['Cronômetro do Discurso', 'Cronômetro do Aparte',
'Cronômetro da Questão de Ordem', 'Cronômetro de Considerações Finais']
Cronometro = apps.get_model('painel', 'Cronometro')
for i,tipo in enumerate(tipos_default):
Cronometro.objects.get_or_create(tipo=tipo, duracao_cronometro='00:05:00', status='S', ativo=True, ordenacao=i+1)
class Migration(migrations.Migration):
dependencies = [
('painel', '0003_auto_20190603_1033'),
]
operations = [
migrations.RunPython(create_default_cronometros)
]

25
sapl/painel/migrations/0006_auto_20190612_1347.py

@ -0,0 +1,25 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.20 on 2019-06-12 16:47
from __future__ import unicode_literals
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('painel', '0005_painelconfig'),
]
operations = [
migrations.AddField(
model_name='painelconfig',
name='disparo_cronometro',
field=models.BooleanField(choices=[(True, 'Sim'), (False, 'Não')], default=True, verbose_name='Cronômetros devem disparar com antecedência?'),
),
migrations.AddField(
model_name='painelconfig',
name='tempo_disparo_antecedencia',
field=models.DurationField(blank=True, default='00:00:30', null=True, verbose_name='Cronômetros devem disparar com quanto tempo de antecedência?'),
),
]

20
sapl/painel/migrations/0007_painelconfig_tempo_disparo_termino.py

@ -0,0 +1,20 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.20 on 2019-06-14 14:04
from __future__ import unicode_literals
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('painel', '0006_auto_20190612_1347'),
]
operations = [
migrations.AddField(
model_name='painelconfig',
name='tempo_disparo_termino',
field=models.DurationField(blank=True, default='00:00:05', null=True, verbose_name='Cronômetros devem permanecer tocando por quanto tempo ao término?'),
),
]

16
sapl/painel/models.py

@ -74,6 +74,22 @@ class PainelConfig(models.Model):
verbose_name=_('Cronômetro da Questão de Ordem deve travar os demais?'), verbose_name=_('Cronômetro da Questão de Ordem deve travar os demais?'),
choices=YES_NO_CHOICES, default=True) choices=YES_NO_CHOICES, default=True)
disparo_cronometro = models.BooleanField(
verbose_name=_('Cronômetros devem disparar com antecedência?'),
choices=YES_NO_CHOICES, default=True)
tempo_disparo_antecedencia = models.DurationField(
verbose_name=_('Cronômetros devem disparar com quanto tempo de antecedência?'),
default="00:00:30",
blank=True,
null=True)
tempo_disparo_termino = models.DurationField(
verbose_name=_('Cronômetros devem permanecer tocando por quanto tempo ao término?'),
default="00:00:05",
blank=True,
null=True)
class Meta: class Meta:
verbose_name = _('Configurações do Painel') verbose_name = _('Configurações do Painel')
verbose_name_plural = _('Configurações do Painel') verbose_name_plural = _('Configurações do Painel')

34
sapl/templates/painel/index.html

@ -149,19 +149,41 @@
return voto return voto
} }
function playAudioNumVezes(audio, times, ended) {
if (times <= 0) {
return;
}
let played = 0;
audio.addEventListener("ended", function() {
played++;
if (played < times) {
audio.play();
} else if (ended) {
ended();
}
});
audio.play();
}
$(document).ready(function() { $(document).ready(function() {
//TODO: replace by a fancy jQuery clock //TODO: replace by a fancy jQuery clock
startTime(); startTime();
var audioAlertFinish = document.getElementById("audio"); var audioAlertFinish = document.getElementById("audio");
// Obtém duração do disparo ao término do tempo e converte para segundos
var duracao_disparo = "{{ painel_config.tempo_disparo_termino }}";
let tmp = duracao_disparo.split(":");
duracao_disparo = parseInt(tmp[0])*3600 + parseInt(tmp[1])*60 + parseInt(tmp[2]);
var num_vezes_toca_audio = Math.round(duracao_disparo/audioAlertFinish.duration);
var cronometros_previous = []; var cronometros_previous = [];
{% for cron in cronometros %} {% for cron in cronometros %}
cronometros_previous.push(0); cronometros_previous.push(0);
$('#cronometro_' + "{{cron.id}}").runner({ $('#cronometro_' + "{{cron.id}}").runner({
autostart: false, autostart: false,
countdown: true, countdown: true,
startAt: {{cron.duracao_cronometro|duration_to_seconds}} * 1000, startAt: parseInt("{{cron.duracao_cronometro|duration_to_seconds}}") * 1000,
stopAt: 0, stopAt: 0,
milliseconds: false, milliseconds: false,
format: function(value) { format: function(value) {
@ -174,10 +196,14 @@
return h.toString() + ":" + m.toString() + ":" + s.toString(); return h.toString() + ":" + m.toString() + ":" + s.toString();
} }
}).on('runnerFinish', function(eventObject, info){ }).on('runnerFinish', function(eventObject, info){
audioAlertFinish.play(); playAudioNumVezes(audioAlertFinish, num_vezes_toca_audio);
}) })
{% endfor %} {% endfor %}
var tempo_disparo_antecedencia = "{{ painel_config.tempo_disparo_antecedencia }}"
tmp = tempo_disparo_antecedencia.split(":");
tempo_disparo_antecedencia = checkTime(parseInt(tmp[0])) + ":" + checkTime(parseInt(tmp[1])) + ":" + checkTime(parseInt(tmp[2]));
var counter = 1; var counter = 1;
(function poll() { (function poll() {
$.ajax({ $.ajax({
@ -296,8 +322,10 @@
cronometros_previous[i] = status_cronometros[i]; cronometros_previous[i] = status_cronometros[i];
} }
if($('#cronometro_' + ids[i]).runner('info').formattedTime == 30) if($('#cronometro_' + ids[i]).runner('info').formattedTime == tempo_disparo_antecedencia &&
"{{ painel_config.disparo_cronometro }}" == "True" )
audioAlertFinish.play(); audioAlertFinish.play();
} }
if(data['sessao_finalizada']){ if(data['sessao_finalizada']){

2
sapl/templates/painel/layouts.yaml

@ -6,3 +6,5 @@ Cronometro:
PainelConfig: PainelConfig:
{% trans 'Configurações do Painel' %}: {% trans 'Configurações do Painel' %}:
- cronometro_ordem - cronometro_ordem
- disparo_cronometro:6 tempo_disparo_antecedencia:6
- tempo_disparo_termino:8

16
sapl/templates/painel/painelconfig_form.html

@ -6,8 +6,24 @@
<script type="text/javascript"> <script type="text/javascript">
function verifica_disparo_cronometro(){
disparar_cronometro = $('#id_disparo_cronometro').val() == "True";
if(!disparar_cronometro){
$('#div_id_tempo_disparo_antecedencia').hide();
$('#div_id_disparo_cronometro').parent().attr("class","col-md-12");
}
else{
$('#div_id_tempo_disparo_antecedencia').show();
$('#div_id_disparo_cronometro').parent().attr("class","col-md-6");
}
}
$(document).ready(function(){ $(document).ready(function(){
$('#div_id_cronometro_ordem').children().first().append("<br>Atenção! Este cronômetro apenas travará os demais se seu nome for o padrão <b>Cronômetro da Questão de Ordem</b>."); $('#div_id_cronometro_ordem').children().first().append("<br>Atenção! Este cronômetro apenas travará os demais se seu nome for o padrão <b>Cronômetro da Questão de Ordem</b>.");
$('#id_disparo_cronometro').ready(verifica_disparo_cronometro);
$('#id_disparo_cronometro').change(verifica_disparo_cronometro);
}); });
</script> </script>

38
sapl/templates/sessao/painel.html

@ -2,7 +2,6 @@
{% load i18n %} {% load i18n %}
{% load common_tags %} {% load common_tags %}
{% load staticfiles %} {% load staticfiles %}
{% load webpack_static from webpack_loader %} {% load webpack_static from webpack_loader %}
{% load render_bundle from webpack_loader %} {% load render_bundle from webpack_loader %}
@ -100,6 +99,23 @@ function startTime() {
},500); },500);
} }
function playAudioNumVezes(audio, times, ended) {
if (times <= 0) {
return;
}
let played = 0;
audio.addEventListener("ended", function() {
played++;
if (played < times) {
audio.play();
} else if (ended) {
ended();
}
});
audio.play();
}
$(document).ready(function(){ $(document).ready(function(){
let pk_sessao = parseInt("{{root_pk}}"); let pk_sessao = parseInt("{{root_pk}}");
let botao_abrir = $('#id_abrir_painel'); let botao_abrir = $('#id_abrir_painel');
@ -127,6 +143,12 @@ $(document).ready(function(){
startTime(); startTime();
let audioAlertFinish = document.getElementById("audio"); let audioAlertFinish = document.getElementById("audio");
// Obtém duração do disparo ao término do tempo e converte para segundos
var duracao_disparo = "{{ painel_config.tempo_disparo_termino }}";
let tmp = duracao_disparo.split(":");
duracao_disparo = parseInt(tmp[0])*3600 + parseInt(tmp[1])*60 + parseInt(tmp[2]);
let num_vezes_toca_audio = Math.round(duracao_disparo/audioAlertFinish.duration);
{% for cron in cronometros %} {% for cron in cronometros %}
$('#cronometro_' + "{{cron.id}}").prop('disabled', false); $('#cronometro_' + "{{cron.id}}").prop('disabled', false);
@ -135,10 +157,19 @@ $(document).ready(function(){
countdown: true, countdown: true,
startAt: parseInt("{{cron.duracao_cronometro|duration_to_seconds}}") * 1000, startAt: parseInt("{{cron.duracao_cronometro|duration_to_seconds}}") * 1000,
stopAt: 0, stopAt: 0,
milliseconds: false 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){ }).on('runnerFinish', function(eventObject, info){
$.get('/painel/cronometro', { tipo: 'cronometro_' + "{{cron.id}}", action: 'stop' } ); $.get('/painel/cronometro', { tipo: 'cronometro_' + "{{cron.id}}", action: 'stop' } );
audioAlertFinish.play(); playAudioNumVezes(audioAlertFinish, num_vezes_toca_audio);
$('#cronometro_' + "{{cron.id}}" + '_Reset').show(); $('#cronometro_' + "{{cron.id}}" + '_Reset').show();
$('#cronometro_' + "{{cron.id}}").runner('stop'); $('#cronometro_' + "{{cron.id}}").runner('stop');
$('#cronometro_' + "{{cron.id}}" + '_Start').text('Iniciar'); $('#cronometro_' + "{{cron.id}}" + '_Start').text('Iniciar');
@ -188,6 +219,7 @@ $(document).ready(function(){
$('#cronometro_' + "{{cron.id}}").runner('stop'); $('#cronometro_' + "{{cron.id}}").runner('stop');
$('#cronometro_' + "{{cron.id}}").runner('reset'); $('#cronometro_' + "{{cron.id}}").runner('reset');
}); });
{% endfor %} {% endfor %}
}); });

Loading…
Cancel
Save