Browse Source

add edit/delete view to dependentes in parlamentar

pull/98/head
Eduardo Edson Batista Cordeiro Alves 9 years ago
parent
commit
1a240a7a8d
  1. 7
      parlamentares/urls.py
  2. 75
      parlamentares/views.py
  3. 2
      templates/parlamentares/parlamentares_cadastro.html
  4. 29
      templates/parlamentares/parlamentares_dependentes.html
  5. 9
      templates/parlamentares/parlamentares_dependentes_edit.html

7
parlamentares/urls.py

@ -1,8 +1,8 @@
from django.conf.urls import include, url from django.conf.urls import include, url
from parlamentares.views import (MesaDiretoraView, ParlamentaresCadastroView, from parlamentares.views import (MesaDiretoraView, ParlamentaresCadastroView,
ParlamentaresEditarView, ParlamentaresView, ParlamentaresDependentesEditView,
ParlamentaresDependentesView, ParlamentaresDependentesView,
ParlamentaresEditarView, ParlamentaresView,
cargo_mesa_crud, coligacao_crud, cargo_mesa_crud, coligacao_crud,
legislatura_crud, nivel_instrucao_crud, legislatura_crud, nivel_instrucao_crud,
partido_crud, sessao_legislativa_crud, partido_crud, sessao_legislativa_crud,
@ -34,6 +34,9 @@ urlpatterns = [
ParlamentaresCadastroView.as_view(), name='parlamentares_cadastro'), ParlamentaresCadastroView.as_view(), name='parlamentares_cadastro'),
url(r'^parlamentares/(?P<pk>\d+)/dependentes$', url(r'^parlamentares/(?P<pk>\d+)/dependentes$',
ParlamentaresDependentesView.as_view(), name='parlamentares_dependentes'), ParlamentaresDependentesView.as_view(), name='parlamentares_dependentes'),
url(r'^parlamentares/(?P<pk>\d+)/dependentes/(?P<dk>\d+)$',
ParlamentaresDependentesEditView.as_view(), name='parlamentares_dependentes_edit'),
url(r'^parlamentares/(?P<pk>\d+)/(?P<pid>\d+)/editar$', url(r'^parlamentares/(?P<pk>\d+)/(?P<pid>\d+)/editar$',
ParlamentaresEditarView.as_view(), name='parlamentares_editar'), ParlamentaresEditarView.as_view(), name='parlamentares_editar'),

75
parlamentares/views.py

@ -348,9 +348,9 @@ class ParlamentaresEditarView(FormMixin, GenericView):
pk = kwargs['pk'] pk = kwargs['pk']
pid = kwargs['pid'] pid = kwargs['pid']
parlamentar = Parlamentar.objects.get(id=pid) parlamentar = Parlamentar.objects.get(id=pid)
form = ParlamentaresEditForm(instance=parlamentar) form = ParlamentaresEditForm(instance=parlamentar)
return self.render_to_response({'form': form, 'legislatura_id': pk}) return self.render_to_response(
{'form': form, 'legislatura_id': pk, 'parlamentar': parlamentar})
def post(self, request, *args, **kwargs): def post(self, request, *args, **kwargs):
pk = kwargs['pk'] pk = kwargs['pk']
@ -409,7 +409,7 @@ class DependenteForm(ModelForm):
Fieldset('Cadastro de Dependentes', Fieldset('Cadastro de Dependentes',
row1, row2, row3, row1, row2, row3,
ButtonHolder( ButtonHolder(
Submit('submit', 'Salvar', Submit('Salvar', 'Salvar',
css_class='button primary'), css_class='button primary'),
)) ))
@ -417,18 +417,35 @@ class DependenteForm(ModelForm):
super(DependenteForm, self).__init__( super(DependenteForm, self).__init__(
*args, **kwargs) *args, **kwargs)
class DependenteEditForm(DependenteForm):
def __init__(self, *args, **kwargs):
super(DependenteEditForm, self).__init__(
*args, **kwargs)
self.helper.layout[0][-1:] = ButtonHolder(
Submit('Salvar', 'Salvar',
css_class='button primary'),
HTML('&nbsp;'),
Submit('Excluir', 'Excluir',
css_class='button primary'),)
class ParlamentaresDependentesView(FormMixin, GenericView): class ParlamentaresDependentesView(FormMixin, GenericView):
template_name = "parlamentares/parlamentares_dependentes.html" template_name = "parlamentares/parlamentares_dependentes.html"
def get_success_url(self): def get_success_url(self):
return reverse('parlamentares_dependentes') pk = self.kwargs['pk']
return reverse('parlamentares_dependentes', kwargs={'pk': pk})
def get(self, request, *args, **kwargs): def get(self, request, *args, **kwargs):
pid = kwargs['pk'] pid = kwargs['pk']
parlamentar = Parlamentar.objects.get(id=pid) parlamentar = Parlamentar.objects.get(id=pid)
dependentes = Dependente.objects.filter(parlamentar = parlamentar).order_by('nome', 'tipo') dependentes = Dependente.objects.filter(
parlamentar=parlamentar).order_by('nome', 'tipo')
form = DependenteForm() form = DependenteForm()
@ -436,6 +453,54 @@ class ParlamentaresDependentesView(FormMixin, GenericView):
'dependentes': dependentes, 'dependentes': dependentes,
'form': form}) 'form': form})
def post(self, request, *args, **kwargs):
form = DependenteForm(request.POST)
if form.is_valid():
dependente = form.save(commit=False)
pid = kwargs['pk']
parlamentar = Parlamentar.objects.get(id=pid)
dependente.parlamentar = parlamentar
dependente.save()
return self.form_valid(form)
else:
pid = kwargs['pk']
parlamentar = Parlamentar.objects.get(id=pid)
dependentes = Dependente.objects.filter(
parlamentar=parlamentar).order_by('nome', 'tipo')
return self.render_to_response({'parlamentar': parlamentar,
'dependentes': dependentes,
'form': form})
class ParlamentaresDependentesEditView(FormMixin, GenericView):
template_name = "parlamentares/parlamentares_dependentes_edit.html"
def get_success_url(self):
pk = self.kwargs['pk']
return reverse('parlamentares_dependentes', kwargs={'pk': pk})
def get(self, request, *args, **kwargs):
dependente = Dependente.objects.get(id=kwargs['dk'])
form = DependenteEditForm(instance=dependente)
return self.render_to_response({'form': form})
def post(self, request, *args, **kwargs):
dependente = Dependente.objects.get(id=kwargs['dk'])
form = DependenteEditForm(request.POST, instance=dependente)
if form.is_valid():
if 'Salvar' in request.POST:
dependente.save()
elif 'Excluir' in request.POST:
dependente.delete()
return self.form_valid(form)
else:
return self.render_to_response(
{'form': form})
class MesaDiretoraForm(forms.Form): class MesaDiretoraForm(forms.Form):

