mirror of https://github.com/CIRCL/AIL-framework
				
				
				
			
		
			
				
	
	
		
			276 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			276 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			HTML
		
	
	
| <!DOCTYPE html>
 | |
| <html>
 | |
| 
 | |
| <head>
 | |
|   <meta charset="utf-8">
 | |
|   <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
| 
 | |
|   <title>Terms Plot Tool - AIL</title>
 | |
|   <link rel="icon" href="{{ url_for('static', filename='image/ail-icon.png') }}">
 | |
| 
 | |
|   <!-- Core CSS -->
 | |
|   <link href="{{ url_for('static', filename='css/bootstrap.min.css') }}" rel="stylesheet">
 | |
|   <link href="{{ url_for('static', filename='font-awesome/css/font-awesome.css') }}" rel="stylesheet">
 | |
|   <link href="{{ url_for('static', filename='css/sb-admin-2.css') }}" rel="stylesheet">
 | |
|   <link href="{{ url_for('static', filename='css/dataTables.bootstrap.css') }}" rel="stylesheet" type="text/css" />
 | |
|   <link href="{{ url_for('static', filename='css/jquery-ui.min.css') }}" rel="stylesheet" type="text/css" />
 | |
|   <link href="{{ url_for('static', filename='css/switch_checkbox.css') }}" rel="stylesheet" type="text/css" />
 | |
|   <script language="javascript" src="{{ url_for('static', filename='js/jquery.js')}}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/bootstrap.min.js') }}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/jquery.dataTables.min.js') }}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/dataTables.bootstrap.js') }}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/jquery-ui.min.js') }}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/jquery.flot.js') }}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/jquery.flot.time.js') }}"></script>
 | |
|   <script src="{{ url_for('static', filename='js/jquery.flot.stack.js') }}"></script>
 | |
| 
 | |
|   <style>
 | |
|       .sparkLineStats ul {
 | |
|           padding-left:0;
 | |
|           list-style:none
 | |
|       }
 | |
|   </style>
 | |
| </head>
 | |
| <body>
 | |
| 
 | |
|    {% include 'navbar.html' %}
 | |
| 
 | |
| <div id="page-wrapper">
 | |
|   <div class="row">
 | |
|       <div class="col-lg-12">
 | |
|           <h1 class="page-header" data-page="page-termsfrequency" >Terms plot tool</h1>
 | |
|       </div>
 | |
|       <!-- /.col-lg-12 -->
 | |
|   </div>
 | |
|     <!-- /.row -->
 | |
|     <div class="row">
 | |
| 
 | |
|     <!-- Panel OPTIONS -->
 | |
|     <div class="row">
 | |
|         <div class="col-lg-12">
 | |
|             <div class="row">
 | |
|                 <div class="col-lg-12">
 | |
|                     <div id="panel-today" class="panel panel-default">
 | |
|                         <div class="panel-heading">
 | |
|                             <strong>Select options</strong>
 | |
|                         </div>
 | |
|                         <div class="panel-body">
 | |
|                             <div aria-disabled="false" class="slider sliderRange sliderBlue ui-slider ui-slider-horizontal ui-widget ui-widget-content ui-corner-all" style="margin-bottom: 5px;"></div>
 | |
|                             <strong>Date:</strong> <input type="text" id="amount" readonly style="border:0; color:#f6931f; font-weight:bold;"> <button id="plot-month" onclick="replot();" class="btn btn-info" style="float: right;">Replot</button>
 | |
| 
 | |
|                             <div class="form-group input-group" style="margin-top: 30px;">
 | |
|                                 <span class="input-group-addon"><span class="glyphicon glyphicon-stats"></span></span>
 | |
|                                 <input id="TermInput" class="form-control" placeholder="Term to plot" type="text" style="max-width: 400px;" data-init-plot="{{ term }}">
 | |
|                                 <button id="plot-btn" class="btn btn-info" style="margin-left: 10px;"><span class="fa fa-caret-down"> Plot a term</button>
 | |
|                                 <button id="plot-btn-add" class="btn btn-success" style="margin-left: 6px;"><span class="fa fa-plus"></span> Add the term to the chart</button>
 | |
|                             </div>
 | |
| 
 | |
|                             <div class='pull_right' style="float: right;">
 | |
|                                 <label class="switch">
 | |
|                                     <input id="per_paste" class="switch-input" value="per_paste" type="checkbox" checked>
 | |
|                                     <span class="switch-label" data-on="On" data-off="Off"></span>
 | |
|                                     <span class="switch-handle"></span>
 | |
