changeset 2:50f204c82159 draft

planemo upload for repository https://github.com/galaxyproject/tools-iuc/tree/master/tools/taxonomy_krona_chart commit 70d4a2d1563e834d8394dce8017a1f0b7ad74f23
author iuc
date Wed, 02 Mar 2016 04:49:06 -0500
parents 09552faff9c0
children f11a04ed443b
files taxonomy_krona_chart.xml test-data/krona_test1.html
diffstat 2 files changed, 105 insertions(+), 50 deletions(-) [+]
line wrap: on
line diff
--- a/taxonomy_krona_chart.xml	Mon Aug 17 11:36:09 2015 -0400
+++ b/taxonomy_krona_chart.xml	Wed Mar 02 04:49:06 2016 -0500
@@ -1,7 +1,7 @@
-<tool id="taxonomy_krona_chart" name="Krona pie chart" version="2.0.0">
+<tool id="taxonomy_krona_chart" name="Krona pie chart" version="2.6.0">
   <description>from taxonomic profile</description>
   <requirements>
-    <requirement type="package" version="2.5">krona</requirement>
+    <requirement type="package" version="2.6">krona</requirement>
   </requirements>
   <version_command>ktImportText | sed -n 's/.*\(KronaTools [[:digit:].]\{1,\}\).*/\1/p'</version_command>
   <command>
@@ -10,10 +10,9 @@
   #if $type_of_data.input[0].is_of_type('taxonomy'):
 
         ktImportGalaxy
-        -a
         -d "${type_of_data.max_rank}"
         -n "${root_name}"
-        -o ${output}
+        -o "${output}"
         ${combine_inputs}
         #for $input_count, $input_dataset in enumerate( $type_of_data.input ):
             "${input_dataset},${input_count}"
@@ -22,9 +21,8 @@
   #else:
 
         ktImportText
-        -a
         -n "${root_name}"
-        -o ${output}
+        -o "${output}"
         ${combine_inputs}
         #for $input_count, $input_dataset in enumerate( $type_of_data.input ):
             "${input_dataset},${input_count}"
@@ -32,6 +30,7 @@
 
   #end if
 
+&& [ -d "${output}.files" ] && ( mkdir "${output.extra_files_path}" && mv "${output}.files" "${output.extra_files_path}/" )
   ]]>
 
   </command>
@@ -72,7 +71,7 @@
         <param name="input" type="data" format="tabular" multiple="True" label="Input file" help="Select a MetaPhlAn dataset" />
       </when>
     </conditional>
-    <param name="root_name" type="text" size="20" value="Root" label="Provide a name for the basal rank" help="-n; Otherwise it will simply be called &quot;Root&quot;"/>
+    <param name="root_name" type="text" value="Root" label="Provide a name for the basal rank" help="-n; Otherwise it will simply be called &quot;Root&quot;"/>
     <param name="combine_inputs" type="boolean" truevalue="-c" falsevalue="" selected="False" label="Combine data from multiple datasets?" help="-c; Combine data from each dataset, rather than creating separate datasets within the chart"/>
   </inputs>
   <outputs>
@@ -94,7 +93,7 @@
 This tool renders results of a metagenomic profiling as a zoomable pie chart using Krona_. 
 
 
-.. _Krona: http://sourceforge.net/p/krona/home/krona/
+.. _Krona: https://github.com/marbl/Krona/wiki
 
 ------
 
--- a/test-data/krona_test1.html	Mon Aug 17 11:36:09 2015 -0400
+++ b/test-data/krona_test1.html	Wed Mar 02 04:49:06 2016 -0500
@@ -76,7 +76,7 @@
 // 
 // FOR MORE INFORMATION VISIT
 // 
-// http://krona.sourceforge.net
+// https://github.com/marbl/Krona/wiki/
 // 
 //-----------------------------------------------------------------------------
 }
@@ -496,7 +496,77 @@
 			}
 		}
 		
