From e12f686b9ce447e1cc6d1e27c6199cd48eb900fe Mon Sep 17 00:00:00 2001 From: Thierry Parmentelat Date: Fri, 18 Mar 2011 18:42:21 +0100 Subject: [PATCH] reviewed the info text attached to toggles --- planetlab/css/my_slice.css | 8 +-- planetlab/icons/close.png | Bin 0 -> 9452 bytes planetlab/icons/info.png | Bin 0 -> 9947 bytes planetlab/nodes/nodes.php | 39 ++++++------- planetlab/slices/slice.php | 111 ++++++++++++++++++++----------------- plekit/php/toggle.php | 43 +++++++++++--- plekit/toggle/toggle.js | 64 ++++++++++----------- 7 files changed, 149 insertions(+), 116 deletions(-) create mode 100644 planetlab/icons/close.png create mode 100644 planetlab/icons/info.png diff --git a/planetlab/css/my_slice.css b/planetlab/css/my_slice.css index 088fc47..d68fb8e 100644 --- a/planetlab/css/my_slice.css +++ b/planetlab/css/my_slice.css @@ -56,12 +56,10 @@ div.in{background-color:#CAE8EA; color:#4f6b72} div.selected{background-color:gray; color:black} div.invisible{display:none} -div.note-div { - padding: 4px; +div.toggle-info { + padding: 10px 20px; background-color: #cae8ea; - width: 800px; - margin-left:auto; - margin-right:auto; + margin: 10px 10px; } diff --git a/planetlab/icons/close.png b/planetlab/icons/close.png new file mode 100644 index 0000000000000000000000000000000000000000..90444f95af1024a34eba953244598e48bed1186e GIT binary patch literal 9452 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 literal 0 HcmV?d00001 diff --git a/planetlab/nodes/nodes.php b/planetlab/nodes/nodes.php index 872b5ee..9a8d839 100644 --- a/planetlab/nodes/nodes.php +++ b/planetlab/nodes/nodes.php @@ -1,7 +1,5 @@ GetPersonTags (array('person_id'=>$plc->person['person_id'])); @@ -271,10 +268,11 @@ $nodes=$api->GetNodes($node_filter,$node_columns); $ConfigureColumns->fetch_live_data($nodes); +$show_columns_message = TRUE; $show_conf = explode(";",$show_configuration); foreach ($show_conf as $ss) { - if ($ss =="columns") - $show_columns_message = '0'; + if ($ss =="columns") + $show_columns_message = FALSE; } @@ -358,9 +356,21 @@ $column_conf_visible = '1'; else $column_conf_visible = '0'; -$toggle_nodes=new PlekitToggle('nodes-column-configuration', +$layout_help=' +This tab allows you to customize the columns in the node tables, +below. Information on the nodes comes from a variety of monitoring +sources. If you, as either a user or a provider of monitoring data, +would like to see additional columns made available, please send us +your request in mail to support@myslice.info. You can +find more information about the MySlice project at http://trac.myslice.info. +'; +$toggle_nodes=new PlekitToggle('nodes-layout', "Node table layout", - array('visible'=>$column_conf_visible, 'info_div'=>'note_columns_div')); + array('visible'=>$column_conf_visible, + 'info_text'=>$layout_help, + 'info_visible'=>$show_columns_message)); $toggle_nodes->start(); print("
"); print(""); @@ -372,20 +382,7 @@ print(""); print(""); -if ($show_columns_message == '0') -$note_display = "display:none;"; -else -$note_display = ""; - - -print << -
-This tab allows you to customize the columns in the node tables, below. Information on the nodes comes from a variety of monitoring sources. If you, as either a user or a provider of monitoring data, would like to see additional columns made available, please send us your request in mail to support@myslice.info. You can find more information about the MySlice project at http://trac.myslice.info. -hide message permanently -
- -EOF; +////////// end $ConfigureColumns->configuration_panel_html(true); $ConfigureColumns->javascript_init(); diff --git a/planetlab/slices/slice.php b/planetlab/slices/slice.php index a8e49c3..eaf926e 100644 --- a/planetlab/slices/slice.php +++ b/planetlab/slices/slice.php @@ -480,8 +480,6 @@ $column_configuration = ""; $slice_column_configuration = ""; $show_configuration = ""; -$show_reservable_message = '1'; -$show_columns_message = '1'; $PersonTags=$api->GetPersonTags (array('person_id'=>$plc->person['person_id'])); //plc_debug('ptags',$PersonTags); @@ -534,12 +532,14 @@ $all_nodes=$api->GetNodes(NULL,$node_columns); $ConfigureColumns->fetch_live_data($all_nodes); +$show_reservable_info = TRUE; +$show_layout_info = '1'; $show_conf = explode(";",$show_configuration); foreach ($show_conf as $ss) { if ($ss =="reservable") - $show_reservable_message = '0'; + $show_reservable_info = FALSE; else if ($ss =="columns") - $show_columns_message = '0'; + $show_layout_info = '0'; } $slice_nodes=array(); @@ -566,39 +566,24 @@ $toggle->start(); //////////////////// reservable nodes area - -$count=count($reservable_nodes); -if ($count && $privileges) { - // having reservable nodes in white lists looks a bit off scope for now... - $toggle_nodes=new PlekitToggle('my-slice-nodes-reserve', - "Leases - " . count($reservable_nodes) . " reservable node(s)", - array('visible'=>get_arg('show_nodes_resa',false), 'info_div'=>'note_reservable_div')); - $toggle_nodes->start(); - -if ($show_reservable_message) - $note_display = ""; -else - $note_display = "display:none;"; - -////////// show a notice to people having attached a reservable node -if (count($reservable_nodes) && $privileges) { - $mark=reservable_mark(); - print << -
-
+$leases_info=" You have attached one or more reservable nodes to your slice. Reservable nodes show up with the '$mark' mark. Your slivers will be available only during timeslots where you have obtained leases. You can manage your leases in the tab below.
-This feature is still experimental; feedback is appreciated at devel@planet-lab.org -
hide message permanently -
-
-EOF; -} +This feature is still experimental; feedback is appreciated at devel@planet-lab.org +"; +$count=count($reservable_nodes); +if ($count && $privileges) { + // having reservable nodes in white lists looks a bit off scope for now... + $toggle_nodes=new PlekitToggle('my-slice-nodes-reserve', + "Leases - " . count($reservable_nodes) . " reservable node(s)", + array('visible'=>get_arg('show_nodes_resa',false), + 'info_text'=>$leases_info, + 'info_visible'=>$show_reservable_info)); + $toggle_nodes->start(); // get settings from environment, otherwise set to defaults // when to start, in hours in the future from now @@ -652,10 +637,21 @@ $column_conf_visible = '1'; else $column_conf_visible = '0'; - +$layout_info=' +This tab allows you to customize the columns in the node tables, +below. Information on the nodes comes from a variety of monitoring +sources. If you, as either a user or a provider of monitoring data, +would like to see additional columns made available, please send us +your request in mail to support@myslice.info. You can +find more information about the MySlice project at http://trac.myslice.info. +'; $toggle_nodes=new PlekitToggle('my-slice-nodes-configuration', "Node table layout", - array('visible'=>$column_conf_visible, 'info_div'=>'note_columns_div')); + array('visible'=>$column_conf_visible, + 'info_text'=>$layout_info, + 'info_visible'=>$show_layout_info)); $toggle_nodes->start(); //usort ($table_headers, create_function('$col1,$col2','return strcmp($col1["header"],$col2["header"]);')); @@ -673,21 +669,6 @@ print("
"); print(""); -//print ("showing column message = ".$show_columns_message); -if ($show_columns_message == '0') - $note_display = "display:none;"; -else - $note_display = ""; - - print << -
-This tab allows you to customize the columns in the node tables, below. Information on the nodes comes from a variety of monitoring sources. If you, as either a user or a provider of monitoring data, would like to see additional columns made available, please send us your request in mail to support@myslice.info. You can find more information about the MySlice project at http://trac.myslice.info. -hide message permanently -
- -EOF; - $ConfigureColumns->configuration_panel_html(true); $ConfigureColumns->javascript_init(); @@ -889,6 +870,33 @@ $tags=$api->GetSliceTags (array('slice_id'=>$slice_id)); // * explain the interface : initscript start|stop|restart slicename // xxx fixme +$initscript_info=" +There are two ways to attach an initscript to a slice:
    + +
  • Shared initscripts are global to the +MyPLC, and managed by the Operations Team. For that reason, regular +users cannot change these scripts, but can reference one of the +available names in the drop down below.
  • + +
  • You also have the option to provide your own +code , with the following conventions:
      + +
    • Like regular initscripts, your script must except to receive as a +first argument start , +stop or restart . It is important +to honor this argument, as your slice may be stopped and restarted at +any time; also this is used whenever the installed code gets changed. +
    • + +
    • As a second argument, you will receive the slicename; in most +cases this can be safely ignored.
    • + +
    +
  • +
