From fa4a13668b3796185fcd6a3b3da6c2d28818a550 Mon Sep 17 00:00:00 2001 From: Roberto Rosario Date: Thu, 17 Nov 2011 23:21:56 -0400 Subject: [PATCH] Added views to create, list and delete document groups via the project setup --- apps/grouping/__init__.py | 29 ++++++- apps/grouping/forms.py | 7 ++ apps/grouping/static/images/icons/package.png | Bin 0 -> 972 bytes .../static/images/icons/package_delete.png | Bin 0 -> 1538 bytes apps/grouping/urls.py | 4 + apps/grouping/views.py | 76 +++++++++++++++++- 6 files changed, 111 insertions(+), 5 deletions(-) create mode 100644 apps/grouping/static/images/icons/package.png create mode 100644 apps/grouping/static/images/icons/package_delete.png diff --git a/apps/grouping/__init__.py b/apps/grouping/__init__.py index b939fc5fa6..4bfe65aea0 100644 --- a/apps/grouping/__init__.py +++ b/apps/grouping/__init__.py @@ -1,11 +1,34 @@ from django.utils.translation import ugettext_lazy as _ from navigation.api import register_links - +from permissions.api import register_permission, set_namespace_title +from project_setup.api import register_setup from documents.literals import PERMISSION_DOCUMENT_VIEW from documents.models import Document -document_group_link = {'text': _(u'group actions'), 'view': 'document_group_view', 'famfam': 'page_go', 'permissions': [PERMISSION_DOCUMENT_VIEW]} -groups_for_document = {'text': _(u'groups'), 'view': 'groups_for_document', 'args': 'object.pk', 'famfam': 'page_go', 'permissions': [PERMISSION_DOCUMENT_VIEW]} +from grouping.models import DocumentGroup + + +PERMISSION_DOCUMENT_GROUP_VIEW = {'namespace': 'grouping', 'name': 'group_view', 'label': _(u'View existing document groups')} +PERMISSION_DOCUMENT_GROUP_CREATE = {'namespace': 'grouping', 'name': 'group_create', 'label': _(u'Create new document groups')} +PERMISSION_DOCUMENT_GROUP_DELETE = {'namespace': 'grouping', 'name': 'group_delete', 'label': _(u'Delete document groups')} + +set_namespace_title('grouping', _(u'Grouping')) +register_permission(PERMISSION_DOCUMENT_GROUP_VIEW) +register_permission(PERMISSION_DOCUMENT_GROUP_CREATE) +register_permission(PERMISSION_DOCUMENT_GROUP_DELETE) + +document_group_link = {'text': _(u'group actions'), 'view': 'document_group_view', 'famfam': 'package_go', 'permissions': [PERMISSION_DOCUMENT_VIEW]} +groups_for_document = {'text': _(u'groups'), 'view': 'groups_for_document', 'args': 'object.pk', 'famfam': 'package_go', 'permissions': [PERMISSION_DOCUMENT_VIEW]} + +document_groups_setup = {'text': _(u'document groups'), 'view': 'document_group_list', 'icon': 'package.png', 'permissions': [PERMISSION_DOCUMENT_GROUP_VIEW]} +document_group_list = {'text': _(u'document groups'), 'view': 'document_group_list', 'famfam': 'package', 'permissions': [PERMISSION_DOCUMENT_GROUP_VIEW]} +document_group_create = {'text': _(u'create new'), 'view': 'document_group_create', 'famfam': 'package_add', 'permissions': [PERMISSION_DOCUMENT_GROUP_CREATE]} +document_group_delete = {'text': _(u'delete'), 'view': 'document_group_delete', 'args': 'object.pk', 'famfam': 'package_delete', 'permissions': [PERMISSION_DOCUMENT_GROUP_DELETE]} register_links(Document, [groups_for_document], menu_name='form_header') + +register_links(DocumentGroup, [document_group_delete]) +register_links(['document_group_list', 'document_group_create', 'document_group_delete'], [document_group_list, document_group_create], menu_name='sidebar') + +register_setup(document_groups_setup) diff --git a/apps/grouping/forms.py b/apps/grouping/forms.py index 389987ab7a..3c5d65792b 100644 --- a/apps/grouping/forms.py +++ b/apps/grouping/forms.py @@ -8,6 +8,13 @@ from django.conf import settings from tags.widgets import get_tags_inline_widget +from grouping.models import DocumentGroup + + +class DocumentGroupForm(forms.ModelForm): + class Meta: + model = DocumentGroup + class DocumentGroupImageWidget(forms.widgets.Widget): def render(self, name, value, attrs=None): diff --git a/apps/grouping/static/images/icons/package.png b/apps/grouping/static/images/icons/package.png new file mode 100644 index 0000000000000000000000000000000000000000..448681eaf5aaf6361059da71e97f791a878a6591 GIT binary patch literal 972 zcmV;-12g=IP)AR(c6?{HTP#idWZ@v2OqcDHd4BW0&pR{AIOo{TOTji@I{@q_ecJT+k;jJ0M!+0S z$1WW8TgynS{s(hM8fleZD?(9pi;AQs+F%ytDiN$OMU7dc!qXzw^2GnZc$>W%tdWgZxuUa5ji}@2S)pzI-W=d1~+nboo!EVuhX*ba#i5Ookvzn{?$}qyfAN)^`yfpI*n{mDwf; z)+~O=I(Xp$Y9DS23()LU6xYhgWeX^*SSXds2!{OVhz5~JgyAkBGVF^5Eagm?YbE&o z2Ex01h{nPQgba#;EiItzzlyi_&Jo0$280V>%#06O{gGag=}^e>4h9kz(O#nBN`8*z1@e%@%xy)GmL>zCmjMn ze|=|Yp~`&m#Z(TlWE9cP2$H>Vgd%N@^&9Pncr`hZHOJC5MZK-%SCN{}AeYV~OBxB% zuq&nKN3Xm*MR5ittr{N~xkix^CC2J{9Hv`#f4N#a8DFBq3)N;e3HIh|XAspRd@)CgQQp;VhwML(9LeVMzit&pr z;-3g;O>ndt8;+X-R-x5Rtw+F10LGJGer9c=^^%j6DQmY9- z6oeu?AWSIFC>{dP_(F?s^Z-zVN-5wTACj1GAvQ!nY#>yeQ~+WRXWjxZF0~lj2%y)Nms*F1?%Q|?Bjl-llIH=rCDX3B ug{N^|KM|SR{aQc^e%z_F|){C0W0IIcuSr5G452^j4}O5RUoSf1wOdgME{D_05Es$S&?sidA05Es%4&+-_ZvqRRp&$vg zseo{_fIFi(_&gT)=UXR%U{Z0A#zT=j8fe_>Hq#shP!y>CmoaeuFajTSP6NTFDc{wW zU%YWA)PZklR04NDcPZh}?!jOhBO~KP9tBpLNn4c57U`dW1q+<;`yE=SNN+i09E4f| zYk3FPe*7GPt(OfTm{IxCeCylaLHYYDP64uBL^fSOG%}9yWFEO(0d|KK^W1j$d`?sj zkmmN#IL4wGWYRfUt!6lDEpU6BusO`+1({}*AS~H|tB2ks5LYHZQ~;Q}_XP57AD&0- z>?XwHc|^nG$YhGNfd%s$-SBv7V6$5^tI7gH3>YhWh)Xt;MXT zzTN`Yy2H4Hd-=eyu<^1|V&K{?nJnc^=46PeMM z6;kMuj-?R19Y%CCh6w5Kkq)_-`)TFYORtijVY7&G`;!|#CQp%Nw7RTMMMhUL(_B?P zjl`b@pvlkhh=x<8$TIXC-`UP}a{v}qmLWC0i15+XfM}VFj5^!dhBlP*@VS?WN>&J>1K@My3(X30x}5dhQ-y{sO9X1PT`-@!hl2So(7 zZ$s%u57I{tpcD?4m3aNAf9833wts>v`}g6-{v!~4q7i^9XDI}nfa1dgU>vW2~IIMb%r?ODe#`v6t8`fj+k7IX*fQTVd2-GT?Bo06{O9*$2 zV$qs;$X)0Iqok%53ioUnm?%OX=!2_mC9V&ZCIM(2j9MTT^BP`V{Iy(0gc5Jv1aT2{ zr!U`kO=81xu-iAGO*R0KWH76vI{xbb1hPy`j1h;d4_?CO#K$Ib4F{k`Q}XZKCr++X zs;oL%`Lzke9S$H4v9=DWH(sEGQ^K?g#^*|sHb;ra4S689_Os4+>F$}Dn5wv>qiu`7 zjA!xzkBc_9SoKcm9?6P#R&+Wd@dT13xeFRKwX}pGl2G+2P`hluj>W%jzGFY+^LezB zr0}9M-2oJ_vfKX+hH)+w-^&{ke&`jwJ<5=zXCT?GL@K(*Q`=HZrxrCfG-x0=FBr9S z{4R3W(>vbWcK&q@{qfYP9le9!(AqI^7K$u4KshlI?OIh=)0|7jAG294a5$ZmBP>KZ zljizpEQX%Geq4(tPruc9{Zm?Vhl6LcROz`PbtH|Ontji$_q*P6OJeKPwmn*subv9V z4jdi|U7)|i{6z9HF\d+)/group/(?P\d+)/$', 'document_group_view', (), 'document_group_view'), url(r'^groups/for_document/(?P\d+)/$', 'groups_for_document', (), 'groups_for_document'), + + url(r'^setup/list/$', 'document_group_list', (), 'document_group_list'), + url(r'^setup/create/$', 'document_group_create', (), 'document_group_create'), + url(r'^setup/(?P\d+)/delete/$', 'document_group_delete', (), 'document_group_delete'), ) diff --git a/apps/grouping/views.py b/apps/grouping/views.py index 704483ce45..a47099eb0d 100644 --- a/apps/grouping/views.py +++ b/apps/grouping/views.py @@ -5,13 +5,20 @@ from django.shortcuts import get_object_or_404, render_to_response from django.core.urlresolvers import reverse from django.template import RequestContext +from common.utils import generate_choices_w_labels, encapsulate +from common.widgets import two_state_template + from documents.models import Document from documents.views import document_list +from permissions.api import check_permissions + from grouping.models import DocumentGroup from grouping.conf.settings import SHOW_EMPTY_GROUPS -from grouping.forms import DocumentDataGroupForm +from grouping.forms import DocumentDataGroupForm, DocumentGroupForm from grouping import document_group_link +from grouping import PERMISSION_DOCUMENT_GROUP_VIEW, \ + PERMISSION_DOCUMENT_GROUP_CREATE, PERMISSION_DOCUMENT_GROUP_DELETE def document_group_action(request): @@ -80,4 +87,69 @@ def groups_for_document(request, document_id): 'object': document, 'document': document, 'subtemplates_list': subtemplates_list, - }, context_instance=RequestContext(request)) + }, context_instance=RequestContext(request)) + + +def document_group_list(request): + check_permissions(request.user, [PERMISSION_DOCUMENT_GROUP_VIEW]) + + return render_to_response('generic_list.html', { + 'title': _(u'document groups'), + 'object_list': DocumentGroup.objects.all(), + 'extra_columns': [ + {'name': _(u'dynamic title'), 'attribute': 'dynamic_title'}, + {'name': _(u'enabled'), 'attribute': encapsulate(lambda x: two_state_template(x.enabled))}, + ], + 'hide_link': True, + }, context_instance=RequestContext(request)) + + +def document_group_create(request): + check_permissions(request.user, [PERMISSION_DOCUMENT_GROUP_CREATE]) + + if request.method == 'POST': + form = DocumentGroupForm(request.POST) + if form.is_valid(): + document_group = form.save() + messages.success(request, _(u'Document group: %s created successfully.') % document_group) + return HttpResponseRedirect(reverse('document_group_list')) + else: + form = DocumentGroupForm() + + return render_to_response('generic_form.html', { + 'form': form, + 'title': _(u'Create new document group') + }, context_instance=RequestContext(request)) + + +def document_group_delete(request, document_group_id): + check_permissions(request.user, [PERMISSION_DOCUMENT_GROUP_DELETE]) + + document_group = get_object_or_404(DocumentGroup, pk=document_group_id) + + next = request.POST.get('next', request.GET.get('next', request.META.get('HTTP_REFERER', '/'))) + previous = request.POST.get('previous', request.GET.get('previous', request.META.get('HTTP_REFERER', '/'))) + + if request.method == 'POST': + try: + document_group.delete() + messages.success(request, _(u'Document group: %s deleted successfully.') % document_group) + except Exception, error: + messages.error(request, _(u'Error deleting document group: %(document_group)s; %(error)s.') % { + 'document_group': document_group, + 'error': error + }) + return HttpResponseRedirect(next) + + return render_to_response('generic_confirm.html', { + 'delete_view': True, + 'object': document_group, + 'next': next, + 'previous': previous, + 'form_icon': u'package_delete.png', + #'temporary_navigation_links': {'form_header': {'staging_file_delete': {'links': results['tab_links']}}}, + }, context_instance=RequestContext(request)) + + + +