Mercurial > libervia-backend
changeset 2330:74c1dbabeec8
jp (blog/edit): pretty format XHTML before editing it
author | Goffi <goffi@goffi.org> |
---|---|
date | Thu, 13 Jul 2017 21:54:15 +0200 (2017-07-13) |
parents | f15b428852a0 |
children | 01877048c94a |
files | frontends/src/jp/cmd_blog.py |
diffstat | 1 files changed, 19 insertions(+), 8 deletions(-) [+] |
line wrap: on
line diff
--- a/frontends/src/jp/cmd_blog.py Thu Jul 13 21:45:26 2017 +0200 +++ b/frontends/src/jp/cmd_blog.py Thu Jul 13 21:54:15 2017 +0200 @@ -38,15 +38,16 @@ __commands__ = ["Blog"] +SYNTAX_XHTML = u'xhtml' # extensions to use with known syntaxes SYNTAX_EXT = { '': 'txt', # used when the syntax is not found - "xhtml": "xhtml", + SYNTAX_XHTML: "xhtml", "markdown": "md" } -CONF_SYNTAX_EXT = 'syntax_ext_dict' +CONF_SYNTAX_EXT = u'syntax_ext_dict' BLOG_TMP_DIR = u"blog" # key to remove from metadata tmp file if they exist KEY_TO_REMOVE_METADATA = ('id','content', 'content_xhtml', 'comments_node', 'comments_service', 'updated') @@ -367,7 +368,7 @@ # default syntax has been used mb_data['content_rich'] = content else: - mb_data['content_xhtml'] = self.host.bridge.syntaxConvert(content, self.current_syntax, 'XHTML', False, self.profile) + mb_data['content_xhtml'] = self.host.bridge.syntaxConvert(content, self.current_syntax, SYNTAX_XHTML, False, self.profile) if self.pubsub_item is not None: mb_data['id'] = self.pubsub_item @@ -389,9 +390,19 @@ except KeyError: content = mb_data['content'] if content: - content = self.host.bridge.syntaxConvert(content, 'text', 'XHTML', False, self.profile) - if content and self.current_syntax != 'XHTML': - content = self.host.bridge.syntaxConvert(content, 'XHTML', self.current_syntax, False, self.profile) + content = self.host.bridge.syntaxConvert(content, 'text', SYNTAX_XHTML, False, self.profile) + if content and self.current_syntax != SYNTAX_XHTML: + content = self.host.bridge.syntaxConvert(content, SYNTAX_XHTML, self.current_syntax, False, self.profile) + if content and self.current_syntax == SYNTAX_XHTML: + try: + from lxml import etree + except ImportError: + self.disp(_(u"You need lxml to edit pretty XHTML")) + else: + parser = etree.XMLParser(remove_blank_text=True) + root = etree.fromstring(content, parser) + content = etree.tostring(root, encoding=unicode, pretty_print=True) + return content, mb_data, mb_data['id'] def start(self): @@ -445,10 +456,10 @@ def updateContent(self): with open(self.content_file_path, 'rb') as f: content = f.read().decode('utf-8-sig') - if content and self.syntax != 'XHTML': + if content and self.syntax != SYNTAX_XHTML: # we use safe=True because we want to have a preview as close as possible to what the # people will see - content = self.host.bridge.syntaxConvert(content, self.syntax, 'XHTML', True, self.profile) + content = self.host.bridge.syntaxConvert(content, self.syntax, SYNTAX_XHTML, True, self.profile) xhtml = (u'<html xmlns="http://www.w3.org/1999/xhtml">' + u'<head><meta http-equiv="Content-Type" content="text/html;charset=utf-8" /></head>'+