|                                 </label>
 | |
|                                 <strong style="top: 3px; position: relative;">1 term per paste</strong>
 | |
|                             </div>
 | |
| 
 | |
|                         </div>
 | |
|                         <!-- /.panel-body -->
 | |
|                     </div>
 | |
|                 </div>
 | |
|                 <!-- /.panel -->
 | |
|             </div>
 | |
|             <!-- /.panel -->
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
|     <!-- Panel PLOT -->
 | |
|     <div class="row">
 | |
|         <div class="col-lg-12">
 | |
|             <div class="row">
 | |
|                 <div class="col-lg-12">
 | |
|                     <div id="panel-today" class="panel panel-default">
 | |
|                         <div class="panel-heading">
 | |
|                             <strong>Graph</strong>
 | |
|                         </div>
 | |
|                         <div class="panel-body">
 | |
|                             <div id="graph" style="height: 300px;"></div>
 | |
|                         </div>
 | |
|                         <!-- /.panel-body -->
 | |
|                     </div>
 | |
|                 </div>
 | |
|                 <!-- /.panel -->
 | |
|             </div>
 | |
|             <!-- /.panel -->
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
| 
 | |
|     <!-- /.row -->
 | |
|     </div>
 | |
| <!-- /#page-wrapper -->
 | |
| </div>
 | |
| 
 | |
| 
 | |
| <div style="position: absolute; border: 1px solid rgb(255, 221, 221); padding: 2px; background-color: #333; color:white; opacity: 0.8; top: 423px; left: 616px; display: none;" id="tooltip"></div>
 | |
| 
 | |
| 
 | |
| <!-- import graph function -->
 | |
| <script>
 | |
