| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | 
|---|
| 2 | <html> | 
|---|
| 3 | <head> | 
|---|
| 4 | <link type="text/css" rel="stylesheet" href="Module/src/css/jscal2.css" /> | 
|---|
| 5 | <link type="text/css" rel="stylesheet" href="Module/src/css/border-radius.css" /> | 
|---|
| 6 |  | 
|---|
| 7 | <link id="skin-win2k" title="Win 2K" type="text/css" rel="alternate stylesheet" href="Module/src/css/win2k/win2k.css" /> | 
|---|
| 8 |  | 
|---|
| 9 | <script src="js/highcharts.js"></script> | 
|---|
| 10 | <script src="js/exporting.js"></script> | 
|---|
| 11 |  | 
|---|
| 12 | <script src="Module/src/js/jscal2.js"></script> | 
|---|
| 13 | <script src="Module/src/js/unicode-letter.js"></script> | 
|---|
| 14 |  | 
|---|
| 15 | <script src="Module/src/js/lang/en.js"></script> | 
|---|
| 16 | <style type="text/css"> | 
|---|
| 17 | .highlight { color: #f00 !important; } | 
|---|
| 18 | .highlight2 { color: #0f0 !important; font-weight: bold; } | 
|---|
| 19 | </style> | 
|---|
| 20 |  | 
|---|
| 21 | </head> | 
|---|
| 22 | <body style="background-color: #fff"> | 
|---|
| 23 |  | 
|---|
| 24 | <table> | 
|---|
| 25 | <tr> | 
|---|
| 26 | <td valign="top" style="width: 30em;"> | 
|---|
| 27 | <div id="cont"></div> | 
|---|
| 28 | <script type="text/javascript"> | 
|---|
| 29 | var DATE_INFO = { | 
|---|
| 30 | <?php | 
|---|
| 31 | $sqlSched=mysql_query("SELECT*FROM schedule"); | 
|---|
| 32 | $SchedCnt=mysql_num_rows($sqlSched); | 
|---|
| 33 | $cntr=1; | 
|---|
| 34 | while($rowSched=mysql_fetch_array($sqlSched)) | 
|---|
| 35 | { | 
|---|
| 36 | $timestamp=strtotime($rowSched['fStart']); | 
|---|
| 37 | if($SchedCnt==$cntr) | 
|---|
| 38 | { | 
|---|
| 39 | echo date("Ymd",$timestamp);?>:{klass: "highlight"}<?php | 
|---|
| 40 | } | 
|---|
| 41 | else | 
|---|
| 42 | { | 
|---|
| 43 | echo date("Ymd",$timestamp);?>:{klass: "highlight"},<?php | 
|---|
| 44 | } | 
|---|
| 45 | $cntr++; | 
|---|
| 46 | ?> | 
|---|
| 47 |  | 
|---|
| 48 | // 20130507: { klass: "highlight", tooltip: "%Y/%m/%d (%A)<br />That was yesterday" }, | 
|---|
| 49 | // 20130508: { klass: "highlight", tooltip: "And this is TODAY" } | 
|---|
| 50 | <?php | 
|---|
| 51 | } | 
|---|
| 52 | ?> | 
|---|
| 53 | }; | 
|---|
| 54 |  | 
|---|
| 55 | function getDateInfo(date, wantsClassName) { | 
|---|
| 56 | var as_number = Calendar.dateToInt(date); | 
|---|
| 57 | return DATE_INFO[as_number]; | 
|---|
| 58 | }; | 
|---|
| 59 | var CAL = Calendar.setup({ | 
|---|
| 60 | cont: "cont", | 
|---|
| 61 | // weekNumbers: true, | 
|---|
| 62 | selectionType: Calendar.SEL_MULTIPLE, | 
|---|
| 63 | showTime: 24, | 
|---|
| 64 | //fdow     : 1, | 
|---|
| 65 | dateInfo:getDateInfo | 
|---|
| 66 | // titleFormat: "%B %Y" | 
|---|
| 67 | }) | 
|---|
| 68 | </script> | 
|---|
| 69 | </td> | 
|---|
| 70 |  | 
|---|
| 71 | <tr> | 
|---|
| 72 | <td> | 
|---|
| 73 | <script type="text/javascript">//<![CDATA[ | 
|---|
| 74 | CAL.addEventListener("onSelect", function(){ | 
|---|
| 75 | var day =this.selection.print("%d").join("\n"); | 
|---|
| 76 | var month =this.selection.print("%m").join("\n"); | 
|---|
| 77 | var year =this.selection.print("%Y").join("\n"); | 
|---|
| 78 | var xml; | 
|---|
| 79 | var Time = [[]]; | 
|---|
| 80 | var DataValue = [[]]; | 
|---|
| 81 | var Time1 = []; | 
|---|
| 82 | var TimeColon = []; | 
|---|
| 83 | var MinTime = []; | 
|---|
| 84 | var HourTime = []; | 
|---|
| 85 | var DataVal = []; | 
|---|
| 86 | var source=['Crab','Mrk 501','Mrk 421']; | 
|---|
| 87 |  | 
|---|
| 88 | function loaddata() | 
|---|
| 89 | { | 
|---|
| 90 | for(var i=0; i<source.length;i++) | 
|---|
| 91 | { | 
|---|
| 92 |  | 
|---|
| 93 | if(window.XMLHttpRequest) | 
|---|
| 94 | { | 
|---|
| 95 | xml=new XMLHttpRequest(); | 
|---|
| 96 | } | 
|---|
| 97 | else | 
|---|
| 98 | { | 
|---|
| 99 | xml=new ActiveXObject("Microsoft.XMLHTTP"); | 
|---|
| 100 | } | 
|---|
| 101 | xml.onreadystatechange = function() | 
|---|
| 102 | { | 
|---|
| 103 | if(xml.readyState==4 && xml.status ==200) | 
|---|
| 104 | { | 
|---|
| 105 | var lines=xml.responseText.split("\n"); | 
|---|
| 106 | for(var row=0;row<lines.length;row++) | 
|---|
| 107 | { | 
|---|
| 108 | var splitted=lines[row].split(','); | 
|---|
| 109 | Time1[row]=splitted[0]; | 
|---|
| 110 | for(var SplittedTime=0;SplittedTime<Time1.length;SplittedTime++) | 
|---|
| 111 | { | 
|---|
| 112 | var SplitTime=Time1[SplittedTime].split(':'); | 
|---|
| 113 | TimeColon[SplittedTime]=SplitTime[0]; | 
|---|
| 114 | MinTime[SplittedTime]=(parseInt(SplitTime[1]/60*100)||parseInt("0")); | 
|---|
| 115 | for(var TimeT=0;TimeT<TimeColon.length;TimeT++) | 
|---|
| 116 | { | 
|---|
| 117 | var SplittedT=TimeColon[TimeT].split('T'); | 
|---|
| 118 | HourTime[TimeT]=(parseFloat(SplittedT[1])||parseInt('0')); | 
|---|
| 119 | } | 
|---|
| 120 | } | 
|---|
| 121 | DataVal[row]=(parseFloat(splitted[4])||parseInt('0')); | 
|---|
| 122 | //document.getElementById('data').innerHTML=DataValue; | 
|---|
| 123 |  | 
|---|
| 124 | for(var Data=0; Data<DataVal.length;Data++) | 
|---|
| 125 | { | 
|---|
| 126 | if(DataVal[Data]==0) | 
|---|
| 127 | { | 
|---|
| 128 |  | 
|---|
| 129 | } | 
|---|
| 130 | else | 
|---|
| 131 | DataValue.push(parseFloat(DataVal[Data])); | 
|---|
| 132 | } | 
|---|
| 133 |  | 
|---|
| 134 |  | 
|---|
| 135 | for(var ConTime=1;ConTime<HourTime.length-1;ConTime++) | 
|---|
| 136 | { | 
|---|
| 137 | if(HourTime[ConTime]==0) | 
|---|
| 138 | { | 
|---|
| 139 | if(MinTime[ConTime]==8) | 
|---|
| 140 | { | 
|---|
| 141 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 142 | } | 
|---|
| 143 | else | 
|---|
| 144 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 145 | } | 
|---|
| 146 | else if(HourTime[ConTime]==1) | 
|---|
| 147 | { | 
|---|
| 148 | if(MinTime[ConTime]==8) | 
|---|
| 149 | { | 
|---|
| 150 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 151 | } | 
|---|
| 152 | else | 
|---|
| 153 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 154 | } | 
|---|
| 155 | else if(HourTime[ConTime]==2) | 
|---|
| 156 | { | 
|---|
| 157 | if(MinTime[ConTime]==8) | 
|---|
| 158 | { | 
|---|
| 159 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 160 | } | 
|---|
| 161 | else | 
|---|
| 162 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 163 | } | 
|---|
| 164 | else if(HourTime[ConTime]==3) | 
|---|
| 165 | { | 
|---|
| 166 | if(MinTime[ConTime]==8) | 
|---|
| 167 | { | 
|---|
| 168 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 169 | } | 
|---|
| 170 | else | 
|---|
| 171 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 172 | } | 
|---|
| 173 | else if(HourTime[ConTime]==4) | 
|---|
| 174 | { | 
|---|
| 175 | if(MinTime[ConTime]==8) | 
|---|
| 176 | { | 
|---|
| 177 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 178 | } | 
|---|
| 179 | else | 
|---|
| 180 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 181 | } | 
|---|
| 182 | else if(HourTime[ConTime]==5) | 
|---|
| 183 | { | 
|---|
| 184 | if(MinTime[ConTime]==8) | 
|---|
| 185 | { | 
|---|
| 186 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 187 | } | 
|---|
| 188 | else | 
|---|
| 189 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 190 | } | 
|---|
| 191 | else if(HourTime[ConTime]==6) | 
|---|
| 192 | { | 
|---|
| 193 | if(MinTime[ConTime]==8) | 
|---|
| 194 | { | 
|---|
| 195 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 196 | } | 
|---|
| 197 | else | 
|---|
| 198 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 199 | } | 
|---|
| 200 | else | 
|---|
| 201 | Time.push(HourTime[ConTime]+'.'+MinTime[ConTime]); | 
|---|
| 202 |  | 
|---|
| 203 | } | 
|---|
| 204 |  | 
|---|
| 205 | //GrapData(Data,Time); | 
|---|
| 206 |  | 
|---|
| 207 | } | 
|---|
| 208 |  | 
|---|
| 209 |  | 
|---|
| 210 | } | 
|---|
| 211 | } | 
|---|
| 212 | xml.open("GET","http://www.fact-project.org/smartfact/index.php?source="+escape(source[i])+"&time="+year+"-"+month+"-"+day,true); | 
|---|
| 213 | xml.send(); | 
|---|
| 214 |  | 
|---|
| 215 |  | 
|---|
| 216 | } | 
|---|
| 217 | loadGraph(DataValue,Time); | 
|---|
| 218 | }, | 
|---|
| 219 | var options = { | 
|---|
| 220 | chart: { | 
|---|
| 221 | renderTo: 'container' | 
|---|
| 222 | /* display to div Graph*/ | 
|---|
| 223 |  | 
|---|
| 224 | }, | 
|---|
| 225 |  | 
|---|
| 226 | xAxis: { | 
|---|
| 227 | categories:["12PM","1PM","2PM","3PM","4PM","5PM","6PM","7PM","8PM","9PM","10PM","11PM","12AM","1AM","2AM","3AM","4AM","5AM","6AM","7AM","8AM","9AM","10AM","12PM"] | 
|---|
| 228 | }, | 
|---|
| 229 | series:[], /* array of Data  */ | 
|---|
| 230 |  | 
|---|
| 231 | remove:function() | 
|---|
| 232 | { | 
|---|
| 233 | return false; | 
|---|
| 234 | }, | 
|---|
| 235 |  | 
|---|
| 236 | exporting: {                                                   /*--------------------*/ | 
|---|
| 237 | buttons: {                                                      /*                                        */ | 
|---|
| 238 | exportButton: {                                 /*              Export            */ | 
|---|
| 239 | menuItems: null,                        /*                to              */ | 
|---|
| 240 | onclick: function() {           /*                      PNG.file  */ | 
|---|
| 241 | this.exportChart();             /*--------------------*/ | 
|---|
| 242 | } | 
|---|
| 243 | } | 
|---|
| 244 | } | 
|---|
| 245 | }, | 
|---|
| 246 | plotOptions : { | 
|---|
| 247 |  | 
|---|
| 248 | series : { | 
|---|
| 249 | lineWidth: 3, | 
|---|
| 250 |  | 
|---|
| 251 | marker : { | 
|---|
| 252 | enabled:false | 
|---|
| 253 | } | 
|---|
| 254 | } | 
|---|
| 255 | } | 
|---|
| 256 | }; | 
|---|
| 257 |  | 
|---|
| 258 |  | 
|---|
| 259 | function loadGraph(x,y) | 
|---|
| 260 | { | 
|---|
| 261 | var chart = new Highcharts.Chart(options); | 
|---|
| 262 | for(var src=0;src<i;src++) | 
|---|
| 263 | { | 
|---|
| 264 | chart.addSeries({name:source[src], data:[]}); // created a series of data and add name of displayed source | 
|---|
| 265 | for(var DataCnt=0;DataCnt<x[src].length;DataCnt++) | 
|---|
| 266 | { | 
|---|
| 267 |  | 
|---|
| 268 | chart.series[src].addPoint({ // series[0] means index of zero in data; | 
|---|
| 269 | x:x[src][DataCnt], // Time | 
|---|
| 270 | y:y[src][DataCnt] // Value | 
|---|
| 271 | }) | 
|---|
| 272 |  | 
|---|
| 273 |  | 
|---|
| 274 | } | 
|---|
| 275 |  | 
|---|
| 276 | } | 
|---|
| 277 | document.getElementById('data').innerHTML=x; | 
|---|
| 278 | } | 
|---|
| 279 | loadGraph(); | 
|---|
| 280 | $('#Graph').load('chart.php?day='+day+"&month="+month+"&year="+year); | 
|---|
| 281 |  | 
|---|
| 282 | }); | 
|---|
| 283 |  | 
|---|
| 284 | //]]></script> | 
|---|
| 285 |  | 
|---|
| 286 | </td> | 
|---|
| 287 | </tr> | 
|---|
| 288 |  | 
|---|
| 289 | </table> | 
|---|
| 290 | </td> | 
|---|
| 291 | </tr> | 
|---|
| 292 | </table> | 
|---|
| 293 |  | 
|---|
| 294 | </body> | 
|---|
| 295 | </html> | 
|---|
| 296 |  | 
|---|
| 297 |  | 
|---|