-		if ( this != selectedNode && ! this.getCollapse() )
+		if ( this.radial )
+		{
+			var angleText = (angleStartCurrent + angleEndCurrent) / 2;
+			var radiusText = (gRadius + radiusInner) / 2;
+			
+			context.rotate(angleText);
+			context.beginPath();
+			context.moveTo(radiusText, -fontSize);
+			context.lineTo(radiusText, fontSize);
+			context.lineTo(radiusText + centerX, fontSize);
+			context.lineTo(radiusText + centerX, -fontSize);
+			context.closePath();
+			context.rotate(-angleText);
+			
+			if ( context.isPointInPath(mouseX - centerX, mouseY - centerY) )
+			{
+				var label = String(this.getPercentage()) + '%' + '   ' + this.name;
+				
+				if ( this.searchResultChildren() )
+			    {
+					label += searchResultString(this.searchResultChildren());
+				}
+				
+				if
+				(
+					Math.sqrt((mouseX - centerX) * (mouseX - centerX) + (mouseY - centerY) * (mouseY - centerY)) <
+					radiusText + measureText(label)
+				)
+				{
+					highlighted = true;
+				}
+			}
+		}
+		else
+		{
+		    for ( var i = 0; i < this.hiddenLabels.length; i++ )
+		    {
+		        var hiddenLabel = this.hiddenLabels[i];
+		        
+				context.rotate(hiddenLabel.angle);
+				context.beginPath();
+				context.moveTo(gRadius, -fontSize);
+				context.lineTo(gRadius, fontSize);
+				context.lineTo(gRadius + centerX, fontSize);
+				context.lineTo(gRadius + centerX, -fontSize);
+				context.closePath();
+				context.rotate(-hiddenLabel.angle);
+				
+				if ( context.isPointInPath(mouseX - centerX, mouseY - centerY) )
+				{
+					var label = String(hiddenLabel.value) + ' more';
+					
+					if ( hiddenLabel.search )
+				    {
+						label += searchResultString(hiddenLabel.search);
+					}
+					
+					if
+					(
+						Math.sqrt((mouseX - centerX) * (mouseX - centerX) + (mouseY - centerY) * (mouseY - centerY)) <
+						gRadius + fontSize + measureText(label)
+					)
+					{
+						highlighted = true;
+						break;
+					}
+				}
+			}
+		}
+		
+		if ( ! highlighted && this != selectedNode && ! this.getCollapse() )
 		{
 			context.beginPath();
 			context.arc(0, 0, radiusInner, angleStartCurrent, angleEndCurrent, false);
@@ -972,6 +1042,8 @@
 			}
 		}
 		
