X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ui%2Ftopmenu.py;h=69a8dd3dd33b709f29f84134820d4b53b1379784;hb=3b28a7842f5464c38ecc968b54c13b442f7b5c9e;hp=bcf74b1c117bfda3c0905b9d57806c23881bef04;hpb=e662708d2f2f1ba05daefe1db50ee08c5439aadc;p=unfold.git diff --git a/ui/topmenu.py b/ui/topmenu.py index bcf74b1c..69a8dd3d 100644 --- a/ui/topmenu.py +++ b/ui/topmenu.py @@ -1,21 +1,36 @@ # a set of utilities to help make the global layout consistent across views +def the_user (request): + "retrieves logged in user's email, or empty string" + if not request.user.is_authenticated (): + return '' + else: + return request.user.email + # 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'} ] } # , ..] -def topmenu_items (current,request=None): + +# see also templates/widget-topmenu.html for how these items are put together +# and plugins/topmenuvalidation 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_static (current, request): has_user=request.user.is_authenticated() result=[] + print request.user if has_user: - result.append({'label':'Platforms', 'href': '/portal/platforms/'}) result.append({'label':'Dashboard', 'href': '/portal/dashboard/'}) - # This should probably go in dashboard at some point + result.append({'label':'Request a slice', 'href': '/portal/slice_request/'}) + # always create a disabled button for validation, and let the + # topmenuvalidation plugin handle that asynchroneously, based on this domid + result.append({'label':'Validation', 'href': '/portal/validate/', 'domid':'topmenu-validation', 'disabled':True}) dropdown = [] - dropdown.append({'label':'Request a slice', 'href': '/portal/slice_request/'}) + 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}) @@ -25,18 +40,49 @@ def topmenu_items (current,request=None): result.append({'label':'Platforms', 'href': '/portal/platforms/'}) result.append({'label':'Register', 'href': '/portal/register/'}) result.append({'label':'Contact Support', 'href': '/portal/contact/'}) - # mark active - for d in result: - if 'dropdown' in d: - for dd in d['contents']: - if dd['label'] == current: dd['is_active']=True - else: - if d['label'] == current: d['is_active']=True + + # mark active if the provided 'current', even if shorter, matches the beginning of d['label'] + if current is not None: + current=current.lower() + curlen=len(current) + 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,d) return result -def the_user (request): - "retrieves logged in user's email, or empty string" - if not request.user.is_authenticated (): - return '' - else: - return request.user.email +# tmp - transition phase +def topmenu_items (current, request): + print "WARNING -- please now use topmenu_items_live (label, page) toplevel_items is deprecated -- WARNING" + return topmenu_items_static (current, request) + +# integrated helper function for an animated menu +from unfold.page import Page +from manifold.core.query import Query +from plugins.topmenuvalidation import TopmenuValidation + +### this is now the 'live' version, that has plugins +# for asynchronous management of topmenu +def topmenu_items_live (current, page): + request=page.request + query_pi_auths = Query.get('user').filter_by('user_hrn', '==', '$user_hrn' ).select('pi_authorities') + page.enqueue_query(query_pi_auths) +# # even though this plugin does not have any html materialization, the corresponding domid +# # must exist because it is searched at init-time to create the JS plugin +# # so we simply piggy-back the target button created in the topmenu + topmenuvalidation = TopmenuValidation ( + page=page, + # see above + domid='topmenu-validation', + query=query_pi_auths, + # this one is the target for a $.show() when the query comes back + button_domid="topmenu-validation") + # although the result does not matter, rendering is required for the JS init code to make it in the page + topmenuvalidation.render(request) + + return topmenu_items_static (current, request) +