X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=myslice%2Fviewutils.py;h=f00a4515df6d5b0c391f5a33527fc18007190d15;hb=202d3226466d433b6347895499fde885a78ab34a;hp=7fbdc77f2f067f227e97880ebc066923b5257c7f;hpb=93ac75da63ac1891764f3ddcb82aebe9b12a2660;p=myslice.git diff --git a/myslice/viewutils.py b/myslice/viewutils.py index 7fbdc77f..f00a4515 100644 --- a/myslice/viewutils.py +++ b/myslice/viewutils.py @@ -1,31 +1,42 @@ # 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 +# [ +# ### a regular first-level button +# {'label':...,'href':...}, +# ### a dropdown +# { 'label': ..., 'href'=..., 'dropdown':True, 'contents': [ { 'label':.., 'href'} ] } +# , ..] def topmenu_items (current,request=None): has_user=request.user.is_authenticated() result=[] if has_user: result.append({'label':'Platforms', 'href': '/portal/platforms/'}) - result.append({ 'label':'Dashboard', 'href': '/portal/dashboard/'}) + 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/'}) - result.append({'label':'My Account', 'href': '/portal/account/'}) + dropdown = [] + dropdown.append({'label':'Request a slice', 'href': '/portal/slice_request/'}) + 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}) else: result.append({'label':'Home', 'href': '/login'}) # looks like this is accessible to non-logged users result.append({'label':'Platforms', 'href': '/portal/platforms/'}) - result.append({ 'label':'Register', 'href': '/portal/register/'}) - result.append({'label':'Contact Support', 'href': '/portal/contact/'}) + result.append({'label':'Register', 'href': '/portal/register/'}) + result.append({'label':'Contact Support', 'href': '/portal/contact/'}) + # mark active for d in result: - #if d['label'].lower()find(current)>=0: d['is_active']=True - if d['label'] == current: d['is_active']=True - if not request: return result -# result.append (login_out_items [ has_user] ) + 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 return result def the_user (request): - "This code below is broken" + "retrieves logged in user's email, or empty string" if not request.user.is_authenticated (): -# print 'void user!' return '' else: return request.user.email