Add vim modeline.
[matthijs/projects/wipi.git] / plugin / theme / site.py
index e9344851be65d92f702aa69a199296f8e569cbaf..d250781ac45348c30e910ffed30f7a37909088b7 100644 (file)
@@ -10,6 +10,7 @@
 """
 
 from MoinMoin.theme import ThemeBase
+from MoinMoin.Page import Page
 
 class SiteTheme(ThemeBase):
 
@@ -24,6 +25,12 @@ class SiteTheme(ThemeBase):
             return ThemeBase.searchform(self, d)
         else:
             return ''
+    
+    def navibar(self, d):
+        if self.request.user.valid:
+            return ThemeBase.navibar(self, d)
+        else:
+            return ''
 
     def header(self, d, **kw):
         """ Assemble wiki header
@@ -38,19 +45,17 @@ class SiteTheme(ThemeBase):
 
             # Header
             u'<div id="header">',
+            self.menu(d),
             #self.logo(),
-            self.searchform(d),
             #self.username(d),
-            u'<div id="locationline">',
+            #u'<div id="locationline">',
             #self.interwiki(d),
-            self.title(d),
-            u'</div>',
-            self.trail(d),
+            #self.title(d),
+            #u'</div>',
             #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),
             u'</div>',
 
             # Post header custom html (not recommended)
@@ -58,6 +63,7 @@ class SiteTheme(ThemeBase):
 
             # Start of page
             self.startPage(),
+            self.msg(d),
         ]
         return u'\n'.join(html)
 
@@ -74,8 +80,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)
@@ -83,6 +88,7 @@ class SiteTheme(ThemeBase):
 
             # Start of page
             self.startPage(),
+            self.msg(d),
         ]
         return u'\n'.join(html)
 
@@ -105,7 +111,9 @@ class SiteTheme(ThemeBase):
 
             # Footer
             u'<div id="footer">',
+            self.searchform(d),
             self.username(d),
+            self.editbar(d),
             #self.editbar(d),
             #self.credits(d),
             #self.showversion(d, **keywords),
@@ -116,6 +124,30 @@ class SiteTheme(ThemeBase):
             ]
         return u'\n'.join(html)
 
+    def menu(self, d):
+        """ Assemble a "main" menu
+            
+            @param d: parameter dictionary
+            @rtype:   unicode
+            @return: menu html
+        """
+        items = Page(self.request, 'Site/Menu').data.split('\n')
+        
+        html = '<ul id="menubar">'
+
+        for item in items:
+            if (not item.startswith("#")):
+                (pagename, link) = self.splitNavilink(item)
+                html = html + ("<li class=\"menulink\">%s</li>" % link)
+        
+        html = html + '</ul>'
+
+        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 execute(request):
     """
@@ -127,3 +159,4 @@ def execute(request):
     """
     return Theme(request)
 
+# vim: set sw=4 sts=4 expandtab: