work in progress: composer.schema, organize.service for tumsm

git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@1853 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
helmutm 2007-08-01 07:47:47 +00:00
parent 78cd39eb12
commit 53acc23802
4 changed files with 45 additions and 15 deletions

View file

@ -24,7 +24,6 @@ $Id$
from zope import component
from zope.cachedescriptors.property import Lazy
from zope.traversing.browser import absoluteURL
from cybertools.composer.interfaces import IInstance
from cybertools.composer.schema.interfaces import IClientFactory
@ -32,10 +31,11 @@ from cybertools.composer.schema.interfaces import IClientFactory
class SchemaView(object):
clientName = None
def __init__(self, context, request):
self.context = context
self.request = request
self.clientName = None
@Lazy
def fields(self):
@ -43,12 +43,17 @@ class SchemaView(object):
@Lazy
def data(self):
form = self.request.form
clientName = self.clientName = form.get('id')
return self.getData()
def getData(self):
if not self.clientName:
form = self.request.form
self.clientName = form.get('id')
clientName = self.clientName
if not clientName:
return {}
manager = self.context.manager
client = manager.clients.get(clientName)
manager = self.context.getManager()
client = manager.getClients().get(clientName)
if client is None:
return {}
instance = IInstance(client)
@ -57,14 +62,15 @@ class SchemaView(object):
def update(self):
form = self.request.form
if not self.clientName:
self.clientName = form.get('id')
clientName = self.clientName
if not form.get('action'):
return True
manager = self.context.manager
clientName = form.get('id')
manager = self.context.getManager()
if clientName:
client = manager.clients.get(clientName)
client = manager.getClients().get(clientName)
if client is None:
# TODO: provide error message (?)
return True
else:
client = IClientFactory(manager)()
@ -72,10 +78,12 @@ class SchemaView(object):
instance = component.getAdapter(client, IInstance, name='editor')
instance.template = self.context
instance.applyTemplate(form)
self.request.response.redirect(self.nextUrl)
return False
return True
#self.request.response.redirect(self.nextUrl)
#return False
@Lazy
def nextUrl(self):
from zope.traversing.browser import absoluteURL
url = absoluteURL(self.context, self.request)
return '%s/thank_you?id=%s' % (url, self.clientName)
return '%s/thankyou.html?id=%s' % (url, self.clientName)

View file

@ -16,4 +16,11 @@
name="index.html"
for="cybertools.composer.schema.interfaces.ISchema" />
<page
for="cybertools.composer.schema.interfaces.ISchema"
name="thankyou.html"
class="cybertools.composer.schema.browser.base.SchemaView"
permission="zope.View"
/>
</configure>

View file

@ -37,8 +37,12 @@ class Schema(Template):
manager = None
def __init__(self, *fields, **kw):
self.name = kw.get('name', u'')
self.manager = self.__parent__ = kw.get('manager', None)
name = kw.get('name', None)
if name is not None:
self.name = name
manager = kw.get('manager', None)
if manager is not None:
self.manager = self.__parent__ = manager
super(Schema, self).__init__()
for f in fields:
self.components.append(f)
@ -50,3 +54,6 @@ class Schema(Template):
@property
def __name__(self):
return self.name
def getManager(self):
return self.manager

View file

@ -54,6 +54,9 @@ class ServiceManager(object):
def clients(self):
return self.clientsFactory()
def getClients(self):
return self.clients
def addClient(self, client):
name = self.generateClientName(client)
self.clients[name] = client
@ -97,3 +100,8 @@ class Registration(object):
def __init__(self, client):
self.client = client
class RegistrationTemplate(object):
pass