Shuffle the layout around a bit again.
[matthijs/projects/wipi.git] / plugin / theme / site.py
index 91c4c262a95dceb5abe19a7bdb8e00ba2ed2807d..37bff91f75dc2e4b3341aa25054417f6f7bf8ab1 100644 (file)
@@ -11,6 +11,7 @@
 
 from MoinMoin.theme import ThemeBase
 from MoinMoin.Page import Page
+from MoinMoin import wikiutil
 
 class SiteTheme(ThemeBase):
 
@@ -52,12 +53,10 @@ class SiteTheme(ThemeBase):
             #self.interwiki(d),
             #self.title(d),
             #u'</div>',
-            self.navibar(d),
+            #self.navibar(d),
             #u'<hr id="pageline">',
             #u'<div id="pageline"><hr style="display:none;"></div>',
-            self.msg(d),
-            self.editbar(d),
-            self.trail(d),
+            ##self.trail(d),
             u'</div>',
 
             # Post header custom html (not recommended)
@@ -65,6 +64,8 @@ class SiteTheme(ThemeBase):
 
             # Start of page
             self.startPage(),
+            self.editbar(d),
+            self.msg(d),
         ]
         return u'\n'.join(html)
 
@@ -81,8 +82,7 @@ class SiteTheme(ThemeBase):
 
             # Header
             u'<div id="header">',
-            self.title(d),
-            self.msg(d),
+            self.menu(d),
             u'</div>',
 
             # Post header custom html (not recommended)
@@ -90,6 +90,7 @@ class SiteTheme(ThemeBase):
 
             # Start of page
             self.startPage(),
+            self.msg(d),
         ]
         return u'\n'.join(html)
 
@@ -104,7 +105,6 @@ class SiteTheme(ThemeBase):
         page = d['page']
         html = [
             # End of page
-            self.pageinfo(page),
             self.endPage(),
 
             # Pre footer custom html (not recommended!)
@@ -113,6 +113,7 @@ class SiteTheme(ThemeBase):
             # Footer
             u'<div id="footer">',
             self.username(d),
+            self.pageinfo(page),
             self.searchform(d),
             #self.editbar(d),
             #self.credits(d),
@@ -125,7 +126,7 @@ class SiteTheme(ThemeBase):
         return u'\n'.join(html)
 
     def menu(self, d):
-        """ Assemble a "main menu
+        """ Assemble a "main" menu
             
             @param d: parameter dictionary
             @rtype:   unicode
@@ -144,6 +145,29 @@ class SiteTheme(ThemeBase):
 
         return html
 
+    def theme_script(self, name):
+        """ Format script html from this theme's static dir """
+        src = '%s/%s/js/%s.js' % (self.request.cfg.url_prefix_static, self.name, name)
+        return '<script type="text/javascript" src="%s"></script>' % src
+
+    def pageinfo(self, page):
+        """ Output page name and "last modified". This overwrites the pageinfo
+        from ThemeBase to hide the username, which is useless and always
+        produces a link to the non-existing homepage of the last editor. """
+        _ = self.request.getText
+        html = ''
+        if self.shouldShowPageinfo(page):
+            info = page.lastEditInfo()
+            if info:
+                info = _("last modified %(time)s") % info
+                pagename = page.page_name
+                info = "%s  (%s)" % (wikiutil.escape(pagename), info)
+                html = '<p id="pageinfo" class="info"%(lang)s>%(info)s</p>\n' % {
+                    'lang': self.ui_lang_attr(),
+                    'info': info
+                    }
+        return html
+
 def execute(request):
     """
     Generate and return a theme object
@@ -154,3 +178,4 @@ def execute(request):
     """
     return Theme(request)
 
+# vim: set sw=4 sts=4 expandtab: