# just one instance of validator from django.views.generic.base import TemplateView from django.template import RequestContext from django.shortcuts import render_to_response from manifold.core.query import Query, AnalyzedQuery from unfold.page import Page from ui.topmenu import topmenu_items, the_user from plugins.validatebutton import ValidateButton class SimpleValidateButtonView (TemplateView): # mention a user name in the URL as .../trash/simplevalidatebutton/ple.inria.thierry_parmentelat def get (self, request, username='ple.inria.thierry_parmentelat'): page=Page(request) page.expose_js_metadata() 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 validatebutton = ValidateButton (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") # variables that will get passed to the view-unfold1.html template template_env = {} # there is a need to call render() for exposing the query and creating the js plugin # even though this returns an empty string rendered=validatebutton.render(request) # write something of our own instead template_env ['unfold_main'] = '