author | Sverre Rabbelier <srabbelier@gmail.com> |
Wed, 21 Jan 2009 23:44:02 +0000 | |
changeset 895 | e70ffd079438 |
parent 880 | d67557c612de |
child 933 | 7331232d6356 |
permissions | -rw-r--r-- |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
1 |
#!/usr/bin/python2.5 |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
2 |
# |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
3 |
# Copyright 2008 the Melange authors. |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
4 |
# |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
5 |
# Licensed under the Apache License, Version 2.0 (the "License"); |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
6 |
# you may not use this file except in compliance with the License. |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
7 |
# You may obtain a copy of the License at |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
8 |
# |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
9 |
# http://www.apache.org/licenses/LICENSE-2.0 |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
10 |
# |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
11 |
# Unless required by applicable law or agreed to in writing, software |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
12 |
# distributed under the License is distributed on an "AS IS" BASIS, |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
13 |
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
14 |
# See the License for the specific language governing permissions and |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
15 |
# limitations under the License. |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
16 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
17 |
"""Helpers functions for displaying views. |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
18 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
19 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
20 |
__authors__ = [ |
429
e50e18936f06
Fixed typo in e-mail address
Sverre Rabbelier <srabbelier@gmail.com>
parents:
428
diff
changeset
|
21 |
'"Sverre Rabbelier" <sverre@rabbelier.nl>', |
516
ec1dcd70b97e
The list method in models/base.py can now use a filter to make a selection of entities to show.
Lennard de Rijk <ljvderijk@gmail.com>
parents:
514
diff
changeset
|
22 |
'"Lennard de Rijk" <ljvderijk@gmail.com>', |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
23 |
'"Pawel Solyga" <pawel.solyga@gmail.com>', |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
24 |
] |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
25 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
26 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
27 |
from django import http |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
28 |
from django.utils.translation import ugettext_lazy |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
29 |
|
387
c55195361cb6
Addressed comments by Todd on r822
Sverre Rabbelier <srabbelier@gmail.com>
parents:
373
diff
changeset
|
30 |
from soc.logic import dicts |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
31 |
from soc.views import helper |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
32 |
from soc.views import out_of_band |
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
33 |
from soc.views.helper import decorators |
612
3cca81b1e5a1
Moved checkAccess and getCleanedFields into access and forms
Sverre Rabbelier <srabbelier@gmail.com>
parents:
611
diff
changeset
|
34 |
from soc.views.helper import forms |
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
35 |
from soc.views.helper import redirects |
613
4880ffa9f3ba
Moved getDjangoURLPatterns to sitemap.sitemap
Sverre Rabbelier <srabbelier@gmail.com>
parents:
612
diff
changeset
|
36 |
from soc.views import sitemap |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
37 |
|
646
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
38 |
import soc.logic |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
39 |
import soc.logic.lists |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
40 |
import soc.views.helper.lists |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
41 |
import soc.views.helper.responses |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
42 |
import soc.views.helper.params |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
43 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
44 |
|
493
6976c4d8d0ac
Refactor the sidebar to use Django templates
Sverre Rabbelier <srabbelier@gmail.com>
parents:
492
diff
changeset
|
45 |
class View(object): |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
46 |
"""Views for entity classes. |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
47 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
48 |
The View class functions specific to Entity classes by relying |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
49 |
on the the child-classes to define the following fields: |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
50 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
51 |
self._logic: the logic singleton for this entity |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
52 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
53 |
|
542
7cc99461b64d
Remove redundant dicts for URL patterns and sidebar menu text, and use the
Todd Larsen <tlarsen@google.com>
parents:
539
diff
changeset
|
54 |
DEF_CREATE_NEW_ENTITY_MSG_FMT = ugettext_lazy( |
502
e1e24c0a4e82
Add new parameters to views: url_name which is name used in urls (instead of using lower entity names) and module_name which is used for constructing django urls. Append changes to all affected files. Fix some title names. Change urls that included underscores like "site_settings" into urls with slash "site/settings". Plus some other minor fixes.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
500
diff
changeset
|
55 |
' You can create a new %(entity_type)s by visiting' |
387
c55195361cb6
Addressed comments by Todd on r822
Sverre Rabbelier <srabbelier@gmail.com>
parents:
373
diff
changeset
|
56 |
' <a href="%(create)s">Create ' |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
57 |
'a New %(entity_type)s</a> page.') |
387
c55195361cb6
Addressed comments by Todd on r822
Sverre Rabbelier <srabbelier@gmail.com>
parents:
373
diff
changeset
|
58 |
|
663
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
59 |
DEF_CREATE_INSTRUCTION_MSG_FMT = ugettext_lazy( |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
60 |
'Please select a %s for the new %s.') |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
61 |
|
507
3603fdafabf7
Fold the _rights dictionary into params
Sverre Rabbelier <srabbelier@gmail.com>
parents:
502
diff
changeset
|
62 |
def __init__(self, params=None): |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
63 |
""" |
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
64 |
|
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
65 |
Args: |
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
66 |
params: This dictionary should be filled with the parameters |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
67 |
specific to this entity. See the methods in this class on |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
68 |
the fields it should contain, and how they are used. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
69 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
70 |
|
611
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
71 |
self._params = helper.params.constructParams(params) |
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
72 |
self._logic = params['logic'] |
554
68c7a1dd3c52
Renamed templates/soc/entity/list/entity_*.html to *.html
Sverre Rabbelier <srabbelier@gmail.com>
parents:
553
diff
changeset
|
73 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
74 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
75 |
@decorators.check_access |
710
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
76 |
def public(self, request, access_type, |
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
77 |
page_name=None, params=None, **kwargs): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
78 |
"""Displays the public page for the entity specified by **kwargs. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
79 |
|
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
80 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
81 |
rights: The rights dictionary is used to check if the user has |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
82 |
the required rights to view the public page for this entity. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
83 |
See checkAccess for more details on how the rights dictionary |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
84 |
is used to check access rights. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
85 |
error_public: The error_public value is used as template when |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
86 |
the key values (as defined by the page's url) do not |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
87 |
correspond to an existing entity. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
88 |
name: The name value is used to set the entity_type in the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
89 |
context so that the template can refer to it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
90 |
public_template: The public_template value is used as template |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
91 |
to display the public page of the found entity. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
92 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
93 |
Args: |
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
94 |
request: the standard Django HTTP request object |
500
44ea4620c5c0
Replace old page parameter doc string description with new one for page_name.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
499
diff
changeset
|
95 |
page_name: the page name displayed in templates as page and header title |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
96 |
params: a dict with params for this View |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
97 |
kwargs: the Key Fields for the specified entity |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
98 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
99 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
100 |
# create default template context for use with any templates |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
101 |
context = helper.responses.getUniversalContext(request) |
482
839740b061ad
Factor out direct use of the page object
Sverre Rabbelier <srabbelier@gmail.com>
parents:
471
diff
changeset
|
102 |
context['page_name'] = page_name |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
103 |
entity = None |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
104 |
|
446
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
105 |
if not all(kwargs.values()): |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
106 |
#TODO: Change this into a proper redirect |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
107 |
return http.HttpResponseRedirect('/') |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
108 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
109 |
try: |
435
829fe8302a8b
Refactor out the abundance of dictionary (un)packing
Sverre Rabbelier <srabbelier@gmail.com>
parents:
429
diff
changeset
|
110 |
key_fields = self._logic.getKeyFieldsFromDict(kwargs) |
829fe8302a8b
Refactor out the abundance of dictionary (un)packing
Sverre Rabbelier <srabbelier@gmail.com>
parents:
429
diff
changeset
|
111 |
entity = self._logic.getIfFields(key_fields) |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
112 |
except out_of_band.Error, error: |
646
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
113 |
return helper.responses.errorResponse( |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
114 |
error, request, template=params['error_public'], context=context) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
115 |
|
446
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
116 |
self._public(request, entity, context) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
117 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
118 |
context['entity'] = entity |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
119 |
context['entity_type'] = params['name'] |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
120 |
|
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
121 |
template = params['public_template'] |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
122 |
|
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
123 |
return helper.responses.respond(request, template, context=context) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
124 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
125 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
126 |
@decorators.check_access |
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
127 |
def export(self, request, access_type, |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
128 |
page_name=None, params=None, **kwargs): |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
129 |
"""Displays the export page for the entity specified by **kwargs. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
130 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
131 |
Params usage: |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
132 |
rights: The rights dictionary is used to check if the user has |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
133 |
the required rights to view the export page for this entity. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
134 |
See checkAccess for more details on how the rights dictionary |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
135 |
is used to check access rights. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
136 |
error_export: The error_export value is used as template when |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
137 |
the key values (as defined by the page's url) do not |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
138 |
correspond to an existing entity. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
139 |
name: The name value is used to set the entity_type in the |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
140 |
context so that the template can refer to it. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
141 |
export_template: The export_template value is used as template |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
142 |
to display the export page of the found entity. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
143 |
export_content_type: The export_content_type value is used to set |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
144 |
the Content-Type header of the HTTP response. If empty (or None), |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
145 |
public() is called instead. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
146 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
147 |
Args: |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
148 |
request: the standard Django HTTP request object |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
149 |
page_name: the page name displayed in templates as page and header title |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
150 |
params: a dict with params for this View |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
151 |
kwargs: the Key Fields for the specified entity |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
152 |
""" |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
153 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
154 |
if not params.get('export_content_type'): |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
155 |
return self.public(request, access_type, page_name=page_name, |
874
30e9629bf590
Fixed two trivial bugs
Sverre Rabbelier <srabbelier@gmail.com>
parents:
858
diff
changeset
|
156 |
params=params, **kwargs) |
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
157 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
158 |
# create default template context for use with any templates |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
159 |
context = helper.responses.getUniversalContext(request) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
160 |
context['page_name'] = page_name |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
161 |
entity = None |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
162 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
163 |
if not all(kwargs.values()): |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
164 |
#TODO: Change this into a proper redirect |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
165 |
return http.HttpResponseRedirect('/') |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
166 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
167 |
try: |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
168 |
key_fields = self._logic.getKeyFieldsFromDict(kwargs) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
169 |
entity = self._logic.getIfFields(key_fields) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
170 |
except out_of_band.Error, error: |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
171 |
return helper.responses.errorResponse( |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
172 |
error, request, template=params['error_export'], context=context) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
173 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
174 |
self._export(request, entity, context) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
175 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
176 |
context['entity'] = entity |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
177 |
context['entity_type'] = params['name'] |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
178 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
179 |
template = params['export_template'] |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
180 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
181 |
response_args = {'mimetype': params['export_content_type']} |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
182 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
183 |
return helper.responses.respond(request, template, context=context, |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
184 |
response_args=response_args) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
185 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
186 |
@decorators.check_access |
710
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
187 |
def create(self, request, access_type, |
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
188 |
page_name=None, params=None, **kwargs): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
189 |
"""Displays the create page for this entity type. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
190 |
|
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
191 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
192 |
The params dictionary is passed on to edit, see the docstring |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
193 |
for edit on how it uses it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
194 |
|
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
195 |
Args: |
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
196 |
request: the standard Django HTTP request object |
500
44ea4620c5c0
Replace old page parameter doc string description with new one for page_name.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
499
diff
changeset
|
197 |
page_name: the page name displayed in templates as page and header title |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
198 |
params: a dict with params for this View |
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
199 |
kwargs: not used for create() |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
200 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
201 |
|
663
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
202 |
new_params = dicts.merge(params, self._params) |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
203 |
|
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
204 |
if ('scope_view' in new_params) and ('scope_path' not in kwargs): |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
205 |
view = new_params['scope_view'].view |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
206 |
redirect = new_params['scope_redirect'] |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
207 |
return self.select(request, view, redirect, |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
208 |
params=params, page_name=page_name, **kwargs) |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
209 |
|
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
210 |
params = new_params |
492
4abdeedfc08e
Fixed redirection after creation to Just Work
Sverre Rabbelier <srabbelier@gmail.com>
parents:
490
diff
changeset
|
211 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
212 |
# Create page is an edit page with no key fields |
490
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
213 |
empty_kwargs = {} |
410
2af7f84f4fc7
Moved all key_name related things to the logic modules
Sverre Rabbelier <srabbelier@gmail.com>
parents:
409
diff
changeset
|
214 |
fields = self._logic.getKeyFieldNames() |
2af7f84f4fc7
Moved all key_name related things to the logic modules
Sverre Rabbelier <srabbelier@gmail.com>
parents:
409
diff
changeset
|
215 |
for field in fields: |
490
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
216 |
empty_kwargs[field] = None |
410
2af7f84f4fc7
Moved all key_name related things to the logic modules
Sverre Rabbelier <srabbelier@gmail.com>
parents:
409
diff
changeset
|
217 |
|
710
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
218 |
return self.edit(request, access_type, page_name=page_name, |
708
89f1a8c2ea59
Some cleanups in role.py and site.py and create()
Sverre Rabbelier <srabbelier@gmail.com>
parents:
703
diff
changeset
|
219 |
params=params, seed=kwargs, **empty_kwargs) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
220 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
221 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
222 |
@decorators.check_access |
710
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
223 |
def edit(self, request, access_type, |
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
224 |
page_name=None, params=None, seed=None, **kwargs): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
225 |
"""Displays the edit page for the entity specified by **kwargs. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
226 |
|
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
227 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
228 |
The params dictionary is passed on to either editGet or editPost |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
229 |
depending on the method type of the request. See the docstring |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
230 |
for editGet and editPost on how they use it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
231 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
232 |
rights: The rights dictionary is used to check if the user has |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
233 |
the required rights to edit (or create) a new entity. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
234 |
See checkAccess for more details on how the rights dictionary |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
235 |
is used to check access rights. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
236 |
name: The name value is used to construct the message_fmt of the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
237 |
raised error when there key_values do not define an existing |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
238 |
entity. See DEF_CREATE_NEW_ENTITY_MSG_FMT on how the name |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
239 |
(and the lower() version of it) is used. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
240 |
missing_redirect: The missing_redirect value is also used to |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
241 |
construct the message_fmt mentioned above. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
242 |
error_public: The error_public value is used as the template for |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
243 |
the error response mentioned above. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
244 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
245 |
Args: |
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
246 |
request: the standard Django HTTP request object |
500
44ea4620c5c0
Replace old page parameter doc string description with new one for page_name.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
499
diff
changeset
|
247 |
page_name: the page name displayed in templates as page and header title |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
248 |
params: a dict with params for this View |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
249 |
kwargs: The Key Fields for the specified entity |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
250 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
251 |
|
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
252 |
context = helper.responses.getUniversalContext(request) |
482
839740b061ad
Factor out direct use of the page object
Sverre Rabbelier <srabbelier@gmail.com>
parents:
471
diff
changeset
|
253 |
context['page_name'] = page_name |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
254 |
entity = None |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
255 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
256 |
try: |
439
0658c3c9a9dc
Minor fixes needed for generic key name
Sverre Rabbelier <srabbelier@gmail.com>
parents:
438
diff
changeset
|
257 |
if all(kwargs.values()): |
0658c3c9a9dc
Minor fixes needed for generic key name
Sverre Rabbelier <srabbelier@gmail.com>
parents:
438
diff
changeset
|
258 |
key_fields = self._logic.getKeyFieldsFromDict(kwargs) |
0658c3c9a9dc
Minor fixes needed for generic key name
Sverre Rabbelier <srabbelier@gmail.com>
parents:
438
diff
changeset
|
259 |
entity = self._logic.getIfFields(key_fields) |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
260 |
except out_of_band.Error, error: |
490
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
261 |
if not seed: |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
262 |
error.message_fmt = ( |
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
263 |
error.message_fmt + self.DEF_CREATE_NEW_ENTITY_MSG_FMT % { |
490
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
264 |
'entity_type_lower' : params['name'].lower(), |
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
265 |
'entity_type' : params['name'], |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
266 |
'create' : params['missing_redirect']}) |
646
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
267 |
return helper.responses.errorResponse( |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
268 |
error, request, template=params['error_public'], context=context) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
269 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
270 |
if request.method == 'POST': |
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
271 |
return self.editPost(request, entity, context, params=params) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
272 |
else: |
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
273 |
return self.editGet(request, entity, context, seed, params=params) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
274 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
275 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
276 |
def editPost(self, request, entity, context, params=None): |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
277 |
"""Processes POST requests for the specified entity. |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
278 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
279 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
280 |
The params dictionary is passed to _constructResponse when the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
281 |
form is not valid (see edit_form and create_form below). See |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
282 |
the docstring of _constructResponse on how it uses it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
283 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
284 |
edit_form: The edit_form value is used as form when there is an |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
285 |
existing entity. It is provided with with the request.POST |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
286 |
dictionary on construction. The collectCleanedFields method |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
287 |
is called with the newly constructed form. If the form is |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
288 |
not valid, it is passed as argument to _constructResponse. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
289 |
create_form: The create_form value is used in a similar way to |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
290 |
edit_form, only it is used when there is no existing entity. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
291 |
edit_redirect: The edit_redirect value is used as the first part |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
292 |
of the url if the form was valid. The last part of the url is |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
293 |
created using the getKeySuffix method of the _logic object. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
294 |
edit_params: The edit_params dictionary is used as argument to |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
295 |
redirectToChangedSuffix, it will be appended to the url in the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
296 |
standard ?key=value format. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
297 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
298 |
Args: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
299 |
request: a django request object |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
300 |
entity: the entity that will be modified or created, may be None |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
301 |
context: the context dictionary that will be provided to Django |
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
302 |
params: required, a dict with params for this View |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
303 |
""" |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
304 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
305 |
if entity: |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
306 |
form = params['edit_form'](request.POST) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
307 |
else: |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
308 |
form = params['create_form'](request.POST) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
309 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
310 |
if not form.is_valid(): |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
311 |
return self._constructResponse(request, entity, context, form, params) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
312 |
|
612
3cca81b1e5a1
Moved checkAccess and getCleanedFields into access and forms
Sverre Rabbelier <srabbelier@gmail.com>
parents:
611
diff
changeset
|
313 |
key_name, fields = forms.collectCleanedFields(form) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
314 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
315 |
self._editPost(request, entity, fields) |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
316 |
|
459
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
317 |
if not key_name: |
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
318 |
key_fields = self._logic.getKeyFieldsFromDict(fields) |
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
319 |
key_name = self._logic.getKeyNameForFields(key_fields) |
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
320 |
|
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
321 |
entity = self._logic.updateOrCreateFromKeyName(fields, key_name) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
322 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
323 |
if not entity: |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
324 |
return http.HttpResponseRedirect('/') |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
325 |
|
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
326 |
page_params = params['edit_params'] |
735
28225172af06
Make it possible to redirect anywhere after editPost
Sverre Rabbelier <srabbelier@gmail.com>
parents:
714
diff
changeset
|
327 |
params['suffix'] = self._logic.getKeySuffix(entity) |
28225172af06
Make it possible to redirect anywhere after editPost
Sverre Rabbelier <srabbelier@gmail.com>
parents:
714
diff
changeset
|
328 |
|
28225172af06
Make it possible to redirect anywhere after editPost
Sverre Rabbelier <srabbelier@gmail.com>
parents:
714
diff
changeset
|
329 |
request.path = params['edit_redirect'] % params |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
330 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
331 |
# redirect to (possibly new) location of the entity |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
332 |
# (causes 'Profile saved' message to be displayed) |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
333 |
return helper.responses.redirectToChangedSuffix( |
735
28225172af06
Make it possible to redirect anywhere after editPost
Sverre Rabbelier <srabbelier@gmail.com>
parents:
714
diff
changeset
|
334 |
request, None, params=page_params) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
335 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
336 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
337 |
def editGet(self, request, entity, context, seed, params=None): |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
338 |
"""Processes GET requests for the specified entity. |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
339 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
340 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
341 |
The params dictionary is passed to _constructResponse, see the |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
342 |
docstring of _constructResponse on how it uses it. |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
343 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
344 |
save_message: The save_message list is used as argument to |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
345 |
getSingleIndexedParamValue when an existing entity was saved. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
346 |
edit_form: The edit_form is used as form if there is an existing |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
347 |
entity. The existing entity is passed as instance to it on |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
348 |
construction. If key_name is part of it's fields it will be |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
349 |
set to the entity's key().name() value. It is also passed as |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
350 |
argument to the _editGet method. See the docstring for |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
351 |
_editGet on how it uses it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
352 |
create_form: The create_form is used as form if there was no |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
353 |
existing entity. If the seed argument is present, it is passed |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
354 |
as the 'initial' argument on construction. Otherwise, it is |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
355 |
called with no arguments. |
611
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
356 |
submit_msg_param_name: The submit_msg_param_name value is used |
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
357 |
as the key part in the ?key=value construct for the submit |
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
358 |
message parameter (see also save_message). |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
359 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
360 |
Args: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
361 |
request: the django request object |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
362 |
entity: the entity that will be edited, may be None |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
363 |
context: the context dictionary that will be provided to django |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
364 |
seed: if no entity is provided, the initial values for the new entity |
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
365 |
params: required, a dict with params for this View |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
366 |
""" |
403
d3e545a8bd26
Some more improvements to the generic view code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
402
diff
changeset
|
367 |
|
410
2af7f84f4fc7
Moved all key_name related things to the logic modules
Sverre Rabbelier <srabbelier@gmail.com>
parents:
409
diff
changeset
|
368 |
suffix = self._logic.getKeySuffix(entity) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
369 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
370 |
# Remove the params from the request, this is relevant only if |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
371 |
# someone bookmarked a POST page. |
387
c55195361cb6
Addressed comments by Todd on r822
Sverre Rabbelier <srabbelier@gmail.com>
parents:
373
diff
changeset
|
372 |
is_self_referrer = helper.requests.isReferrerSelf(request, suffix=suffix) |
611
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
373 |
if request.GET.get(params['submit_msg_param_name']): |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
374 |
if (not entity) or (not is_self_referrer): |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
375 |
return http.HttpResponseRedirect(request.path) |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
376 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
377 |
if entity: |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
378 |
# Note: no message will be displayed if parameter is not present |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
379 |
context['notice'] = helper.requests.getSingleIndexedParamValue( |
611
2ec30182e5f1
Move parameter construction into a seperate module
Sverre Rabbelier <srabbelier@gmail.com>
parents:
610
diff
changeset
|
380 |
request, params['submit_msg_param_name'], |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
381 |
values=params['save_message']) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
382 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
383 |
# populate form with the existing entity |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
384 |
form = params['edit_form'](instance=entity) |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
385 |
|
459
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
386 |
if 'key_name' in form.fields: |
2cfcedaf7c16
Preparation for generic user views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
458
diff
changeset
|
387 |
form.fields['key_name'].initial = entity.key().name() |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
388 |
|
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
389 |
self._editGet(request, entity, form) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
390 |
else: |
490
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
391 |
if seed: |
495
87afae6e4c51
Added basic 'invite' functionality
Sverre Rabbelier <srabbelier@gmail.com>
parents:
494
diff
changeset
|
392 |
self._editSeed(request, seed) |
490
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
393 |
form = params['create_form'](initial=seed) |
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
394 |
else: |
7cfa2ad62944
Allow pre-seeding a create form
Sverre Rabbelier <srabbelier@gmail.com>
parents:
482
diff
changeset
|
395 |
form = params['create_form']() |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
396 |
|
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
397 |
return self._constructResponse(request, entity, context, form, params) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
398 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
399 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
400 |
@decorators.check_access |
710
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
401 |
def list(self, request, access_type, |
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
402 |
page_name=None, params=None, filter=None): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
403 |
"""Displays the list page for the entity type. |
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
404 |
|
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
405 |
Args: |
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
406 |
request: the standard Django HTTP request object |
500
44ea4620c5c0
Replace old page parameter doc string description with new one for page_name.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
499
diff
changeset
|
407 |
page_name: the page name displayed in templates as page and header title |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
408 |
params: a dict with params for this View |
516
ec1dcd70b97e
The list method in models/base.py can now use a filter to make a selection of entities to show.
Lennard de Rijk <ljvderijk@gmail.com>
parents:
514
diff
changeset
|
409 |
filter: a dict for the properties that the entities should have |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
410 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
411 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
412 |
The params dictionary is passed as argument to getListContent in |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
413 |
the soc.views.helper.list module. See the docstring for getListContent |
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
414 |
on how it uses it. The params dictionary is also passed as argument to |
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
415 |
the _list method. See the docstring for _list on how it uses it. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
416 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
417 |
|
651
ef6e22d463cb
Remove the logic parameter from getListContent
Sverre Rabbelier <srabbelier@gmail.com>
parents:
646
diff
changeset
|
418 |
content = helper.lists.getListContent(request, params, filter) |
555
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
419 |
contents = [content] |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
420 |
|
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
421 |
return self._list(request, params, contents, page_name) |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
422 |
|
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
423 |
def _list(self, request, params, contents, page_name): |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
424 |
"""Returns the list page for the specified contents. |
555
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
425 |
|
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
426 |
Args: |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
427 |
request: the standard Django HTTP request object |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
428 |
params: a dict with params for this View |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
429 |
contents: a list of content dicts |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
430 |
page_name: the page name displayed in templates as page and header title |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
431 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
432 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
433 |
name: The name value is used to set the entity_type in the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
434 |
context so that the template can refer to it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
435 |
name_plural: The name_plural value is used to set |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
436 |
the entity_type_plural value in the context so that the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
437 |
template can refer to it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
438 |
list_template: The list_template value is used as template for |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
439 |
to display the list of all entities for this View. |
555
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
440 |
""" |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
441 |
|
555
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
442 |
context = helper.responses.getUniversalContext(request) |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
443 |
context['page_name'] = page_name |
3cdfb42d941b
Split the list view code up in three pieces
Sverre Rabbelier <srabbelier@gmail.com>
parents:
554
diff
changeset
|
444 |
context['list'] = soc.logic.lists.Lists(contents) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
445 |
|
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
446 |
context['entity_type'] = params['name'] |
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
447 |
context['entity_type_plural'] = params['name_plural'] |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
448 |
|
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
449 |
template = params['list_template'] |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
450 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
451 |
return helper.responses.respond(request, template, context) |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
452 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
453 |
@decorators.merge_params |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
454 |
@decorators.check_access |
710
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
455 |
def delete(self, request, access_type, |
edb5dbb1dea7
Add explicit access_types from the url
Sverre Rabbelier <srabbelier@gmail.com>
parents:
708
diff
changeset
|
456 |
page_name=None, params=None, **kwargs): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
457 |
"""Shows the delete page for the entity specified by **kwargs. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
458 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
459 |
Args: |
373
dcd7013ae0d5
Add the Page object to the context of each view method. Also, add some missing
Todd Larsen <tlarsen@google.com>
parents:
363
diff
changeset
|
460 |
request: the standard Django HTTP request object |
500
44ea4620c5c0
Replace old page parameter doc string description with new one for page_name.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
499
diff
changeset
|
461 |
page_name: the page name displayed in templates as page and header title |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
462 |
params: a dict with params for this View |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
463 |
kwargs: The Key Fields for the specified entity |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
464 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
465 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
466 |
rights: The rights dictionary is used to check if the user has |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
467 |
the required rights to delete the specified entity. See checkAccess |
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
468 |
for more details on how the rights dictionary is used to check access |
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
469 |
rights. |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
470 |
name: used in the same way as in edit(), see it's docstring for |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
471 |
a more detailed explanation on how it is used. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
472 |
missing_redirect: see name |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
473 |
error_edit: see name |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
474 |
delete_redirect: The delete_redirect value is used as the url to |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
475 |
redirect to after having successfully deleted the entity. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
476 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
477 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
478 |
# create default template context for use with any templates |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
479 |
context = helper.responses.getUniversalContext(request) |
482
839740b061ad
Factor out direct use of the page object
Sverre Rabbelier <srabbelier@gmail.com>
parents:
471
diff
changeset
|
480 |
context['page_name'] = page_name |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
481 |
entity = None |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
482 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
483 |
try: |
438
af082c92ddda
Quick fix to fix user profile creation
Sverre Rabbelier <srabbelier@gmail.com>
parents:
435
diff
changeset
|
484 |
key_fields = self._logic.getKeyFieldsFromDict(kwargs) |
435
829fe8302a8b
Refactor out the abundance of dictionary (un)packing
Sverre Rabbelier <srabbelier@gmail.com>
parents:
429
diff
changeset
|
485 |
entity = self._logic.getIfFields(key_fields) |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
486 |
except out_of_band.Error, error: |
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
487 |
error.message_fmt = ( |
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
488 |
error.message_fmt + self.DEF_CREATE_NEW_ENTITY_MSG_FMT % { |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
489 |
'entity_type_lower' : params['name'].lower(), |
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
490 |
'entity_type' : params['name'], |
543
280a1ac6bcc1
Merge soc/logic/out_of_band.py into soc/views/out_of_band.py. Merge
Todd Larsen <tlarsen@google.com>
parents:
542
diff
changeset
|
491 |
'create' : params['missing_redirect']}) |
646
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
492 |
return helper.responses.errorResponse( |
860e17e5118f
Remove cyclic imports by moving response method of out_of_band.Error class to soc.views.helper.responses module as errorResponse function. Apply changes to affected files.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
639
diff
changeset
|
493 |
error, request, template=params['error_edit'], context=context) |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
494 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
495 |
if not entity: |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
496 |
#TODO: Create a proper error page for this |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
497 |
return http.HttpResponseRedirect('/') |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
498 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
499 |
if not self._logic.isDeletable(entity): |
389
9b873166d7d5
Fix identions, too long lines, unused imports and some other mistakes.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
387
diff
changeset
|
500 |
# TODO: Update the notice area telling the user that they |
9b873166d7d5
Fix identions, too long lines, unused imports and some other mistakes.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
387
diff
changeset
|
501 |
# can't delete the entity |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
502 |
pass |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
503 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
504 |
self._logic.delete(entity) |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
505 |
redirect = params['delete_redirect'] |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
506 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
507 |
return http.HttpResponseRedirect(redirect) |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
508 |
|
653
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
509 |
def select(self, request, view, redirect, page_name=None, params=None): |
668
77f9a6ea6e67
Some style and typo fixes in different modules.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
663
diff
changeset
|
510 |
"""Displays a list page allowing the user to select an entity. |
653
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
511 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
512 |
After having selected the Scope, the user is redirected to the |
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
513 |
'create a new entity' page with the scope_path set appropriately. |
653
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
514 |
|
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
515 |
Params usage: |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
516 |
The params dictionary is also passed to getListContent from |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
517 |
the helper.list module, please refer to its docstring also. |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
518 |
The params dictionary is passed to self._list as well, refer |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
519 |
to its docstring for details on how it uses it. |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
520 |
|
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
521 |
Args: |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
522 |
request: the standard Django HTTP request object |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
523 |
page_name: the page name displayed in templates as page and header title |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
524 |
params: a dict with params for this View |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
525 |
""" |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
526 |
|
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
527 |
params = dicts.merge(params, view.getParams()) |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
528 |
params = dicts.merge(params, self._params) |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
529 |
params['list_action'] = (redirect, self._params) |
663
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
530 |
params['list_description'] = self.DEF_CREATE_INSTRUCTION_MSG_FMT % ( |
c2dcae606699
Make base.View.create lookup the scope if appropriate
Sverre Rabbelier <srabbelier@gmail.com>
parents:
662
diff
changeset
|
531 |
params['name'], self._params['name']) |
653
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
532 |
|
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
533 |
content = helper.lists.getListContent(request, params) |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
534 |
contents = [content] |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
535 |
|
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
536 |
return self._list(request, params, contents, page_name) |
5105939d3bb4
Make the 'select entity' View generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
652
diff
changeset
|
537 |
|
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
538 |
def _editPost(self, request, entity, fields): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
539 |
"""Performs any required processing on the entity to post its edit page. |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
540 |
|
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
541 |
Args: |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
542 |
request: the django request object |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
543 |
entity: the entity to create or update from POST contents |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
544 |
fields: the new field values |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
545 |
""" |
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
546 |
|
662
0e89b027b140
Make use of the new generic key_name by lookup up scope_path
Sverre Rabbelier <srabbelier@gmail.com>
parents:
653
diff
changeset
|
547 |
# If scope_logic is not defined, this entity has no scope |
677
c8f24e3078b8
Fix scope lookup for unscoped entities
Sverre Rabbelier <srabbelier@gmail.com>
parents:
668
diff
changeset
|
548 |
if not self._params['scope_logic']: |
662
0e89b027b140
Make use of the new generic key_name by lookup up scope_path
Sverre Rabbelier <srabbelier@gmail.com>
parents:
653
diff
changeset
|
549 |
return |
0e89b027b140
Make use of the new generic key_name by lookup up scope_path
Sverre Rabbelier <srabbelier@gmail.com>
parents:
653
diff
changeset
|
550 |
|
714
3e2ce3d8057a
Add missing dots in docstrings, proper sorting of imports and small docstring typo fixes.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
710
diff
changeset
|
551 |
# If this entity is unscoped, do not try to retrieve a scope |
701
d6f5d34cff5a
If an entity is unscoped, do not try to retrieve a scope
Sverre Rabbelier <srabbelier@gmail.com>
parents:
677
diff
changeset
|
552 |
if 'scope_path' not in fields: |
d6f5d34cff5a
If an entity is unscoped, do not try to retrieve a scope
Sverre Rabbelier <srabbelier@gmail.com>
parents:
677
diff
changeset
|
553 |
return |
d6f5d34cff5a
If an entity is unscoped, do not try to retrieve a scope
Sverre Rabbelier <srabbelier@gmail.com>
parents:
677
diff
changeset
|
554 |
|
755
1ed041c0cdc6
Remove unused imports and variables in different soc.views.models modules.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
735
diff
changeset
|
555 |
scope = self._params['scope_logic'].logic.getFromKeyName( |
1ed041c0cdc6
Remove unused imports and variables in different soc.views.models modules.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
735
diff
changeset
|
556 |
fields['scope_path']) |
662
0e89b027b140
Make use of the new generic key_name by lookup up scope_path
Sverre Rabbelier <srabbelier@gmail.com>
parents:
653
diff
changeset
|
557 |
fields['scope'] = scope |
446
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
558 |
|
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
559 |
def _public(self, request, entity, context): |
880 | 560 |
"""Performs any required processing to get an entity's public page. |
446
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
561 |
|
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
562 |
Args: |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
563 |
request: the django request object |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
564 |
entity: the entity to make public |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
565 |
context: the context object |
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
566 |
""" |
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
567 |
pass |
446
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
568 |
|
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
569 |
def _export(self, request, entity, context): |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
570 |
"""Performs any required processing to get an entity's export page. |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
571 |
|
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
572 |
Args: |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
573 |
request: the django request object |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
574 |
entity: the entity to export |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
575 |
context: the context object |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
576 |
""" |
446
0b479d573a4c
Refactoring of {site/home}_settings to make them use base.View
Sverre Rabbelier <srabbelier@gmail.com>
parents:
445
diff
changeset
|
577 |
pass |
363
d35ffa6ca643
Add a framework for generic views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
diff
changeset
|
578 |
|
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
579 |
def _editGet(self, request, entity, form): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
580 |
"""Performs any required processing on the form to get its edit page. |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
581 |
|
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
582 |
Args: |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
583 |
request: the django request object |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
584 |
entity: the entity to get |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
585 |
form: the django form that will be used for the page |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
586 |
""" |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
587 |
|
662
0e89b027b140
Make use of the new generic key_name by lookup up scope_path
Sverre Rabbelier <srabbelier@gmail.com>
parents:
653
diff
changeset
|
588 |
# fill in the email field with the data from the entity |
677
c8f24e3078b8
Fix scope lookup for unscoped entities
Sverre Rabbelier <srabbelier@gmail.com>
parents:
668
diff
changeset
|
589 |
if 'scope_path' in form.fields: |
c8f24e3078b8
Fix scope lookup for unscoped entities
Sverre Rabbelier <srabbelier@gmail.com>
parents:
668
diff
changeset
|
590 |
form.fields['scope_path'].initial = entity.scope_path |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
591 |
|
497
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
592 |
def _editSeed(self, request, seed): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
593 |
"""Performs any required processing on the form to get its edit page. |
497
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
594 |
|
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
595 |
Args: |
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
596 |
request: the django request object |
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
597 |
seed: the fields to seed the create page with |
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
598 |
""" |
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
599 |
|
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
600 |
pass |
73666a7cd718
Added a default _editSeed method
Sverre Rabbelier <srabbelier@gmail.com>
parents:
495
diff
changeset
|
601 |
|
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
602 |
def _constructResponse(self, request, entity, context, form, params): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
603 |
"""Updates the context and returns a response for the specified arguments. |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
604 |
|
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
605 |
Args: |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
606 |
request: the django request object |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
607 |
entity: the entity that is used and set in the context |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
608 |
context: the context to be used |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
609 |
form: the form that will be used and set in the context |
471
dcb1f7821b39
Remove stop parameter from home_settings and site_settings views. This is something Sverre didn't mean to commit :-) Add missing params description to the models Base class docs.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
459
diff
changeset
|
610 |
params: a dict with params for this View |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
611 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
612 |
Params usage: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
613 |
name: The name_plural value is used to set the entity_type |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
614 |
value in the context so that the template can refer to it. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
615 |
name_plural: same as name, but used to set entity_type_plural |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
616 |
name_short: same as name, but used to set entity_type_short |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
617 |
url_name: same as name, but used to set entity_type_url |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
618 |
edit_template: The edit_template value is used as template when |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
619 |
there is an existing entity to display the edit page for the |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
620 |
specified entity. |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
621 |
create_template: similar to edit_template, but is used when |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
622 |
there is no existing entity. |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
623 |
""" |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
624 |
|
410
2af7f84f4fc7
Moved all key_name related things to the logic modules
Sverre Rabbelier <srabbelier@gmail.com>
parents:
409
diff
changeset
|
625 |
suffix = self._logic.getKeySuffix(entity) |
403
d3e545a8bd26
Some more improvements to the generic view code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
402
diff
changeset
|
626 |
|
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
627 |
context['form'] = form |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
628 |
context['entity'] = entity |
403
d3e545a8bd26
Some more improvements to the generic view code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
402
diff
changeset
|
629 |
context['entity_suffix'] = suffix |
455
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
630 |
context['entity_type'] = params['name'] |
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
631 |
context['entity_type_plural'] = params['name_plural'] |
4d98832b43ba
Added support for providing a custom params dict
Sverre Rabbelier <srabbelier@gmail.com>
parents:
446
diff
changeset
|
632 |
context['entity_type_short'] = params['name_short'] |
502
e1e24c0a4e82
Add new parameters to views: url_name which is name used in urls (instead of using lower entity names) and module_name which is used for constructing django urls. Append changes to all affected files. Fix some title names. Change urls that included underscores like "site_settings" into urls with slash "site/settings". Plus some other minor fixes.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
500
diff
changeset
|
633 |
context['entity_type_url'] = params['url_name'] |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
634 |
|
874
30e9629bf590
Fixed two trivial bugs
Sverre Rabbelier <srabbelier@gmail.com>
parents:
858
diff
changeset
|
635 |
if params.get('export_content_type') and entity: |
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
636 |
context['export_link'] = redirects.getExportRedirect(entity, params) |
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
637 |
|
576
6614d3f545b7
Fixed spurious 'Invite Host' button in 'create host'
Sverre Rabbelier <srabbelier@gmail.com>
parents:
573
diff
changeset
|
638 |
if entity: |
6614d3f545b7
Fixed spurious 'Invite Host' button in 'create host'
Sverre Rabbelier <srabbelier@gmail.com>
parents:
573
diff
changeset
|
639 |
template = params['edit_template'] |
6614d3f545b7
Fixed spurious 'Invite Host' button in 'create host'
Sverre Rabbelier <srabbelier@gmail.com>
parents:
573
diff
changeset
|
640 |
else: |
6614d3f545b7
Fixed spurious 'Invite Host' button in 'create host'
Sverre Rabbelier <srabbelier@gmail.com>
parents:
573
diff
changeset
|
641 |
template = params['create_template'] |
399
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
642 |
|
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
643 |
return helper.responses.respond(request, template, context) |
b82852e6963e
Various improvements to the generic View code
Sverre Rabbelier <srabbelier@gmail.com>
parents:
389
diff
changeset
|
644 |
|
652
02323664d532
Cleanups in preparation of general selector view
Sverre Rabbelier <srabbelier@gmail.com>
parents:
651
diff
changeset
|
645 |
def getParams(self): |
668
77f9a6ea6e67
Some style and typo fixes in different modules.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
663
diff
changeset
|
646 |
"""Returns this view's params attribute. |
652
02323664d532
Cleanups in preparation of general selector view
Sverre Rabbelier <srabbelier@gmail.com>
parents:
651
diff
changeset
|
647 |
""" |
02323664d532
Cleanups in preparation of general selector view
Sverre Rabbelier <srabbelier@gmail.com>
parents:
651
diff
changeset
|
648 |
|
02323664d532
Cleanups in preparation of general selector view
Sverre Rabbelier <srabbelier@gmail.com>
parents:
651
diff
changeset
|
649 |
return self._params |
02323664d532
Cleanups in preparation of general selector view
Sverre Rabbelier <srabbelier@gmail.com>
parents:
651
diff
changeset
|
650 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
651 |
@decorators.merge_params |
703
c4f3997becd9
Rename getSidebarLinks to getSidebarMenus
Sverre Rabbelier <srabbelier@gmail.com>
parents:
701
diff
changeset
|
652 |
def getSidebarMenus(self, request, params=None): |
499
d22e4fe8e64b
Fix missing dots in doc strings and some other doc string corrections.
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
497
diff
changeset
|
653 |
"""Returns an dictionary with one sidebar entry. |
493
6976c4d8d0ac
Refactor the sidebar to use Django templates
Sverre Rabbelier <srabbelier@gmail.com>
parents:
492
diff
changeset
|
654 |
|
6976c4d8d0ac
Refactor the sidebar to use Django templates
Sverre Rabbelier <srabbelier@gmail.com>
parents:
492
diff
changeset
|
655 |
Args: |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
656 |
request: the django request object |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
657 |
params: a dict with params for this View |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
658 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
659 |
Params usage: |
614
53a3e46fc512
Moved getSidebarLinks to sitemap.sidebar
Sverre Rabbelier <srabbelier@gmail.com>
parents:
613
diff
changeset
|
660 |
The params dictionary is passed as argument to getSidebarItems |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
661 |
from the soc.views.sitemap.sidebar module, see the docstring |
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
662 |
of _getSidebarItems on how it uses it. |
493
6976c4d8d0ac
Refactor the sidebar to use Django templates
Sverre Rabbelier <srabbelier@gmail.com>
parents:
492
diff
changeset
|
663 |
""" |
6976c4d8d0ac
Refactor the sidebar to use Django templates
Sverre Rabbelier <srabbelier@gmail.com>
parents:
492
diff
changeset
|
664 |
|
703
c4f3997becd9
Rename getSidebarLinks to getSidebarMenus
Sverre Rabbelier <srabbelier@gmail.com>
parents:
701
diff
changeset
|
665 |
return sitemap.sidebar.getSidebarMenus(request, params) |
494
5e9c656a1b68
Refactored SiteMap to be generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
493
diff
changeset
|
666 |
|
876
0c1329d4b514
Make use of the new decorators in all applicable views
Sverre Rabbelier <srabbelier@gmail.com>
parents:
874
diff
changeset
|
667 |
@decorators.merge_params |
494
5e9c656a1b68
Refactored SiteMap to be generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
493
diff
changeset
|
668 |
def getDjangoURLPatterns(self, params=None): |
614
53a3e46fc512
Moved getSidebarLinks to sitemap.sidebar
Sverre Rabbelier <srabbelier@gmail.com>
parents:
613
diff
changeset
|
669 |
"""Retrieves a list of sidebar entries for this view |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
670 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
671 |
Params usage: |
614
53a3e46fc512
Moved getSidebarLinks to sitemap.sidebar
Sverre Rabbelier <srabbelier@gmail.com>
parents:
613
diff
changeset
|
672 |
The params dictionary is passed to the getDjangoURLPatterns |
639
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
673 |
function in the soc.views.sitemap.sitemap module, see the |
1f92bd41b914
Some docstring fixes in few modules (soc.views.helper soc.views.models.base).
Pawel Solyga <Pawel.Solyga@gmail.com>
parents:
632
diff
changeset
|
674 |
docstring of getDjangoURLPatterns on how it uses it. |
610
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
675 |
|
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
676 |
Args: |
e0bd276ffd82
Documented params usage in soc/views/models/base.py
Sverre Rabbelier <srabbelier@gmail.com>
parents:
606
diff
changeset
|
677 |
params: a dict with params for this View |
494
5e9c656a1b68
Refactored SiteMap to be generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
493
diff
changeset
|
678 |
""" |
5e9c656a1b68
Refactored SiteMap to be generic
Sverre Rabbelier <srabbelier@gmail.com>
parents:
493
diff
changeset
|
679 |
|
613
4880ffa9f3ba
Moved getDjangoURLPatterns to sitemap.sitemap
Sverre Rabbelier <srabbelier@gmail.com>
parents:
612
diff
changeset
|
680 |
return sitemap.sitemap.getDjangoURLPatterns(params) |
858
e79e7a22326f
Add an export() view, and implement it as text/text for Document.
Todd Larsen <tlarsen@google.com>
parents:
755
diff
changeset
|
681 |