separated ZPT-based template implementation
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@1521 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
parent
335c15f17a
commit
5f9675c871
6 changed files with 45 additions and 14 deletions
|
@ -23,5 +23,5 @@ the standard Zope 3 TestRequest.
|
|||
>>> from cybertools.web.view import View
|
||||
>>> view = View(None, TestRequest())
|
||||
>>> view.render()
|
||||
u'<html...<body>...</body>...</html>...'
|
||||
u'<html...>...<body...>...</body>...</html>...'
|
||||
|
||||
|
|
|
@ -17,23 +17,19 @@
|
|||
#
|
||||
|
||||
"""
|
||||
Generic template base class (if fact it is the ZPT-based type...).
|
||||
Generic template base class.
|
||||
|
||||
$Id$
|
||||
"""
|
||||
|
||||
from zope.app.pagetemplate import ViewPageTemplateFile
|
||||
|
||||
|
||||
class Template(object):
|
||||
|
||||
zpt = ViewPageTemplateFile('content.pt')
|
||||
|
||||
def __init__(self, view):
|
||||
self.view = view
|
||||
self.context = view.context
|
||||
self.request = view.request
|
||||
|
||||
def render(self, *args, **kw):
|
||||
return self.zpt(*args, **kw)
|
||||
return u''
|
||||
|
||||
|
|
11
web/view.py
11
web/view.py
|
@ -22,24 +22,21 @@ Generic view base class.
|
|||
$Id$
|
||||
"""
|
||||
|
||||
from cybertools.web.template import Template
|
||||
from zope.cachedescriptors.property import Lazy
|
||||
from cybertools.web.zpt.template import Template
|
||||
|
||||
|
||||
class View(object):
|
||||
|
||||
templateFactory = Template
|
||||
|
||||
_template = None
|
||||
|
||||
def __init__(self, context, request):
|
||||
self.context = context
|
||||
self.request = request
|
||||
|
||||
@property
|
||||
@Lazy
|
||||
def template(self):
|
||||
if self._template is None and self.templateFactory:
|
||||
self._template = self.templateFactory(self)
|
||||
return self._template
|
||||
return self.templateFactory(self)
|
||||
|
||||
def render(self, *args, **kw):
|
||||
return self.template.render(*args, **kw)
|
||||
|
|
3
web/zpt/__init__.py
Normal file
3
web/zpt/__init__.py
Normal file
|
@ -0,0 +1,3 @@
|
|||
"""
|
||||
$Id$
|
||||
"""
|
35
web/zpt/template.py
Normal file
35
web/zpt/template.py
Normal file
|
@ -0,0 +1,35 @@
|
|||
#
|
||||
# Copyright (c) 2006 Helmut Merz helmutm@cy55.de
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
#
|
||||
|
||||
"""
|
||||
ZPT-based template base class.
|
||||
|
||||
$Id$
|
||||
"""
|
||||
|
||||
from zope.app.pagetemplate import ViewPageTemplateFile
|
||||
from cybertools.web import template
|
||||
|
||||
|
||||
class Template(template.Template):
|
||||
|
||||
zpt = ViewPageTemplateFile('content.pt')
|
||||
|
||||
def render(self, *args, **kw):
|
||||
return self.zpt(*args, **kw)
|
||||
|
Loading…
Add table
Reference in a new issue