+The slice-specific setting has precedence on a shared initscript. +"; + $shared_initscripts=$api->GetInitScripts(array('-SORT'=>'name'),array('name')); //$shared_initscripts=$api->GetInitScripts(); if ($profiling) plc_debug_prof('6 initscripts',count($initscripts)); @@ -914,7 +922,11 @@ if ($local_peer) { $toggle = new PlekitToggle('slice-initscripts',$label, array('bubble'=>'Manage initscript on that slice', - 'visible'=>get_arg('show_initscripts',false))); + 'visible'=>get_arg('show_initscripts',false), + 'info_text'=>$initscript_info + // not messing with persontags to guess whether this should be displayed or not + // hopefully some day toggle will know how to handle that using web storage + )); $toggle->start(); $details=new PlekitDetails(TRUE); @@ -956,7 +968,6 @@ if ($local_peer) { } $details->th_td('slice initscript',$initscript_body,'initscript-body', array('input_type'=>'textarea', 'width'=>$script_width,'height'=>$script_height)); - $details->th_td('Howto',"xxx yourscript start|stop|restart slicename"); $details->tr_submit('unused','Update initscripts'); $details->form_end(); $details->end(); diff --git a/plekit/php/toggle.php b/plekit/php/toggle.php index 98085a6..897a8b8 100644 --- a/plekit/php/toggle.php +++ b/plekit/php/toggle.php @@ -21,6 +21,9 @@ drupal_set_html_head(' // - trigger-tagname : to be used instead of for wrapping the trigger // - bubble : might not work if trigger-tagname is redefined // - init-hidden : start hidden rather than visible +// - info_div : the id of a 'div' element that contains a help text +// - info_text : the text for help on the tab +// - info_visible : whether info needs to be visible at startup // // methods are as follows // (*) trigger_html (): return the html code for the trigger @@ -33,7 +36,6 @@ class PlekitToggle { // mandatory var $id; var $nifty; - var $info_div = ""; function PlekitToggle ($id,$trigger,$options=NULL) { $this->id = $id; @@ -44,10 +46,6 @@ class PlekitToggle { unset ($options['visible']); } - if (array_key_exists ('info_div',$options)) { - $this->info_div = $options['info_div']; - } - if (!isset ($options['start-hidden'])) $options['start-hidden']=false; $this->options = $options; } @@ -60,6 +58,7 @@ class PlekitToggle { $html .= $this->container_start(); $html .= $this->trigger_html(); $html .= $this->area_start_html(); + $html .= $this->info_html(); return $html; } @@ -98,15 +97,43 @@ class PlekitToggle { $html .= " id='$trigger_id'"; $html .= " class='plc-toggle-trigger'"; if ($bubble) $html .= " title='$bubble'"; - $html .= " onclick=\"plc_toggle('$this->id')\""; + $html .= " onclick=\"plekit_toggle('$this->id')\""; $html .= ">"; $html .= $this->image_html(); $html .= $this->trigger; $html .= ""; - if ($this->info_div != "") - $html .= " (info_div','$this->id')>?)"; + if (array_key_exists ('info_text',$this->options)) { + $id=$this->id; + $html .= "close info"; + } + return $html; + } + + function info() { print $this->info_html();} + function info_html () { + if (! array_key_exists ('info_text',$this->options)) return ""; + + // compute if info should be visible at startup + // xxx in fact the default should be fetched in the browser storage xxx + $info_visible=TRUE; + // if info_visible is set, use this value + if (array_key_exists ('info_visible',$this->options)) + $info_visible=$this->options['info_visible']; + + $id=$this->id; + $div_id=$this->id_name('info'); + $html=""; + $html .= "
options['info_text']; + $html .= "toggle info"; + $html .= "
"; return $html; } + function area_start () { print $this->area_start_html(); } function area_start_html () { diff --git a/plekit/toggle/toggle.js b/plekit/toggle/toggle.js index faae1b8..37dddda 100644 --- a/plekit/toggle/toggle.js +++ b/plekit/toggle/toggle.js @@ -1,38 +1,38 @@ +function plekit_toggle(id){ -function plc_toggle(id){ - - var area=$('toggle-area-'+id); - area.toggle(); - var visible=$('toggle-image-visible-'+id); - var hidden=$('toggle-image-hidden-'+id); - if(area.visible()){ - visible.show(); - hidden.hide(); - } - else{ - visible.hide(); - hidden.show(); - } + var area=$('toggle-area-'+id); + area.toggle(); + var visible=$('toggle-image-visible-'+id); + var hidden=$('toggle-image-hidden-'+id); + if (area.visible()) { + visible.show(); + hidden.hide(); + } else { + visible.hide(); + hidden.show(); + } } -function plc_show_toggle_info(div, id) { -//debugfilter("showing "+div); - - var area=$('toggle-area-'+id); - var visible=$('toggle-image-visible-'+id); - var hidden=$('toggle-image-hidden-'+id); - - if (document.getElementById(div).style.display == "none") - document.getElementById(div).style.display = ""; - else - document.getElementById(div).style.display = "none"; +// make sure it's open +function plekit_toggle_show(id) { + var area=$('toggle-area-'+id); + if (!area.visible()) plekit_toggle (id); +} - if(! area.visible()){ - area.toggle(); - visible.show(); - hidden.hide(); - document.getElementById(div).style.display = ""; - } +// open or close the info box +function plekit_toggle_info(id){ - //plc_toggle(id); + // need to take care of the area as well + var area=$('toggle-area-'+id); + var info=$('toggle-info-'+id); + if (area.visible() && info.visible()) { + window.console.log('PTI hiding'); + info.hide(); + } else { + // make sure area is visible, take of the triggers + window.console.log('PTI showing'); + plekit_toggle_show(id); + info.show(); + } } + -- 2.43.0