|     $(document).ready(function(){
 | |
|         activePage = $('h1.page-header').attr('data-page');
 | |
|         $("#"+activePage).addClass("active");
 | |
| 
 | |
| 
 | |
|         /* Create the slider and button*/
 | |
|         $('#plot-btn-add').hide();
 | |
|         var today = Date.now();
 | |
|         var old_day = today - (12*31*24*60*60)*1000;
 | |
|         $( ".sliderRange" ).slider({
 | |
|             range: true,
 | |
|             min: old_day,
 | |
|             max: today,
 | |
|             values: [ today - (7*24*60*60)*1000, today ],
 | |
|             step: 24*60*60*1000,
 | |
|             slide: function( event, ui ) {
 | |
|                 $( "#amount" ).val( new Date(ui.values[ 0 ]).toLocaleDateString() + " - " + new Date(ui.values[ 1 ]).toLocaleDateString() );
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         $( "#amount" ).val( new Date($( ".sliderRange" ).slider( "values", 0 )).toLocaleDateString() +
 | |
|           " - " + new Date($( ".sliderRange" ).slider( "values", 1 )).toLocaleDateString() );
 | |
| 
 | |
|         $('#plot-btn').click(plotData);
 | |
|         $('#plot-btn-add').click(addData);
 | |
| 
 | |
|         $("#TermInput").val($("#TermInput").attr("data-init-plot"));
 | |
|         if($("#TermInput").attr("data-init-plot") != "") {
 | |
|             $("#plot-btn").click();
 | |
|         }
 | |
| 
 | |
|         $("#TermInput").keyup(function(event){
 | |
|             if(event.keyCode == 13){
 | |
|                 $("#plot-btn").click();
 | |
|                 $("#TermInput").val("");
 | |
|             }
 | |
|         });
 | |
| 
 | |
|    });
 | |
| </script>
 | |
| 
 | |
| <script>
 | |
| var plot;
 | |
| var graph_data = [];
 | |
| var plotted_terms = [];
 | |
| var graph_options = {
 | |
|                         series: {
 | |
|                             lines: {
 | |
|                                 show: true,
 | |
|                                 lineWidth: 2
 | |
|                             },
 | |
|                             bars: {show: false, barWidth: 60*60*1000},
 | |
|                             shadowSize: 0
 | |
|                         },
 | |
|                         grid: {
 | |
|                             hoverable: true,
 | |
|                             clickable: true,
 | |
|                             tickColor: "#f9f9f9",
 | |
|                             borderWidth: 0
 | |
|                         },
 | |
|                         xaxis: {
 | |
|                               mode: "time",
 | |
|                               timeformat: "%m/%d",
 | |
|                               minTickSize: [1, "day"]
 | |
|                         },
 | |
|                         yaxis: {
 | |
|                             autoscaleMargin: 0.1,
 | |
|                         },
 | |
|                     }
 | |
| 
 | |
| 
 | |
| function plotData() {
 | |
|     $('#plot-btn-add').show("fast");
 | |
|     var curthis = $(this);
 | |
|     var term = $('#TermInput').val();
 | |
|     plotted_terms = [term]
 | |
|     var range_start = new Date($( ".sliderRange" ).slider( "values", 0 )).getTime() / 1000;
 | |
|     var range_end = new Date($( ".sliderRange" ).slider( "values", 1 )).getTime() / 1000;
 | |
|     var checked = $("#per_paste").prop( "checked" ) ? 1 : 0;
 | |
| 
 | |
|     $.getJSON("{{ url_for('terms.terms_plot_tool_data') }}", { range_start: range_start, range_end: range_end, term: term, per_paste: checked }, function(data, status){
 | |
|         graph_data = [];
 | |
|         var to_plot = [];
 | |
|         var curr_data = [];
 | |
|         for(i=1; i<data.length; i++) {
 | |
|             curr_data.push([data[i][0]*1000, data[i][1]]);
 | |
|         }
 | |
|         to_plot.push({ data: curr_data, label: term});
 | |
|         graph_data.push({ data: curr_data, label: term});
 | |
|         plot = $.plot($("#graph"), to_plot, graph_options);
 | |
| 
 | |
|         $("#graph").bind("plothover", function (event, pos, item) {
 | |
|             if (item) {
 | |
|                 var date = new Date(item.datapoint[0]);
 | |
|                 var x = parseInt(date.getUTCMonth())+1 + "/" + date.getUTCDate();
 | |
|                 var y = item.datapoint[1];
 | |
| 
 | |
|                 $("#tooltip").html(item.series.label + " for "+x + " = " + y)
 | |
|                     .css({top: item.pageY-15, left: item.pageX+5})
 | |
|                     .fadeIn(200);
 | |
|             } else {
 | |
|                 $("#tooltip").hide();
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         $("#TermInput").val("");
 | |
|     })
 | |
| }
 | |
| 
 | |
| 
 | |
| function addData() {
 | |
|     var curthis = $(this);
 | |
|     var term = $('#TermInput').val();
 | |
|     plotted_terms.push(term)
 | |
|     var range_start = new Date($( ".sliderRange" ).slider( "values", 0 )).getTime() / 1000;
 | |
|     var range_end = new Date($( ".sliderRange" ).slider( "values", 1 )).getTime() / 1000;
 | |
|     var checked = $("#per_paste").prop( "checked" ) ? 1 : 0;
 | |
| 
 | |
|     $.getJSON("{{ url_for('terms.terms_plot_tool_data') }}", { range_start: range_start, range_end: range_end, term: term, per_paste: checked }, function(data, status){
 | |
|         var curr_data = [];
 | |
|         for(i=1; i<data.length; i++) {
 | |
|                 curr_data.push([data[i][0]*1000, data[i][1]]);
 | |
|         }
 | |
|         graph_data.push({ data: curr_data, label: term});
 | |
|         plot = $.plot($("#graph"), graph_data, graph_options);
 | |
|         $("#TermInput").val("");
 | |
|     })
 | |
| }
 | |
| 
 | |
| 
 | |
| function replot() {
 | |
|     graph_data = [];
 | |
|     promises = [];
 | |
|     for(i=0; i<plotted_terms.length; i++) {
 | |
|         var term = plotted_terms[i];
 | |
|         var range_start = new Date($( ".sliderRange" ).slider( "values", 0 )).getTime() / 1000;
 | |
|         var range_end = new Date($( ".sliderRange" ).slider( "values", 1 )).getTime() / 1000;
 | |
|         var checked = $("#per_paste").prop( "checked" ) ? 1 : 0;
 | |
| 
 | |
|         promises.push($.getJSON("{{ url_for('terms.terms_plot_tool_data') }}", { range_start: range_start, range_end: range_end, term: term, per_paste: checked }, function(data, status){
 | |
|             var curr_data = [];
 | |
|             for(i=1; i<data.length; i++) {
 | |
|                     curr_data.push([data[i][0]*1000, data[i][1]]);
 | |
|             }
 | |
|             graph_data.push({ data: curr_data, label: data[0]});
 | |
|             $("#TermInput").val("");
 | |
|         }))
 | |
|     }
 | |
| 
 | |
|     $.when.apply($, promises).done( function () {
 | |
|         plot = $.plot($("#graph"), graph_data, graph_options);
 | |
|     });
 | |
| 
 | |
| }
 | |
| 
 | |
| </script>
 |