curriculum in pdf footer
[librarian.git] / librarian / pypdf.py
index aa4dc1d..5ba5131 100644 (file)
@@ -83,7 +83,7 @@ class EduModule(Xmill):
     def get_dc(self, element, dc_field, single=False):
         values = map(lambda t: t.text, element.xpath("//dc:%s" % dc_field, namespaces={'dc': DCNS.uri}))
         if single:
-            return values[0]
+            return values[0] if len(values) else ''
         return values
 
     def handle_rdf__RDF(self, _):
@@ -93,7 +93,7 @@ class EduModule(Xmill):
     @escape(True)
     def get_rightsinfo(self, element):
         rights_lic = self.get_dc(element, 'rights.license', True)
-        return u'<cmd name="rightsinfostr">' + (rights_lic and u'<opt>%s</opt>' % rights_lic or '') + \
+        return u'<cmd name="rightsinfostr">' + (u'<opt>%s</opt>' % rights_lic if rights_lic else '') + \
             u'<parm>%s</parm>' % self.get_dc(element, 'rights', True) + \
             u'</cmd>'
 
@@ -114,7 +114,34 @@ class EduModule(Xmill):
 
     @escape(True)
     def get_description(self, element):
-        return self.get_dc(element, 'description', single=True)
+        desc = self.get_dc(element, 'description', single=True)
+        if not desc:
+            print '!! no description'
+        return desc
+
+    @escape(True)
+    def get_curriculum(self, element):
+        identifiers = self.get_dc(element, 'subject.curriculum')
+        if not identifiers:
+            return ''
+        try:
+            from curriculum.templatetags.curriculum_tags import curriculum
+            curr_elements = curriculum(identifiers)
+        except ImportError:
+            curr_elements = {'identifiers': identifiers}
+        items = ['Podstawa programowa:']
+        newline = '<ctrl ch="\\"/>\n'
+        if 'currset' in curr_elements:
+            for (course, level), types in curr_elements['currset'].iteritems():
+                lines = [u'%s, %s poziom edukacyjny' % (course, level)]
+                for type, currs in types.iteritems():
+                    lines.append(type)
+                    lines += [curr.title for curr in currs]
+                items.append(newline.join(lines))
+        else:
+            items += identifiers
+        return '\n<cmd name="vspace"><parm>.6em</parm></cmd>\n'.join(
+            '<cmd name="akap"><parm>%s</parm></cmd>' % item for item in items)
 
     def handle_utwor(self, element):
         lines = [
@@ -140,6 +167,7 @@ class EduModule(Xmill):
             u'''\\title{%s}''' % self.get_title(element),
             u'''\\def\\bookurl{%s}''' % self.options['wldoc'].book_info.url.canonical(),
             u'''\\def\\rightsinfo{%s}''' % self.get_rightsinfo(element),
+            u'''\\def\\curriculum{%s}''' % self.get_curriculum(element),
             u'</TeXML>'
         ]