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 extra_views import InlineFormSetView from materia.models import Autoria, TipoMateriaLegislativa from parlamentares.models import Parlamentar from sapl.crud import build_crud from .models import (CargoMesa, ExpedienteMateria, ExpedienteSessao, IntegranteMesa, 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 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', 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 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 += ' ' 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_tipos(self): tipos = TipoExpediente.objects.all() for t in tipos: yield (t.nome, t.id) def get_success_url(self): pk = self.kwargs['pk'] return reverse('sessaoplenaria:expediente', kwargs={'pk': pk})