From 666d9c6b29b417a93e3bef50b3f7a4c0f10d1f0a Mon Sep 17 00:00:00 2001 From: richard Date: Sun, 14 Dec 2003 21:40:57 +0000 Subject: [PATCH] give access to the input() method all over the place git-svn-id: http://svn.roundup-tracker.org/svnroot/roundup/trunk@2023 57a73879-2fb5-44c3-a270-3262357dd7e2 --- roundup/cgi/templating.py | 64 ++++++++++++++++++--------------------- 1 file changed, 30 insertions(+), 34 deletions(-) diff --git a/roundup/cgi/templating.py b/roundup/cgi/templating.py index 6fa573e..cbc742b 100644 --- a/roundup/cgi/templating.py +++ b/roundup/cgi/templating.py @@ -24,14 +24,6 @@ from roundup.cgi.PageTemplates.Expressions import getEngine from roundup.cgi.TAL.TALInterpreter import TALInterpreter from roundup.cgi import ZTUtils -def input_html4(**attrs): - """Generate an 'input' (html4) element with given attributes""" - return ''%' '.join(['%s="%s"'%item for item in attrs.items()]) - -def input_xhtml(**attrs): - """Generate an 'input' (xhtml) element with given attributes""" - return ''%' '.join(['%s="%s"'%item for item in attrs.items()]) - class NoTemplate(Exception): pass @@ -289,7 +281,26 @@ class HTMLPermissions: ''' return self.is_view_ok() and not self.is_edit_ok() -class HTMLClass(HTMLPermissions): +def input_html4(**attrs): + """Generate an 'input' (html4) element with given attributes""" + return ''%' '.join(['%s="%s"'%item for item in attrs.items()]) + +def input_xhtml(**attrs): + """Generate an 'input' (xhtml) element with given attributes""" + return ''%' '.join(['%s="%s"'%item for item in attrs.items()]) + +class HTMLInputMixin: + ''' requires a _client property ''' + def __init__(self): + html_version = 'html4' + if hasattr(self._client.instance.config, 'HTML_VERSION'): + html_version = self._client.instance.config.HTML_VERSION + if html_version == 'xhtml': + self.input = input_xhtml + else: + self.input = input_html4 + +class HTMLClass(HTMLInputMixin, HTMLPermissions): ''' Accesses through a class (either through *class* or *db.*) ''' def __init__(self, client, classname, anonymous=0): @@ -303,13 +314,7 @@ class HTMLClass(HTMLPermissions): self._klass = self._db.getclass(self.classname) self._props = self._klass.getprops() - html_version = 'html4' - if hasattr(self._client.instance.config, 'HTML_VERSION'): - html_version = self._client.instance.config.HTML_VERSION - if html_version == 'xhtml': - self.input = input_xhtml - else: - self.input = input_html4 + HTMLInputMixin.__init__(self) def __repr__(self): return ''%(id(self), self.classname) @@ -514,7 +519,7 @@ class HTMLClass(HTMLPermissions): # use our fabricated request return pt.render(self._client, self.classname, req) -class HTMLItem(HTMLPermissions): +class HTMLItem(HTMLInputMixin, HTMLPermissions): ''' Accesses through an *item* ''' def __init__(self, client, classname, nodeid, anonymous=0): @@ -528,6 +533,8 @@ class HTMLItem(HTMLPermissions): # do we prefix the form items with the item's identification? self._anonymous = anonymous + HTMLInputMixin.__init__(self) + def __repr__(self): return ''%(id(self), self._classname, self._nodeid) @@ -836,7 +843,7 @@ class HTMLUser(HTMLItem): self._classname) or (self._nodeid == self._client.userid and self._db.user.get(self._client.userid, 'username') != 'anonymous') -class HTMLProperty: +class HTMLProperty(HTMLInputMixin): ''' String, Number, Date, Interval HTMLProperty Has useful attributes: @@ -861,13 +868,7 @@ class HTMLProperty: else: self._formname = name - html_version = 'html4' - if hasattr(self._client.instance.config, 'HTML_VERSION'): - html_version = self._client.instance.config.HTML_VERSION - if html_version == 'xhtml': - self.input = input_xhtml - else: - self.input = input_html4 + HTMLInputMixin.__init__(self) def __repr__(self): return ''%(id(self), self._formname, @@ -1441,7 +1442,7 @@ class ShowDict: def __getitem__(self, name): return self.columns.has_key(name) -class HTMLRequest: +class HTMLRequest(HTMLInputMixin): ''' The *request*, holding the CGI form and environment. "form" the CGI form as a cgi.FieldStorage @@ -1463,7 +1464,8 @@ class HTMLRequest: ''' def __init__(self, client): - self.client = client + # _client is needed by HTMLInputMixin + self._client = self.client = client # easier access vars self.form = client.form @@ -1478,13 +1480,7 @@ class HTMLRequest: # the special char to use for special vars self.special_char = '@' - html_version = 'html4' - if hasattr(self.client.instance.config, 'HTML_VERSION'): - html_version = self.client.instance.config.HTML_VERSION - if html_version == 'xhtml': - self.input = input_xhtml - else: - self.input = input_html4 + HTMLInputMixin.__init__(self) self._post_init() -- 2.30.2