source: schedule/Module/calendar.php@ 16115

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