|
|
|
from datetime import datetime
|
|
|
|
from re import sub
|
|
|
|
|
|
|
|
from django import forms
|
|
|
|
from django.core.urlresolvers import reverse
|
|
|
|
from django.utils.html import strip_tags
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from django.views.generic.edit import FormMixin
|
|
|
|
|
|
|
|
from materia.models import Autoria, TipoMateriaLegislativa
|
|
|
|
from parlamentares.models import Parlamentar
|
|
|
|
from sapl.crud import build_crud
|
|
|
|
|
|
|
|
from .models import (CargoMesa, ExpedienteMateria, ExpedienteSessao,
|
|
|
|
IntegranteMesa, Orador, OradorExpediente, OrdemDia,
|
|
|
|
PresencaOrdemDia, RegistroVotacao, SessaoPlenaria,
|
|
|
|
SessaoPlenariaPresenca, TipoExpediente,
|
|
|
|
TipoResultadoVotacao, TipoSessaoPlenaria)
|
|
|
|
|
|
|
|
tipo_sessao_crud = build_crud(
|
|
|
|
TipoSessaoPlenaria, 'tipo_sessao_plenaria', [
|
|
|
|
|
|
|
|
[_('Tipo de Sessão Plenária'),
|
|
|
|
[('nome', 6), ('quorum_minimo', 6)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
sessao_crud = build_crud(
|
|
|
|
SessaoPlenaria, '', [
|
|
|
|
|
|
|
|
[_('Dados Básicos'),
|
|
|
|
[('numero', 1),
|
|
|
|
('tipo', 3),
|
|
|
|
('legislatura', 4),
|
|
|
|
('sessao_legislativa', 4)],
|
|
|
|
[('data_inicio', 5), ('hora_inicio', 5), ('iniciada', 2)],
|
|
|
|
[('data_fim', 5), ('hora_fim', 5), ('finalizada', 2)],
|
|
|
|
[('upload_pauta', 6), ('upload_ata', 6)],
|
|
|
|
[('url_audio', 6), ('url_video', 6)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
expediente_materia_crud = build_crud(
|
|
|
|
ExpedienteMateria, '', [
|
|
|
|
|
|
|
|
[_('Cadastro de Matérias do Expediente'),
|
|
|
|
[('data_ordem', 4), ('tip_sessao_FIXME', 4), ('numero_ordem', 4)],
|
|
|
|
[('tip_id_basica_FIXME', 4),
|
|
|
|
('num_ident_basica_FIXME', 4),
|
|
|
|
('ano_ident_basica_FIXME', 4)],
|
|
|
|
[('tipo_votacao', 12)],
|
|
|
|
[('observacao', 12)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
ordem_dia_crud = build_crud(
|
|
|
|
OrdemDia, '', [
|
|
|
|
|
|
|
|
[_('Cadastro de Matérias da Ordem do Dia'),
|
|
|
|
[('data_ordem', 4), ('tip_sessao_FIXME', 4), ('numero_ordem', 4)],
|
|
|
|
[('tip_id_basica_FIXME', 4),
|
|
|
|
('num_ident_basica_FIXME', 4),
|
|
|
|
('ano_ident_basica_FIXME', 4)],
|
|
|
|
[('tipo_votacao', 12)],
|
|
|
|
[('observacao', 12)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
tipo_resultado_votacao_crud = build_crud(
|
|
|
|
TipoResultadoVotacao, 'tipo_resultado_votacao', [
|
|
|
|
|
|
|
|
[_('Tipo de Resultado da Votação'),
|
|
|
|
[('nome', 12)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
tipo_expediente_crud = build_crud(
|
|
|
|
TipoExpediente, 'tipo_expediente', [
|
|
|
|
|
|
|
|
[_('Tipo de Expediente'),
|
|
|
|
[('nome', 12)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
registro_votacao_crud = build_crud(
|
|
|
|
RegistroVotacao, '', [
|
|
|
|
|
|
|
|
[_('Votação Simbólica'),
|
|
|
|
[('numero_votos_sim', 3),
|
|
|
|
('numero_votos_nao', 3),
|
|
|
|
('numero_abstencoes', 3),
|
|
|
|
('nao_votou_FIXME', 3)],
|
|
|
|
[('votacao_branco_FIXME', 6),
|
|
|
|
('ind_votacao_presidente_FIXME', 6)],
|
|
|
|
[('tipo_resultado_votacao', 12)],
|
|
|
|
[('observacao', 12)]],
|
|
|
|
])
|
|
|
|
|
|
|
|
|
|
|
|
class PresencaForm(forms.Form):
|
|
|
|
presenca = forms.CharField(required=False, initial=False)
|
|
|
|
parlamentar = forms.CharField(required=False, max_length=20)
|
|
|
|
|
|
|
|
|
|
|
|
class PresencaView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/presenca.html'
|
|
|
|
form_class = PresencaForm
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = self.get_form()
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
# Pegar os presentes salvos no banco
|
|
|
|
presentes_banco = SessaoPlenariaPresenca.objects.filter(
|
|
|
|
sessao_plen_id=self.object.id)
|
|
|
|
|
|
|
|
# Id dos parlamentares presentes
|
|
|
|
marcados = request.POST.getlist('presenca')
|
|
|
|
|
|
|
|
# Deletar os que foram desmarcadors
|
|
|
|
deletar = set(set(presentes_banco) - set(marcados))
|
|
|
|
for d in deletar:
|
|
|
|
SessaoPlenariaPresenca.objects.filter(
|
|
|
|
parlamentar_id=d.parlamentar_id).delete()
|
|
|
|
|
|
|
|
for p in marcados:
|
|
|
|
sessao = SessaoPlenariaPresenca()
|
|
|
|
sessao.sessao_plen = self.object
|
|
|
|
sessao.parlamentar = Parlamentar.objects.get(id=p)
|
|
|
|
sessao.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:presenca', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
def get_parlamentares(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
|
|
|
|
presencas = SessaoPlenariaPresenca.objects.filter(
|
|
|
|
sessao_plen_id=self.object.id
|
|
|
|
)
|
|
|
|
|
|
|
|
presentes = []
|
|
|
|
for p in presencas:
|
|
|
|
presentes.append(p.parlamentar.id)
|
|
|
|
|
|
|
|
for parlamentar in Parlamentar.objects.all():
|
|
|
|
if parlamentar.ativo:
|
|
|
|
try:
|
|
|
|
presentes.index(parlamentar.id)
|
|
|
|
except ValueError:
|
|
|
|
yield (parlamentar, False)
|
|
|
|
else:
|
|
|
|
yield (parlamentar, True)
|
|
|
|
|
|
|
|
|
|
|
|
class PainelView(sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/painel.html'
|
|
|
|
|
|
|
|
|
|
|
|
class PresencaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/presencaOrdemDia.html'
|
|
|
|
form_class = PresencaForm
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = self.get_form()
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
# Pegar os presentes salvos no banco
|
|
|
|
presentes_banco = PresencaOrdemDia.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id)
|
|
|
|
|
|
|
|
# Id dos parlamentares presentes
|
|
|
|
marcados = request.POST.getlist('presenca')
|
|
|
|
|
|
|
|
# Deletar os que foram desmarcadors
|
|
|
|
deletar = set(set(presentes_banco) - set(marcados))
|
|
|
|
for d in deletar:
|
|
|
|
PresencaOrdemDia.objects.filter(
|
|
|
|
parlamentar_id=d.parlamentar_id).delete()
|
|
|
|
|
|
|
|
for p in marcados:
|
|
|
|
ordem = PresencaOrdemDia()
|
|
|
|
ordem.sessao_plenaria = self.object
|
|
|
|
ordem.parlamentar = Parlamentar.objects.get(id=p)
|
|
|
|
ordem.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:presencaordemdia', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
def get_parlamentares(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
|
|
|
|
presencas = PresencaOrdemDia.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id
|
|
|
|
)
|
|
|
|
|
|
|
|
presentes = []
|
|
|
|
for p in presencas:
|
|
|
|
presentes.append(p.parlamentar.id)
|
|
|
|
|
|
|
|
for parlamentar in Parlamentar.objects.all():
|
|
|
|
if parlamentar.ativo:
|
|
|
|
try:
|
|
|
|
presentes.index(parlamentar.id)
|
|
|
|
except ValueError:
|
|
|
|
yield (parlamentar, False)
|
|
|
|
else:
|
|
|
|
yield (parlamentar, True)
|
|
|
|
|
|
|
|
|
|
|
|
class ListMateriaOrdemDiaView(sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/materia_ordemdia_list.html'
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
ordem = OrdemDia.objects.filter(sessao_plenaria_id=pk)
|
|
|
|
|
|
|
|
materias_ordem = []
|
|
|
|
for o in ordem:
|
|
|
|
ementa = o.observacao
|
|
|
|
titulo = o.materia
|
|
|
|
numero = o.numero_ordem
|
|
|
|
|
|
|
|
print(ementa)
|
|
|
|
|
|
|
|
autoria = Autoria.objects.filter(materia_id=o.materia_id)
|
|
|
|
if len(autoria) > 1:
|
|
|
|
autor = 'Autores: '
|
|
|
|
else:
|
|
|
|
autor = 'Autor: '
|
|
|
|
|
|
|
|
for a in autoria:
|
|
|
|
autor += str(a.autor)
|
|
|
|
autor += ' '
|
|
|
|
|
|
|
|
resultado = ''
|
|
|
|
|
|
|
|
mat = {'pk': pk,
|
|
|
|
'oid': o.id,
|
|
|
|
'ementa': ementa,
|
|
|
|
'titulo': titulo,
|
|
|
|
'numero': numero,
|
|
|
|
'resultado': o.resultado,
|
|
|
|
'autor': autor,
|
|
|
|
}
|
|
|
|
materias_ordem.append(mat)
|
|
|
|
|
|
|
|
sorted(materias_ordem, key=lambda x: x['numero'])
|
|
|
|
|
|
|
|
context.update({'materias_ordem': materias_ordem})
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
|
|
|
class MateriaOrdemDiaForm(forms.Form):
|
|
|
|
data_sessao = forms.CharField(required=True)
|
|
|
|
numero_ordem = forms.IntegerField(required=True)
|
|
|
|
tipo_votacao = forms.IntegerField(required=True)
|
|
|
|
tipo_sessao = forms.IntegerField(required=True)
|
|
|
|
ano_materia = forms.IntegerField(required=True)
|
|
|
|
numero_materia = forms.IntegerField(required=True)
|
|
|
|
tipo_materia = forms.IntegerField(required=True)
|
|
|
|
observacao = forms.CharField(required=False)
|
|
|
|
|
|
|
|
|
|
|
|
class MateriaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/materia_ordemdia.html'
|
|
|
|
form_class = MateriaOrdemDiaForm
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:materiaordemdia_list', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
now = datetime.now()
|
|
|
|
|
|
|
|
tipo_materia = TipoMateriaLegislativa.objects.all()
|
|
|
|
data_sessao = "%s/%s/%s" % (now.day, now.month, now.year)
|
|
|
|
tipo_sessao = TipoSessaoPlenaria.objects.all()
|
|
|
|
tipo_votacao = ExpedienteMateria.TIPO_VOTACAO_CHOICES
|
|
|
|
ano_materia = now.year
|
|
|
|
|
|
|
|
context.update({'data_sessao': data_sessao,
|
|
|
|
'tipo_sessao': tipo_sessao,
|
|
|
|
'tipo_materia': tipo_materia,
|
|
|
|
'tipo_votacao': tipo_votacao,
|
|
|
|
'ano_materia': ano_materia,
|
|
|
|
'error_message': '', })
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
form = MateriaOrdemDiaForm(request.POST)
|
|
|
|
|
|
|
|
# print(form)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
|
|
|
|
# TODO: Pra que tipo_materia e tipo_sessao
|
|
|
|
# se já existem em seus respectivos objetos???
|
|
|
|
# TODO: barrar matérias não existentes
|
|
|
|
# TODO: barrar criação de ordemdia para materias já incluídas
|
|
|
|
|
|
|
|
ordemdia = OrdemDia()
|
|
|
|
ordemdia.sessao_plenaria_id = self.object.id
|
|
|
|
ordemdia.materia_id = request.POST['numero_materia']
|
|
|
|
ordemdia.numero_ordem = request.POST['numero_ordem']
|
|
|
|
ordemdia.data_ordem = datetime.now()
|
|
|
|
ordemdia.observacao = sub(
|
|
|
|
' ', ' ', strip_tags(request.POST['observacao']))
|
|
|
|
ordemdia.tipo_votacao = request.POST['tipo_votacao']
|
|
|
|
|
|
|
|
ordemdia.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
context.update(
|
|
|
|
{'error_message': "Não foi possível salvar formulário!"})
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
|
|
|
|
class EditMateriaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/materia_ordemdia.html'
|
|
|
|
form_class = MateriaOrdemDiaForm
|
|
|
|
|
|
|
|
|
|
|
|
class OradorForm(forms.Form):
|
|
|
|
numero_ordem = forms.IntegerField(required=True)
|
|
|
|
parlamentar = forms.CharField(required=False, max_length=20)
|
|
|
|
url_discurso = forms.CharField(required=False, max_length=100)
|
|
|
|
|
|
|
|
|
|
|
|
class OradorDeleteForm(forms.Form):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class OradorExpedienteDelete(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/delete_orador.html'
|
|
|
|
form_class = OradorDeleteForm
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
current_url = request.get_full_path()
|
|
|
|
words = current_url.split('/')
|
|
|
|
form = OradorDeleteForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
orador = OradorExpediente.objects.get(
|
|
|
|
sessao_plenaria_id=self.object.id,
|
|
|
|
parlamentar_id=words[-1])
|
|
|
|
orador.delete()
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:oradorexpediente', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
|
|
|
|
class OradorExpedienteEdit(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/edit_orador.html'
|
|
|
|
form_class = OradorForm
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:oradorexpediente', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = OradorForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
current_url = request.get_full_path()
|
|
|
|
words = current_url.split('/')
|
|
|
|
|
|
|
|
orador = OradorExpediente.objects.get(
|
|
|
|
sessao_plenaria_id=self.object.id,
|
|
|
|
parlamentar_id=words[-1])
|
|
|
|
orador.delete()
|
|
|
|
|
|
|
|
orador = OradorExpediente()
|
|
|
|
orador.sessao_plenaria_id = self.object.id
|
|
|
|
orador.numero_ordem = request.POST['numero_ordem']
|
|
|
|
orador.parlamentar = Parlamentar.objects.get(
|
|
|
|
id=words[-1])
|
|
|
|
orador.url_discurso = request.POST['url_discurso']
|
|
|
|
orador.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
current_url = self.request.get_full_path()
|
|
|
|
words = current_url.split('/')
|
|
|
|
|
|
|
|
parlamentar = Parlamentar.objects.get(id=words[-1])
|
|
|
|
orador = OradorExpediente.objects.get(
|
|
|
|
sessao_plenaria=self.object, parlamentar=parlamentar)
|
|
|
|
|
|
|
|
orador = {'parlamentar': parlamentar, 'numero_ordem':
|
|
|
|
orador.numero_ordem, 'url_discurso': orador.url_discurso}
|
|
|
|
context.update({'orador': orador})
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
|
|
|
class OradorExpedienteView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/oradorExpediente.html'
|
|
|
|
form_class = OradorForm
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def get_candidatos_orador(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
lista_parlamentares = []
|
|
|
|
lista_oradores = []
|
|
|
|
|
|
|
|
for parlamentar in Parlamentar.objects.all():
|
|
|
|
if parlamentar.ativo:
|
|
|
|
lista_parlamentares.append(parlamentar)
|
|
|
|
|
|
|
|
for orador in OradorExpediente.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id):
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=orador.parlamentar_id)
|
|
|
|
lista_oradores.append(parlamentar)
|
|
|
|
|
|
|
|
lista = list(set(lista_parlamentares) - set(lista_oradores))
|
|
|
|
lista.sort(key=lambda x: x.nome_parlamentar)
|
|
|
|
return lista
|
|
|
|
|
|
|
|
def get_oradores(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
|
|
|
|
for orador in OradorExpediente.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id):
|
|
|
|
numero_ordem = orador.numero_ordem
|
|
|
|
url_discurso = orador.url_discurso
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=orador.parlamentar_id)
|
|
|
|
yield(numero_ordem, url_discurso, parlamentar)
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = OradorForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
orador = OradorExpediente()
|
|
|
|
orador.sessao_plenaria_id = self.object.id
|
|
|
|
orador.numero_ordem = request.POST['numero_ordem']
|
|
|
|
orador.parlamentar = Parlamentar.objects.get(
|
|
|
|
id=request.POST['parlamentar'])
|
|
|
|
orador.url_discurso = request.POST['url_discurso']
|
|
|
|
orador.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:oradorexpediente', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
|
|
|
|
class MesaForm(forms.Form):
|
|
|
|
parlamentar = forms.IntegerField(required=True)
|
|
|
|
cargo = forms.IntegerField(required=True)
|
|
|
|
|
|
|
|
|
|
|
|
class MesaView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/mesa.html'
|
|
|
|
form_class = MesaForm
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:mesa', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = MesaForm(request.POST)
|
|
|
|
|
|
|
|
if 'Incluir' in request.POST:
|
|
|
|
if form.is_valid():
|
|
|
|
integrante = IntegranteMesa()
|
|
|
|
integrante.sessao_plenaria_id = self.object.id
|
|
|
|
integrante.parlamentar_id = request.POST['parlamentar']
|
|
|
|
integrante.cargo_id = request.POST['cargo']
|
|
|
|
integrante.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
|
|
|
|
else:
|
|
|
|
form.clean()
|
|
|
|
return self.form_valid(form)
|
|
|
|
elif 'Excluir' in request.POST:
|
|
|
|
ids = request.POST['composicao_mesa'].split(':')
|
|
|
|
IntegranteMesa.objects.get(
|
|
|
|
sessao_plenaria_id=self.object.id,
|
|
|
|
parlamentar_id=ids[0],
|
|
|
|
cargo_id=ids[1]
|
|
|
|
).delete()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
mesa = IntegranteMesa.objects.filter(
|
|
|
|
sessao_plenaria=self.object)
|
|
|
|
|
|
|
|
integrantes = []
|
|
|
|
for m in mesa:
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=m.parlamentar_id)
|
|
|
|
cargo = CargoMesa.objects.get(
|
|
|
|
id=m.cargo_id)
|
|
|
|
integrante = {'parlamentar': parlamentar, 'cargo': cargo}
|
|
|
|
integrantes.append(integrante)
|
|
|
|
|
|
|
|
context.update({'integrantes': integrantes})
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def get_candidatos_mesa(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
lista_parlamentares = []
|
|
|
|
lista_integrantes = []
|
|
|
|
|
|
|
|
for parlamentar in Parlamentar.objects.all():
|
|
|
|
if parlamentar.ativo:
|
|
|
|
lista_parlamentares.append(parlamentar)
|
|
|
|
|
|
|
|
for integrante in IntegranteMesa.objects.filter(
|
|
|
|
sessao_plenaria=self.object):
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=integrante.parlamentar_id)
|
|
|
|
lista_integrantes.append(parlamentar)
|
|
|
|
|
|
|
|
lista = list(set(lista_parlamentares) - set(lista_integrantes))
|
|
|
|
lista.sort(key=lambda x: x.nome_parlamentar)
|
|
|
|
return lista
|
|
|
|
|
|
|
|
def get_cargos_mesa(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
lista_cargos = CargoMesa.objects.all()
|
|
|
|
lista_cargos_ocupados = []
|
|
|
|
|
|
|
|
for integrante in IntegranteMesa.objects.filter(
|
|
|
|
sessao_plenaria=self.object):
|
|
|
|
cargo = CargoMesa.objects.get(
|
|
|
|
id=integrante.cargo_id)
|
|
|
|
lista_cargos_ocupados.append(cargo)
|
|
|
|
|
|
|
|
lista = list(set(lista_cargos) - set(lista_cargos_ocupados))
|
|
|
|
lista.sort(key=lambda x: x.descricao)
|
|
|
|
return lista
|
|
|
|
|
|
|
|
|
|
|
|
class ResumoView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/Resumo.html'
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Identificação Básica
|
|
|
|
context.update({'basica': ['Tipo de Sessão: ' + str(self.object.tipo),
|
|
|
|
'Abertura: ' + str(self.object.data_inicio),
|
|
|
|
'Encerramento: ' + str(self.object.data_fim)
|
|
|
|
]})
|
|
|
|
# =====================================================================
|
|
|
|
# Conteúdo Multimídia
|
|
|
|
if(self.object.url_audio):
|
|
|
|
context.update({'multimidia_audio':
|
|
|
|
'Audio: ' + str(self.object.url_audio)})
|
|
|
|
else:
|
|
|
|
context.update({'multimidia_audio': 'Audio: Indisponivel'})
|
|
|
|
|
|
|
|
if(self.object.url_video):
|
|
|
|
context.update({'multimidia_video':
|
|
|
|
'Video: ' + str(self.object.url_video)})
|
|
|
|
else:
|
|
|
|
context.update({'multimidia_video': 'Video: Indisponivel'})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Mesa Diretora
|
|
|
|
mesa = IntegranteMesa.objects.filter(
|
|
|
|
sessao_plenaria=self.object)
|
|
|
|
|
|
|
|
integrantes = []
|
|
|
|
for m in mesa:
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=m.parlamentar_id)
|
|
|
|
cargo = CargoMesa.objects.get(
|
|
|
|
id=m.cargo_id)
|
|
|
|
integrante = {'parlamentar': parlamentar, 'cargo': cargo}
|
|
|
|
integrantes.append(integrante)
|
|
|
|
|
|
|
|
context.update({'mesa': integrantes})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Presença Sessão
|
|
|
|
presencas = SessaoPlenariaPresenca.objects.filter(
|
|
|
|
sessao_plen_id=self.object.id
|
|
|
|
)
|
|
|
|
|
|
|
|
parlamentares_sessao = []
|
|
|
|
for p in presencas:
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=p.parlamentar_id)
|
|
|
|
parlamentares_sessao.append(parlamentar)
|
|
|
|
|
|
|
|
context.update({'presenca_sessao': parlamentares_sessao})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Expedientes
|
|
|
|
expediente = ExpedienteSessao.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id)
|
|
|
|
|
|
|
|
expedientes = []
|
|
|
|
for e in expediente:
|
|
|
|
tipo = TipoExpediente.objects.get(
|
|
|
|
id=e.tipo_id)
|
|
|
|
conteudo = sub(
|
|
|
|
' ', ' ', strip_tags(e.conteudo))
|
|
|
|
|
|
|
|
ex = {'tipo': tipo, 'conteudo': conteudo}
|
|
|
|
expedientes.append(ex)
|
|
|
|
|
|
|
|
context.update({'expedientes': expedientes})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Matérias Expediente
|
|
|
|
materias = ExpedienteMateria.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id)
|
|
|
|
|
|
|
|
materias_expediente = []
|
|
|
|
for m in materias:
|
|
|
|
ementa = m.observacao
|
|
|
|
titulo = m.materia
|
|
|
|
numero = m.numero_ordem
|
|
|
|
|
|
|
|
if m.resultado:
|
|
|
|
resultado = m.resultado
|
|
|
|
else:
|
|
|
|
resultado = 'Matéria não votada'
|
|
|
|
|
|
|
|
autoria = Autoria.objects.filter(
|
|
|
|
materia_id=m.materia_id)
|
|
|
|
if len(autoria) > 1:
|
|
|
|
autor = 'Autores: '
|
|
|
|
else:
|
|
|
|
autor = 'Autor: '
|
|
|
|
|
|
|
|
for a in autoria:
|
|
|
|
autor += str(a.autor)
|
|
|
|
autor += ' '
|
|
|
|
|
|
|
|
mat = {'ementa': ementa,
|
|
|
|
'titulo': titulo,
|
|
|
|
'numero': numero,
|
|
|
|
'resultado': resultado,
|
|
|
|
'autor': autor
|
|
|
|
}
|
|
|
|
materias_expediente.append(mat)
|
|
|
|
|
|
|
|
context.update({'materia_expediente': materias_expediente})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Oradores Expediente
|
|
|
|
oradores = []
|
|
|
|
for orador in OradorExpediente.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id):
|
|
|
|
numero_ordem = orador.numero_ordem
|
|
|
|
url_discurso = orador.url_discurso
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=orador.parlamentar_id)
|
|
|
|
ora = {'numero_ordem': numero_ordem,
|
|
|
|
'url_discurso': url_discurso,
|
|
|
|
'parlamentar': parlamentar
|
|
|
|
}
|
|
|
|
oradores.append(ora)
|
|
|
|
|
|
|
|
context.update({'oradores': oradores})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Presença Ordem do Dia
|
|
|
|
presencas = PresencaOrdemDia.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id
|
|
|
|
)
|
|
|
|
|
|
|
|
parlamentares_ordem = []
|
|
|
|
for p in presencas:
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=p.parlamentar_id)
|
|
|
|
parlamentares_ordem.append(parlamentar)
|
|
|
|
|
|
|
|
context.update({'presenca_ordem': parlamentares_ordem})
|
|
|
|
|
|
|
|
# =====================================================================
|
|
|
|
# Matérias Ordem do Dia
|
|
|
|
ordem = OrdemDia.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id)
|
|
|
|
|
|
|
|
materias_ordem = []
|
|
|
|
for o in ordem:
|
|
|
|
ementa = o.observacao
|
|
|
|
titulo = o.materia
|
|
|
|
numero = o.numero_ordem
|
|
|
|
|
|
|
|
# Verificar resultado
|
|
|
|
if m.resultado:
|
|
|
|
resultado = m.resultado
|
|
|
|
else:
|
|
|
|
resultado = 'Matéria não votada'
|
|
|
|
|
|
|
|
autoria = Autoria.objects.filter(
|
|
|
|
materia_id=o.materia_id)
|
|
|
|
if len(autoria) > 1:
|
|
|
|
autor = 'Autores: '
|
|
|
|
else:
|
|
|
|
autor = 'Autor: '
|
|
|
|
|
|
|
|
for a in autoria:
|
|
|
|
autor += str(a.autor)
|
|
|
|
autor += ' '
|
|
|
|
# autor += ' '.join(map(lambda a : str(a.autor), autoria))
|
|
|
|
|
|
|
|
mat = {'ementa': ementa,
|
|
|
|
'titulo': titulo,
|
|
|
|
'numero': numero,
|
|
|
|
'resultado': resultado,
|
|
|
|
'autor': autor
|
|
|
|
}
|
|
|
|
materias_ordem.append(mat)
|
|
|
|
|
|
|
|
context.update({'materias_ordem': materias_ordem})
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
|
|
|
class ExpedienteForm(forms.Form):
|
|
|
|
conteudo = forms.CharField(required=False, widget=forms.Textarea)
|
|
|
|
|
|
|
|
|
|
|
|
class ExpedienteView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/expediente.html'
|
|
|
|
form_class = ExpedienteForm
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = ExpedienteForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
list_tipo = request.POST.getlist('tipo')
|
|
|
|
list_conteudo = request.POST.getlist('conteudo')
|
|
|
|
|
|
|
|
for tipo, conteudo in zip(list_tipo, list_conteudo):
|
|
|
|
try:
|
|
|
|
ExpedienteSessao.objects.get(
|
|
|
|
sessao_plenaria_id=self.object.id,
|
|
|
|
tipo_id=tipo
|
|
|
|
).delete()
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
|
|
|
|
expediente = ExpedienteSessao()
|
|
|
|
expediente.sessao_plenaria_id = self.object.id
|
|
|
|
expediente.tipo_id = tipo
|
|
|
|
expediente.conteudo = conteudo
|
|
|
|
expediente.save()
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_valid(form)
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
tipos = TipoExpediente.objects.all()
|
|
|
|
expedientes_sessao = ExpedienteSessao.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id)
|
|
|
|
|
|
|
|
expedientes_salvos = []
|
|
|
|
for e in expedientes_sessao:
|
|
|
|
expedientes_salvos.append(e.tipo)
|
|
|
|
|
|
|
|
tipos_null = list(set(tipos) - set(expedientes_salvos))
|
|
|
|
|
|
|
|
expedientes = []
|
|
|
|
for e, t in zip(expedientes_sessao, tipos):
|
|
|
|
expedientes.append({'tipo': e.tipo,
|
|
|
|
'conteudo': e.conteudo
|
|
|
|
})
|
|
|
|
context.update({'expedientes': expedientes})
|
|
|
|
|
|
|
|
for e in tipos_null:
|
|
|
|
expedientes.append({'tipo': e,
|
|
|
|
'conteudo': ''
|
|
|
|
})
|
|
|
|
|
|
|
|
context.update({'expedientes': expedientes})
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:expediente', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
|
|
|
|
class ExplicacaoView(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/explicacao.html'
|
|
|
|
form_class = OradorForm
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def get_candidatos_orador(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
lista_parlamentares = []
|
|
|
|
lista_oradores = []
|
|
|
|
|
|
|
|
for parlamentar in Parlamentar.objects.all():
|
|
|
|
if parlamentar.ativo:
|
|
|
|
lista_parlamentares.append(parlamentar)
|
|
|
|
|
|
|
|
for orador in Orador.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id):
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=orador.parlamentar_id)
|
|
|
|
lista_oradores.append(parlamentar)
|
|
|
|
|
|
|
|
lista = list(set(lista_parlamentares) - set(lista_oradores))
|
|
|
|
lista.sort(key=lambda x: x.nome_parlamentar)
|
|
|
|
return lista
|
|
|
|
|
|
|
|
def get_oradores(self):
|
|
|
|
self.object = self.get_object()
|
|
|
|
|
|
|
|
for orador in Orador.objects.filter(
|
|
|
|
sessao_plenaria_id=self.object.id):
|
|
|
|
numero_ordem = orador.numero_ordem
|
|
|
|
url_discurso = orador.url_discurso
|
|
|
|
parlamentar = Parlamentar.objects.get(
|
|
|
|
id=orador.parlamentar_id)
|
|
|
|
yield(numero_ordem, url_discurso, parlamentar)
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = OradorForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
orador = Orador()
|
|
|
|
orador.sessao_plenaria_id = self.object.id
|
|
|
|
orador.numero_ordem = request.POST['numero_ordem']
|
|
|
|
orador.parlamentar = Parlamentar.objects.get(
|
|
|
|
id=request.POST['parlamentar'])
|
|
|
|
orador.url_discurso = request.POST['url_discurso']
|
|
|
|
orador.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:explicacao', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
|
|
|
|
class ExplicacaoDelete(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/delete_explicacao.html'
|
|
|
|
form_class = OradorDeleteForm
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
current_url = request.get_full_path()
|
|
|
|
words = current_url.split('/')
|
|
|
|
form = OradorDeleteForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
orador = Orador.objects.get(
|
|
|
|
sessao_plenaria_id=self.object.id,
|
|
|
|
parlamentar_id=words[-1])
|
|
|
|
orador.delete()
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:explicacao', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
|
|
|
|
class ExplicacaoEdit(FormMixin, sessao_crud.CrudDetailView):
|
|
|
|
template_name = 'sessao/edit_explicacao.html'
|
|
|
|
form_class = OradorForm
|
|
|
|
|
|
|
|
def get_success_url(self):
|
|
|
|
pk = self.kwargs['pk']
|
|
|
|
return reverse('sessaoplenaria:explicacao', kwargs={'pk': pk})
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
form = OradorForm(request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
current_url = request.get_full_path()
|
|
|
|
words = current_url.split('/')
|
|
|
|
|
|
|
|
orador = Orador.objects.get(
|
|
|
|
sessao_plenaria_id=self.object.id,
|
|
|
|
parlamentar_id=words[-1])
|
|
|
|
orador.delete()
|
|
|
|
|
|
|
|
orador = Orador()
|
|
|
|
orador.sessao_plenaria_id = self.object.id
|
|
|
|
orador.numero_ordem = request.POST['numero_ordem']
|
|
|
|
orador.parlamentar = Parlamentar.objects.get(
|
|
|
|
id=words[-1])
|
|
|
|
orador.url_discurso = request.POST['url_discurso']
|
|
|
|
orador.save()
|
|
|
|
|
|
|
|
return self.form_valid(form)
|
|
|
|
else:
|
|
|
|
return self.form_invalid(form)
|
|
|
|
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
context = self.get_context_data(object=self.object)
|
|
|
|
|
|
|
|
current_url = self.request.get_full_path()
|
|
|
|
words = current_url.split('/')
|
|
|
|
|
|
|
|
parlamentar = Parlamentar.objects.get(id=words[-1])
|
|
|
|
orador = Orador.objects.get(
|
|
|
|
sessao_plenaria=self.object, parlamentar=parlamentar)
|
|
|
|
|
|
|
|
explicacao = {'parlamentar': parlamentar, 'numero_ordem':
|
|
|
|
orador.numero_ordem, 'url_discurso': orador.url_discurso}
|
|
|
|
context.update({'explicacao': explicacao})
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|