from datetime import date import datetime from django.core.exceptions import ObjectDoesNotExist from django.http import HttpResponse, JsonResponse from django.shortcuts import render from django.utils.translation import ugettext_lazy as _ from painel.models import Painel from parlamentares.models import Filiacao from sapl.crud import build_crud from sessao.models import (OrdemDia, PresencaOrdemDia, RegistroVotacao, SessaoPlenaria, SessaoPlenariaPresenca, VotoParlamentar) from .models import Cronometro cronometro_painel_crud = build_crud( Cronometro, '', [ [_('Cronometro'), [('status', 3), ('data_cronometro', 6), ('tipo', 3)]], ]) def controlador_painel(request): painel_created = Painel.objects.get_or_create(data_painel=date.today()) painel = painel_created[0] if request.method == 'POST': if 'start-painel' in request.POST: painel.aberto = True painel.save() elif 'stop-painel' in request.POST: painel.aberto = False painel.save() elif 'save-painel' in request.POST: painel.mostrar = request.POST['tipo_painel'] painel.save() context = {'painel': painel, 'PAINEL_TYPES': Painel.PAINEL_TYPES} return render(request, 'painel/controlador.html', context) def painel_view(request, pk): context = {'head_title': 'Painel Plenário', 'sessao_id': pk} return render(request, 'painel/index.html', context) def painel_mensagem_view(request): return render(request, 'painel/mensagem.html') def painel_parlamentares_view(request): return render(request, 'painel/parlamentares.html') def painel_votacao_view(request): return render(request, 'painel/votacao.html') def cronometro_painel(request): request.session[request.GET['tipo']] = request.GET['action'] return HttpResponse({}) def get_cronometro_status(request, name): try: cronometro = request.session[name] except KeyError: cronometro = '' return cronometro def get_dados_painel(request, pk): # Sessão Plenária sessao_plenaria_id = pk sessao_plenaria = SessaoPlenaria.objects.get(id=sessao_plenaria_id) status_painel = "FECHADO" try: painel = Painel.objects.get(data_painel=datetime.date.today()) if painel.aberto: status_painel = "ABERTO" else: response = {"sessao_plenaria": str(sessao_plenaria), "sessao_plenaria_data": sessao_plenaria.data_inicio.strftime("%d/%m/%Y"), "sessao_plenaria_hora_inicio": sessao_plenaria.hora_inicio, "status_painel": status_painel, } return JsonResponse(response) except ObjectDoesNotExist: response = {"sessao_plenaria": str(sessao_plenaria), "sessao_plenaria_data": sessao_plenaria.data_inicio.strftime("%d/%m/%Y"), "sessao_plenaria_hora_inicio": sessao_plenaria.hora_inicio, "status_painel": status_painel, } return JsonResponse(response) # # Pra recuperar o partido do parlamentar # # tem que fazer OUTRA query, deve ter uma # # forma de fazer isso na base do join de data models. filiacao = Filiacao.objects.filter( data_desfiliacao__isnull=True, parlamentar__ativo=True) parlamentar_partido = {} for f in filiacao: parlamentar_partido[f.parlamentar.nome_parlamentar] = f.partido.sigla # Presença Sessão Plenária sessao_plenaria_presenca = SessaoPlenariaPresenca.objects.filter( sessao_plenaria_id=sessao_plenaria_id) presentes_sessao_plenaria = [ p.parlamentar.nome_parlamentar for p in sessao_plenaria_presenca] num_presentes_sessao_plen = len(presentes_sessao_plenaria) # Presença Ordem do dia presenca_ordem_dia = PresencaOrdemDia.objects.filter( sessao_plenaria_id=sessao_plenaria_id) presentes_ordem_dia = [] for p in presenca_ordem_dia: nome_parlamentar = p.parlamentar.nome_parlamentar presentes_ordem_dia.append( {'id': p.id, 'nome': nome_parlamentar, 'partido': parlamentar_partido[nome_parlamentar], }) num_presentes_ordem_dia = len(presentes_ordem_dia) try: ordemdia = OrdemDia.objects.get( sessao_plenaria_id=sessao_plenaria_id, votacao_aberta=True) votacao_aberta = True materia_legislativa_texto = ordemdia.materia.ementa materia_observacao = ordemdia.materia.observacao tipo_votacao = ordemdia.tipo_votacao # materia_titulo = ordemdia.materia materia_titulo = "" try: votacao = RegistroVotacao.objects.get( ordem_id=ordemdia.id, materia_id=ordemdia.materia.id) numero_votos_sim = votacao.numero_votos_sim numero_votos_nao = votacao.numero_votos_nao numero_abstencoes = votacao.numero_abstencoes tipo_resultado = votacao.tipo_resultado_votacao.nome votacao_id = votacao.id except ObjectDoesNotExist: votacao_id = -1 numero_votos_sim = 0 numero_votos_nao = 0 numero_abstencoes = 0 tipo_resultado = "" total_votos = numero_votos_sim + numero_votos_nao + numero_abstencoes votos = {} try: voto_parlamentar = VotoParlamentar.objects.filter( votacao_id=votacao_id) for vp in voto_parlamentar: votos[vp.parlamentar.id] = vp.voto except ObjectDoesNotExist: pass except ObjectDoesNotExist: votacao_aberta = False materia_titulo = "" materia_legislativa_texto = "" materia_observacao = "" tipo_votacao = "" cronometro_discurso = get_cronometro_status(request, 'discurso') cronometro_aparte = get_cronometro_status(request, 'aparte') cronometro_ordem = get_cronometro_status(request, 'ordem') response = {"sessao_plenaria": str(sessao_plenaria), "sessao_plenaria_data": sessao_plenaria.data_inicio.strftime("%d/%m/%Y"), "sessao_plenaria_hora_inicio": sessao_plenaria.hora_inicio, "materia_titulo": materia_titulo, "materia_legislativa_texto": materia_legislativa_texto, "materia_observacao": materia_observacao, "tipo_votacao": tipo_votacao, "presentes_ordem_dia": presentes_ordem_dia, "num_presentes_ordem_dia": num_presentes_ordem_dia, "presentes_sessao_plenaria": presentes_sessao_plenaria, "num_presentes_sessao_plenaria": num_presentes_sessao_plen, "votacao_aberta": votacao_aberta, "numero_votos_sim": numero_votos_sim, "numero_votos_nao": numero_votos_nao, "numero_abstencoes": numero_abstencoes, "total_votos": total_votos, "tipo_resultado": tipo_resultado, "votos": votos, "cronometro_aparte": cronometro_aparte, "cronometro_discurso": cronometro_discurso, "cronometro_ordem": cronometro_ordem, "status_painel": status_painel, } return JsonResponse(response)