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
txt = txt.replace("/\n", "<br/>\n")
return txt
self.register_text_filter(functions.substitute_entities)
- self.register_text_filter(swap_endlines)
+ self.register_escaped_text_filter(swap_endlines)
@tagged('div', 'stanza')
def handle_strofa(self, element):
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_wyroznienie = tag('em')
handle_tytul_dziela = tag('em', 'title')
handle_slowo_obce = tag('em', 'foreign')
+ def naglowek_to_anchor(self, naglowek):
+ return self.options['urlmapper'].naglowek_to_anchor(naglowek)
+
def handle_nazwa_utworu(self, element):
toc = []
for naglowek in element.getparent().findall('.//naglowek_rozdzial'):
a = etree.Element("a")
- a.attrib["href"] = "#" + naglowek_to_anchor(naglowek)
+ a.attrib["href"] = "#" + self.naglowek_to_anchor(naglowek)
a.text = naglowek.text
atxt = etree.tostring(a, encoding=unicode)
toc.append("<li>%s</li>" % atxt)
def handle_naglowek_rozdzial(self, element):
return_to_top = u"<a href='#top' class='top-link'>wróć do spisu treści</a>"
- pre, post = tag_open_close("h2", id=naglowek_to_anchor(element))
+ pre, post = tag_open_close("h2", id=self.naglowek_to_anchor(element))
+ url = self.options['urlmapper'].get_help_url(element)
+ if url:
+ post = " <a class='help' href='%s'>?</a>" % (url,) + post
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
else: pomoce = ''
forma = ''.join(element.xpath('forma/text()'))
+ get_forma_url = self.options['urlmapper'].get_forma_url
+ forms = []
+ for form_name in forma.split(','):
+ name = form_name.strip()
+ url = get_forma_url(name)
+ if url:
+ forms.append("<a href='%s'>%s</a>" % (url, name))
+ else:
+ forms.append(name)
+ forma = ', '.join(forms)
+ if forma:
+ forma = '<section class="infobox kind"><h1>Metoda</h1><p>%s</p></section>' % forma
czas = ''.join(element.xpath('czas/text()'))
+ if czas:
+ czas = '<section class="infobox time"><h1>Czas</h1><p>%s min</p></section>' % czas
counter = self.activity_counter
+ if element.getnext().tag == 'aktywnosc' or self.activity_last.getnext() == element:
+ counter_html = """<span class="act_counter">%(counter)d.</span>""" % locals()
+ else:
+ counter_html = ''
+
+ self.activity_last = element
+
return u"""
<div class="activity">
<div class="text">
- <span class="act_counter">%(counter)d.</span>
+ %(counter_html)s
%(opis)s""" % locals(), \
u"""%(wskazowki)s
</div>
<aside class="info">
- <section class="infobox time"><h1>Czas</h1><p>%(czas)s min</p></section>
- <section class="infobox kind"><h1>Metoda</h1><p>%(forma)s</p></section>
+ %(czas)s
+ %(forma)s
%(pomoce)s
</aside>
<div class="clearboth"></div>
if surl is None:
# print '** missing src on <slowniczek>, setting default'
surl = 'http://edukacjamedialna.edu.pl/lekcje/slowniczek/'
- sxml = None
- if surl:
- sxml = etree.fromstring(self.options['provider'].by_uri(surl).get_string())
+ sxml = etree.fromstring(self.options['provider'].by_uri(surl).get_string())
+
self.options = {'slowniczek': True, 'slowniczek_xml': sxml }
pre, post = '<div class="slowniczek">', '</div>'
- if self.options['wldoc'].book_info.url.slug != 'slowniczek':
+ if not self.options['wldoc'].book_info.url.slug.startswith('slowniczek'):
post += u'<p class="see-more"><a href="%s">Zobacz cały słowniczek.</a></p>' % surl
return pre, post
subgen = EduModule(self.options)
definiens_s = subgen.generate(definiens)
else:
- print '!! Missing definiendum in source:', element.text
+ print "!! Missing definiendum in source: '%s'" % element.text
- return u"<dt>", u"</dt>" + definiens_s
+ return u"<dt id='%s'>" % self.naglowek_to_anchor(element), u"</dt>" + definiens_s
def handle_definiens(self, element):
return u"<dd>", u"</dd>"
'data-target': lista.attrib['cel'],
'class': 'subject'
}
+ if lista.attrib.get('krotkie'):
+ self.options = {'short': True}
self.options = {'subject': True}
else:
attrs = {}
if self.options['handles']:
return '<li><span data-solution="%s" data-no="%s" class="question-piece draggable handle add-li">%s</span>' % (element.attrib.get('rozw', ''), self.piece_counter, self.piece_counter), '</li>'
else:
- return '<li data-solution="%s" data-no="%s" class="question-piece draggable">' % (element.attrib.get('rozw', ''), self.piece_counter), '</li>'
+ extra_class = ""
+ if self.options['short']:
+ extra_class += ' short'
+ return '<li data-solution="%s" data-no="%s" class="question-piece draggable%s">' % (element.attrib.get('rozw', ''), self.piece_counter, extra_class), '</li>'
elif self.options['predicate']:
if self.options['min']:
def url_for_image(self, slug, fmt, width=None):
return self.url_for_material(self, slug, fmt)
+ def text_to_anchor(self, text):
+ return re.sub(r" +", " ", text)
+
+ def naglowek_to_anchor(self, naglowek):
+ return self.text_to_anchor(naglowek.text.strip())
+
+ def get_forma_url(self, forma):
+ return None
+
+ def get_help_url(self, naglowek):
+ return None
+
-def transform(wldoc, stylesheet='edumed', options=None, flags=None):
+def transform(wldoc, stylesheet='edumed', options=None, flags=None, verbose=None):
"""Transforms the WL document to XHTML.
If output_filename is None, returns an XML,