Browse Source

Add dynamic fields to form in sessao

pull/6/head
Eduardo Edson Batista Cordeiro Alves 10 years ago
parent
commit
877e0a54e9
  1. 7
      parlamentares/models.py
  2. 2
      sessao/models.py
  3. 21
      sessao/views.py
  4. 11
      templates/sessao/expediente.html

7
parlamentares/models.py

@ -1,8 +1,9 @@
import datetime
from django.db import models
from django.utils.translation import ugettext_lazy as _
from sapl.utils import YES_NO_CHOICES, make_choices
import datetime
class Legislatura(models.Model):
@ -17,8 +18,8 @@ class Legislatura(models.Model):
def __str__(self):
# XXX Usar id mesmo? Ou criar campo para nº legislatura?
current_date = datetime.datetime.now().year
if(self.data_inicio.year <= current_date
and self.data_fim.year >= current_date):
if(self.data_inicio.year <= current_date and
self.data_fim.year >= current_date):
current = ' (%s)' % _('Atual')
else:
current = ''

2
sessao/models.py

@ -4,7 +4,7 @@ from django.utils.translation import ugettext_lazy as _
from materia.models import MateriaLegislativa
from parlamentares.models import (CargoMesa, Legislatura, Parlamentar,
SessaoLegislativa)
from sapl.utils import make_choices, YES_NO_CHOICES
from sapl.utils import YES_NO_CHOICES, make_choices
class TipoSessaoPlenaria(models.Model):

21
sessao/views.py

@ -1,5 +1,4 @@
from django import forms
from django.core.urlresolvers import reverse
from django.utils.translation import ugettext_lazy as _
from django.views.generic.edit import FormMixin
@ -83,8 +82,17 @@ registro_votacao_crud = build_crud(
])
def expediente_form_field(index):
return 'ExpedienteForm_%d' % index
class ExpedienteForm(forms.Form):
teste = forms.CharField(widget=forms.Textarea, max_length=100)
def __init__(self, *args, **kwargs):
super(ExpedienteForm, self).__init__(*args, **kwargs)
for i, values in enumerate(TipoExpediente.objects.all()):
self.fields[expediente_form_field(i)] = forms.CharField(
widget=forms.Textarea, max_length=100, required=False)
class ExpedienteView(FormMixin, sessao_crud.CrudDetailView):
@ -95,10 +103,11 @@ class ExpedienteView(FormMixin, sessao_crud.CrudDetailView):
self.object = self.get_object()
form = self.get_form()
if form.is_valid():
for i, values in enumerate(TipoExpediente.objects.all()):
expediente = ExpedienteSessao()
expediente.sessao_plenaria = self.object
expediente.tipo = TipoExpediente.objects.first()
expediente.conteudo = form.fields['teste']
expediente.tipo = values
expediente.conteudo = form.data[expediente_form_field(i)]
expediente.save()
return self.form_valid(form)
else:
@ -106,3 +115,7 @@ class ExpedienteView(FormMixin, sessao_crud.CrudDetailView):
def get_success_url(self):
return self.detail_url
def get_title_and_fieldnames(self):
for i, tipo in enumerate(TipoExpediente.objects.all()):
yield tipo.nome, expediente_form_field(i)

11
templates/sessao/expediente.html

@ -2,10 +2,15 @@
{% load i18n %}
{% block detail_content %}
<form method="Post" action="">
<form method="Post">
{% csrf_token %}
<textarea name="teste"></textarea>
<input type="submit" name="Salvar" />
{% for title, fieldname in view.get_title_and_fieldnames %}
<h5>{{ title }}:</h5>
<textarea name="{{ fieldname }}"></textarea>
{% endfor %}
<br /><input type="submit" value="Salvar" />
</form>
{% endblock detail_content %}

Loading…
Cancel
Save