A first stab at the ‘validatebutton’ plugin
[myslice.git] / ui / topmenu.py
index 6fbede5..d023878 100644 (file)
@@ -7,11 +7,14 @@ from manifold.core.query        import Query
 # dropdowns are kind of ad hoc for now, and limited to one level
 # [ 
 # ### a regular first-level button
-# {'label':...,'href':...}, 
+# {'label':...,'href':..., ['domid':.., 'disabled':...]}, 
 # ### a dropdown
 # { 'label': ..., 'href'=..., 'dropdown':True, 'contents': [ { 'label':.., 'href'} ] }
 # , ..]
 
+# see also templates/widget-topmenu.html for how these items are put together
+# and plugins/validatebutton for how this hident button is turned on when necessary
+
 # current: the beginning of the label in the menu that you want to outline
 def topmenu_items (current,request=None):
     has_user=request.user.is_authenticated()
@@ -20,41 +23,44 @@ def topmenu_items (current,request=None):
     if has_user:
         result.append({'label':'Dashboard', 'href': '/portal/dashboard/'})
         result.append({'label':'Request a slice', 'href': '/portal/slice_request/'})
-        # ** Where am I a PI **
-        # For this we need to ask SFA (of all authorities) = PI function
-        user_query  = Query().get('local:user').select('config','email')
-        user_details = execute_query(request, user_query)
-
-        # Required: the user must have an authority in its user.config
-        # XXX Temporary solution
-        # not always found in user_details...
-        config={}
-# Deactivated until fixed 
-#        if user_details is not None:
-#            for user_detail in user_details:
-#                #email = user_detail['email']
-#                if user_detail['config']:
-#                    config = json.loads(user_detail['config'])
-#            user_detail['authority'] = config.get('authority',"Unknown Authority")
-#            print "topmenu: %s", (user_detail['authority'])
-#            if user_detail['authority'] is not None:
-#                sub_authority = user_detail['authority'].split('.')
-#                root_authority = sub_authority[0]
-#                pi_authorities_query = Query.get(root_authority+':user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities')
-#        else:
-#            pi_authorities_query = Query.get('user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities')
-#        try:
-#            pi_authorities_tmp = execute_query(request, pi_authorities_query)
-#        except:
-#            pi_authorities_tmp = set()
-#        pi_authorities = set()
-#        for pa in pi_authorities_tmp:
-#            if 'pi_authorities' in pa:
-#                pi_authorities |= set(pa['pi_authorities'])
-#        print "pi_authorities =", pi_authorities
-#        if len(pi_authorities) > 0:
-#            result.append({'label':'Validation', 'href': '/portal/validate/'})
-        result.append({'label':'Validation', 'href': '/portal/validate/'})
+###        # ** Where am I a PI **
+###        # For this we need to ask SFA (of all authorities) = PI function
+###        user_query  = Query().get('local:user').select('config','email')
+###        user_details = execute_query(request, user_query)
+###
+###        # Required: the user must have an authority in its user.config
+###        # XXX Temporary solution
+###        # not always found in user_details...
+###        config={}
+#### Deactivated until fixed 
+####        if user_details is not None:
+####            for user_detail in user_details:
+####                #email = user_detail['email']
+####                if user_detail['config']:
+####                    config = json.loads(user_detail['config'])
+####            user_detail['authority'] = config.get('authority',"Unknown Authority")
+####            print "topmenu: %s", (user_detail['authority'])
+####            if user_detail['authority'] is not None:
+####                sub_authority = user_detail['authority'].split('.')
+####                root_authority = sub_authority[0]
+####                pi_authorities_query = Query.get(root_authority+':user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities')
+####        else:
+####            pi_authorities_query = Query.get('user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities')
+####        try:
+####            pi_authorities_tmp = execute_query(request, pi_authorities_query)
+####        except:
+####            pi_authorities_tmp = set()
+####        pi_authorities = set()
+####        for pa in pi_authorities_tmp:
+####            if 'pi_authorities' in pa:
+####                pi_authorities |= set(pa['pi_authorities'])
+####        print "pi_authorities =", pi_authorities
+####        if len(pi_authorities) > 0:
+####            result.append({'label':'Validation', 'href': '/portal/validate/'})
+###        result.append({'label':'Validation', 'href': '/portal/validate/'})
+        # always create a disabled button for validation, and let the 
+        # validatebutton plugin handle that asynchroneously, based on this domid
+        result.append({'label':'Validation', 'href': '/portal/validate/', 'domid':'topmenu-validation', 'disabled':True})
         dropdown = []
         dropdown.append({'label':'Platforms', 'href': '/portal/platforms/'})
         dropdown.append({'label':'My Account', 'href': '/portal/account/'})