# -*- coding: utf-8 -*- from django.db import models from django.utils.translation import ugettext as _ from materia.models import MateriaLegislativa from parlamentares.models import CargoMesa, Parlamentar, SessaoLegislativa, Legislatura from sapl.utils import make_choices class TipoSessaoPlenaria(models.Model): nome = models.CharField(max_length=30, verbose_name=_(u'Tipo')) quorum_minimo = models.IntegerField(verbose_name=_(u'Quórum mínimo')) class Meta: verbose_name = _(u'Tipo de Sessão Plenária') verbose_name_plural = _(u'Tipos de Sessão Plenária') def __unicode__(self): return self.nome class SessaoPlenaria(models.Model): # TODO trash??? Seems to have been a FK in the past. Would be: # andamento_sessao = models.ForeignKey(AndamentoSessao, blank=True, null=True) # TODO analyze querying all hosted databases ! cod_andamento_sessao = models.IntegerField(blank=True, null=True) tipo = models.ForeignKey(TipoSessaoPlenaria, verbose_name=_(u'Tipo')) sessao_legislativa = models.ForeignKey(SessaoLegislativa, verbose_name=_(u'Sessão Legislativa')) legislatura = models.ForeignKey(Legislatura, verbose_name=_(u'Legislatura')) # XXX seems to be empty tipo_expediente = models.CharField(max_length=10) data_inicio = models.DateField(verbose_name=_(u'Abertura')) dia = models.CharField(max_length=15) hora_inicio = models.CharField(max_length=5, verbose_name=_(u'Horário')) hora_fim = models.CharField(max_length=5, blank=True, null=True, verbose_name=_(u'Horário')) numero = models.IntegerField(verbose_name=_(u'Número')) data_fim = models.DateField(blank=True, null=True, verbose_name=_(u'Encerramento')) url_audio = models.CharField(max_length=150, blank=True, null=True, verbose_name=_(u'URL Arquivo Áudio (Formatos MP3 / AAC)')) url_video = models.CharField(max_length=150, blank=True, null=True, verbose_name=_(u'URL Arquivo Vídeo (Formatos MP4 / FLV / WebM)')) class Meta: verbose_name = _(u'Sessão Plenária') verbose_name_plural = _(u'Sessões Plenárias') def __unicode__(self): return _(u'%sª Sessão %s da %sª Sessão Legislativa da %sª Legislatura') % ( self.numero, self.tipo.nome, self.sessao_legislativa.numero, self.legislatura.id) # XXX check if it shouldn't be legislatura.numero class AbstractOrdemDia(models.Model): TIPO_VOTACAO_CHOICES, SIMBOLICA, NOMINAL, SECRETA = make_choices( 1, _(u'Simbólica'), 2, _(u'Nominal'), 3, _(u'Secreta'), ) sessao_plenaria = models.ForeignKey(SessaoPlenaria) materia = models.ForeignKey(MateriaLegislativa) data_ordem = models.DateField(verbose_name=_(u'Data da Sessão')) observacao = models.TextField(blank=True, null=True, verbose_name=_(u'Ementa')) numero_ordem = models.IntegerField(verbose_name=_(u'Nº Ordem')) resultado = models.TextField(blank=True, null=True) tipo_votacao = models.IntegerField(verbose_name=_(u'Tipo de votação'), choices=TIPO_VOTACAO_CHOICES) class Meta: abstract = True def __unicode__(self): return u'%s - %s' % (self.numero_ordem, self.sessao_plenaria) class ExpedienteMateria(AbstractOrdemDia): class Meta: verbose_name = _(u'Matéria do Expediente') verbose_name_plural = _(u'Matérias do Expediente') class TipoExpediente(models.Model): nome = models.CharField(max_length=100, verbose_name=_(u'Tipo')) class Meta: verbose_name = _(u'Tipo de Expediente') verbose_name_plural = _(u'Tipos de Expediente') def __unicode__(self): return self.nome class ExpedienteSessao(models.Model): # ExpedienteSessaoPlenaria sessao_plenaria = models.ForeignKey(SessaoPlenaria) tipo = models.ForeignKey(TipoExpediente) conteudo = models.TextField(blank=True, null=True, verbose_name=_(u'Conteúdo do expediente')) class Meta: verbose_name = _(u'Expediente de Sessão Plenaria') verbose_name_plural = _(u'Expedientes de Sessão Plenaria') def __unicode__(self): return u'%s - %s' % (self.tipo, self.sessao_plenaria) class IntegranteMesa(models.Model): # MesaSessaoPlenaria sessao_plenaria = models.ForeignKey(SessaoPlenaria) cargo = models.ForeignKey(CargoMesa) parlamentar = models.ForeignKey(Parlamentar) class Meta: verbose_name = _(u'Participação em Mesa de Sessão Plenaria') verbose_name_plural = _(u'Participações em Mesas de Sessão Plenaria') def __unicode__(self): return u'%s - %s' % (self.cargo, self.parlamentar) class AbstractOrador(models.Model): # Oradores sessao_plenaria = models.ForeignKey(SessaoPlenaria) parlamentar = models.ForeignKey(Parlamentar, verbose_name=_(u'Parlamentar')) numero_ordem = models.IntegerField(verbose_name=_(u'Ordem de pronunciamento')) url_discurso = models.CharField(max_length=150, blank=True, null=True, verbose_name=_(u'URL Vídeo')) class Meta: abstract = True def __unicode__(self): return _(u'%(nome)s (%(numero)sº orador)') % { 'nome': self.parlamentar, 'numero': self.numero_ordem} class Orador(AbstractOrador): # Oradores class Meta: verbose_name = _(u'Orador das Explicações Pessoais') verbose_name_plural = _(u'Oradores das Explicações Pessoais') class OradorExpediente(AbstractOrador): # OradoresExpediente class Meta: verbose_name = _(u'Orador do Expediente') verbose_name_plural = _(u'Oradores do Expediente') class OrdemDia(AbstractOrdemDia): class Meta: verbose_name = _(u'Matéria da Ordem do Dia') verbose_name_plural = _(u'Matérias da Ordem do Dia') class PresencaOrdemDia(models.Model): # OrdemDiaPresenca sessao_plenaria = models.ForeignKey(SessaoPlenaria) parlamentar = models.ForeignKey(Parlamentar) data_ordem = models.DateField() class Meta: verbose_name = _(u'Presença da Ordem do Dia') verbose_name_plural = _(u'Presenças da Ordem do Dia') def __unicode__(self): return self.parlamentar class TipoResultadoVotacao(models.Model): nome = models.CharField(max_length=100, verbose_name=_(u'Tipo')) class Meta: verbose_name = _(u'Tipo de Resultado de Votação') verbose_name_plural = _(u'Tipos de Resultado de Votação') def __unicode__(self): return self.nome class RegistroVotacao(models.Model): tipo_resultado_votacao = models.ForeignKey(TipoResultadoVotacao, verbose_name=_(u'Resultado da Votação')) materia = models.ForeignKey(MateriaLegislativa) ordem = models.ForeignKey(OrdemDia) numero_votos_sim = models.IntegerField(verbose_name=_(u'Sim')) numero_votos_nao = models.IntegerField(verbose_name=_(u'Não')) numero_abstencoes = models.IntegerField(verbose_name=_(u'Abstenções')) observacao = models.TextField(blank=True, null=True, verbose_name=_(u'Observações')) class Meta: verbose_name = _(u'Votação') verbose_name_plural = _(u'Votações') def __unicode__(self): return self.materia # XXX ? class VotoParlamentar(models.Model): # RegistroVotacaoParlamentar votacao = models.ForeignKey(RegistroVotacao) parlamentar = models.ForeignKey(Parlamentar) # XXX change to restricted choices voto = models.CharField(max_length=10) class Meta: verbose_name = _(u'Registro de Votação de Parlamentar') verbose_name_plural = _(u'Registros de Votações de Parlamentares') def __unicode__(self): return self.parlamentar # XXX ? class SessaoPlenariaPresenca(models.Model): sessao_plen = models.ForeignKey(SessaoPlenaria) parlamentar = models.ForeignKey(Parlamentar) data_sessao = models.DateField(blank=True, null=True) class Meta: verbose_name = _(u'Presença em Sessão Plenária') verbose_name_plural = _(u'Presenças em Sessões Plenárias') def __unicode__(self): return self.parlamentar # XXX ?