X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=portal%2Fsliceview.py;h=9b96d4f413149431c28bd81e6036bb51c121841c;hb=4a99831db81024d5d25869d4c475d381fd39f75a;hp=dc7aff88f78f88e22708a67cd81592479e79dd60;hpb=284cc91fde307f26673742cf5972db0b5fc56513;p=unfold.git
diff --git a/portal/sliceview.py b/portal/sliceview.py
index dc7aff88..9b96d4f4 100644
--- a/portal/sliceview.py
+++ b/portal/sliceview.py
@@ -1,44 +1,43 @@
-# Create your views here.
-
from django.template import RequestContext
from django.shortcuts import render_to_response
-from django.contrib.auth.decorators import login_required
-from portal.templateviews import LoginRequiredAutoLogoutView
+from unfold.loginrequired import LoginRequiredAutoLogoutView
from unfold.page import Page
from manifold.core.query import Query, AnalyzedQuery
-from manifold.manifoldresult import ManifoldException
-from manifold.metadata import MetaData as Metadata
-from myslice.viewutils import topmenu_items, the_user
+from ui.topmenu import topmenu_items, the_user
-from plugins.raw.raw import Raw
-from plugins.stack.stack import Stack
-from plugins.tabs.tabs import Tabs
-from plugins.lists.slicelist import SliceList
+from plugins.raw import Raw
+from plugins.stack import Stack
+from plugins.tabs import Tabs
from plugins.hazelnut import Hazelnut
from plugins.resources_selected import ResourcesSelected
-from plugins.googlemaps import GoogleMaps
+from plugins.googlemap import GoogleMap
from plugins.senslabmap.senslabmap import SensLabMap
-from plugins.querycode.querycode import QueryCode
+from plugins.querycode import QueryCode
from plugins.query_editor import QueryEditor
from plugins.active_filters import ActiveFilters
-from plugins.quickfilter.quickfilter import QuickFilter
-from plugins.messages.messages import Messages
-#from plugins.updater import Updater
+from plugins.quickfilter import QuickFilter
+from plugins.messages import Messages
+
+from myslice.config import Config
tmp_default_slice='ple.upmc.myslicedemo'
-debug = True
-class SliceView (LoginRequiredAutoLogoutView):
+# temporary : turn off the users part to speed things up
+do_query_users=True
-# def __init__ (self, slicename=None):
-# self.slicename = slicename or tmp_default_slice
+class SliceView (LoginRequiredAutoLogoutView):
def get (self,request, slicename=tmp_default_slice):
page = Page(request)
+ page.add_css_files ('css/slice-view.css')
+ page.add_js_files ( [ "js/common.functions.js" ] )
+ page.add_js_chunks ('$(function() { messages.debug("sliceview: jQuery version " + $.fn.jquery); });')
+ page.add_js_chunks ('$(function() { messages.debug("sliceview: users turned %s"); });'%("on" if do_query_users else "off"))
+ page.add_js_chunks ('$(function() { messages.debug("manifold URL %s"); });'%(Config.manifold_url()))
page.expose_js_metadata()
metadata = page.get_metadata()
@@ -52,19 +51,30 @@ class SliceView (LoginRequiredAutoLogoutView):
main_query = Query.get('slice').filter_by('slice_hrn', '=', slicename)
main_query.select(
'slice_hrn',
- 'resource.resource_hrn', 'resource.hostname', 'resource.type', 'resource.network_hrn',
+ 'resource.hrn', 'resource.hostname', 'resource.type',
+ 'resource.network_hrn',
#'lease.urn',
'user.user_hrn',
#'application.measurement_point.counter'
)
query_resource_all = Query.get('resource').select(resource_fields)
- query_user_all = Query.get('user').select(user_fields)
+ if do_query_users:
+ query_user_all = Query.get('user').select(user_fields)
aq = AnalyzedQuery(main_query, metadata=metadata)
page.enqueue_query(main_query, analyzed_query=aq)
page.enqueue_query(query_resource_all)
- page.enqueue_query(query_user_all)
+ if do_query_users:
+ page.enqueue_query(query_user_all)
+
+ # ... and for the relations
+ # XXX Let's hardcode resources for now
+ sq_resource = aq.subquery('resource')
+ sq_user = aq.subquery('user')
+ sq_lease = aq.subquery('lease')
+ sq_measurement = aq.subquery('measurement')
+
# Prepare the display according to all metadata
# (some parts will be pending, others can be triggered by users).
@@ -72,93 +82,70 @@ class SliceView (LoginRequiredAutoLogoutView):
# For example slice measurements will not be requested by default...
# Create the base layout (Stack)...
- main_plugin = Stack (
+ main_stack = Stack (
page=page,
- title="Slice !!view for %s"%slicename,
+ title="Slice %s"%slicename,
sons=[],
)
# ... responsible for the slice properties...
-
- main_plugin.insert (
- Raw (page=page,togglable=False, toggled=True,html="
Slice page for %s
"%slicename)
- )
-
- main_plugin.insert(
- Raw (page=page,togglable=False, toggled=True,html='Description: TODO')
- )
-
- sq_plugin = Tabs (
- page=page,
- title="Slice view for %s"%slicename,
- togglable=False,
- sons=[],
- )
-
-
- # ... and for the relations
- # XXX Let's hardcode resources for now
- sq_resource = aq.subquery('resource')
- sq_user = aq.subquery('user')
- sq_lease = aq.subquery('lease')
- sq_measurement = aq.subquery('measurement')
-
-
- ############################################################################
- # RESOURCES
- #
- # A stack inserted in the subquery tab that will hold all operations
- # related to resources
- #
-
- stack_resources = Stack(
- page = page,
- title = 'Resources',
- sons=[],
+ # a nice header
+ main_stack.insert (
+ Raw (page=page,
+ togglable=False,
+ toggled=True,
+ html=" Slice %s
"%slicename)
)
- resource_query_editor = QueryEditor(
+ # --------------------------------------------------------------------------
+ # ResourcesSelected (Pending Operations)
+
+ main_stack.insert(ResourcesSelected(
+ page = page,
+ title = 'Pending operations',
+ query = main_query,
+ togglable = True,
+ # start turned off, it will open up itself when stuff comes in
+ toggled = False,
+ domid = 'pending',
+ outline_complete = True,
+ ))
+
+ # --------------------------------------------------------------------------
+ # Filter Resources
+
+ filter_query_editor = QueryEditor(
page = page,
- query = sq_resource,
- )
- stack_resources.insert(resource_query_editor)
-
- resource_active_filters = ActiveFilters(
+ query = query_resource_all,
+ title = "Select Columns",
+ domid = 'select-columns',
+ )
+ filter_active_filters = ActiveFilters(
page = page,
query = sq_resource,
+ title = "Active Filters",
+ )
+ filters_area = Stack(
+ page = page,
+ title = 'Filter Resources',
+ domid = 'filters',
+ sons = [filter_query_editor, filter_active_filters],
+ togglable = True,
+ # start turned off, it will open up itself when stuff comes in
+ toggled = False,
+ outline_complete = True,
)
- stack_resources.insert(resource_active_filters)
-
+ main_stack.insert (filters_area)
+
# --------------------------------------------------------------------------
- # Different displays = DataTables + GoogleMaps
- #
- tab_resource_plugins = Tabs(
- page = page,
- sons = []
- )
-
- tab_resource_plugins.insert(Hazelnut(
- page = page,
- title = 'List',
- domid = 'checkboxes',
- # this is the query at the core of the slice list
- query = sq_resource,
- query_all = query_resource_all,
- checkboxes = True,
- datatables_options = {
- # for now we turn off sorting on the checkboxes columns this way
- # this of course should be automatic in hazelnut
- 'aoColumns' : [None, None, None, None, {'bSortable': False}],
- 'iDisplayLength' : 25,
- 'bLengthChange' : True,
- },
- ))
-
- tab_resource_plugins.insert(GoogleMaps(
+ # RESOURCES
+ # the resources part is made of a Tabs (Geographic, List),
+
+ resources_as_map = GoogleMap(
page = page,
title = 'Geographic view',
- domid = 'gmap',
+ domid = 'resources-map',
# tab's sons preferably turn this off
togglable = False,
query = sq_resource,
@@ -166,105 +153,134 @@ class SliceView (LoginRequiredAutoLogoutView):
checkboxes = True,
# center on Paris
latitude = 49.,
- longitude = 2.2,
- zoom = 3,
- ))
-
- stack_resources.insert(tab_resource_plugins)
-
- sq_plugin.insert(stack_resources)
-
- ############################################################################
- # USERS
- #
-
- tab_users = Tabs(
- page = page,
- title = 'Users',
- domid = 'thetabs2',
- # activeid = 'checkboxes',
- active_domid = 'checkboxes2',
+ longitude = 9,
+ zoom = 4,
)
- sq_plugin.insert(tab_users)
-
- tab_users.insert(Hazelnut(
- page = page,
- title = 'List',
- domid = 'checkboxes2',
- # tab's sons preferably turn this off
- togglable = False,
+
+ resources_as_list = Hazelnut(
+ page = page,
+ domid = 'resources-list',
# this is the query at the core of the slice list
- query = sq_user,
- query_all = query_user_all,
- checkboxes = True,
+ query = sq_resource,
+ query_all = query_resource_all,
+ checkboxes = True,
datatables_options = {
- # for now we turn off sorting on the checkboxes columns this way
- # this of course should be automatic in hazelnut
- 'aoColumns' : [None, None, None, None, {'bSortable': False}],
- 'iDisplayLength' : 25,
- 'bLengthChange' : True,
- },
- ))
+ 'iDisplayLength': 25,
+ 'bLengthChange' : True,
+ 'bAutoWidth' : True,
+ },
+ )
+
+ # List area itself is a Stack with hazelnut on top,
+ # and a togglable tabs for customization plugins
+ resources_as_list_area = Stack(
+ page = page,
+ title = 'Resources as a List',
+ domid = 'resources-list-area',
+ sons= [ resources_as_list,
+ Tabs ( page=page,
+ title="Customize Resources layout",
+ togglable=True,
+ toggled='persistent',
+ domid="customize-resources",
+ outline_complete=True,
+ #sons = [ resources_query_editor, resources_active_filters, ],
+ ),
+ ],
+ )
+ resources_area = Tabs ( page=page,
+ domid="resources",
+ togglable=True,
+ title="Resources",
+ outline_complete=True,
+ sons=[ resources_as_map, resources_as_list_area, ],
+ active_domid = 'resources-map',
+ )
+ main_stack.insert (resources_area)
+
+
+ # --------------------------------------------------------------------------
+ # USERS
+ if do_query_users:
+ tab_users = Tabs(
+ page = page,
+ domid = 'users',
+ outline_complete = True,
+ togglable = True,
+ title = 'Users',
+ active_domid = 'users-list',
+ )
+ main_stack.insert(tab_users)
+
+ tab_users.insert(Hazelnut(
+ page = page,
+ title = 'Users List',
+ domid = 'users-list',
+ # tab's sons preferably turn this off
+ togglable = False,
+ # this is the query at the core of the slice list
+ query = sq_user,
+ query_all = query_user_all,
+ checkboxes = True,
+ datatables_options = {
+ 'iDisplayLength' : 25,
+ 'bLengthChange' : True,
+ 'bAutoWidth' : True,
+ },
+ ))
+
+ # --------------------------------------------------------------------------
+ # MEASUREMENTS
tab_measurements = Tabs (
- page = page,
- title = 'Measurements',
- domid = 'thetabs3',
- # activeid = 'checkboxes',
- active_domid = 'checkboxes3',
+ page = page,
+ active_domid = 'measurements-list',
+ outline_complete = True,
+ togglable = True,
+ title = 'Measurements',
+ domid = 'measurements',
)
- sq_plugin.insert(tab_measurements)
+ main_stack.insert(tab_measurements)
tab_measurements.insert(Hazelnut(
page = page,
- title = 'List',
- domid = 'checkboxes3',
+ title = 'Measurements',
+ domid = 'measurements-list',
# tab's sons preferably turn this off
togglable = False,
# this is the query at the core of the slice list
query = sq_measurement,
+ # do NOT set checkboxes to False
+ # this table being otherwise empty, it just does not fly with dataTables
checkboxes = True,
datatables_options = {
- # for now we turn off sorting on the checkboxes columns this way
- # this of course should be automatic in hazelnut
- 'aoColumns' : [None, None, None, None, {'bSortable': False}],
'iDisplayLength' : 25,
'bLengthChange' : True,
+ 'bAutoWidth' : True,
},
))
- main_plugin.insert(sq_plugin)
-
# --------------------------------------------------------------------------
- # ResourcesSelected
- #
- main_plugin.insert(ResourcesSelected(
- page = page,
- title = 'Pending operations',
- query = main_query,
- togglable = True,
- ))
-
- main_plugin.insert(Messages(
+ # MESSAGES (we use transient=False for now)
+ main_stack.insert(Messages(
page = page,
title = "Runtime messages for slice %s"%slicename,
domid = "msgs-pre",
levels = "ALL",
+ # plain messages are probably less nice for production but more reliable for development for now
+ transient = False,
+ # these make sense only in non-transient mode..
+ togglable = True,
+ toggled = 'persistent',
+ outline_complete = True,
))
- # main_plugin.insert(Updater(
- # page = page,
- # title = "wont show up as non togglable by default",
- # query = main_query,
- # label = "Update slice",
- # ))
-
# variables that will get passed to the view-unfold1.html template
template_env = {}
# define 'unfold1_main' to the template engine - the main contents
- template_env [ 'unfold1_main' ] = main_plugin.render(request)
+ template_env [ 'unfold1_main' ] = main_stack.render(request)
# more general variables expected in the template
template_env [ 'title' ] = '%(slicename)s'%locals()