| 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 | <script src="Module/Graph.js"></script> | 
|---|
| 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 | Graph(); | 
|---|
| 88 | for(var i=0; i<source.length;i++) | 
|---|
| 89 | { | 
|---|
| 90 |  | 
|---|
| 91 | if(window.XMLHttpRequest) | 
|---|
| 92 | { | 
|---|
| 93 | xml=new XMLHttpRequest(); | 
|---|
| 94 | } | 
|---|
| 95 | else | 
|---|
| 96 | { | 
|---|
| 97 | xml=new ActiveXObject("Microsoft.XMLHTTP"); | 
|---|
| 98 | } | 
|---|
| 99 | xml.onreadystatechange = function() | 
|---|
| 100 | { | 
|---|
| 101 | if(xml.readyState==4 && xml.status ==200) | 
|---|
| 102 | { | 
|---|
| 103 | var lines=xml.responseText.split("\n"); | 
|---|
| 104 | for(var row=0;row<lines.length;row++) | 
|---|
| 105 | { | 
|---|
| 106 | var splitted=lines[row].split(','); | 
|---|
| 107 | Time1[row]=splitted[0]; | 
|---|
| 108 | for(var SplittedTime=0;SplittedTime<Time1.length;SplittedTime++) | 
|---|
| 109 | { | 
|---|
| 110 | var SplitTime=Time1[SplittedTime].split(':'); | 
|---|
| 111 | TimeColon[SplittedTime]=SplitTime[0]; | 
|---|
| 112 | MinTime[SplittedTime]=(parseInt(SplitTime[1]/60*100)||parseInt("0")); | 
|---|
| 113 | for(var TimeT=0;TimeT<TimeColon.length;TimeT++) | 
|---|
| 114 | { | 
|---|
| 115 | var SplittedT=TimeColon[TimeT].split('T'); | 
|---|
| 116 | HourTime[TimeT]=(parseFloat(SplittedT[1])||parseInt('0')); | 
|---|
| 117 | } | 
|---|
| 118 | } | 
|---|
| 119 | DataVal[row]=(parseFloat(splitted[4])||parseInt('0')); | 
|---|
| 120 | //document.getElementById('data').innerHTML=DataValue; | 
|---|
| 121 |  | 
|---|
| 122 | for(var Data=0; Data<DataVal.length;Data++) | 
|---|
| 123 | { | 
|---|
| 124 | if(DataVal[Data]==0) | 
|---|
| 125 | { | 
|---|
| 126 |  | 
|---|
| 127 | } | 
|---|
| 128 | else | 
|---|
| 129 | DataValue.push(parseFloat(DataVal[Data])); | 
|---|
| 130 | } | 
|---|
| 131 |  | 
|---|
| 132 |  | 
|---|
| 133 | for(var ConTime=1;ConTime<HourTime.length-1;ConTime++) | 
|---|
| 134 | { | 
|---|
| 135 | if(HourTime[ConTime]==0) | 
|---|
| 136 | { | 
|---|
| 137 | if(MinTime[ConTime]==8) | 
|---|
| 138 | { | 
|---|
| 139 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 140 | } | 
|---|
| 141 | else | 
|---|
| 142 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 143 | } | 
|---|
| 144 | else if(HourTime[ConTime]==1) | 
|---|
| 145 | { | 
|---|
| 146 | if(MinTime[ConTime]==8) | 
|---|
| 147 | { | 
|---|
| 148 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 149 | } | 
|---|
| 150 | else | 
|---|
| 151 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 152 | } | 
|---|
| 153 | else if(HourTime[ConTime]==2) | 
|---|
| 154 | { | 
|---|
| 155 | if(MinTime[ConTime]==8) | 
|---|
| 156 | { | 
|---|
| 157 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 158 | } | 
|---|
| 159 | else | 
|---|
| 160 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 161 | } | 
|---|
| 162 | else if(HourTime[ConTime]==3) | 
|---|
| 163 | { | 
|---|
| 164 | if(MinTime[ConTime]==8) | 
|---|
| 165 | { | 
|---|
| 166 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 167 | } | 
|---|
| 168 | else | 
|---|
| 169 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 170 | } | 
|---|
| 171 | else if(HourTime[ConTime]==4) | 
|---|
| 172 | { | 
|---|
| 173 | if(MinTime[ConTime]==8) | 
|---|
| 174 | { | 
|---|
| 175 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 176 | } | 
|---|
| 177 | else | 
|---|
| 178 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 179 | } | 
|---|
| 180 | else if(HourTime[ConTime]==5) | 
|---|
| 181 | { | 
|---|
| 182 | if(MinTime[ConTime]==8) | 
|---|
| 183 | { | 
|---|
| 184 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 185 | } | 
|---|
| 186 | else | 
|---|
| 187 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 188 | } | 
|---|
| 189 | else if(HourTime[ConTime]==6) | 
|---|
| 190 | { | 
|---|
| 191 | if(MinTime[ConTime]==8) | 
|---|
| 192 | { | 
|---|
| 193 | Time.push(HourTime[ConTime]+24+'.'+'.08'); | 
|---|
| 194 | } | 
|---|
| 195 | else | 
|---|
| 196 | Time.push(HourTime[ConTime]+24+'.'+MinTime[ConTime]); | 
|---|
| 197 | } | 
|---|
| 198 | else | 
|---|
| 199 | Time.push(HourTime[ConTime]+'.'+MinTime[ConTime]); | 
|---|
| 200 |  | 
|---|
| 201 | } | 
|---|
| 202 |  | 
|---|
| 203 | //GrapData(Data,Time); | 
|---|
| 204 |  | 
|---|
| 205 | } | 
|---|
| 206 |  | 
|---|
| 207 | var chart = new Highcharts.Chart(options); | 
|---|
| 208 | for(var src=0;src<i;src++) | 
|---|
| 209 | { | 
|---|
| 210 | chart.addSeries({name:source[src], data:[]}); // created a series of data and add name of displayed source | 
|---|
| 211 | for(var DataCnt=0;DataCnt<DataValue[src].length;DataCnt++) | 
|---|
| 212 | { | 
|---|
| 213 |  | 
|---|
| 214 | chart.series[src].addPoint({ // series[0] means index of zero in data; | 
|---|
| 215 | x:Time[src][DataCnt], // Time | 
|---|
| 216 | y:DataValue[src][DataCnt] // Value | 
|---|
| 217 | }) | 
|---|
| 218 | //document.getElementById('data').innerHTML=Time[src][DataCnt]; | 
|---|
| 219 |  | 
|---|
| 220 | } | 
|---|
| 221 |  | 
|---|
| 222 | } | 
|---|
| 223 |  | 
|---|
| 224 |  | 
|---|
| 225 | } | 
|---|
| 226 | } | 
|---|
| 227 | xml.open("GET","http://www.fact-project.org/smartfact/index.php?source="+escape(source[i])+"&time="+year+"-"+month+"-"+day,true); | 
|---|
| 228 | xml.send(); | 
|---|
| 229 |  | 
|---|
| 230 |  | 
|---|
| 231 | } | 
|---|
| 232 | $('#Graph').load('chart.php?day='+day+"&month="+month+"&year="+year); | 
|---|
| 233 |  | 
|---|
| 234 | }); | 
|---|
| 235 |  | 
|---|
| 236 | //]]></script> | 
|---|
| 237 | </td> | 
|---|
| 238 | </tr> | 
|---|
| 239 |  | 
|---|
| 240 | </table> | 
|---|
| 241 | </td> | 
|---|
| 242 | </tr> | 
|---|
| 243 | </table> | 
|---|
| 244 |  | 
|---|
| 245 | </body> | 
|---|
| 246 | </html> | 
|---|
| 247 |  | 
|---|
| 248 |  | 
|---|