source: schedule/Module/calendar.php@ 16145

Last change on this file since 16145 was 16145, checked in by tanio, 12 years ago
File size: 8.6 KB
Line 
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 402'];
87 var options = {
88 chart: {
89 renderTo: 'container' /* display to div Graph*/
90
91 },
92
93 xAxis: {
94 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"]
95 },
96 series:[], /* array of Data */
97
98 remove:function()
99 {
100 return false;
101 },
102
103 exporting: { /*--------------------*/
104 buttons: { /* */
105 exportButton: { /* Export */
106 menuItems: null, /* to */
107 onclick: function() { /* PNG.file */
108 this.exportChart(); /*--------------------*/
109 }
110 }
111 }
112 },
113 plotOptions : {
114
115 series : {
116 lineWidth: 3,
117
118 marker : {
119 enabled:false
120 }
121 }
122 }
123 };
124 for(var i=0; i<source.length;i++)
125 {
126
127 if(window.XMLHttpRequest)
128 {
129 xml=new XMLHttpRequest();
130 }
131 else
132 {
133 xml=new ActiveXObject("Microsoft.XMLHTTP");
134 }
135 xml.onreadystatechange = function()
136 {
137 if(xml.readyState==4 && xml.status ==200)
138 {
139 var lines=xml.responseText.split("\n");
140 for(var row=0;row<lines.length;row++)
141 {
142 var splitted=lines[row].split(',');
143 Time1[row]=splitted[0];
144 for(var SplittedTime=0;SplittedTime<Time1.length;SplittedTime++)
145 {
146 var SplitTime=Time1[SplittedTime].split(':');
147 TimeColon[SplittedTime]=SplitTime[0];
148 MinTime[SplittedTime]=(parseInt(SplitTime[1]/60*100)||parseInt("0"));
149 for(var TimeT=0;TimeT<TimeColon.length;TimeT++)
150 {
151 var SplittedT=TimeColon[TimeT].split('T');
152 HourTime[TimeT]=(parseFloat(SplittedT[1])||parseInt('0'));
153 }
154 }
155 DataVal[row]=(parseFloat(splitted[4])||parseInt('0'));
156 for(var Data=0; Data<DataVal.length;Data++)
157 {
158 if(DataVal[Data]==0)
159 {
160
161 }
162 else
163 DataValue[i][Data]=parseFlaot(DataVal[Data]);
164 }
165 for(var ConTime=1;ConTime<HourTime.length-1;ConTime++)
166 {
167 if(HourTime[ConTime]=='0')
168 {
169 if(MinTime[ConTime]==8)
170 {
171 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
172 }
173 else
174 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
175 }
176 else if(HourTime[ConTime]=='1')
177 {
178 if(MinTime[ConTime]==8)
179 {
180 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
181 }
182 else
183 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
184 }
185 else if(HourTime[ConTime]==2)
186 {
187 if(MinTime[ConTime]==8)
188 {
189 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
190 }
191 else
192 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
193 }
194 else if(HourTime[ConTime]==3)
195 {
196 if(MinTime[ConTime]==8)
197 {
198 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
199 }
200 else
201 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
202 }
203 else if(HourTime[ConTime]==4)
204 {
205 if(MinTime[ConTime]==8)
206 {
207 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
208 }
209 else
210 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
211 }
212 else if(HourTime[ConTime]==5)
213 {
214 if(MinTime[ConTime]==8)
215 {
216 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
217 }
218 else
219 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
220 }
221 else if(HourTime[ConTime]==6)
222 {
223 if(MinTime[ConTime]==8)
224 {
225 Time[i][ConTime]=HourTime[ConTime]+24+'.'+'.08';
226 }
227 else
228 Time[i][ConTime]=HourTime[ConTime]+24+'.'+MinTime[ConTime];
229 }
230 else
231 Time[i][ConTime]=HourTime[ConTime]+'.'+MinTime[ConTime];
232
233 }
234 //GrapData(Data,Time);
235
236 }
237
238 var chart = new Highcharts.Chart(options);
239 for(var src=0;src<i;src++)
240 {
241 chart.addSeries({name:source[src], data:[]}); // created a series of data and add name of displayed source
242 for(var DataCnt=0;DataCnt<Data[src].length;DataCnt++)
243 {
244
245 chart.series[src].addPoint({ // series[0] means index of zero in data;
246 x:Time[src][DataCnt], // Time
247 y:DataValue[src][DataCnt] // Value
248 })
249
250 }
251
252 }
253
254
255 }
256 }
257 xml.open("GET","http://www.fact-project.org/smartfact/index.php?source="+escape(source[i])+"&time="+year+"-"+month+"-"+day,true);
258 xml.send();
259
260
261 }
262 $('#Graph').load('chart.php?day='+day+"&month="+month+"&year="+year);
263
264 });
265
266 //]]></script>
267 </td>
268 </tr>
269
270 </table>
271 </td>
272 </tr>
273 </table>
274
275 </body>
276</html>
277
278
Note: See TracBrowser for help on using the repository browser.