# -*- coding: utf-8 -*- from django.db import models from django.utils.translation import ugettext as _ from materia.models import Autor, TipoMateriaLegislativa class TipoDocumentoAdministrativo(models.Model): sigla_tipo_documento = models.CharField(max_length=5, verbose_name=_(u'Sigla')) # sgl_tipo_documento descricao_tipo_documento = models.CharField(max_length=50, verbose_name=_(u'Descrição')) # des_tipo_documento class Meta: verbose_name = _(u'Tipo de Documento Administrativo') verbose_name_plural = _(u'Tipos de Documento Administrativo') class DocumentoAdministrativo(models.Model): tipo = models.ForeignKey(TipoDocumentoAdministrativo, verbose_name=_(u'Tipo Documento')) # tip_documento numero_documento = models.IntegerField(verbose_name=_(u'Número')) # num_documento ano_documento = models.SmallIntegerField(verbose_name=_(u'Ano')) # ano_documento data_documento = models.DateField(verbose_name=_(u'Data')) # dat_documento numero_protocolo = models.IntegerField(blank=True, null=True, verbose_name=_(u'Núm. Protocolo')) # num_protocolo interessado = models.CharField(max_length=50, blank=True, null=True, verbose_name=_(u'Interessado')) # txt_interessado autor = models.ForeignKey(Autor, blank=True, null=True) # cod_autor numero_dias_prazo = models.IntegerField(blank=True, null=True, verbose_name=_(u'Dias Prazo')) # num_dias_prazo data_fim_prazo = models.DateField(blank=True, null=True, verbose_name=_(u'Data Fim Prazo')) # dat_fim_prazo tramitacao = models.BooleanField(verbose_name=_(u'Em Tramitação?')) # ind_tramitacao assunto = models.TextField(verbose_name=_(u'Assunto')) # txt_assunto observacao = models.TextField(blank=True, null=True, verbose_name=_(u'Observação')) # txt_observacao class Meta: verbose_name = _(u'Documento Administrativo') verbose_name_plural = _(u'Documentos Administrativos') class DocumentoAcessorioAdministrativo(models.Model): documento = models.ForeignKey(DocumentoAdministrativo) # cod_documento tipo = models.ForeignKey(TipoDocumentoAdministrativo, verbose_name=_(u'Tipo')) # tip_documento nome_documento = models.CharField(max_length=30, verbose_name=_(u'Nome')) # nom_documento nome_arquivo = models.CharField(max_length=100, verbose_name=_(u'Arquivo')) # nom_arquivo data_documento = models.DateField(blank=True, null=True, verbose_name=_(u'Data')) # dat_documento nome_autor_documento = models.CharField(max_length=50, blank=True, null=True, verbose_name=_(u'Autor')) # nom_autor_documento assunto = models.TextField(blank=True, null=True, verbose_name=_(u'Assunto')) # txt_assunto indexacao = models.TextField(blank=True, null=True) # txt_indexacao class Meta: verbose_name = _(u'Documento Acessório') verbose_name_plural = _(u'Documentos Acessórios') class Protocolo(models.Model): numero_protocolo = models.IntegerField(blank=True, null=True, verbose_name=_(u'Núm. Protocolo')) # num_protocolo ano_protocolo = models.SmallIntegerField() # ano_protocolo data_protocolo = models.DateField() # dat_protocolo hora_protocolo = models.TimeField() # hor_protocolo data_timestamp = models.DateTimeField() # dat_timestamp tipo_protocolo = models.IntegerField(verbose_name=_(u'Tipo de Protocolo')) # tip_protocolo tipo_processo = models.IntegerField() # tip_processo interessado = models.CharField(max_length=60, blank=True, null=True, verbose_name=_(u'Interessado')) # txt_interessado autor = models.ForeignKey(Autor, blank=True, null=True) # cod_autor assunto_ementa = models.TextField(blank=True, null=True) # txt_assunto_ementa tipo_documento = models.ForeignKey(TipoDocumentoAdministrativo, blank=True, null=True, verbose_name=_(u'Tipo de documento')) # tip_documento tipo_materia = models.ForeignKey(TipoMateriaLegislativa, blank=True, null=True, verbose_name=_(u'Tipo Matéria')) # tip_materia numero_paginas = models.IntegerField(blank=True, null=True, verbose_name=_(u'Núm. Páginas')) # num_paginas observacao = models.TextField(blank=True, null=True, verbose_name=_(u'Observação')) # txt_observacao anulado = models.BooleanField() # ind_anulado user_anulacao = models.CharField(max_length=20, blank=True, null=True) # txt_user_anulacao ip_anulacao = models.CharField(max_length=15, blank=True, null=True) # txt_ip_anulacao just_anulacao = models.CharField(max_length=60, blank=True, null=True) # txt_just_anulacao timestamp_anulacao = models.DateTimeField(blank=True, null=True) # timestamp_anulacao class Meta: verbose_name = _(u'Protocolo') verbose_name_plural = _(u'Protocolos') class StatusTramitacaoAdministrativo(models.Model): sigla_status = models.CharField(max_length=10, verbose_name=_(u'Sigla')) # sgl_status descricao_status = models.CharField(max_length=60, verbose_name=_(u'Descrição')) # des_status fim_tramitacao = models.BooleanField() # ind_fim_tramitacao retorno_tramitacao = models.BooleanField() # ind_retorno_tramitacao class Meta: verbose_name = _(u'Status de Tramitação') verbose_name_plural = _(u'Status de Tramitação') class TramitacaoAdministrativo(models.Model): documento = models.ForeignKey(DocumentoAdministrativo) # cod_documento data_tramitacao = models.DateField(blank=True, null=True, verbose_name=_(u'Data Tramitação')) # dat_tramitacao cod_unid_tram_local = models.IntegerField(blank=True, null=True, verbose_name=_(u'Unidade Local')) # cod_unid_tram_local data_encaminha = models.DateField(blank=True, null=True, verbose_name=_(u'Data Encaminhamento')) # dat_encaminha cod_unid_tram_dest = models.IntegerField(blank=True, null=True, verbose_name=_(u'Unidade Destino')) # cod_unid_tram_dest status = models.ForeignKey(StatusTramitacaoAdministrativo, blank=True, null=True, verbose_name=_(u'Status')) # cod_status ult_tramitacao = models.BooleanField() # ind_ult_tramitacao tramitacao = models.TextField(blank=True, null=True, verbose_name=_(u'Texto da Ação')) # txt_tramitacao data_fim_prazo = models.DateField(blank=True, null=True, verbose_name=_(u'Data Fim do Prazo')) # dat_fim_prazo class Meta: verbose_name = _(u'Tramitação de Documento Administrativo') verbose_name_plural = _(u'Tramitações de Documento Administrativo')