1 # a set of utilities to help make the global layout consistent across views
3 def the_user (request):
4 "retrieves logged in user's email, or empty string"
5 if not request.user.is_authenticated ():
8 return request.user.email
10 # dropdowns are kind of ad hoc for now, and limited to one level
12 # ### a regular first-level button
13 # {'label':...,'href':..., ['domid':.., 'disabled':...]},
15 # { 'label': ..., 'href'=..., 'dropdown':True, 'contents': [ { 'label':.., 'href'} ] }
18 # see also templates/widget-topmenu.html for how these items are put together
19 # and plugins/topmenuvalidation for how this hident button is turned on when necessary
21 # current: the beginning of the label in the menu that you want to outline
22 def topmenu_items_static (current, request):
23 has_user=request.user.is_authenticated()
27 result.append({'label':'Dashboard', 'href': '/portal/dashboard/'})
28 result.append({'label':'Request a slice', 'href': '/portal/slice_request/'})
29 # always create a disabled button for validation, and let the
30 # topmenuvalidation plugin handle that asynchroneously, based on this domid
31 result.append({'label':'Validation', 'href': '/portal/validate/', 'domid':'topmenu-validation', 'disabled':True})
33 dropdown.append({'label':'Platforms', 'href': '/portal/platforms/'})
34 dropdown.append({'label':'My Account', 'href': '/portal/account/'})
35 dropdown.append({'label':'Contact Support', 'href': '/portal/contact/'})
36 result.append({'label': 'More', 'href':"#", 'dropdown':True, 'contents':dropdown})
38 result.append({'label':'Home', 'href': '/login'})
39 # looks like this is accessible to non-logged users
40 result.append({'label':'Platforms', 'href': '/portal/platforms/'})
41 result.append({'label':'Register', 'href': '/portal/register/'})
42 result.append({'label':'Join us', 'href': '/portal/join/'})
43 result.append({'label':'Contact Support', 'href': '/portal/contact/'})
45 # mark active if the provided 'current', even if shorter, matches the beginning of d['label']
46 if current is not None:
47 current=current.lower()
49 def mark_active(d,up=None):
50 if d['label'][:curlen].lower() == current:
52 if up is not None: up['is_active']=True
56 for dd in d['contents']: mark_active(dd,d)
59 # tmp - transition phase
60 def topmenu_items (current, request):
61 print "WARNING -- please now use topmenu_items_live (label, page) toplevel_items is deprecated -- WARNING"
62 return topmenu_items_static (current, request)
64 # integrated helper function for an animated menu
65 from unfold.page import Page
66 from manifold.core.query import Query
67 from plugins.topmenuvalidation import TopmenuValidation
69 ### this is now the 'live' version, that has plugins
70 # for asynchronous management of topmenu
71 def topmenu_items_live (current, page):
73 # XXX TODO This should be triggered only when user is logged in
74 # We might use local storage instead
76 # REGISTRY ONLY TO BE REMOVED WITH MANIFOLD-V2
77 query_pi_auths = Query.get('myslice:user').filter_by('user_hrn', '==', '$user_hrn' ).select('user_hrn','pi_authorities')
78 page.enqueue_query(query_pi_auths)
79 # # even though this plugin does not have any html materialization, the corresponding domid
80 # # must exist because it is searched at init-time to create the JS plugin
81 # # so we simply piggy-back the target button created in the topmenu
82 topmenuvalidation = TopmenuValidation (
85 domid='topmenu-validation',
87 # this one is the target for a $.show() when the query comes back
88 button_domid="topmenu-validation")
89 # although the result does not matter, rendering is required for the JS init code to make it in the page
90 topmenuvalidation.render(request)
92 return topmenu_items_static (current, request)