A first stab at the ‘validatebutton’ plugin
[myslice.git] / trash / simplevalidatebutton.py
1 # just one instance of validator
2 from django.views.generic.base import TemplateView
3 from django.template import RequestContext
4 from django.shortcuts import render_to_response
5
6 from manifold.core.query import Query, AnalyzedQuery
7
8 from unfold.page import Page
9
10 from ui.topmenu import topmenu_items, the_user
11
12 from plugins.validatebutton import ValidateButton
13
14 class SimpleValidateButtonView (TemplateView):
15
16     # mention a user name in the URL as .../trash/simplevalidatebutton/ple.inria.thierry_parmentelat
17     def get (self, request, username='ple.inria.thierry_parmentelat'):
18
19         page=Page(request)
20         page.expose_js_metadata()
21         query_pi_auths = Query.get('ple:user').filter_by('user_hrn', '==', username ).select('pi_authorities')
22         page.enqueue_query(query_pi_auths)
23
24         # even though this plugin does not have any html materialization, the corresponding domid
25         # must exist because it is searched at init-time to create the JS plugin
26         # so we simply piggy-back the target button here
27         validatebutton = ValidateButton (page=page, 
28                                          # see above
29                                          domid='topmenu-validation',
30                                          query=query_pi_auths,
31                                          # this one is the target for a $.show() when the query comes back
32                                          button_domid="topmenu-validation")
33
34         # variables that will get passed to the view-unfold1.html template
35         template_env = {}
36         
37         # there is a need to call render() for exposing the query and creating the js plugin
38         # even though this returns an empty string
39         rendered=validatebutton.render(request)
40
41         # write something of our own instead
42         template_env ['unfold_main'] = '<h1>Some title </h1>'
43         
44         # more general variables expected in the template
45         template_env [ 'title' ] = 'simple validatebutton %(username)s'%locals()
46         # the menu items on the top
47         template_env [ 'topmenu_items' ] = topmenu_items('Slice', request) 
48         # so we can see who is logged
49         template_env [ 'username' ] = the_user (request) 
50     
51         # don't forget to run the requests
52         page.expose_queries ()
53
54         # the prelude object in page contains a summary of the requirements() for all plugins
55         # define {js,css}_{files,chunks}
56         prelude_env = page.prelude_env()
57
58 #        print prelude_env.keys()
59 #        for k in [ 'js_files' ] :
60 #            print 'prelude_env',prelude_env,k,prelude_env[k]
61
62         template_env.update(prelude_env)
63         result=render_to_response ('view-unfold1.html',template_env,
64                                    context_instance=RequestContext(request))
65         return result