+		this.hiddenLabels = Array();
+		
 		if ( drawChildren )
 		{
 			// draw children
@@ -1122,6 +1194,14 @@
 		var textAngle = (angleStart + angleEnd) / 2;
 		var labelRadius = gRadius + fontSize;//(radiusInner + radius) / 2;
 		
+		var hiddenLabel = Array();
+		
+		hiddenLabel.value = value;
+		hiddenLabel.angle = textAngle;
+		hiddenLabel.search = hiddenSearchResults;
+		
+		this.hiddenLabels.push(hiddenLabel);
+		
 		drawTick(gRadius - fontSize * .75, fontSize * 1.5, textAngle);
 		drawTextPolar
 		(
@@ -2172,7 +2252,7 @@
 	{
 		var nameWidthOld = this.nameWidth;
 		
-		if ( ! this.radial )//&& fontSize != fontSizeLast )
+		if ( true || ! this.radial )//&& fontSize != fontSizeLast )
 		{
 			var dim = context.measureText(this.name);
 			this.nameWidth = dim.width;
@@ -3459,14 +3539,14 @@
 	}
 	else
 	{
-		logoImage = 'http://krona.sourceforge.net/img/logo.png';
+		logoImage = 'http://marbl.github.io/Krona/img/logo-small.png';
 	}
 	
 //	document.getElementById('options').style.fontSize = '9pt';
 	position = addOptionElement
 	(
 		position,
-'<a style="margin:2px" target="_blank" href="http://krona.sourceforge.net"><div style="display:inline-block;vertical-align:middle;background-color:#EEEEEE;border:1px solid gray;padding:2px;font-size:18px"><img style="vertical-align:middle;" src="' + logoImage + '"/><span style="vertical-align:middle;color:#555555">Krona</span></div></a><input type="button" id="back" value="&larr;" title="Go back (Shortcut: &larr;)"/>\
+'<a style="margin:2px" target="_blank" href="https://github.com/marbl/Krona/wiki"><img style="vertical-align:middle;" src="' + logoImage + '"/></a><input type="button" id="back" value="&larr;" title="Go back (Shortcut: &larr;)"/>\
 <input type="button" id="forward" value="&rarr;" title="Go forward (Shortcut: &rarr;)"/> \
 &nbsp;Search: <input type="text" id="search"/>\
 <input id="searchClear" type="button" value="x" onclick="clearSearch()"/> \
@@ -3586,7 +3666,7 @@
 	(
 		position + 5,
 '<input type="button" id="help" value="?"\
-onclick="window.open(\'https://sourceforge.net/p/krona/wiki/Browsing%20Krona%20charts/\', \'help\')"/>',
+onclick="window.open(\'https://github.com/marbl/Krona/wiki/Browsing%20Krona%20charts\', \'help\')"/>',
 'Help'
 	);
 }
@@ -4753,7 +4833,7 @@
 	{
 		document.body.innerHTML = '\
 <br/>This browser does not support HTML5 (see \
-<a href="http://sourceforge.net/p/krona/wiki/Browser%20support/">Browser support</a>).\
+<a href="https://github.com/marbl/Krona/wiki/Browser%20support">Browser support</a>).\
 	';
 		return;
 	}
@@ -4762,7 +4842,7 @@
 	{
 		document.body.innerHTML = '\
 <br/>This browser does not support HTML5 canvas text (see \
-<a href="http://sourceforge.net/p/krona/wiki/Browser%20support/">Browser support</a>).\
+<a href="https://github.com/marbl/Krona/wiki/Browser%20support">Browser support</a>).\
 	';
 		return;
 	}
@@ -6507,7 +6587,7 @@
  <body>
   <img id="hiddenImage" src="" style="display:none"/>
   <img id="loadingImage" src="" style="display:none"/>
-  <img id="logo" src="" style="display:none"/>
+  <img id="logo" src="" style="display:none"/>
   <noscript>Javascript must be enabled to view this page.</noscript>
   <div style="display:none">
   <krona collapse="true" key="true">
@@ -6532,47 +6612,23 @@
     <rank><val>phylum</val></rank>
     <count><val>94</val></count>
     <node name="Craniata">
+     <rank><val>subphylum</val></rank>
      <count><val>94</val></count>
-     <rank><val>subphylum</val></rank>
      <node name="Gnathostomata">
       <count><val>94</val></count>
       <rank><val>superclass</val></rank>
       <node name="Mammalia">
+       <count><val>94</val></count>
        <rank><val>class</val></rank>
-       <count><val>94</val></count>
        <node name="Euarchontoglires">
+        <rank><val>superorder</val></rank>
         <count><val>94</val></count>
-        <rank><val>superorder</val></rank>
         <node name="Rodentia">
-         <count><val>94</val></count>
+         <members>
+          <vals><val>IA_1-144417</val><val>IA_1-278966</val><val>IA_1-314709</val><val>IA_1-324951</val><val>IA_1-27817</val><val>IA_1-95255</val><val>IA_1-104173</val><val>IA_1-135979</val><val>IA_1-139090</val><val>IA_1-139090</val><val>IA_1-139090</val><val>IA_1-144996</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-161439</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-216231</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-237681</val><val>IA_1-250166</val><val>IA_1-254274</val><val>IA_1-254274</val><val>IA_1-27817</val><val>IA_1-29000</val><val>IA_1-291427</val><val>IA_1-291427</val><val>IA_1-293054</val><val>IA_1-293054</val><val>IA_1-296315</val><val>IA_1-296315</val><val>IA_1-310974</val><val>IA_1-310974</val><val>IA_1-311282</val><val>IA_1-311282</val><val>IA_1-322295</val><val>IA_1-42600</val><val>IA_1-45102</val><val>IA_1-45102</val><val>IA_1-48105</val><val>IA_1-48105</val><val>IA_1-57254</val><val>IA_1-61975</val><val>IA_1-61975</val><val>IA_1-66943</val><val>IA_1-68288</val><val>IA_1-82334</val><val>IA_1-95526</val></vals>
+         </members>
          <rank><val>order</val></rank>
-         <node name="Sciurognathi">
-          <count><val>94</val></count>
-          <rank><val>suborder</val></rank>
-          <node name="Muridae">
-           <count><val>94</val></count>
-           <rank><val>family</val></rank>
-           <node name="Murinae">
-            <rank><val>subfamily</val></rank>
-            <count><val>94</val></count>
-            <node name="Rattus">
-             <rank><val>genus</val></rank>
-             <count><val>94</val></count>
-             <members>
-              <vals><val>IA_1-296315</val><val>IA_1-322295</val></vals>
-             </members>
-             <unassigned><val>2</val></unassigned>
-             <node name="Rattus norvegicus">
-              <rank><val>species</val></rank>
-              <count><val>92</val></count>
-              <members>
-               <vals><val>IA_1-144417</val><val>IA_1-278966</val><val>IA_1-314709</val><val>IA_1-324951</val><val>IA_1-27817</val><val>IA_1-95255</val><val>IA_1-104173</val><val>IA_1-135979</val><val>IA_1-139090</val><val>IA_1-139090</val><val>IA_1-139090</val><val>IA_1-144996</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-160446</val><val>IA_1-161439</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-190855</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-205154</val><val>IA_1-216231</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-236286</val><val>IA_1-237681</val><val>IA_1-250166</val><val>IA_1-254274</val><val>IA_1-254274</val><val>IA_1-27817</val><val>IA_1-29000</val><val>IA_1-291427</val><val>IA_1-291427</val><val>IA_1-293054</val><val>IA_1-293054</val><val>IA_1-296315</val><val>IA_1-310974</val><val>IA_1-310974</val><val>IA_1-311282</val><val>IA_1-311282</val><val>IA_1-42600</val><val>IA_1-45102</val><val>IA_1-45102</val><val>IA_1-48105</val><val>IA_1-48105</val><val>IA_1-57254</val><val>IA_1-61975</val><val>IA_1-61975</val><val>IA_1-66943</val><val>IA_1-68288</val><val>IA_1-82334</val><val>IA_1-95526</val></vals>
-              </members>
-             </node>
-            </node>
-           </node>
-          </node>
-         </node>
+         <count><val>94</val></count>
         </node>
        </node>
       </node>
@@ -6582,8 +6638,8 @@
   </node>
  </node>
  <node name="Bacteria">
+  <count><val>6</val></count>
   <rank><val>superkingdom</val></rank>
-  <count><val>6</val></count>
   <node name="Proteobacteria">
    <count><val>6</val></count>
    <rank><val>phylum</val></rank>
@@ -6597,8 +6653,8 @@
       <count><val>6</val></count>
       <rank><val>family</val></rank>
       <node name="Shigella">
+       <count><val>6</val></count>
        <rank><val>genus</val></rank>
-       <count><val>6</val></count>
        <node name="Shigella flexneri">
         <count><val>6</val></count>
         <rank><val>species</val></rank>