1 # Create your views here.
3 from django.core.context_processors import csrf
4 from django.template import RequestContext
5 from django.template.loader import render_to_string
6 from django.shortcuts import render_to_response
8 from django.contrib.auth.decorators import login_required
10 from engine.page import Page
11 from engine.manifoldquery import ManifoldQuery
13 from plugins.verticallayout import VerticalLayout
14 from plugins.slicelist import SliceList
15 from plugins.querycode import QueryCode
18 from myslice.viewutils import topmenu_items, the_user
21 def dashboard_view (request):
25 slices_query = ManifoldQuery (action='get',
29 # xxx filter : should filter on the slices the logged user can see
30 # we don't have the user's hrn yet
31 # in addition this currently returns all slices anyways
34 page.enqueue_query (slices_query)
36 main_plugin = VerticalLayout (
38 title="Putting stuff together",
40 SliceList ( # setting visible attributes first
42 title='Asynchroneous SliceList',
44 with_datatables=False,
46 # this is the query at the core of the slice list
51 title="Vizualize your query",
56 # variables that will get passed to the view-plugin.html template
59 # define 'content_main' to the template engine
60 template_env [ 'content_main' ] = main_plugin.render(request)
62 # ########## add another plugin with the same request, on the RHS pane
63 # # lacks a/href to /slice/%s
64 # related_plugin = SliceList (title='SliceList plugin',domid='slicelist1',
65 # with_datatables='yes',
66 # list=hard_wired_slice_names,
68 # # likewise but on the side view
69 # template_env [ 'content_related' ] = related_plugin.render (request)
71 # more general variables expected in the template
72 template_env [ 'title' ] = 'Test view for a full request cycle'
73 # the menu items on the top
74 template_env [ 'topmenu_items' ] = topmenu_items('dashboard', request)
75 # so we can sho who is logged
76 template_env [ 'username' ] = the_user (request)
79 # lacks a/href to /slice/%s
80 related_plugin = SliceList (
82 title='Same request, other layout',
85 header='paginated slices',
89 # likewise but on the side view
90 template_env [ 'content_related' ] = related_plugin.render (request)
92 # add our own css in the mix
93 page.add_css_files ( 'css/dashboard.css')
95 # don't forget to run the requests
96 page.exec_queue_asynchroneously ()
98 # xxx create another plugin with the same query and a different layout (with_datatables)
99 # show that it worls as expected, one single api call to backend and 2 refreshed views
101 # the prelude object in page contains a summary of the requirements() for all plugins
102 # define {js,css}_{files,chunks}
103 prelude_env = page.template_env()
104 template_env.update(prelude_env)
105 return render_to_response ('view-plugin.html',template_env,
106 context_instance=RequestContext(request))