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:
parent
78cd39eb12
commit
53acc23802
4 changed files with 45 additions and 15 deletions
|
@ -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)
|
||||
|
|
|
@ -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>
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue