]> git.llucax.com Git - z.facultad/75.52/sercom.git/blobdiff - sercom/menu.py
Corregir bug: en realidad tiene más sentido fijarse la fecha de corrección para...
[z.facultad/75.52/sercom.git] / sercom / menu.py
index 965e91175b99a7280f3abc886032f3a3b8e054fe..a72d6a29bebf04bb98737bc6a19bc10682f75f0d 100644 (file)
@@ -1,12 +1,17 @@
 
 from turbogears import url
 from turbogears.controllers import Controller
 
 from turbogears import url
 from turbogears.controllers import Controller
+from turbogears import identity
 
 class Menu:
     def __init__(self, base):
 
 class Menu:
     def __init__(self, base):
-        # Armo la lista de subcontrollers
+        self.base = base
         self.items = filter(lambda i: isinstance(getattr(base, i), Controller), base.__dict__)
         self.items.sort()
         self.items = filter(lambda i: isinstance(getattr(base, i), Controller), base.__dict__)
         self.items.sort()
+        self.items = ['dashboard'] + self.items
+
+    def _check(self, c):
+        return c.require.eval_with_object(identity.current)
 
     def __repr__(self):
         option = u"""<option value="%s">%s</option>" """
 
     def __repr__(self):
         option = u"""<option value="%s">%s</option>" """
@@ -18,8 +23,9 @@ class Menu:
                        </select>
                </div>
         """
                        </select>
                </div>
         """
-        s = ''
+        s = option % ('', '-----')
         for i in self.items:
         for i in self.items:
-            s += option % (url('/' + i), i.capitalize().replace('_', ' '))
+            if i == 'dashboard' or self._check(getattr(self.base, i)):
+                s += option % (url('/' + i), i.capitalize().replace('_', ' '))
         return template % s
 
         return template % s