[Zope-Checkins] CVS: Zope/lib/python/ZClasses - ZClass.py:1.60.34.1
Casey Duncan
casey@zope.com
Thu, 28 Mar 2002 12:22:20 -0500
Update of /cvs-repository/Zope/lib/python/ZClasses
In directory cvs.zope.org:/tmp/cvs-serv4715
Modified Files:
Tag: casey-spruce-up-zclass-constructor-branch
ZClass.py
Log Message:
ZClasses now create a python script as their constructor instead of a dtml
method.
=== Zope/lib/python/ZClasses/ZClass.py 1.60 => 1.60.34.1 ===
from App.FactoryDispatcher import FactoryDispatcher
from ComputedAttribute import ComputedAttribute
+from Products.PythonScripts.PythonScript import PythonScript
import webdav.Collection
import marshal
@@ -153,11 +154,9 @@
id+' constructor input form',
addFormDefault % {'id': id, 'meta_type': meta_type},
)
- self.manage_addDTMLMethod(
- id+'_add',
- id+' constructor',
- addDefault % {'id': id},
- )
+ constScript = PythonScript(id+'_add')
+ constScript.write(addDefault % {'id': id, 'title':id+' constructor'})
+ self._setObject(constScript.getId(), constScript)
self.manage_addPermission(
id+'_add_permission',
id+' constructor permission',
@@ -705,51 +704,31 @@
</body></html>
"""
-addDefault="""<HTML>
-<HEAD><TITLE>Add %(id)s</TITLE></HEAD>
-<BODY BGCOLOR="#FFFFFF" LINK="#000099" VLINK="#555555">
-
-<dtml-comment> We add the new object by calling the class in
- a with tag. Not only does this get the thing
- added, it adds the new thing's attributes to
- the DTML name space, so we can call methods
- to initialize the object.
-</dtml-comment>
-
-<dtml-with "%(id)s.createInObjectManager(REQUEST['id'], REQUEST)">
-
- <dtml-comment>
-
- You can add code that modifies the new instance here.
-
- For example, if you have a property sheet that you want to update
- from form values, you can call it here:
-
- <dtml-call "propertysheets.Basic.manage_editProperties(
- REQUEST)">
-
- </dtml-comment>
-
-</dtml-with>
-
-<dtml-comment> Now we need to return something. We do this via
- a redirect so that the URL is correct.
-
- Unfortunately, the way we do this depends on
- whether we live in a product or in a class.
- If we live in a product, we need to use DestinationURL
- to decide where to go. If we live in a class,
- DestinationURL won't be available, so we use URL2.
-</dtml-comment>
-<dtml-if DestinationURL>
-
- <dtml-call "RESPONSE.redirect(
- DestinationURL+'/manage_workspace')">
-
-<dtml-else>
-
- <dtml-call "RESPONSE.redirect(
- URL2+'/manage_workspace')">
-</dtml-if>
-</body></html>
+addDefault="""## Script (Python) "%(id)s_add"
+##bind container=container
+##bind context=context
+##bind namespace=
+##bind script=script
+##bind subpath=traverse_subpath
+##parameters=redirect=1
+##title=%(title)s
+##
+# Add a new instance of the ZClass
+request = context.REQUEST
+instance = container.%(id)s.createInObjectManager(request['id'], request)
+
+# *****************************************************************
+# Perform any initialization of the new instance here.
+# For example, to update a property sheet named "Basic" from the
+# form values, uncomment the following line of code:
+# instance.propertysheets.Basic.manage_editProperties(request)
+# *****************************************************************
+
+if redirect:
+ # redirect to the management view of the instance's container
+ request.RESPONSE.redirect(instance.aq_parent.absolute_url() + '/manage_main')
+else:
+ # If we aren't supposed to redirect (ie, we are called from a script)
+ # then just return the ZClass instance to the caller
+ return instance
"""