|
@ -2,23 +2,6 @@ from datetime import datetime, date |
|
|
from random import choice |
|
|
from random import choice |
|
|
from string import ascii_letters, digits |
|
|
from string import ascii_letters, digits |
|
|
|
|
|
|
|
|
from .email_utils import do_envia_email_confirmacao |
|
|
|
|
|
from .forms import (AcessorioEmLoteFilterSet, AcompanhamentoMateriaForm, |
|
|
|
|
|
AdicionarVariasAutoriasFilterSet, DespachoInicialForm, |
|
|
|
|
|
DocumentoAcessorioForm, MateriaAssuntoForm, |
|
|
|
|
|
MateriaLegislativaFilterSet, MateriaSimplificadaForm, |
|
|
|
|
|
PrimeiraTramitacaoEmLoteFilterSet, ReceberProposicaoForm, |
|
|
|
|
|
RelatoriaForm, TramitacaoEmLoteFilterSet, |
|
|
|
|
|
filtra_tramitacao_destino, |
|
|
|
|
|
filtra_tramitacao_destino_and_status, |
|
|
|
|
|
filtra_tramitacao_status) |
|
|
|
|
|
from .models import (AcompanhamentoMateria, Anexada, AssuntoMateria, Autoria, |
|
|
|
|
|
DespachoInicial, DocumentoAcessorio, MateriaAssunto, |
|
|
|
|
|
MateriaLegislativa, Numeracao, Orgao, Origem, Proposicao, |
|
|
|
|
|
RegimeTramitacao, Relatoria, StatusTramitacao, |
|
|
|
|
|
TipoDocumento, TipoFimRelatoria, TipoMateriaLegislativa, |
|
|
|
|
|
TipoProposicao, Tramitacao, UnidadeTramitacao) |
|
|
|
|
|
from .signals import tramitacao_signal |
|
|
|
|
|
from crispy_forms.helper import FormHelper |
|
|
from crispy_forms.helper import FormHelper |
|
|
from crispy_forms.layout import HTML |
|
|
from crispy_forms.layout import HTML |
|
|
from django import forms |
|
|
from django import forms |
|
@ -39,9 +22,8 @@ from django.views.generic import CreateView, ListView, TemplateView, UpdateView |
|
|
from django.views.generic.base import RedirectView |
|
|
from django.views.generic.base import RedirectView |
|
|
from django.views.generic.edit import FormView |
|
|
from django.views.generic.edit import FormView |
|
|
from django_filters.views import FilterView |
|
|
from django_filters.views import FilterView |
|
|
import sapl |
|
|
|
|
|
from sapl.base.models import Autor, CasaLegislativa |
|
|
from sapl.base.models import Autor, CasaLegislativa |
|
|
from sapl.comissoes.models import Comissao |
|
|
|
|
|
from sapl.comissoes.models import Comissao, Participacao |
|
|
from sapl.comissoes.models import Comissao, Participacao |
|
|
from sapl.compilacao.models import (STATUS_TA_IMMUTABLE_RESTRICT, |
|
|
from sapl.compilacao.models import (STATUS_TA_IMMUTABLE_RESTRICT, |
|
|
STATUS_TA_PRIVATE) |
|
|
STATUS_TA_PRIVATE) |
|
@ -54,15 +36,31 @@ from sapl.crud.base import (ACTION_CREATE, ACTION_DELETE, ACTION_DETAIL, |
|
|
from sapl.materia.forms import (AnexadaForm, ConfirmarProposicaoForm, |
|
|
from sapl.materia.forms import (AnexadaForm, ConfirmarProposicaoForm, |
|
|
LegislacaoCitadaForm, AutoriaForm, ProposicaoForm, |
|
|
LegislacaoCitadaForm, AutoriaForm, ProposicaoForm, |
|
|
TipoProposicaoForm, TramitacaoForm, |
|
|
TipoProposicaoForm, TramitacaoForm, |
|
|
TramitacaoUpdateForm) |
|
|
TramitacaoUpdateForm, AutoriaMultiCreateForm) |
|
|
from sapl.materia.models import Autor |
|
|
|
|
|
from sapl.norma.models import LegislacaoCitada |
|
|
from sapl.norma.models import LegislacaoCitada |
|
|
from sapl.parlamentares.models import Parlamentar |
|
|
|
|
|
from sapl.protocoloadm.models import Protocolo |
|
|
from sapl.protocoloadm.models import Protocolo |
|
|
from sapl.utils import (TURNO_TRAMITACAO_CHOICES, YES_NO_CHOICES, autor_label, |
|
|
from sapl.utils import (TURNO_TRAMITACAO_CHOICES, YES_NO_CHOICES, autor_label, |
|
|
autor_modal, gerar_hash_arquivo, get_base_url, |
|
|
autor_modal, gerar_hash_arquivo, get_base_url, |
|
|
montar_row_autor) |
|
|
montar_row_autor) |
|
|
|
|
|
import sapl |
|
|
|
|
|
|
|
|
|
|
|
from .email_utils import do_envia_email_confirmacao |
|
|
|
|
|
from .forms import (AcessorioEmLoteFilterSet, AcompanhamentoMateriaForm, |
|
|
|
|
|
AdicionarVariasAutoriasFilterSet, DespachoInicialForm, |
|
|
|
|
|
DocumentoAcessorioForm, MateriaAssuntoForm, |
|
|
|
|
|
MateriaLegislativaFilterSet, MateriaSimplificadaForm, |
|
|
|
|
|
PrimeiraTramitacaoEmLoteFilterSet, ReceberProposicaoForm, |
|
|
|
|
|
RelatoriaForm, TramitacaoEmLoteFilterSet, |
|
|
|
|
|
filtra_tramitacao_destino, |
|
|
|
|
|
filtra_tramitacao_destino_and_status, |
|
|
|
|
|
filtra_tramitacao_status) |
|
|
|
|
|
from .models import (AcompanhamentoMateria, Anexada, AssuntoMateria, Autoria, |
|
|
|
|
|
DespachoInicial, DocumentoAcessorio, MateriaAssunto, |
|
|
|
|
|
MateriaLegislativa, Numeracao, Orgao, Origem, Proposicao, |
|
|
|
|
|
RegimeTramitacao, Relatoria, StatusTramitacao, |
|
|
|
|
|
TipoDocumento, TipoFimRelatoria, TipoMateriaLegislativa, |
|
|
|
|
|
TipoProposicao, Tramitacao, UnidadeTramitacao) |
|
|
|
|
|
from .signals import tramitacao_signal |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
AssuntoMateriaCrud = Crud.build(AssuntoMateria, 'assunto_materia') |
|
|
AssuntoMateriaCrud = Crud.build(AssuntoMateria, 'assunto_materia') |
|
@ -93,8 +91,8 @@ def proposicao_texto(request, pk): |
|
|
|
|
|
|
|
|
if proposicao.texto_original: |
|
|
if proposicao.texto_original: |
|
|
if (not proposicao.data_recebimento and |
|
|
if (not proposicao.data_recebimento and |
|
|
proposicao.autor.user_id != request.user.id): |
|
|
proposicao.autor.user_id != request.user.id): |
|
|
raise Http404 |
|
|
raise Http404 |
|
|
|
|
|
|
|
|
arquivo = proposicao.texto_original |
|
|
arquivo = proposicao.texto_original |
|
|
|
|
|
|
|
@ -1064,6 +1062,11 @@ class DocumentoAcessorioCrud(MasterDetailCrud): |
|
|
def __init__(self, **kwargs): |
|
|
def __init__(self, **kwargs): |
|
|
super(MasterDetailCrud.CreateView, self).__init__(**kwargs) |
|
|
super(MasterDetailCrud.CreateView, self).__init__(**kwargs) |
|
|
|
|
|
|
|
|
|
|
|
def get_initial(self): |
|
|
|
|
|
self.initial['data'] = datetime.now().date() |
|
|
|
|
|
|
|
|
|
|
|
return self.initial |
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs): |
|
|
def get_context_data(self, **kwargs): |
|
|
context = super( |
|
|
context = super( |
|
|
MasterDetailCrud.CreateView, self).get_context_data(**kwargs) |
|
|
MasterDetailCrud.CreateView, self).get_context_data(**kwargs) |
|
@ -1085,41 +1088,74 @@ class AutoriaCrud(MasterDetailCrud): |
|
|
parent_field = 'materia' |
|
|
parent_field = 'materia' |
|
|
help_path = '' |
|
|
help_path = '' |
|
|
public = [RP_LIST, RP_DETAIL] |
|
|
public = [RP_LIST, RP_DETAIL] |
|
|
|
|
|
list_field_names = ['autor', 'autor__tipo__descricao', 'primeiro_autor'] |
|
|
|
|
|
|
|
|
class CreateView(MasterDetailCrud.CreateView): |
|
|
class LocalBaseMixin(): |
|
|
form_class = AutoriaForm |
|
|
form_class = AutoriaForm |
|
|
|
|
|
|
|
|
@property |
|
|
@property |
|
|
def layout_key(self): |
|
|
def layout_key(self): |
|
|
return 'AutoriaCreate' |
|
|
return None |
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs): |
|
|
class CreateView(LocalBaseMixin, MasterDetailCrud.CreateView): |
|
|
context = super(CreateView, self).get_context_data(**kwargs) |
|
|
|
|
|
autores_ativos = self.autores_ativos() |
|
|
def get_initial(self): |
|
|
|
|
|
initial = super().get_initial() |
|
|
|
|
|
materia = MateriaLegislativa.objects.get(id=self.kwargs['pk']) |
|
|
|
|
|
initial['data_relativa'] = materia.data_apresentacao |
|
|
|
|
|
initial['autor'] = [] |
|
|
|
|
|
return initial |
|
|
|
|
|
|
|
|
autores = [] |
|
|
class UpdateView(LocalBaseMixin, MasterDetailCrud.UpdateView): |
|
|
|
|
|
|
|
|
|
|
|
def get_initial(self): |
|
|
|
|
|
initial = super().get_initial() |
|
|
|
|
|
initial.update({ |
|
|
|
|
|
'data_relativa': self.object.materia.data_apresentacao, |
|
|
|
|
|
'tipo_autor': self.object.autor.tipo.id, |
|
|
|
|
|
}) |
|
|
|
|
|
return initial |
|
|
|
|
|
|
|
|
context['form'].fields['autor'].choices = autores |
|
|
|
|
|
return context |
|
|
|
|
|
|
|
|
|
|
|
def autores_ativos(self): |
|
|
class AutoriaMultiCreateView(PermissionRequiredForAppCrudMixin, FormView): |
|
|
lista_parlamentares = Parlamentar.objects.filter(ativo=True).values_list('id', flat=True) |
|
|
app_label = sapl.materia.apps.AppConfig.label |
|
|
model_parlamentar = ContentType.objects.get_for_model(Parlamentar) |
|
|
form_class = AutoriaMultiCreateForm |
|
|
autor_parlamentar = Autor.objects.filter(content_type=model_parlamentar, object_id__in=lista_parlamentares) |
|
|
template_name = 'materia/autoria_multicreate_form.html' |
|
|
|
|
|
|
|
|
lista_comissoes = Comissao.objects.filter(Q(data_extincao__isnull=True)|Q(data_extincao__gt=date.today())).values_list('id', flat=True) |
|
|
@classmethod |
|
|
model_comissao = ContentType.objects.get_for_model(Comissao) |
|
|
def get_url_regex(cls): |
|
|
autor_comissoes = Autor.objects.filter(content_type=model_comissao, object_id__in=lista_comissoes) |
|
|
return r'^(?P<pk>\d+)/%s/multicreate' % cls.model._meta.model_name |
|
|
autores_outros = Autor.objects.exclude(content_type__in=[model_parlamentar, model_comissao]) |
|
|
|
|
|
q = autor_parlamentar | autor_comissoes | autores_outros |
|
|
|
|
|
return q |
|
|
|
|
|
|
|
|
|
|
|
class ListView(MasterDetailCrud.ListView): |
|
|
@property |
|
|
|
|
|
def layout_key(self): |
|
|
|
|
|
return None |
|
|
|
|
|
|
|
|
def get_queryset(self): |
|
|
def get_initial(self): |
|
|
qs = super().get_queryset() |
|
|
initial = super().get_initial() |
|
|
|
|
|
self.materia = MateriaLegislativa.objects.get(id=self.kwargs['pk']) |
|
|
|
|
|
initial['data_relativa'] = self.materia.data_apresentacao |
|
|
|
|
|
initial['autores'] = self.materia.autores.all() |
|
|
|
|
|
return initial |
|
|
|
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs): |
|
|
|
|
|
context = super().get_context_data(**kwargs) |
|
|
|
|
|
context['title'] = '%s <small>(%s)</small>' % ( |
|
|
|
|
|
_('Adicionar Várias Autorias'), self.materia) |
|
|
|
|
|
return context |
|
|
|
|
|
|
|
|
|
|
|
def get_success_url(self): |
|
|
|
|
|
messages.add_message( |
|
|
|
|
|
self.request, messages.SUCCESS, |
|
|
|
|
|
_('Autorias adicionadas com sucesso.')) |
|
|
|
|
|
return reverse( |
|
|
|
|
|
'sapl.materia:autoria_list', kwargs={'pk': self.materia.pk}) |
|
|
|
|
|
|
|
|
|
|
|
def form_valid(self, form): |
|
|
|
|
|
autores_selecionados = form.cleaned_data['autor'] |
|
|
|
|
|
for autor in autores_selecionados: |
|
|
|
|
|
Autoria.objects.create(materia=self.materia, autor=autor) |
|
|
|
|
|
|
|
|
return qs.order_by('-primeiro_autor', 'autor__nome') |
|
|
return FormView.form_valid(self, form) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DespachoInicialCrud(MasterDetailCrud): |
|
|
class DespachoInicialCrud(MasterDetailCrud): |
|
@ -1516,9 +1552,9 @@ class AcompanhamentoMateriaView(CreateView): |
|
|
base_url = get_base_url(request) |
|
|
base_url = get_base_url(request) |
|
|
|
|
|
|
|
|
destinatario = AcompanhamentoMateria.objects.get( |
|
|
destinatario = AcompanhamentoMateria.objects.get( |
|
|
materia=materia, |
|
|
materia=materia, |
|
|
email=email, |
|
|
email=email, |
|
|
confirmado=False) |
|
|
confirmado=False) |
|
|
casa = CasaLegislativa.objects.first() |
|
|
casa = CasaLegislativa.objects.first() |
|
|
|
|
|
|
|
|
do_envia_email_confirmacao(base_url, |
|
|
do_envia_email_confirmacao(base_url, |
|
@ -1699,10 +1735,10 @@ class TramitacaoEmLoteView(PrimeiraTramitacaoEmLoteView): |
|
|
context['primeira_tramitacao'] = False |
|
|
context['primeira_tramitacao'] = False |
|
|
|
|
|
|
|
|
if ('tramitacao__status' in qr and |
|
|
if ('tramitacao__status' in qr and |
|
|
'tramitacao__unidade_tramitacao_destino' in qr and |
|
|
'tramitacao__unidade_tramitacao_destino' in qr and |
|
|
qr['tramitacao__status'] and |
|
|
qr['tramitacao__status'] and |
|
|
qr['tramitacao__unidade_tramitacao_destino'] |
|
|
qr['tramitacao__unidade_tramitacao_destino'] |
|
|
): |
|
|
): |
|
|
lista = filtra_tramitacao_destino_and_status( |
|
|
lista = filtra_tramitacao_destino_and_status( |
|
|
qr['tramitacao__status'], |
|
|
qr['tramitacao__status'], |
|
|
qr['tramitacao__unidade_tramitacao_destino']) |
|
|
qr['tramitacao__unidade_tramitacao_destino']) |
|
|