## $Id: htmlwidget.py 11949 2014-11-13 14:40:27Z henrik $
##
## Copyright (C) 2012 Uli Fouquet & Henrik Bettermann
## 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
##
"""A widget that renders localized html.
"""
from zope.component import getUtility
from zope.formlib.widget import renderElement, DisplayWidget
from waeup.ikoba.interfaces import IIkobaUtils
class HTMLDisplayWidget(DisplayWidget):
"""Restructured Text widget.
"""
def __call__(self):
"""The HTMLDisplayWidget transforms an localizez HTML text string into
a dictionary.
Different languages must be separated by `>>xy<<` whereas
xy is the language code. Text parts without correct leading
language separator - usually the first part has no language
descriptor - are interpreted as texts in the portal's language.
The latter can be configured in waeup.srp.utils.utils.IkobaUtils.
"""
if self._renderedValueSet():
value = self._data
else:
value = self.context.default
if value == self.context.missing_value:
return {}
parts = value.split('>>')
elements = {}
lang = getUtility(IIkobaUtils).PORTAL_LANGUAGE
for part in parts:
if part[2:4] == u'<<':
lang = part[0:2].lower()
text = part[4:]
elements[lang] = renderElement(u'div id="html"',
contents=text)
else:
text = part
elements[lang] = renderElement(u'div id="html"',
contents=text)
return elements