X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/3ffce80e2f1c58f741cd6a3d31aa86199e8874f1..515398ba21b6ac3c0db230a465cfc8528db8d10e:/librarian/pyhtml.py diff --git a/librarian/pyhtml.py b/librarian/pyhtml.py index 302d790..1f1f3df 100644 --- a/librarian/pyhtml.py +++ b/librarian/pyhtml.py @@ -9,16 +9,39 @@ from xmlutils import Xmill, tag, tagged, ifoption, tag_open_close from librarian import functions import re import random +from copy import deepcopy +IMAGE_THUMB_WIDTH = 300 -DEFAULT_MATERIAL_FORMAT = 'odt' - +try: + from fnpdjango.utils.text.slughifi import slughifi + def naglowek_to_anchor(naglowek): + return slughifi(naglowek.text) +except ImportError: + from urllib import quote + def naglowek_to_anchor(naglowek): + return quote(re.sub(r" +", " ", naglowek.text.strip())) + + class EduModule(Xmill): def __init__(self, options=None): super(EduModule, self).__init__(options) self.activity_counter = 0 + self.exercise_counter = 0 + + # text filters + def swap_endlines(txt): + if self.options['strofa']: + txt = txt.replace("/\n", "
\n") + return txt self.register_text_filter(functions.substitute_entities) + self.register_text_filter(swap_endlines) + + @tagged('div', 'stanza') + def handle_strofa(self, element): + self.options = {'strofa': True} + return "", "" def handle_powiesc(self, element): return u""" @@ -37,7 +60,7 @@ class EduModule(Xmill): handle_naglowek_scena = tag('h2') handle_naglowek_osoba = handle_naglowek_podrozdzial = tag('h3') handle_akap = handle_akap_dialog = handle_akap_cd = tag('p', 'paragraph') - handle_strofa = tag('div', 'stanza') + handle_wyroznienie = tag('em') handle_tytul_dziela = tag('em', 'title') handle_slowo_obce = tag('em', 'foreign') @@ -46,16 +69,18 @@ class EduModule(Xmill): toc = [] for naglowek in element.getparent().findall('.//naglowek_rozdzial'): a = etree.Element("a") - a.attrib["href"] = "#" + naglowek.text + a.attrib["href"] = "#" + naglowek_to_anchor(naglowek) a.text = naglowek.text atxt = etree.tostring(a, encoding=unicode) toc.append("
  • %s
  • " % atxt) toc = "" % "".join(toc) - return "

    Lekcja: ", "

    " + toc + add_header = "Lekcja: " if self.options['wldoc'].book_info.type in ('course', 'synthetic') else '' + return "

    %s" % add_header, "

    " + toc - @tagged("h2") def handle_naglowek_rozdzial(self, element): - return "", "".join(tag_open_close("a", name=element.text)) + return_to_top = u"wróć do spisu treści" + pre, post = tag_open_close("h2", id=naglowek_to_anchor(element)) + return return_to_top + pre, post def handle_uwaga(self, _e): return None @@ -89,8 +114,8 @@ class EduModule(Xmill):
    %(counter)d. - %(opis)s - %(wskazowki)s + %(opis)s""" % locals(), \ +u"""%(wskazowki)s