X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ui%2Ftopmenu.py;h=860e180b70956d76fb36f19a3c21bf4c1a0cf3ec;hb=1e05d200f9cdd0c8965f66be87962bf19c9c69e0;hp=bdee674d5fa9547bbbad711d09112cc842d102ad;hpb=d4fc2d235475cfd6f536e7cd584aa8524d02b242;p=myslice.git diff --git a/ui/topmenu.py b/ui/topmenu.py index bdee674d..860e180b 100644 --- a/ui/topmenu.py +++ b/ui/topmenu.py @@ -1,3 +1,6 @@ +from pprint import pprint +from manifold.manifoldapi import execute_query +from manifold.core.query import Query # a set of utilities to help make the global layout consistent across views # dropdowns are kind of ad hoc for now, and limited to one level @@ -15,7 +18,21 @@ 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 + pi_authorities_query = Query.get('ple: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: + pi_authorities |= set(pa['pi_authorities']) + print "pi_authorities =", pi_authorities + if len(pi_authorities) > 0: + result.append({'label':'Validation', 'href': '/portal/validate/'}) dropdown = [] + dropdown.append({'label':'Platforms', 'href': '/portal/platforms/'}) dropdown.append({'label':'My Account', 'href': '/portal/account/'}) dropdown.append({'label':'Contact Support', 'href': '/portal/contact/'}) result.append({'label': 'More', 'href':"#", 'dropdown':True, 'contents':dropdown}) @@ -30,12 +47,14 @@ def topmenu_items (current,request=None): if current is not None: current=current.lower() curlen=len(current) - def mark_active(d): - if d['label'][:curlen].lower() == current: d['is_active']=True + def mark_active(d,up=None): + if d['label'][:curlen].lower() == current: + d['is_active']=True + if up is not None: up['is_active']=True for d in result: mark_active(d) if 'dropdown' in d: - for dd in d['contents']: mark_active(dd) + for dd in d['contents']: mark_active(dd,d) return result def the_user (request):