from manifold.core.query import Query, AnalyzedQuery
from manifold.manifoldapi import execute_query
-from ui.topmenu import topmenu_items, the_user
+from ui.topmenu import topmenu_items_live, the_user
-from plugins.topmenuvalidation import TopmenuValidation
from plugins.raw import Raw
from plugins.stack import Stack
from plugins.tabs import Tabs
outline_complete = True,
))
-# topmenu animation
-# xxx all this should go into a plugin if its own with the topmenu and all...
- query_pi_auths = Query.get('ple: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 here
- 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)
-# end topmenu addition
-
# variables that will get passed to the view-unfold1.html template
template_env = {}
# more general variables expected in the template
template_env [ 'title' ] = '%(slicename)s'%locals()
# the menu items on the top
- template_env [ 'topmenu_items' ] = topmenu_items('Slice', request)
+ template_env [ 'topmenu_items' ] = topmenu_items_live('Slice', page)
# so we can sho who is logged
template_env [ 'username' ] = the_user (request)
from unfold.page import Page
-from ui.topmenu import topmenu_items, the_user
-
-from plugins.topmenuvalidation import TopmenuValidation
+from ui.topmenu import topmenu_items_live, the_user
class TopmenuValidationView (TemplateView):
page=Page(request)
- query_pi_auths = Query.get('ple:user').filter_by('user_hrn', '==', username ).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 here
- topmenuvalidation = TopmenuValidation (
- page=page,
- # see above
- domid='topmenu-validation',
- query=query_pi_auths,
- # this one is the target for enabling when the query comes back
- button_domid="topmenu-validation")
- # there is a need to call render() for exposing the query and creating the js plugin
- # even though this returns an empty string
- topmenuvalidation.render(request)
-
-
# variables that will get passed to the view-unfold1.html template
template_env = {}
# more general variables expected in the template
template_env [ 'title' ] = 'simple topmenuvalidation %(username)s'%locals()
# the menu items on the top
- template_env [ 'topmenu_items' ] = topmenu_items('Slice', request)
+ template_env [ 'topmenu_items' ] = topmenu_items_live('Slice', page)
# so we can see who is logged
template_env [ 'username' ] = the_user (request)
# 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 (current,request=None):
+def topmenu_items_static (current, request):
has_user=request.user.is_authenticated()
result=[]
print request.user
result.append({'label':'Platforms', 'href': '/portal/platforms/'})
result.append({'label':'Register', 'href': '/portal/register/'})
result.append({'label':'Contact Support', 'href': '/portal/contact/'})
+
# 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)
for dd in d['contents']: mark_active(dd,d)
return result
+# 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('ple: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)
+