2
templates/parlamentares/parlamentares_cadastro.html

@ -5,7 +5,7 @@
<dl class="sub-nav left"> <dl class="sub-nav left">
<dd><a href="" id="incluir-parlamentar" class="button secondary">{% trans 'Mandatos' %}</a></dd> <dd><a href="" id="incluir-parlamentar" class="button secondary">{% trans 'Mandatos' %}</a></dd>
<dd><a href="" id="incluir-parlamentar" class="button secondary">{% trans 'Filiações Partidárias' %}</a></dd> <dd><a href="" id="incluir-parlamentar" class="button secondary">{% trans 'Filiações Partidárias' %}</a></dd>
<dd><a href="" id="incluir-parlamentar" class="button secondary">{% trans 'Dependentes' %}</a></dd> <dd><a href="{% url 'parlamentares_dependentes' parlamentar.id %}" id="incluir-parlamentar" class="button secondary">{% trans 'Dependentes' %}</a></dd>
</dl> </dl>
{% endblock sections_nav %} {% endblock sections_nav %}
{% block detail_content %} {% block detail_content %}

29
templates/parlamentares/parlamentares_dependentes.html

@ -1,31 +1,30 @@
{% extends "crud/detail.html" %} {% extends "crud/detail.html" %}
{% load i18n %} {% load i18n %}
{% load crispy_forms_tags %} {% load crispy_forms_tags %}
{% block actions %}{% endblock %}
{% block detail_content %} {% block detail_content %}
<strong>Parlamentar: </strong>{{ parlamentar.nome_parlamentar }}
<strong>{{ parlamentar.nome_parlamentar }}</strong>
<fieldset> <fieldset>
<legend>Dependentes</legend> <legend>Dependentes</legend>
<ul class="small-block-grid-4 medium-block-grid-4 large-block-grid-4"> <table>
<li><strong>Nome Dependente</strong></li> <tr>
<li><strong>Tipo</strong></li> <th><strong>Nome Dependente</strong></th>
<li><strong>Data de Nascimento</strong></li> <th><strong>Tipo</strong></th>
</ul> <th><strong>Data de Nascimento</strong></th>
</tr>
{% for d in dependentes %} {% for d in dependentes %}
<ul class="small-block-grid-4 medium-block-grid-4 large-block-grid-4"> <tr>
<li>{{d.nome}}</li> <td><a href="{% url 'parlamentares_dependentes_edit' parlamentar.id d.id %}">{{d.nome}}</a></td>
<li>{{d.tipo }}</li> <td>{{d.tipo }}</td>
<li>{{d.data_nascimento}}</li> <td>{{d.data_nascimento}}</td>
<li><a href="#">Editar</a> <a href="#">Excluir</a></li> </tr>
</ul>
{% endfor %} {% endfor %}
</table>
</fieldset> </fieldset>
{% crispy form %} {% crispy form %}
{% endblock detail_content %} {% endblock detail_content %}

9
templates/parlamentares/parlamentares_dependentes_edit.html

@ -0,0 +1,9 @@
{% extends "crud/detail.html" %}
{% load i18n %}
{% load crispy_forms_tags %}
{% block actions %}{% endblock %}
{% block detail_content %}
{% crispy form %}
{% endblock detail_content %}
Loading…
Cancel
Save