############################################################################## # # Copyright (c) 2005 Zope Corporation and Contributors. # All Rights Reserved. # # This software is subject to the provisions of the Zope Public License, # Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution. # THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED # WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS # FOR A PARTICULAR PURPOSE. # ############################################################################## """Five-compatible version of ObjectWidget This is needed because ObjectWidget uses ViewPageTemplateFile whose macro definition is unfortunately incompatible with ZopeTwoPageTemplateFile. So this subclass uses ZopeTwoPageTemplateFile for the template that renders the widget's sub-editform. Acquisition has to be mixed in to provide the ZopeTwoPageTemplateFile with the proper acquisition context. $Id: objectwidget.py 71269 2006-11-22 13:37:06Z yuppie $ """ import Acquisition import zope.app.form.browser.objectwidget from AccessControl import ClassSecurityInfo from Globals import InitializeClass as initializeClass from Products.Five.browser.pagetemplatefile import ZopeTwoPageTemplateFile class ObjectWidgetView(Acquisition.Explicit, zope.app.form.browser.objectwidget.ObjectWidgetView): security = ClassSecurityInfo() security.declareObjectPublic() template = ZopeTwoPageTemplateFile('objectwidget.pt') initializeClass(ObjectWidgetView) class ObjectWidgetClass(Acquisition.Explicit, zope.app.form.browser.objectwidget.ObjectWidget): def __init__(self, context, request, factory, **kw): super(ObjectWidgetClass, self).__init__(context, request, factory, **kw) self.view = ObjectWidgetView(self, request) def setRenderedValue(self, value): """Slightly more robust re-implementation this method.""" # re-call setupwidgets with the content self._setUpEditWidgets() for name in self.names: val = getattr(value, name, None) if val is None: # this is where we are more robust than Zope 3.2's # object widget: we supply subwidgets with the default # from the schema, not None (Zope 3.2's list widget # breaks when the rendered value is None) val = self.context.schema[name].default self.getSubWidget(name).setRenderedValue(val) def ObjectWidget(context, request, factory, **kw): """Return an ObjectWidget suitable in the Five environment, with right acquisition context""" return ObjectWidgetClass(context, request, factory, **kw ).__of__(context.context)