author | Sverre Rabbelier <srabbelier@gmail.com> |
Tue, 02 Dec 2008 22:04:38 +0000 | |
changeset 653 | 5105939d3bb4 |
parent 642 | 671dc971c3d1 |
child 656 | a76f1b443ea4 |
permissions | -rw-r--r-- |
#!/usr/bin/python2.5 # # Copyright 2008 the Melange authors. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. """Views for Host profiles. """ __authors__ = [ '"Sverre Rabbelier" <sverre@rabbelier.nl>', ] from soc.logic import dicts from soc.logic.models import user as user_logic from soc.logic.models import sponsor as sponsor_logic from soc.views import helper from soc.views.models import role from soc.views.helper import access import soc.models.host import soc.logic.models.host import soc.views.helper import soc.views.models.sponsor class CreateForm(helper.forms.BaseForm): """Django form displayed when creating a Host. """ class Meta: """Inner Meta class that defines some behavior for the form. """ #: db.Model subclass for which the form will gather information model = soc.models.host.Host #: list of model fields which will *not* be gathered by the form exclude = ['scope', 'user'] def clean_empty(self, field): data = self.cleaned_data.get(field) if not data or data == u'': return None return data def clean_home_page(self): return self.clean_empty('home_page') def clean_blog(self): return self.clean_empty('blog') def clean_photo_url(self): return self.clean_empty('photo_url') class EditForm(CreateForm): """Django form displayed when editing a Host. """ pass class View(role.RoleView): """View methods for the Host model. """ def __init__(self, original_params=None): """Defines the fields and methods required for the base View class to provide the user with list, public, create, edit and delete views. Params: original_params: a dict with params for this View """ rights = {} rights['edit'] = [access.checkIsInvited] params = {} params['rights'] = rights params['logic'] = soc.logic.models.host.logic params['logic'] = soc.logic.models.host.logic params['group_view'] = soc.views.models.sponsor.view params['invite_filter'] = {'group_ln': 'link_id'} params['name'] = "Host" params['name_short'] = "Host" params['name_plural'] = "Hosts" params['url_name'] = "host" params['module_name'] = "host" params['edit_form'] = EditForm params['create_form'] = CreateForm params = dicts.merge(original_params, params) role.RoleView.__init__(self, params=params) def _editPost(self, request, entity, fields): """See base.View._editPost(). """ user = user_logic.logic.getForFields( {'link_id': fields['link_id']}, unique=True) fields['user'] = user sponsor = sponsor_logic.logic.getForFields( {'link_id': fields['scope_path']}, unique=True) fields['scope'] = sponsor view = View() create = view.create delete = view.delete edit = view.edit list = view.list public = view.public invite = view.invite