|  | @ -2,6 +2,7 @@ from datetime import datetime | 
			
		
	
		
		
			
				
					|  |  | from re import sub |  |  | from re import sub | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | from django import forms |  |  | from django import forms | 
			
		
	
		
		
			
				
					|  |  |  |  |  | from django.core.exceptions import ObjectDoesNotExist | 
			
		
	
		
		
			
				
					|  |  | from django.core.urlresolvers import reverse |  |  | from django.core.urlresolvers import reverse | 
			
		
	
		
		
			
				
					|  |  | from django.utils.html import strip_tags |  |  | from django.utils.html import strip_tags | 
			
		
	
		
		
			
				
					|  |  | from django.utils.translation import ugettext_lazy as _ |  |  | from django.utils.translation import ugettext_lazy as _ | 
			
		
	
	
		
		
			
				
					|  | @ -286,7 +287,7 @@ class MateriaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView): | 
			
		
	
		
		
			
				
					|  |  |         now = datetime.now() |  |  |         now = datetime.now() | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |         tipo_materia = TipoMateriaLegislativa.objects.all() |  |  |         tipo_materia = TipoMateriaLegislativa.objects.all() | 
			
		
	
		
		
			
				
					
					|  |  |         data_sessao = "%s/%s/%s" % (now.day, now.month, now.year) |  |  |         data_sessao = now | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |         tipo_sessao = TipoSessaoPlenaria.objects.all() |  |  |         tipo_sessao = TipoSessaoPlenaria.objects.all() | 
			
		
	
		
		
			
				
					|  |  |         tipo_votacao = ExpedienteMateria.TIPO_VOTACAO_CHOICES |  |  |         tipo_votacao = ExpedienteMateria.TIPO_VOTACAO_CHOICES | 
			
		
	
		
		
			
				
					|  |  |         ano_materia = now.year |  |  |         ano_materia = now.year | 
			
		
	
	
		
		
			
				
					|  | @ -306,29 +307,27 @@ class MateriaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView): | 
			
		
	
		
		
			
				
					|  |  |         form = MateriaOrdemDiaForm(request.POST) |  |  |         form = MateriaOrdemDiaForm(request.POST) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |         if form.is_valid(): |  |  |         if form.is_valid(): | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             try: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 materia = MateriaLegislativa.objects.get( | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     numero=request.POST['numero_materia'], | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     tipo_id=request.POST['tipo_materia'], | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     ano=request.POST['ano_materia']) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             except ObjectDoesNotExist: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 context.update( | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     {'error_message': "Matéria inexistente!"}) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 return self.form_invalid(form) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             # TODO: Pra que tipo_materia e tipo_sessao |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             # se já existem em seus respectivos objetos??? |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             # TODO: barrar matérias não existentes |  |  |             # TODO: barrar matérias não existentes | 
			
		
	
		
		
			
				
					|  |  |             # TODO: barrar criação de ordemdia para materias já incluídas |  |  |             # TODO: barrar criação de ordemdia para materias já incluídas | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             # ordem = OrdemDia.objects.get( |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             #     sessao_plenaria_id=self.object.id) |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             # # Verficar se matéria existe |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             # materia = MateriaLegislativa.objects.get( |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             #     id=ordem.materia_id,  |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             #     tipo=request.POST['tipo_materia']) |  |  |  | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             ordemdia = OrdemDia() |  |  |             ordemdia = OrdemDia() | 
			
		
	
		
		
			
				
					|  |  |             ordemdia.sessao_plenaria_id = self.object.id |  |  |             ordemdia.sessao_plenaria_id = self.object.id | 
			
		
	
		
		
			
				
					
					|  |  |             ordemdia.materia_id = ordem.materia_id |  |  |             ordemdia.materia_id = materia.id | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             ordemdia.numero_ordem = request.POST['numero_ordem'] |  |  |             ordemdia.numero_ordem = request.POST['numero_ordem'] | 
			
		
	
		
		
			
				
					|  |  |             ordemdia.data_ordem = datetime.now() |  |  |             ordemdia.data_ordem = datetime.now() | 
			
		
	
		
		
			
				
					
					|  |  |             ordemdia.observacao = sub( |  |  |             ordemdia.observacao = sub(' ', ' ', | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |                 ' ', ' ', strip_tags(request.POST['observacao'])) |  |  |                                       strip_tags(request.POST['observacao'])) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  |             ordemdia.tipo_votacao = request.POST['tipo_votacao'] |  |  |             ordemdia.tipo_votacao = request.POST['tipo_votacao'] | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             ordemdia.save() |  |  |             ordemdia.save() | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             return self.form_valid(form) |  |  |             return self.form_valid(form) | 
			
		
	
	
		
		
			
				
					|  | @ -346,21 +345,19 @@ class EditMateriaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView): | 
			
		
	
		
		
			
				
					|  |  |         self.object = self.get_object() |  |  |         self.object = self.get_object() | 
			
		
	
		
		
			
				
					|  |  |         context = self.get_context_data(object=self.object) |  |  |         context = self.get_context_data(object=self.object) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |         current_url = request.get_full_path() |  |  |         pk = kwargs['pk'] | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |         words = current_url.split('/') |  |  |         oid = kwargs['oid'] | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  | 
 |  |  |         ordem = OrdemDia.objects.get(sessao_plenaria_id=pk, materia_id=oid) | 
			
				
				
			
		
	
		
		
			
				
					|  |  |         ordem = OrdemDia.objects.get( |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             sessao_plenaria_id=self.object.id, |  |  |  | 
			
		
	
		
		
			
				
					|  |  |             materia_id=words[-1]) |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |         materia = MateriaLegislativa.objects.get( |  |  |         materia = MateriaLegislativa.objects.get( | 
			
		
	
		
		
			
				
					|  |  |             id=ordem.materia_id) |  |  |             id=ordem.materia_id) | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         data_ordem = ordem.data_ordem | 
			
		
	
		
		
			
				
					|  |  |         tipo_votacao = ExpedienteMateria.TIPO_VOTACAO_CHOICES |  |  |         tipo_votacao = ExpedienteMateria.TIPO_VOTACAO_CHOICES | 
			
		
	
		
		
			
				
					|  |  |         tipo_sessao = TipoSessaoPlenaria.objects.all() |  |  |         tipo_sessao = TipoSessaoPlenaria.objects.all() | 
			
		
	
		
		
			
				
					|  |  |         tipo_materia = TipoMateriaLegislativa.objects.all() |  |  |         tipo_materia = TipoMateriaLegislativa.objects.all() | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |         context.update({'data_sessao': self.object.data_fim, |  |  |         context.update({'data_sessao': data_ordem, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                         'tipo_sessao': tipo_sessao, |  |  |                         'tipo_sessao': tipo_sessao, | 
			
		
	
		
		
			
				
					|  |  |                         'tipo_sessao_selected': self.object.tipo, |  |  |                         'tipo_sessao_selected': self.object.tipo, | 
			
		
	
		
		
			
				
					|  |  |                         'tipo_materia': tipo_materia, |  |  |                         'tipo_materia': tipo_materia, | 
			
		
	
	
		
		
			
				
					|  | @ -370,11 +367,50 @@ class EditMateriaOrdemDiaView(FormMixin, sessao_crud.CrudDetailView): | 
			
		
	
		
		
			
				
					|  |  |                         'ano_materia': materia.ano, |  |  |                         'ano_materia': materia.ano, | 
			
		
	
		
		
			
				
					|  |  |                         'numero_ordem': ordem.numero_ordem, |  |  |                         'numero_ordem': ordem.numero_ordem, | 
			
		
	
		
		
			
				
					|  |  |                         'numero_materia': materia.numero, |  |  |                         'numero_materia': materia.numero, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         'ordem_id': oid, | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         'oid': '', | 
			
		
	
		
		
			
				
					|  |  |                         'observacao': sub( |  |  |                         'observacao': sub( | 
			
		
	
		
		
			
				
					|  |  |                             ' ', ' ', strip_tags(ordem.observacao)), |  |  |                             ' ', ' ', strip_tags(ordem.observacao)), | 
			
		
	
		
		
			
				
					|  |  |                         'error_message': '', }) |  |  |                         'error_message': '', }) | 
			
		
	
		
		
			
				
					|  |  |         return self.render_to_response(context) |  |  |         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) | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         pk = kwargs['pk'] | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         oid = kwargs['oid'] | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         ordemdia = OrdemDia.objects.get(sessao_plenaria_id=pk, materia_id=oid) | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         if 'update-ordemdia' in request.POST: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             if form.is_valid(): | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 try: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     materia = MateriaLegislativa.objects.get( | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         numero=request.POST['numero_materia'], | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         tipo_id=request.POST['tipo_materia'], | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         ano=request.POST['ano_materia']) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 except ObjectDoesNotExist: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     context.update( | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                         {'error_message': "Matéria inexistente!"}) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     return self.form_invalid(form) | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 ordemdia.materia_id = materia.id | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 ordemdia.numero_ordem = request.POST['numero_ordem'] | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 ordemdia.tipo_votacao = request.POST['tipo_votacao'] | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 obs = strip_tags(request.POST['observacao']) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 ordemdia.observacao = sub(' ', '  ', obs) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 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) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         elif 'delete-ordemdia' in request.POST: | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             ordemdia.delete() | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             return self.form_valid(form) | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     def get_success_url(self): |  |  |     def get_success_url(self): | 
			
		
	
		
		
			
				
					|  |  |         pk = self.kwargs['pk'] |  |  |         pk = self.kwargs['pk'] | 
			
		
	
		
		
			
				
					|  |  |         return reverse('sessaoplenaria:materiaordemdia_list', |  |  |         return reverse('sessaoplenaria:materiaordemdia_list', | 
			
		
	
	
		
		
			
				
					|  | 
 |