Browse Source

Start crud abstraction

pull/6/head
Marcio Mazza 10 years ago
parent
commit
0c71c1d91c
  1. 13
      comissoes/urls.py
  2. 82
      comissoes/views.py
  3. 4
      sapl/urls.py

13
comissoes/urls.py

@ -1,13 +0,0 @@
from django.conf.urls import url
from comissoes.views import (
ComissaoListView, ComissaoDetailView, ComissaoUpdateView)
urlpatterns = [
url(r'^$', ComissaoListView.as_view(), name='comissao_list'),
url(r'^(?P<pk>\d+)$', ComissaoDetailView.as_view(),
name='comissao_detail'),
url(r'^(?P<pk>\d+)/edit$', ComissaoUpdateView.as_view(),
name='comissao_update'),
]

82
comissoes/views.py

@ -1,39 +1,60 @@
from braces.views import FormMessagesMixin from braces.views import FormMessagesMixin
from django.core.urlresolvers import reverse_lazy from django.conf.urls import url
from django.core.urlresolvers import reverse, reverse_lazy
from django.utils.translation import ugettext as _ from django.utils.translation import ugettext as _
from django.views.generic import ( from django.views.generic import (
CreateView, DeleteView, ListView, UpdateView, DetailView) CreateView, DeleteView, ListView, UpdateView, DetailView)
from .forms import ComissaoForm from .forms import ComissaoForm
from .models import Comissao
class Crud(object):
def __init__(self, model_form, create_title):
self.model_form = model_form
self.create_title = create_title
self.model = model_form._meta.model
# urls names
self.namespace = self.model._meta.model_name
list_url_name = 'list'
create_url_name = 'create'
detail_url_name = 'detail'
update_url_name = 'update'
delete_url_name = 'delete'
def with_namespace(url_name):
return '%s:%s' % (self.namespace, url_name)
class BaseMixin(object): class BaseMixin(object):
@property @property
def title(self): def title(self):
return self.get_object() return self.get_object()
help_url = '/comissoes/ajuda' help_url = '/comissoes/ajuda' # FIXME
class CrudListView(BaseMixin, ListView):
model = self.model
title = model._meta.verbose_name_plural
class ComissaoListView(BaseMixin, ListView): class CrudCreateView(BaseMixin, CreateView):
model = Comissao model = self.model
title = Comissao._meta.verbose_name_plural form_class = ComissaoForm
title = self.create_title
class ComissaoDetailView(BaseMixin, DetailView):
model = Comissao
def get_success_url(self):
return reverse(with_namespace(detail_url_name),
args=(self.object.id,))
class ComissaoCreateView(BaseMixin, CreateView): class CrudDetailView(BaseMixin, DetailView):
model = Comissao model = self.model
success_url = reverse_lazy('comissao_list')
title = _('Nova Comissão')
class CrudUpdateView(BaseMixin, FormMessagesMixin, UpdateView):
class ComissaoUpdateView(BaseMixin, FormMessagesMixin, UpdateView): model = self.model
model = Comissao
form_class = ComissaoForm form_class = ComissaoForm
success_url = reverse_lazy('comissao_list') success_url = reverse_lazy('comissao_list')
form_invalid_message = u"Something went wrong, post was not saved" form_invalid_message = u"Something went wrong, post was not saved"
@ -41,7 +62,28 @@ class ComissaoUpdateView(BaseMixin, FormMessagesMixin, UpdateView):
def get_form_valid_message(self): def get_form_valid_message(self):
return u"{0} updated successfully!".format(self.object) return u"{0} updated successfully!".format(self.object)
class CrudDeleteView(BaseMixin, DeleteView):
class ComissaoDeleteView(BaseMixin, DeleteView): model = self.model
model = Comissao
success_url = reverse_lazy('comissao_list') success_url = reverse_lazy('comissao_list')
self.CrudListView = CrudListView
self.CrudCreateView = CrudCreateView
self.CrudDetailView = CrudDetailView
self.CrudUpdateView = CrudUpdateView
self.CrudDeleteView = CrudDeleteView
self.urls = [
url(r'^$',
CrudListView.as_view(), name=list_url_name),
url(r'^create$',
CrudCreateView.as_view(), name=create_url_name),
url(r'^(?P<pk>\d+)$',
CrudDetailView.as_view(), name=detail_url_name),
url(r'^(?P<pk>\d+)/edit$',
CrudUpdateView.as_view(), name=update_url_name),
url(r'^(?P<pk>\d+)/delete$',
CrudDeleteView.as_view(), name=delete_url_name),
], 'comissao', 'comissao'
comissao_crud = Crud(ComissaoForm, _('Nova Comissão'))

4
sapl/urls.py

@ -17,10 +17,12 @@ from django.conf.urls import include, url
from django.contrib import admin from django.contrib import admin
from django.views.generic.base import TemplateView from django.views.generic.base import TemplateView
from comissoes.views import comissao_crud
urlpatterns = [ urlpatterns = [
url(r'^$', TemplateView.as_view(template_name='index.html')), url(r'^$', TemplateView.as_view(template_name='index.html')),
url(r'^admin/', include(admin.site.urls)), url(r'^admin/', include(admin.site.urls)),
url(r'^comissoes/', include('comissoes.urls')), url(r'^comissoes/', include(comissao_crud.urls)),
url(r'^sessao/', include('sessao.urls')), url(r'^sessao/', include('sessao.urls')),
] ]

Loading…
Cancel
Save