X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/b25d910280f7c8573560bbe9ca2718332c438ec3..b90a579e68c18d9fea2170fe38b61d44b8e1d4c3:/librarian/pyhtml.py diff --git a/librarian/pyhtml.py b/librarian/pyhtml.py index 424e10c..900d068 100644 --- a/librarian/pyhtml.py +++ b/librarian/pyhtml.py @@ -9,13 +9,40 @@ 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 + +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.activity_last = None + 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_escaped_text_filter(swap_endlines) + + @tagged('div', 'stanza') + def handle_strofa(self, element): + self.options = {'strofa': True} + return "", "" def handle_powiesc(self, element): return u""" @@ -32,9 +59,9 @@ class EduModule(Xmill): handle_podtytul = tag("span", "subtitle") handle_naglowek_akt = handle_naglowek_czesc = handle_srodtytul = tag("h2") handle_naglowek_scena = tag('h2') - handle_naglowek_osoba = handle_naglowek_podrozdzial = tag('h3') + handle_naglowek_osoba = 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') @@ -43,16 +70,22 @@ 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_naglowek_podrozdzial(self, element): + self.activity_counter = 0 + return tag('h3')(self, element) def handle_uwaga(self, _e): return None @@ -65,7 +98,10 @@ class EduModule(Xmill): } submill = EduModule(dict(self.options.items() + {'sub_gen': True}.items())) - opis = submill.generate(element.xpath('opis')[0]) + if element.xpath('opis'): + opis = submill.generate(element.xpath('opis')[0]) + else: + opis = '' n = element.xpath('wskazowki') if n: wskazowki = submill.generate(n[0]) @@ -82,12 +118,19 @@ class EduModule(Xmill): counter = self.activity_counter + if element.getnext().tag == 'aktywnosc' or self.activity_last.getnext() == element: + counter_html = """%(counter)d.""" % locals() + else: + counter_html = '' + + self.activity_last = element + return u"""
    - %(counter)d. - %(opis)s - %(wskazowki)s + %(counter_html)s + %(opis)s""" % locals(), \ +u"""%(wskazowki)s