]> git.llucax.com Git - software/sercom.git/blobdiff - sercom/menu.py
otro fix mas
[software/sercom.git] / sercom / menu.py
index ef9f5909ed5eb315756c4f65e7be026eba0c4c82..da714d168c7a10c2ac8ee6e73b01c421f5f94346 100644 (file)
@@ -1,18 +1,23 @@
+# vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
 
 from turbogears import url
-from turbogears import controllers
+from turbogears.identity import SecureResource
+from turbogears import identity
 
 class Menu:
-    def __init__(self, controller):
-        # Armo la lista de subcontrollers
-        self.items = []
-        for i in controller.__dict__:
-            if isinstance(getattr(controller, i),controllers.Controller):
-                self.items.append(i)
+    def __init__(self, base):
+        self.base = base
+        self.items = [i for i in dir(base)
+            if isinstance(getattr(base, i), SecureResource)]
         self.items.sort()
+        self.items = ['dashboard'] + self.items
+
+    def _check(self, c):
+        return c.require.eval_with_object(identity.current)
 
     def __repr__(self):
-        t = """
+        option = u"""<option value="%s">%s</option>" """
+        template = """
         <div id="navbar">
                        Ir a :
                        <select OnChange="window.location=this.options[this.selectedIndex].value;">
@@ -20,8 +25,9 @@ class Menu:
                        </select>
                </div>
         """
-        s = ''
+        s = option % ('', '-----')
         for i in self.items:
-            s = s + u"""<option value="%s" %s>%s</option>" """ % (url('/' + i), i.capitalize().replace('_', ' '))
-        return t % s
+            if i == 'dashboard' or self._check(getattr(self.base, i)):
+                s += option % (url('/' + i), i.capitalize().replace('_', ' '))
+        return template % s