@ -84,21 +84,8 @@ def get_cronometro_status(request, name):
def get_materia_aberta ( pk ) :
def get_materia_aberta ( pk ) :
try :
return OrdemDia . objects . filter (
materia = OrdemDia . objects . filter (
sessao_plenaria_id = pk , votacao_aberta = True ) . last ( )
sessao_plenaria_id = pk , votacao_aberta = True ) . last ( )
return materia
except ObjectDoesNotExist :
return False
def get_last_materia ( pk ) :
try :
materia = OrdemDia . objects . filter (
sessao_plenaria_id = pk ) . last ( )
return materia
except ObjectDoesNotExist :
return None
def get_presentes ( pk , response , materia ) :
def get_presentes ( pk , response , materia ) :
@ -138,11 +125,14 @@ def get_presentes(pk, response, materia):
num_presentes_ordem_dia = len ( presentes_ordem_dia )
num_presentes_ordem_dia = len ( presentes_ordem_dia )
if materia . tipo_votacao == 1 :
if materia . tipo_votacao == 1 :
tipo_votacao = ' Simbólica '
tipo_votacao = str ( _ ( ' Simbólica ' ) )
response = get_votos ( response , materia )
elif materia . tipo_votacao == 2 :
elif materia . tipo_votacao == 2 :
tipo_votacao = ' Nominal '
tipo_votacao = ' Nominal '
response = get_votos_nominal ( response , materia )
elif materia . tipo_votacao == 3 :
elif materia . tipo_votacao == 3 :
tipo_votacao = ' Secreta '
tipo_votacao = ' Secreta '
response = get_votos ( response , materia )
response . update ( {
response . update ( {
' presentes_ordem_dia ' : presentes_ordem_dia ,
' presentes_ordem_dia ' : presentes_ordem_dia ,
@ -151,10 +141,6 @@ def get_presentes(pk, response, materia):
' num_presentes_sessao_plenaria ' : num_presentes_sessao_plen ,
' num_presentes_sessao_plenaria ' : num_presentes_sessao_plen ,
' status_painel ' : ' ABERTO ' ,
' status_painel ' : ' ABERTO ' ,
' msg_painel ' : str ( _ ( ' Votação aberta! ' ) ) ,
' msg_painel ' : str ( _ ( ' Votação aberta! ' ) ) ,
' numero_votos_sim ' : 0 ,
' numero_votos_nao ' : 0 ,
' numero_abstencoes ' : 0 ,
' total_votos ' : 0 ,
' tipo_resultado ' : tipo_votacao ,
' tipo_resultado ' : tipo_votacao ,
' observacao_materia ' : materia . observacao ,
' observacao_materia ' : materia . observacao ,
' materia_legislativa_texto ' : str ( materia . materia ) } )
' materia_legislativa_texto ' : str ( materia . materia ) } )
@ -166,21 +152,8 @@ def get_presentes(pk, response, materia):
def get_materia_expediente_aberta ( pk ) :
def get_materia_expediente_aberta ( pk ) :
try :
return ExpedienteMateria . objects . filter (
materia = ExpedienteMateria . objects . filter (
sessao_plenaria_id = pk , votacao_aberta = True ) . last ( )
sessao_plenaria_id = pk , votacao_aberta = True ) . last ( )
return materia
except ObjectDoesNotExist :
return False
def get_last_materia_expediente ( pk ) :
try :
materia = ExpedienteMateria . objects . filter (
sessao_plenaria_id = pk ) . last ( )
return materia
except ObjectDoesNotExist :
return None
def get_presentes_expediente ( pk , response , materia ) :
def get_presentes_expediente ( pk , response , materia ) :
@ -221,10 +194,14 @@ def get_presentes_expediente(pk, response, materia):
if materia . tipo_votacao == 1 :
if materia . tipo_votacao == 1 :
tipo_votacao = ' Simbólica '
tipo_votacao = ' Simbólica '
response = get_votos ( response , materia )
elif materia . tipo_votacao == 2 :
elif materia . tipo_votacao == 2 :
tipo_votacao = ' Nominal '
tipo_votacao = ' Nominal '
response = get_votos_nominal ( response , materia )
elif materia . tipo_votacao == 3 :
elif materia . tipo_votacao == 3 :
tipo_votacao = ' Secreta '
tipo_votacao = ' Secreta '
response = get_votos ( response , materia )
response . update ( {
response . update ( {
' presentes_expediente ' : presentes_expediente ,
' presentes_expediente ' : presentes_expediente ,
' num_presentes_expediente ' : num_presentes_expediente ,
' num_presentes_expediente ' : num_presentes_expediente ,
@ -232,10 +209,6 @@ def get_presentes_expediente(pk, response, materia):
' num_presentes_sessao_plenaria ' : num_presentes_sessao_plen ,
' num_presentes_sessao_plenaria ' : num_presentes_sessao_plen ,
' status_painel ' : str ( _ ( ' ABERTO ' ) ) ,
' status_painel ' : str ( _ ( ' ABERTO ' ) ) ,
' msg_painel ' : str ( _ ( ' Votação aberta! ' ) ) ,
' msg_painel ' : str ( _ ( ' Votação aberta! ' ) ) ,
' numero_votos_sim ' : 0 ,
' numero_votos_nao ' : 0 ,
' numero_abstencoes ' : 0 ,
' total_votos ' : 0 ,
' tipo_resultado ' : tipo_votacao ,
' tipo_resultado ' : tipo_votacao ,
' observacao_materia ' : materia . observacao ,
' observacao_materia ' : materia . observacao ,
' materia_legislativa_texto ' : str ( materia . materia ) } )
' materia_legislativa_texto ' : str ( materia . materia ) } )
@ -245,16 +218,14 @@ def get_presentes_expediente(pk, response, materia):
# ##########################GENERAL FUNCTIONS#############################
# ##########################GENERAL FUNCTIONS#############################
def response_null _materia ( response ) :
def response_nenhuma _materia ( response ) :
response . update ( {
response . update ( {
' status_painel ' : ' FECHADO ' ,
' status_painel ' : ' FECHADO ' ,
' msg_painel ' : str ( _ ( ' Nenhuma matéria disponivel para votação. ' ) )
' msg_painel ' : str ( _ ( ' Nenhuma matéria disponivel para votação. ' ) ) } )
} )
return JsonResponse ( response )
return JsonResponse ( response )
def get_votos ( response , materia ) :
def get_votos ( response , materia ) :
if materia . tipo_votacao == 1 :
if materia . tipo_votacao == 1 :
tipo_votacao = ' Simbólica '
tipo_votacao = ' Simbólica '
elif materia . tipo_votacao == 2 :
elif materia . tipo_votacao == 2 :
@ -262,19 +233,34 @@ def get_votos(response, materia):
elif materia . tipo_votacao == 3 :
elif materia . tipo_votacao == 3 :
tipo_votacao = ' Secreta '
tipo_votacao = ' Secreta '
registro = RegistroVotacao . objects . filter (
if type ( materia ) == OrdemDia :
ordem = materia , materia = materia . materia ) . last ( )
registro = RegistroVotacao . objects . filter (
total = ( registro . numero_votos_sim +
ordem = materia , materia = materia . materia ) . last ( )
registro . numero_votos_nao +
else :
registro . numero_abstencoes )
registro = RegistroVotacao . objects . filter (
response . update ( {
expediente = materia , materia = materia . materia ) . last ( )
' numero_votos_sim ' : registro . numero_votos_sim ,
' numero_votos_nao ' : registro . numero_votos_nao ,
if registro :
' numero_abstencoes ' : registro . numero_abstencoes ,
total = ( registro . numero_votos_sim +
' total_votos ' : total ,
registro . numero_votos_nao +
' tipo_votacao ' : tipo_votacao ,
registro . numero_abstencoes )
' tipo_resultado ' : registro . tipo_resultado_votacao . nome ,
response . update ( {
} )
' numero_votos_sim ' : registro . numero_votos_sim ,
' numero_votos_nao ' : registro . numero_votos_nao ,
' numero_abstencoes ' : registro . numero_abstencoes ,
' total_votos ' : total ,
' tipo_votacao ' : tipo_votacao ,
' tipo_resultado ' : registro . tipo_resultado_votacao . nome ,
} )
else :
response . update ( {
' numero_votos_sim ' : 0 ,
' numero_votos_nao ' : 0 ,
' numero_abstencoes ' : 0 ,
' total_votos ' : 0 ,
' tipo_votacao ' : tipo_votacao ,
' tipo_resultado ' : ' Ainda não foi votada. ' ,
} )
return response
return response
@ -288,48 +274,65 @@ def get_votos_nominal(response, materia):
elif materia . tipo_votacao == 3 :
elif materia . tipo_votacao == 3 :
tipo_votacao = ' Secreta '
tipo_votacao = ' Secreta '
registro = RegistroVotacao . objects . get (
if type ( materia ) == OrdemDia :
ordem = materia , materia = materia . materia )
registro = RegistroVotacao . objects . filter (
ordem = materia , materia = materia . materia ) . last ( )
votos_parlamentares = VotoParlamentar . objects . filter (
else :
votacao_id = registro . id )
registro = RegistroVotacao . objects . filter (
expediente = materia , materia = materia . materia ) . last ( )
filiacao = Filiacao . objects . filter (
data_desfiliacao__isnull = True , parlamentar__ativo = True )
if not registro :
parlamentar_partido = { }
response . update ( {
for f in filiacao :
' numero_votos_sim ' : 0 ,
parlamentar_partido [
' numero_votos_nao ' : 0 ,
f . parlamentar . nome_parlamentar ] = f . partido . sigla
' numero_abstencoes ' : 0 ,
' total_votos ' : 0 ,
for v in votos_parlamentares :
' tipo_votacao ' : tipo_votacao ,
try :
' tipo_resultado ' : ' Não foi votado ainda ' ,
parlamentar_partido [ v . parlamentar . nome_parlamentar ]
' votos ' : None
except KeyError :
} )
votos . update ( { v . parlamentar . id : {
' parlamentar ' : v . parlamentar . nome_parlamentar ,
' voto ' : str ( v . voto ) ,
' partido ' : str ( _ ( ' Sem Registro ' ) )
} } )
else :
votos . update ( { v . parlamentar . id : {
' parlamentar ' : v . parlamentar . nome_parlamentar ,
' voto ' : str ( v . voto ) ,
' partido ' : parlamentar_partido [ v . parlamentar . nome_parlamentar ]
} } )
total = ( registro . numero_votos_sim +
registro . numero_votos_nao +
registro . numero_abstencoes )
response . update ( {
else :
' numero_votos_sim ' : registro . numero_votos_sim ,
votos_parlamentares = VotoParlamentar . objects . filter (
' numero_votos_nao ' : registro . numero_votos_nao ,
votacao_id = registro . id )
' numero_abstencoes ' : registro . numero_abstencoes ,
' total_votos ' : total ,
filiacao = Filiacao . objects . filter (
' tipo_votacao ' : tipo_votacao ,
data_desfiliacao__isnull = True , parlamentar__ativo = True )
' tipo_resultado ' : registro . tipo_resultado_votacao . nome ,
parlamentar_partido = { }
' votos ' : votos
for f in filiacao :
} )
parlamentar_partido [
f . parlamentar . nome_parlamentar ] = f . partido . sigla
for v in votos_parlamentares :
try :
parlamentar_partido [ v . parlamentar . nome_parlamentar ]
except KeyError :
votos . update ( { v . parlamentar . id : {
' parlamentar ' : v . parlamentar . nome_parlamentar ,
' voto ' : str ( v . voto ) ,
' partido ' : str ( _ ( ' Sem Registro ' ) )
} } )
else :
votos . update ( { v . parlamentar . id : {
' parlamentar ' : v . parlamentar . nome_parlamentar ,
' voto ' : str ( v . voto ) ,
' partido ' : parlamentar_partido [
v . parlamentar . nome_parlamentar ]
} } )
total = ( registro . numero_votos_sim +
registro . numero_votos_nao +
registro . numero_abstencoes )
response . update ( {
' numero_votos_sim ' : registro . numero_votos_sim ,
' numero_votos_nao ' : registro . numero_votos_nao ,
' numero_abstencoes ' : registro . numero_abstencoes ,
' total_votos ' : total ,
' tipo_votacao ' : tipo_votacao ,
' tipo_resultado ' : registro . tipo_resultado_votacao . nome ,
' votos ' : votos
} )
return response
return response
@ -358,37 +361,57 @@ def get_dados_painel(request, pk):
elif expediente :
elif expediente :
return JsonResponse ( get_presentes_expediente ( pk , response , expediente ) )
return JsonResponse ( get_presentes_expediente ( pk , response , expediente ) )
ultima_ordem = get_last_materia ( pk )
# Ultimo voto em ordem e ultimo voto em expediente
last_ordem_voto = RegistroVotacao . objects . filter (
if ultima_ordem :
ordem__sessao_plenaria = sessao ) . last ( )
if ultima_ordem . resultado :
last_expediente_voto = RegistroVotacao . objects . filter (
if ultima_ordem . tipo_votacao in [ 1 , 3 ] :
expediente__sessao_plenaria = sessao ) . last ( )
return JsonResponse (
get_votos ( get_presentes (
# Ultimas materias votadas
pk , response , ultima_ordem ) , ultima_ordem ) )
if last_ordem_voto :
elif ultima_ordem . tipo_votacao == 2 :
ultima_ordem_votada = last_ordem_voto . ordem
return JsonResponse (
if last_expediente_voto :
get_votos_nominal ( get_presentes (
ultimo_expediente_votado = last_expediente_voto . expediente
pk , response , ultima_ordem ) , ultima_ordem ) )
else :
# Caso não tenha nenhuma votação aberta
return JsonResponse ( get_presentes ( pk , response , ultima_ordem ) )
if last_ordem_voto or last_expediente_voto :
ultimo_expediente = get_last_materia_expediente ( pk )
# Se alguma ordem E algum expediente já tiver sido votado...
if last_ordem_voto and last_expediente_voto :
if ultimo_expediente :
# Verifica se o último resultado é um uma ordem do dia
if ultimo_expediente . resultado :
if last_ordem_voto . pk > = last_expediente_voto . pk :
if ultimo_expediente . tipo_votacao in [ 1 , 3 ] :
if ultima_ordem_votada . tipo_votacao in [ 1 , 3 ] :
return JsonResponse (
return JsonResponse (
get_votos ( get_presentes (
get_votos ( get_presentes (
pk , response , ultimo_expediente ) ,
pk , response , ultima_ordem_votada ) ,
ultimo_expediente ) )
ultima_ordem_votada ) )
elif ultimo_expediente . tipo_votacao == 2 :
elif ultima_ordem_votada . tipo_votacao == 2 :
return JsonResponse (
return JsonResponse (
get_votos_nominal ( get_presentes (
get_votos_nominal ( get_presentes (
pk , response , ultimo_expediente ) ,
pk , response , ultima_ordem_votada ) ,
ultimo_expediente ) )
ultima_ordem_votada ) )
else :
# Caso não seja, verifica se é um expediente
else :
if ultimo_expediente_votado . tipo_votacao in [ 1 , 3 ] :
return JsonResponse (
get_votos ( get_presentes (
pk , response , ultimo_expediente_votado ) ,
ultimo_expediente_votado ) )
elif ultimo_expediente_votado . tipo_votacao == 2 :
return JsonResponse (
get_votos_nominal ( get_presentes (
pk , response ,
ultimo_expediente_votado ) ,
ultimo_expediente_votado ) )
# Caso somente um deles tenha resultado, prioriza a Ordem do Dia
if last_ordem_voto :
return JsonResponse ( get_presentes (
pk , response , ultima_ordem_votada ) )
# Caso a Ordem do dia não tenha resultado, mostra o último expediente
if last_expediente_voto :
return JsonResponse ( get_presentes ( pk , response ,
return JsonResponse ( get_presentes ( pk , response ,
ultimo_expediente ) )
ultimo_expediente_votado ) )
else :
return response_null_materia ( response )
# Retorna que não há nenhuma matéria já votada ou aberta
return response_nenhuma_materia ( response )