+# 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
+ # XXX TODO This should be triggered only when user is logged in
+ # We might use local storage instead
+
+ # REGISTRY ONLY TO BE REMOVED WITH MANIFOLD-V2
+ query_pi_auths = Query.get('myslice:user').filter_by('user_hrn', '==', '$user_hrn' ).select('user_hrn','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)
+