• R/O
  • SSH
  • HTTPS

shibuya-trac: Commit


Commit MetaInfo

Revision800 (tree)
Zeit2011-06-01 12:23:49
Autorkanu

Log Message

merge from 0.5-SNAPSHOT for 0.11

Ändern Zusammenfassung

Diff

--- plugins/reportincludeplugin/trunk/0.12/reportinclude/tests/__init__.py (nonexistent)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/tests/__init__.py (revision 800)
@@ -0,0 +1,9 @@
1+import unittest
2+
3+def suite():
4+ suite = unittest.TestSuite()
5+ suite.addTest(dateutils_test.suite())
6+ return suite
7+
8+if __name__ == '__main__':
9+ unittest.main(defaultTest="suite")
\ No newline at end of file
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/tests/renderer_test.py (nonexistent)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/tests/renderer_test.py (revision 800)
@@ -0,0 +1,136 @@
1+# -*- coding: utf-8 -*-
2+
3+import sys
4+import os
5+import re
6+import unittest
7+
8+script_dir = os.path.dirname(os.path.abspath(__file__))
9+base_dir = script_dir + os.sep + '../'
10+if not base_dir in sys.path:
11+ sys.path.insert(0, base_dir)
12+
13+from renderer import ReportRenderer
14+
15+class ComponentManagerStub(object):
16+ components = {}
17+
18+ def component_activated(self, dummy):
19+ pass
20+
21+ def get_db_cnx(self):
22+ return DBStub()
23+
24+class RequestStub(object):
25+ def __init__(self):
26+ self.href = HrefStub()
27+ self.tz = None
28+
29+class HrefStub(object):
30+ def worktime(self, id):
31+ return 'worktime/%s' % id
32+
33+class ConfigStub(object):
34+ def get(self, tag, key):
35+ pass
36+
37+class DBStub(object):
38+ def __init__(self, row=None):
39+ self.row = row
40+
41+ def cursor(self):
42+ print "cursor"
43+ return self
44+
45+ def execute(self, sql , args):
46+ print "excecute"
47+ return self
48+
49+ def fetchone(self):
50+ print "fetchone"
51+ return self.row
52+
53+ def commit(self):
54+ print "commit"
55+
56+class RendererTest(unittest.TestCase):
57+
58+ def setUp(self):
59+ self.env = ComponentManagerStub()
60+ self.req = RequestStub()
61+ self.db = DBStub()
62+
63+ def test_getXAxisType(self):
64+ renderer = ReportRenderer(self.env)
65+
66+ type = renderer._getXAxisType(self.req, ['2011-04-31'], [])
67+ self.assertEqual("string", type)
68+
69+ type = renderer._getXAxisType(self.req, ['2011-04-30'], [])
70+ self.assertEqual("date", type)
71+
72+ type = renderer._getXAxisType(self.req, [100, 110], [])
73+ self.assertEqual("number", type)
74+
75+ type = renderer._getXAxisType(self.req, ["100", "110"], [])
76+ self.assertEqual("number", type)
77+
78+ def test_to_js_array(self):
79+ renderer = ReportRenderer(self.env)
80+
81+ result = renderer._to_js_array([1, 2, 3])
82+ self.assertEqual("[1,2,3]", result)
83+
84+ result = renderer._to_js_array([1, 'a', 3])
85+ self.assertEqual("['1','a','3']", result)
86+
87+ result = renderer._to_js_array([])
88+ self.assertEqual("[]", result)
89+
90+ result = renderer._to_js_array(None)
91+ self.assertEqual("null", result)
92+
93+ def test_convert_col(self):
94+ renderer = ReportRenderer(self.env)
95+
96+ col = renderer._convert_col(self.req, 'test', '1')
97+ self.assertEqual('1', col)
98+
99+ col = renderer._convert_col(self.req, '時刻', '100000')
100+ self.assertEqual('12:46:40', col)
101+
102+ col = renderer._convert_col(self.req, '日付', '100000')
103+ self.assertEqual('1970/01/02', col)
104+
105+ col = renderer._convert_col(self.req, '日時', '100000')
106+ self.assertEqual('1970/01/02 12:46:40', col)
107+
108+ col = renderer._convert_col(self.req, 'time', '100000')
109+ self.assertEqual('12:46:40', col)
110+
111+ col = renderer._convert_col(self.req, 'date', '100000')
112+ self.assertEqual('1970/01/02', col)
113+
114+ col = renderer._convert_col(self.req, 'datetime', '100000')
115+ self.assertEqual('1970/01/02 12:46:40', col)
116+
117+ def ticket(id):
118+ return '/ticket/%s' % id
119+ self.req.href.ticket = ticket
120+
121+ col = renderer._convert_col(self.req, 'ticket', '100')
122+ self.assertEqual('<a class="ticket" href="/ticket/100" title="View Ticket">#100</a>',
123+ str(col))
124+
125+ col = renderer._convert_col(self.req, 'id', '100')
126+ self.assertEqual('<a class="ticket" href="/ticket/100" title="View Ticket">#100</a>',
127+ str(col))
128+
129+ col = renderer._convert_col(self.req, 'チケット', '100')
130+ self.assertEqual('<a class="ticket" href="/ticket/100" title="View Ticket">#100</a>',
131+ str(col))
132+
133+
134+if __name__ == '__main__':
135+ unittest.main()
136+
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/test.html (nonexistent)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/test.html (revision 800)
@@ -0,0 +1,233 @@
1+<html>
2+<head>
3+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
4+<title>test</title>
5+<script type="text/javascript" src="/test/chrome/common/js/jquery.js"></script>
6+<script type="text/javascript" src="/test/chrome/common/js/trac.js"></script>
7+<link rel="stylesheet" type="text/css"
8+ href="/test/chrome/reportinclude/css/jqplot/jquery.jqplot.min.css">
9+</head>
10+<body>
11+
12+<script type="text/javascript">
13+ jQuery.loadStyleSheet("/test/chrome/reportinclude/css/jqplot/jquery.jqplot.min.css", "text/css");
14+</script>
15+<script type="text/javascript"
16+ src="/test/chrome/reportinclude/js/jquery-1.4.4.js"></script>
17+<script type="text/javascript"
18+ src="/test/chrome/reportinclude/js/jqplot/excanvas.min.js"></script>
19+<script type="text/javascript"
20+ src="/test/chrome/reportinclude/js/jqplot/jquery.jqplot.min.js"></script>
21+<script type="text/javascript"
22+ src="/test/chrome/reportinclude/js/jqplot/jqplot.pointLabels.min.js"></script>
23+<script type="text/javascript"
24+ src="/test/chrome/reportinclude/js/jqplot/jqplot.barRenderer.min.js"></script>
25+<script type="text/javascript"
26+ src="/test/chrome/reportinclude/js/jqplot/jqplot.pieRenderer.min.js"></script>
27+<script type="text/javascript"
28+ src="/test/chrome/reportinclude/js/jqplot/jqplot.categoryAxisRenderer.min.js"></script>
29+<script type="text/javascript"
30+ src="/test/chrome/reportinclude/js/jqplot/jqplot.dateAxisRenderer.min.js"></script>
31+<script type="text/javascript"
32+ src="/test/chrome/reportinclude/js/jqplot/jqplot.cursor.min.js"></script>
33+<script type="text/javascript"
34+ src="/test/chrome/reportinclude/js/jqplot/jqplot.highlighter.min.js"></script>
35+<script type="text/javascript"
36+ src="/test/chrome/reportinclude/js/jqplot/reportgraph.js"></script>
37+
38+<script>
39+jQuery(document).ready(function($) {
40+ $('#reportgraph_0').reportGraph({
41+ graph: 'lines',
42+ seriesLabel: ['チケット数','クローズ数'],
43+ data: [[5,10,15], [25,10,15]],
44+ ticks: [1,2,3],
45+ title: 'NumberAxisTest',
46+ stack: false,
47+ legendLoc: 'se',
48+ legendXOffset: -100,
49+ legendYOffset: 0,
50+ xaxisType: 'number',
51+ xaxisMin: null,
52+ xaxisMax: null,
53+ yaxisMin: null,
54+ yaxisMax: null,
55+ xaxisFormatString: '%.1f',
56+ yaxisFormatString: '%.2f'
57+ });
58+});
59+</script>
60+
61+<script>
62+jQuery(document).ready(function($) {
63+ $('#reportgraph_1').reportGraph({
64+ graph: 'lines',
65+ seriesLabel: ['チケット数','クローズ数'],
66+ data: [[5,10,15]],
67+ ticks: ['2011-01-01','2011-01-02','2011-01-03'],
68+ title: 'DateAxisTest',
69+ stack: false,
70+ legendLoc: 'se',
71+ legendXOffset: 0,
72+ legendYOffset: 0,
73+ xaxisType: 'date',
74+ xaxisMin: null,
75+ xaxisMax: null,
76+ yaxisMin: null,
77+ yaxisMax: null,
78+ xaxisFormatString: null,
79+ yaxisFormatString: null
80+ });
81+});
82+</script>
83+
84+
85+<script>
86+jQuery(document).ready(function($) {
87+ $('#reportgraph_2').reportGraph({
88+ graph: 'lines',
89+ seriesLabel: ['チケット数','クローズ数'],
90+ data: [[5,10,15], [25,10,15]],
91+ ticks: ['A','B','C'],
92+ title: 'CategoryAxisTest',
93+ stack: false,
94+ legendLoc: 'se',
95+ legendXOffset: 0,
96+ legendYOffset: 0,
97+ xaxisType: 'string',
98+ xaxisMin: null,
99+ xaxisMax: null,
100+ yaxisMin: null,
101+ yaxisMax: null,
102+ xaxisFormatString: '',
103+ yaxisFormatString: ''
104+ });
105+});
106+</script>
107+
108+<script>
109+jQuery(document).ready(function($) {
110+ $('#reportgraph_3').reportGraph({
111+ graph: 'bars',
112+ seriesLabel: ['チケット数','クローズ数'],
113+ data: [[5,10,15], [25,10,15]],
114+ ticks: [1,2,3],
115+ title: 'Bar NumberAxisTest',
116+ stack: true,
117+ legendLoc: 'se',
118+ legendXOffset: -100,
119+ legendYOffset: 0,
120+ xaxisType: 'number',
121+ xaxisMin: null,
122+ xaxisMax: null,
123+ yaxisMin: null,
124+ yaxisMax: null,
125+ xaxisFormatString: '%.1f',
126+ yaxisFormatString: '%.2f',
127+ barWidth: 50
128+ });
129+});
130+</script>
131+
132+<script>
133+jQuery(document).ready(function($) {
134+ $('#reportgraph_4').reportGraph({
135+ graph: 'bars',
136+ seriesLabel: ['チケット数','クローズ数'],
137+ data: [[5,10,15]],
138+ ticks: ['2011-01-01','2011-01-02','2011-01-03'],
139+ title: 'Bar DateAxisTest',
140+ stack: false,
141+ legendLoc: 'se',
142+ legendXOffset: 0,
143+ legendYOffset: 0,
144+ xaxisType: 'date',
145+ xaxisMin: null,
146+ xaxisMax: null,
147+ yaxisMin: null,
148+ yaxisMax: null,
149+ xaxisFormatString: null,
150+ yaxisFormatString: null,
151+ barWidth: 50
152+ });
153+});
154+</script>
155+
156+
157+<script>
158+jQuery(document).ready(function($) {
159+ $('#reportgraph_5').reportGraph({
160+ graph: 'bars',
161+ seriesLabel: ['チケット数','クローズ数'],
162+ data: [[5,10,15], [25,10,15]],
163+ ticks: ['A','B','C'],
164+ title: 'Bar CategoryAxisTest',
165+ stack: false,
166+ legendLoc: 'se',
167+ legendXOffset: 0,
168+ legendYOffset: 0,
169+ xaxisType: 'string',
170+ xaxisMin: null,
171+ xaxisMax: null,
172+ yaxisMin: null,
173+ yaxisMax: null,
174+ xaxisFormatString: '',
175+ yaxisFormatString: ''
176+ });
177+});
178+</script>
179+
180+<script>
181+jQuery(document).ready(function($) {
182+ $('#reportgraph_6').reportGraph({
183+ graph: 'pie',
184+ seriesLabel: ['チケット数','クローズ数'],
185+ //data: [[['A',5],['B',10],['C',15]]],
186+ data: [[5,10,15], [25,10,15]],
187+ ticks: ['A','B','C'],
188+ title: 'PieTest',
189+ stack: false,
190+ legendLoc: 'se',
191+ legendXOffset: 0,
192+ legendYOffset: 0,
193+ xaxisType: 'number',
194+ xaxisMin: null,
195+ xaxisMax: null,
196+ yaxisMin: null,
197+ yaxisMax: null,
198+ xaxisFormatString: '',
199+ yaxisFormatString: ''
200+ });
201+});
202+</script>
203+
204+<div id="reportgraphtable_0">
205+<div class="reportgraph" id="reportgraph_0">
206+</div>
207+</div>
208+<div id="reportgraphtable_1">
209+<div class="reportgraph" id="reportgraph_1">
210+</div>
211+</div>
212+<div id="reportgraphtable_2">
213+<div class="reportgraph" id="reportgraph_2">
214+</div>
215+</div>
216+<div id="reportgraphtable_3">
217+<div class="reportgraph" id="reportgraph_3">
218+</div>
219+</div>
220+<div id="reportgraphtable_4">
221+<div class="reportgraph" id="reportgraph_4">
222+</div>
223+</div>
224+<div id="reportgraphtable_5">
225+<div class="reportgraph" id="reportgraph_5">
226+</div>
227+</div>
228+<div id="reportgraphtable_6">
229+<div class="reportgraph" id="reportgraph_6">
230+</div>
231+</div>
232+</body>
233+</html>
\ No newline at end of file
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/js/dateformat.js (revision 799)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/js/dateformat.js (nonexistent)
@@ -1,309 +0,0 @@
1-/*
2---------------------------------------------------------
3-dateformat.js - Simple date formatter
4-Version 1.1 (Update 2008/04/02)
5-
6-Copyright (c) 2007-2008 onozaty (http://www.enjoyxstudy.com)
7-
8-Released under an MIT-style license.
9-
10-For details, see the web site:
11- http://www.enjoyxstudy.com/javascript/dateformat/
12-
13---------------------------------------------------------
14-patterns
15-y : Year ex. "yyyy" -> "2007", "yy" -> "07"
16-M : Month ex. "MM" -> "05" "12", "M" -> "5" "12"
17-d : Day ex. "dd" -> "09" "30", "d" -> "9" "30"
18-H : Hour (0-23) ex. "HH" -> "00" "23", "H" -> "0" "23"
19-m : Minute ex. "mm" -> "01" "59", "m" -> "1" "59"
20-s : Second ex. "ss" -> "00" "59", "H" -> "0" "59"
21-S : Millisecond ex. "SSS" -> "000" "012" "999",
22- "SS" -> "00" "12" "999", "S" -> "0" "12" "999"
23-
24-Text can be quoted using single quotes (') to avoid interpretation.
25-"''" represents a single quote.
26-
27-
28-Useing..
29-
30- var fmt = new DateFormat("yyyy/MM/dd HH:mm:ss SSS");
31-
32- var str = fmt.format(new Date()); // "2007/05/10 12:21:19 002"
33- var date = fmt.parse("2007/05/10 12:21:19 002"); // return Date object
34-
35---------------------------------------------------------
36-*/
37-
38-var DateFormat = function(pattern) {
39- this._init(pattern);
40-};
41-
42-DateFormat.prototype = {
43- _init: function(pattern) {
44-
45- this.pattern = pattern;
46- this._patterns = [];
47-
48- for (var i = 0; i < pattern.length; i++) {
49- var ch = pattern.charAt(i);
50- if (this._patterns.length == 0) {
51- this._patterns[0] = ch;
52- } else {
53- var index = this._patterns.length - 1;
54- if (this._patterns[index].charAt(0) == "'") {
55- if (this._patterns[index].length == 1
56- || this._patterns[index].charAt(this._patterns[index].length - 1) != "'") {
57- this._patterns[index] += ch;
58- } else {
59- this._patterns[index + 1] = ch;
60- }
61- } else if (this._patterns[index].charAt(0) == ch) {
62- this._patterns[index] += ch;
63- } else {
64- this._patterns[index + 1] = ch;
65- }
66- }
67- }
68- },
69-
70- format: function(date) {
71-
72- var result = [];
73- for (var i = 0; i < this._patterns.length; i++) {
74- result[i] = this._formatWord(date, this._patterns[i]);
75- }
76- return result.join('');
77- },
78- _formatWord: function(date, pattern) {
79-
80- var formatter = this._formatter[pattern.charAt(0)];
81- if (formatter) {
82- return formatter.apply(this, [date, pattern]);
83- } else {
84- return pattern;
85- }
86- },
87- _formatter: {
88- "y": function(date, pattern) {
89- // Year
90- var year = String(date.getFullYear());
91- if (pattern.length <= 2) {
92- year = year.substring(2, 4);
93- } else {
94- year = this._zeroPadding(year, pattern.length);
95- }
96- return year;
97- },
98- "M": function(date, pattern) {
99- // Month in year
100- return this._zeroPadding(String(date.getMonth() + 1), pattern.length);
101- },
102- "d": function(date, pattern) {
103- // Day in month
104- return this._zeroPadding(String(date.getDate()), pattern.length);
105- },
106- "H": function(date, pattern) {
107- // Hour in day (0-23)
108- return this._zeroPadding(String(date.getHours()), pattern.length);
109- },
110- "m": function(date, pattern) {
111- // Minute in hour
112- return this._zeroPadding(String(date.getMinutes()), pattern.length);
113- },
114- "s": function(date, pattern) {
115- // Second in minute
116- return this._zeroPadding(String(date.getSeconds()), pattern.length);
117- },
118- "S": function(date, pattern) {
119- // Millisecond
120- return this._zeroPadding(String(date.getMilliseconds()), pattern.length);
121- },
122- "'": function(date, pattern) {
123- // escape
124- if (pattern == "''") {
125- return "'";
126- } else {
127- return pattern.replace(/'/g, '');
128- }
129- }
130- },
131-
132- _zeroPadding: function(str, length) {
133- if (str.length >= length) {
134- return str;
135- }
136-
137- return new Array(length - str.length + 1).join("0") + str;
138- },
139-
140-
141- /// Parser ///
142- parse: function(text) {
143-
144- if (typeof text != 'string' || text == '') return null;
145-
146- var result = {year: 1970, month: 1, day: 1, hour: 0, min: 0, sec: 0, msec: 0};
147-
148- for (var i = 0; i < this._patterns.length; i++) {
149- if (text == '') return null; // parse error!!
150- text = this._parseWord(text, this._patterns[i], result);
151- if (text === null) return null; // parse error!!
152- }
153- if (text != '') return null; // parse error!!
154-
155- return new Date(
156- result.year,
157- result.month - 1,
158- result.day,
159- result.hour,
160- result.min,
161- result.sec,
162- result.msec);
163- },
164- _parseWord: function(text, pattern, result) {
165-
166- var parser = this._parser[pattern.charAt(0)];
167- if (parser) {
168- return parser.apply(this, [text, pattern, result]);
169- } else {
170- if (text.indexOf(pattern) != 0) {
171- return null;
172- } else {
173- return text.substring(pattern.length);
174- }
175- }
176- },
177- _parser: {
178- "y": function(text, pattern, result) {
179- // Year
180- var year;
181- if (pattern.length <= 2) {
182- year = text.substring(0, 2);
183- year = year < 70 ? '20' + year : '19' + year;
184- text = text.substring(2);
185- } else {
186- var length = (pattern.length == 3) ? 4 : pattern.length;
187- year = text.substring(0, length);
188- text = text.substring(length);
189- }
190- if (!this._isNumber(year)) return null; // error
191- result.year = parseInt(year, 10);
192- return text;
193- },
194- "M": function(text, pattern, result) {
195- // Month in year
196- var month;
197- if (pattern.length == 1 && text.length > 1
198- && text.substring(0, 2).match(/1[0-2]/) != null) {
199- month = text.substring(0, 2);
200- text = text.substring(2);
201- } else {
202- month = text.substring(0, pattern.length);
203- text = text.substring(pattern.length);
204- }
205- if (!this._isNumber(month)) return null; // error
206- result.month = parseInt(month, 10);
207- return text;
208- },
209- "d": function(text, pattern, result) {
210- // Day in month
211- var day;
212- if (pattern.length == 1 && text.length > 1
213- && text.substring(0, 2).match(/1[0-9]|2[0-9]|3[0-1]/) != null) {
214- day = text.substring(0, 2);
215- text = text.substring(2);
216- } else {
217- day = text.substring(0, pattern.length);
218- text = text.substring(pattern.length);
219- }
220- if (!this._isNumber(day)) return null; // error
221- result.day = parseInt(day, 10);
222- return text;
223- },
224- "H": function(text, pattern, result) {
225- // Hour in day (0-23)
226- var hour;
227- if (pattern.length == 1 && text.length > 1
228- && text.substring(0, 2).match(/1[0-9]|2[0-3]/) != null) {
229- hour = text.substring(0, 2);
230- text = text.substring(2);
231- } else {
232- hour = text.substring(0, pattern.length);
233- text = text.substring(pattern.length);
234- }
235- if (!this._isNumber(hour)) return null; // error
236- result.hour = parseInt(hour, 10);
237- return text;
238- },
239- "m": function(text, pattern, result) {
240- // Minute in hour
241- var min;
242- if (pattern.length == 1 && text.length > 1
243- && text.substring(0, 2).match(/[1-5][0-9]/) != null) {
244- min = text.substring(0, 2);
245- text = text.substring(2);
246- } else {
247- min = text.substring(0, pattern.length);
248- text = text.substring(pattern.length);
249- }
250- if (!this._isNumber(min)) return null; // error
251- result.min = parseInt(min, 10);
252- return text;
253- },
254- "s": function(text, pattern, result) {
255- // Second in minute
256- var sec;
257- if (pattern.length == 1 && text.length > 1
258- && text.substring(0, 2).match(/[1-5][0-9]/) != null) {
259- sec = text.substring(0, 2);
260- text = text.substring(2);
261- } else {
262- sec = text.substring(0, pattern.length);
263- text = text.substring(pattern.length);
264- }
265- if (!this._isNumber(sec)) return null; // error
266- result.sec = parseInt(sec, 10);
267- return text;
268- },
269- "S": function(text, pattern, result) {
270- // Millimsecond
271- var msec;
272- if (pattern.length == 1 || pattern.length == 2) {
273- if (text.length > 2 && text.substring(0, 3).match(/[1-9][0-9][0-9]/) != null) {
274- msec = text.substring(0, 3);
275- text = text.substring(3);
276- } else if (text.length > 1 && text.substring(0, 2).match(/[1-9][0-9]/) != null) {
277- msec = text.substring(0, 2);
278- text = text.substring(2);
279- } else {
280- msec = text.substring(0, pattern.length);
281- text = text.substring(pattern.length);
282- }
283- } else {
284- msec = text.substring(0, pattern.length);
285- text = text.substring(pattern.length);
286- }
287- if (!this._isNumber(msec)) return null; // error
288- result.msec = parseInt(msec, 10);
289- return text;
290- },
291- "'": function(text, pattern, result) {
292- // escape
293- if (pattern == "''") {
294- pattern = "'";
295- } else {
296- pattern = pattern.replace(/'/g, '');
297- }
298- if (text.indexOf(pattern) != 0) {
299- return null; // error
300- } else {
301- return text.substring(pattern.length);
302- }
303- }
304- },
305-
306- _isNumber: function(str) {
307- return /^[0-9]*$/.test(str);
308- }
309-}
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/js/jqplot/jquery-1.3.2.min.js (revision 799)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/js/jqplot/jquery-1.3.2.min.js (nonexistent)
@@ -1,19 +0,0 @@
1-/*
2- * jQuery JavaScript Library v1.3.2
3- * http://jquery.com/
4- *
5- * Copyright (c) 2009 John Resig
6- * Dual licensed under the MIT and GPL licenses.
7- * http://docs.jquery.com/License
8- *
9- * Date: 2009-02-19 17:34:21 -0500 (Thu, 19 Feb 2009)
10- * Revision: 6246
11- */
12-(function(){var l=this,g,y=l.jQuery,p=l.$,o=l.jQuery=l.$=function(E,F){return new o.fn.init(E,F)},D=/^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/,f=/^.[^:#\[\.,]*$/;o.fn=o.prototype={init:function(E,H){E=E||document;if(E.nodeType){this[0]=E;this.length=1;this.context=E;return this}if(typeof E==="string"){var G=D.exec(E);if(G&&(G[1]||!H)){if(G[1]){E=o.clean([G[1]],H)}else{var I=document.getElementById(G[3]);if(I&&I.id!=G[3]){return o().find(E)}var F=o(I||[]);F.context=document;F.selector=E;return F}}else{return o(H).find(E)}}else{if(o.isFunction(E)){return o(document).ready(E)}}if(E.selector&&E.context){this.selector=E.selector;this.context=E.context}return this.setArray(o.isArray(E)?E:o.makeArray(E))},selector:"",jquery:"1.3.2",size:function(){return this.length},get:function(E){return E===g?Array.prototype.slice.call(this):this[E]},pushStack:function(F,H,E){var G=o(F);G.prevObject=this;G.context=this.context;if(H==="find"){G.selector=this.selector+(this.selector?" ":"")+E}else{if(H){G.selector=this.selector+"."+H+"("+E+")"}}return G},setArray:function(E){this.length=0;Array.prototype.push.apply(this,E);return this},each:function(F,E){return o.each(this,F,E)},index:function(E){return o.inArray(E&&E.jquery?E[0]:E,this)},attr:function(F,H,G){var E=F;if(typeof F==="string"){if(H===g){return this[0]&&o[G||"attr"](this[0],F)}else{E={};E[F]=H}}return this.each(function(I){for(F in E){o.attr(G?this.style:this,F,o.prop(this,E[F],G,I,F))}})},css:function(E,F){if((E=="width"||E=="height")&&parseFloat(F)<0){F=g}return this.attr(E,F,"curCSS")},text:function(F){if(typeof F!=="object"&&F!=null){return this.empty().append((this[0]&&this[0].ownerDocument||document).createTextNode(F))}var E="";o.each(F||this,function(){o.each(this.childNodes,function(){if(this.nodeType!=8){E+=this.nodeType!=1?this.nodeValue:o.fn.text([this])}})});return E},wrapAll:function(E){if(this[0]){var F=o(E,this[0].ownerDocument).clone();if(this[0].parentNode){F.insertBefore(this[0])}F.map(function(){var G=this;while(G.firstChild){G=G.firstChild}return G}).append(this)}return this},wrapInner:function(E){return this.each(function(){o(this).contents().wrapAll(E)})},wrap:function(E){return this.each(function(){o(this).wrapAll(E)})},append:function(){return this.domManip(arguments,true,function(E){if(this.nodeType==1){this.appendChild(E)}})},prepend:function(){return this.domManip(arguments,true,function(E){if(this.nodeType==1){this.insertBefore(E,this.firstChild)}})},before:function(){return this.domManip(arguments,false,function(E){this.parentNode.insertBefore(E,this)})},after:function(){return this.domManip(arguments,false,function(E){this.parentNode.insertBefore(E,this.nextSibling)})},end:function(){return this.prevObject||o([])},push:[].push,sort:[].sort,splice:[].splice,find:function(E){if(this.length===1){var F=this.pushStack([],"find",E);F.length=0;o.find(E,this[0],F);return F}else{return this.pushStack(o.unique(o.map(this,function(G){return o.find(E,G)})),"find",E)}},clone:function(G){var E=this.map(function(){if(!o.support.noCloneEvent&&!o.isXMLDoc(this)){var I=this.outerHTML;if(!I){var J=this.ownerDocument.createElement("div");J.appendChild(this.cloneNode(true));I=J.innerHTML}return o.clean([I.replace(/ jQuery\d+="(?:\d+|null)"/g,"").replace(/^\s*/,"")])[0]}else{return this.cloneNode(true)}});if(G===true){var H=this.find("*").andSelf(),F=0;E.find("*").andSelf().each(function(){if(this.nodeName!==H[F].nodeName){return}var I=o.data(H[F],"events");for(var K in I){for(var J in I[K]){o.event.add(this,K,I[K][J],I[K][J].data)}}F++})}return E},filter:function(E){return this.pushStack(o.isFunction(E)&&o.grep(this,function(G,F){return E.call(G,F)})||o.multiFilter(E,o.grep(this,function(F){return F.nodeType===1})),"filter",E)},closest:function(E){var G=o.expr.match.POS.test(E)?o(E):null,F=0;return this.map(function(){var H=this;while(H&&H.ownerDocument){if(G?G.index(H)>-1:o(H).is(E)){o.data(H,"closest",F);return H}H=H.parentNode;F++}})},not:function(E){if(typeof E==="string"){if(f.test(E)){return this.pushStack(o.multiFilter(E,this,true),"not",E)}else{E=o.multiFilter(E,this)}}var F=E.length&&E[E.length-1]!==g&&!E.nodeType;return this.filter(function(){return F?o.inArray(this,E)<0:this!=E})},add:function(E){return this.pushStack(o.unique(o.merge(this.get(),typeof E==="string"?o(E):o.makeArray(E))))},is:function(E){return !!E&&o.multiFilter(E,this).length>0},hasClass:function(E){return !!E&&this.is("."+E)},val:function(K){if(K===g){var E=this[0];if(E){if(o.nodeName(E,"option")){return(E.attributes.value||{}).specified?E.value:E.text}if(o.nodeName(E,"select")){var I=E.selectedIndex,L=[],M=E.options,H=E.type=="select-one";if(I<0){return null}for(var F=H?I:0,J=H?I+1:M.length;F<J;F++){var G=M[F];if(G.selected){K=o(G).val();if(H){return K}L.push(K)}}return L}return(E.value||"").replace(/\r/g,"")}return g}if(typeof K==="number"){K+=""}return this.each(function(){if(this.nodeType!=1){return}if(o.isArray(K)&&/radio|checkbox/.test(this.type)){this.checked=(o.inArray(this.value,K)>=0||o.inArray(this.name,K)>=0)}else{if(o.nodeName(this,"select")){var N=o.makeArray(K);o("option",this).each(function(){this.selected=(o.inArray(this.value,N)>=0||o.inArray(this.text,N)>=0)});if(!N.length){this.selectedIndex=-1}}else{this.value=K}}})},html:function(E){return E===g?(this[0]?this[0].innerHTML.replace(/ jQuery\d+="(?:\d+|null)"/g,""):null):this.empty().append(E)},replaceWith:function(E){return this.after(E).remove()},eq:function(E){return this.slice(E,+E+1)},slice:function(){return this.pushStack(Array.prototype.slice.apply(this,arguments),"slice",Array.prototype.slice.call(arguments).join(","))},map:function(E){return this.pushStack(o.map(this,function(G,F){return E.call(G,F,G)}))},andSelf:function(){return this.add(this.prevObject)},domManip:function(J,M,L){if(this[0]){var I=(this[0].ownerDocument||this[0]).createDocumentFragment(),F=o.clean(J,(this[0].ownerDocument||this[0]),I),H=I.firstChild;if(H){for(var G=0,E=this.length;G<E;G++){L.call(K(this[G],H),this.length>1||G>0?I.cloneNode(true):I)}}if(F){o.each(F,z)}}return this;function K(N,O){return M&&o.nodeName(N,"table")&&o.nodeName(O,"tr")?(N.getElementsByTagName("tbody")[0]||N.appendChild(N.ownerDocument.createElement("tbody"))):N}}};o.fn.init.prototype=o.fn;function z(E,F){if(F.src){o.ajax({url:F.src,async:false,dataType:"script"})}else{o.globalEval(F.text||F.textContent||F.innerHTML||"")}if(F.parentNode){F.parentNode.removeChild(F)}}function e(){return +new Date}o.extend=o.fn.extend=function(){var J=arguments[0]||{},H=1,I=arguments.length,E=false,G;if(typeof J==="boolean"){E=J;J=arguments[1]||{};H=2}if(typeof J!=="object"&&!o.isFunction(J)){J={}}if(I==H){J=this;--H}for(;H<I;H++){if((G=arguments[H])!=null){for(var F in G){var K=J[F],L=G[F];if(J===L){continue}if(E&&L&&typeof L==="object"&&!L.nodeType){J[F]=o.extend(E,K||(L.length!=null?[]:{}),L)}else{if(L!==g){J[F]=L}}}}}return J};var b=/z-?index|font-?weight|opacity|zoom|line-?height/i,q=document.defaultView||{},s=Object.prototype.toString;o.extend({noConflict:function(E){l.$=p;if(E){l.jQuery=y}return o},isFunction:function(E){return s.call(E)==="[object Function]"},isArray:function(E){return s.call(E)==="[object Array]"},isXMLDoc:function(E){return E.nodeType===9&&E.documentElement.nodeName!=="HTML"||!!E.ownerDocument&&o.isXMLDoc(E.ownerDocument)},globalEval:function(G){if(G&&/\S/.test(G)){var F=document.getElementsByTagName("head")[0]||document.documentElement,E=document.createElement("script");E.type="text/javascript";if(o.support.scriptEval){E.appendChild(document.createTextNode(G))}else{E.text=G}F.insertBefore(E,F.firstChild);F.removeChild(E)}},nodeName:function(F,E){return F.nodeName&&F.nodeName.toUpperCase()==E.toUpperCase()},each:function(G,K,F){var E,H=0,I=G.length;if(F){if(I===g){for(E in G){if(K.apply(G[E],F)===false){break}}}else{for(;H<I;){if(K.apply(G[H++],F)===false){break}}}}else{if(I===g){for(E in G){if(K.call(G[E],E,G[E])===false){break}}}else{for(var J=G[0];H<I&&K.call(J,H,J)!==false;J=G[++H]){}}}return G},prop:function(H,I,G,F,E){if(o.isFunction(I)){I=I.call(H,F)}return typeof I==="number"&&G=="curCSS"&&!b.test(E)?I+"px":I},className:{add:function(E,F){o.each((F||"").split(/\s+/),function(G,H){if(E.nodeType==1&&!o.className.has(E.className,H)){E.className+=(E.className?" ":"")+H}})},remove:function(E,F){if(E.nodeType==1){E.className=F!==g?o.grep(E.className.split(/\s+/),function(G){return !o.className.has(F,G)}).join(" "):""}},has:function(F,E){return F&&o.inArray(E,(F.className||F).toString().split(/\s+/))>-1}},swap:function(H,G,I){var E={};for(var F in G){E[F]=H.style[F];H.style[F]=G[F]}I.call(H);for(var F in G){H.style[F]=E[F]}},css:function(H,F,J,E){if(F=="width"||F=="height"){var L,G={position:"absolute",visibility:"hidden",display:"block"},K=F=="width"?["Left","Right"]:["Top","Bottom"];function I(){L=F=="width"?H.offsetWidth:H.offsetHeight;if(E==="border"){return}o.each(K,function(){if(!E){L-=parseFloat(o.curCSS(H,"padding"+this,true))||0}if(E==="margin"){L+=parseFloat(o.curCSS(H,"margin"+this,true))||0}else{L-=parseFloat(o.curCSS(H,"border"+this+"Width",true))||0}})}if(H.offsetWidth!==0){I()}else{o.swap(H,G,I)}return Math.max(0,Math.round(L))}return o.curCSS(H,F,J)},curCSS:function(I,F,G){var L,E=I.style;if(F=="opacity"&&!o.support.opacity){L=o.attr(E,"opacity");return L==""?"1":L}if(F.match(/float/i)){F=w}if(!G&&E&&E[F]){L=E[F]}else{if(q.getComputedStyle){if(F.match(/float/i)){F="float"}F=F.replace(/([A-Z])/g,"-$1").toLowerCase();var M=q.getComputedStyle(I,null);if(M){L=M.getPropertyValue(F)}if(F=="opacity"&&L==""){L="1"}}else{if(I.currentStyle){var J=F.replace(/\-(\w)/g,function(N,O){return O.toUpperCase()});L=I.currentStyle[F]||I.currentStyle[J];if(!/^\d+(px)?$/i.test(L)&&/^\d/.test(L)){var H=E.left,K=I.runtimeStyle.left;I.runtimeStyle.left=I.currentStyle.left;E.left=L||0;L=E.pixelLeft+"px";E.left=H;I.runtimeStyle.left=K}}}}return L},clean:function(F,K,I){K=K||document;if(typeof K.createElement==="undefined"){K=K.ownerDocument||K[0]&&K[0].ownerDocument||document}if(!I&&F.length===1&&typeof F[0]==="string"){var H=/^<(\w+)\s*\/?>$/.exec(F[0]);if(H){return[K.createElement(H[1])]}}var G=[],E=[],L=K.createElement("div");o.each(F,function(P,S){if(typeof S==="number"){S+=""}if(!S){return}if(typeof S==="string"){S=S.replace(/(<(\w+)[^>]*?)\/>/g,function(U,V,T){return T.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i)?U:V+"></"+T+">"});var O=S.replace(/^\s+/,"").substring(0,10).toLowerCase();var Q=!O.indexOf("<opt")&&[1,"<select multiple='multiple'>","</select>"]||!O.indexOf("<leg")&&[1,"<fieldset>","</fieldset>"]||O.match(/^<(thead|tbody|tfoot|colg|cap)/)&&[1,"<table>","</table>"]||!O.indexOf("<tr")&&[2,"<table><tbody>","</tbody></table>"]||(!O.indexOf("<td")||!O.indexOf("<th"))&&[3,"<table><tbody><tr>","</tr></tbody></table>"]||!O.indexOf("<col")&&[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"]||!o.support.htmlSerialize&&[1,"div<div>","</div>"]||[0,"",""];L.innerHTML=Q[1]+S+Q[2];while(Q[0]--){L=L.lastChild}if(!o.support.tbody){var R=/<tbody/i.test(S),N=!O.indexOf("<table")&&!R?L.firstChild&&L.firstChild.childNodes:Q[1]=="<table>"&&!R?L.childNodes:[];for(var M=N.length-1;M>=0;--M){if(o.nodeName(N[M],"tbody")&&!N[M].childNodes.length){N[M].parentNode.removeChild(N[M])}}}if(!o.support.leadingWhitespace&&/^\s/.test(S)){L.insertBefore(K.createTextNode(S.match(/^\s*/)[0]),L.firstChild)}S=o.makeArray(L.childNodes)}if(S.nodeType){G.push(S)}else{G=o.merge(G,S)}});if(I){for(var J=0;G[J];J++){if(o.nodeName(G[J],"script")&&(!G[J].type||G[J].type.toLowerCase()==="text/javascript")){E.push(G[J].parentNode?G[J].parentNode.removeChild(G[J]):G[J])}else{if(G[J].nodeType===1){G.splice.apply(G,[J+1,0].concat(o.makeArray(G[J].getElementsByTagName("script"))))}I.appendChild(G[J])}}return E}return G},attr:function(J,G,K){if(!J||J.nodeType==3||J.nodeType==8){return g}var H=!o.isXMLDoc(J),L=K!==g;G=H&&o.props[G]||G;if(J.tagName){var F=/href|src|style/.test(G);if(G=="selected"&&J.parentNode){J.parentNode.selectedIndex}if(G in J&&H&&!F){if(L){if(G=="type"&&o.nodeName(J,"input")&&J.parentNode){throw"type property can't be changed"}J[G]=K}if(o.nodeName(J,"form")&&J.getAttributeNode(G)){return J.getAttributeNode(G).nodeValue}if(G=="tabIndex"){var I=J.getAttributeNode("tabIndex");return I&&I.specified?I.value:J.nodeName.match(/(button|input|object|select|textarea)/i)?0:J.nodeName.match(/^(a|area)$/i)&&J.href?0:g}return J[G]}if(!o.support.style&&H&&G=="style"){return o.attr(J.style,"cssText",K)}if(L){J.setAttribute(G,""+K)}var E=!o.support.hrefNormalized&&H&&F?J.getAttribute(G,2):J.getAttribute(G);return E===null?g:E}if(!o.support.opacity&&G=="opacity"){if(L){J.zoom=1;J.filter=(J.filter||"").replace(/alpha\([^)]*\)/,"")+(parseInt(K)+""=="NaN"?"":"alpha(opacity="+K*100+")")}return J.filter&&J.filter.indexOf("opacity=")>=0?(parseFloat(J.filter.match(/opacity=([^)]*)/)[1])/100)+"":""}G=G.replace(/-([a-z])/ig,function(M,N){return N.toUpperCase()});if(L){J[G]=K}return J[G]},trim:function(E){return(E||"").replace(/^\s+|\s+$/g,"")},makeArray:function(G){var E=[];if(G!=null){var F=G.length;if(F==null||typeof G==="string"||o.isFunction(G)||G.setInterval){E[0]=G}else{while(F){E[--F]=G[F]}}}return E},inArray:function(G,H){for(var E=0,F=H.length;E<F;E++){if(H[E]===G){return E}}return -1},merge:function(H,E){var F=0,G,I=H.length;if(!o.support.getAll){while((G=E[F++])!=null){if(G.nodeType!=8){H[I++]=G}}}else{while((G=E[F++])!=null){H[I++]=G}}return H},unique:function(K){var F=[],E={};try{for(var G=0,H=K.length;G<H;G++){var J=o.data(K[G]);if(!E[J]){E[J]=true;F.push(K[G])}}}catch(I){F=K}return F},grep:function(F,J,E){var G=[];for(var H=0,I=F.length;H<I;H++){if(!E!=!J(F[H],H)){G.push(F[H])}}return G},map:function(E,J){var F=[];for(var G=0,H=E.length;G<H;G++){var I=J(E[G],G);if(I!=null){F[F.length]=I}}return F.concat.apply([],F)}});var C=navigator.userAgent.toLowerCase();o.browser={version:(C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/)||[0,"0"])[1],safari:/webkit/.test(C),opera:/opera/.test(C),msie:/msie/.test(C)&&!/opera/.test(C),mozilla:/mozilla/.test(C)&&!/(compatible|webkit)/.test(C)};o.each({parent:function(E){return E.parentNode},parents:function(E){return o.dir(E,"parentNode")},next:function(E){return o.nth(E,2,"nextSibling")},prev:function(E){return o.nth(E,2,"previousSibling")},nextAll:function(E){return o.dir(E,"nextSibling")},prevAll:function(E){return o.dir(E,"previousSibling")},siblings:function(E){return o.sibling(E.parentNode.firstChild,E)},children:function(E){return o.sibling(E.firstChild)},contents:function(E){return o.nodeName(E,"iframe")?E.contentDocument||E.contentWindow.document:o.makeArray(E.childNodes)}},function(E,F){o.fn[E]=function(G){var H=o.map(this,F);if(G&&typeof G=="string"){H=o.multiFilter(G,H)}return this.pushStack(o.unique(H),E,G)}});o.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(E,F){o.fn[E]=function(G){var J=[],L=o(G);for(var K=0,H=L.length;K<H;K++){var I=(K>0?this.clone(true):this).get();o.fn[F].apply(o(L[K]),I);J=J.concat(I)}return this.pushStack(J,E,G)}});o.each({removeAttr:function(E){o.attr(this,E,"");if(this.nodeType==1){this.removeAttribute(E)}},addClass:function(E){o.className.add(this,E)},removeClass:function(E){o.className.remove(this,E)},toggleClass:function(F,E){if(typeof E!=="boolean"){E=!o.className.has(this,F)}o.className[E?"add":"remove"](this,F)},remove:function(E){if(!E||o.filter(E,[this]).length){o("*",this).add([this]).each(function(){o.event.remove(this);o.removeData(this)});if(this.parentNode){this.parentNode.removeChild(this)}}},empty:function(){o(this).children().remove();while(this.firstChild){this.removeChild(this.firstChild)}}},function(E,F){o.fn[E]=function(){return this.each(F,arguments)}});function j(E,F){return E[0]&&parseInt(o.curCSS(E[0],F,true),10)||0}var h="jQuery"+e(),v=0,A={};o.extend({cache:{},data:function(F,E,G){F=F==l?A:F;var H=F[h];if(!H){H=F[h]=++v}if(E&&!o.cache[H]){o.cache[H]={}}if(G!==g){o.cache[H][E]=G}return E?o.cache[H][E]:H},removeData:function(F,E){F=F==l?A:F;var H=F[h];if(E){if(o.cache[H]){delete o.cache[H][E];E="";for(E in o.cache[H]){break}if(!E){o.removeData(F)}}}else{try{delete F[h]}catch(G){if(F.removeAttribute){F.removeAttribute(h)}}delete o.cache[H]}},queue:function(F,E,H){if(F){E=(E||"fx")+"queue";var G=o.data(F,E);if(!G||o.isArray(H)){G=o.data(F,E,o.makeArray(H))}else{if(H){G.push(H)}}}return G},dequeue:function(H,G){var E=o.queue(H,G),F=E.shift();if(!G||G==="fx"){F=E[0]}if(F!==g){F.call(H)}}});o.fn.extend({data:function(E,G){var H=E.split(".");H[1]=H[1]?"."+H[1]:"";if(G===g){var F=this.triggerHandler("getData"+H[1]+"!",[H[0]]);if(F===g&&this.length){F=o.data(this[0],E)}return F===g&&H[1]?this.data(H[0]):F}else{return this.trigger("setData"+H[1]+"!",[H[0],G]).each(function(){o.data(this,E,G)})}},removeData:function(E){return this.each(function(){o.removeData(this,E)})},queue:function(E,F){if(typeof E!=="string"){F=E;E="fx"}if(F===g){return o.queue(this[0],E)}return this.each(function(){var G=o.queue(this,E,F);if(E=="fx"&&G.length==1){G[0].call(this)}})},dequeue:function(E){return this.each(function(){o.dequeue(this,E)})}});
13-/*
14- * Sizzle CSS Selector Engine - v0.9.3
15- * Copyright 2009, The Dojo Foundation
16- * Released under the MIT, BSD, and GPL Licenses.
17- * More information: http://sizzlejs.com/
18- */
19-(function(){var R=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?/g,L=0,H=Object.prototype.toString;var F=function(Y,U,ab,ac){ab=ab||[];U=U||document;if(U.nodeType!==1&&U.nodeType!==9){return[]}if(!Y||typeof Y!=="string"){return ab}var Z=[],W,af,ai,T,ad,V,X=true;R.lastIndex=0;while((W=R.exec(Y))!==null){Z.push(W[1]);if(W[2]){V=RegExp.rightContext;break}}if(Z.length>1&&M.exec(Y)){if(Z.length===2&&I.relative[Z[0]]){af=J(Z[0]+Z[1],U)}else{af=I.relative[Z[0]]?[U]:F(Z.shift(),U);while(Z.length){Y=Z.shift();if(I.relative[Y]){Y+=Z.shift()}af=J(Y,af)}}}else{var ae=ac?{expr:Z.pop(),set:E(ac)}:F.find(Z.pop(),Z.length===1&&U.parentNode?U.parentNode:U,Q(U));af=F.filter(ae.expr,ae.set);if(Z.length>0){ai=E(af)}else{X=false}while(Z.length){var ah=Z.pop(),ag=ah;if(!I.relative[ah]){ah=""}else{ag=Z.pop()}if(ag==null){ag=U}I.relative[ah](ai,ag,Q(U))}}if(!ai){ai=af}if(!ai){throw"Syntax error, unrecognized expression: "+(ah||Y)}if(H.call(ai)==="[object Array]"){if(!X){ab.push.apply(ab,ai)}else{if(U.nodeType===1){for(var aa=0;ai[aa]!=null;aa++){if(ai[aa]&&(ai[aa]===true||ai[aa].nodeType===1&&K(U,ai[aa]))){ab.push(af[aa])}}}else{for(var aa=0;ai[aa]!=null;aa++){if(ai[aa]&&ai[aa].nodeType===1){ab.push(af[aa])}}}}}else{E(ai,ab)}if(V){F(V,U,ab,ac);if(G){hasDuplicate=false;ab.sort(G);if(hasDuplicate){for(var aa=1;aa<ab.length;aa++){if(ab[aa]===ab[aa-1]){ab.splice(aa--,1)}}}}}return ab};F.matches=function(T,U){return F(T,null,null,U)};F.find=function(aa,T,ab){var Z,X;if(!aa){return[]}for(var W=0,V=I.order.length;W<V;W++){var Y=I.order[W],X;if((X=I.match[Y].exec(aa))){var U=RegExp.leftContext;if(U.substr(U.length-1)!=="\\"){X[1]=(X[1]||"").replace(/\\/g,"");Z=I.find[Y](X,T,ab);if(Z!=null){aa=aa.replace(I.match[Y],"");break}}}}if(!Z){Z=T.getElementsByTagName("*")}return{set:Z,expr:aa}};F.filter=function(ad,ac,ag,W){var V=ad,ai=[],aa=ac,Y,T,Z=ac&&ac[0]&&Q(ac[0]);while(ad&&ac.length){for(var ab in I.filter){if((Y=I.match[ab].exec(ad))!=null){var U=I.filter[ab],ah,af;T=false;if(aa==ai){ai=[]}if(I.preFilter[ab]){Y=I.preFilter[ab](Y,aa,ag,ai,W,Z);if(!Y){T=ah=true}else{if(Y===true){continue}}}if(Y){for(var X=0;(af=aa[X])!=null;X++){if(af){ah=U(af,Y,X,aa);var ae=W^!!ah;if(ag&&ah!=null){if(ae){T=true}else{aa[X]=false}}else{if(ae){ai.push(af);T=true}}}}}if(ah!==g){if(!ag){aa=ai}ad=ad.replace(I.match[ab],"");if(!T){return[]}break}}}if(ad==V){if(T==null){throw"Syntax error, unrecognized expression: "+ad}else{break}}V=ad}return aa};var I=F.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(T){return T.getAttribute("href")}},relative:{"+":function(aa,T,Z){var X=typeof T==="string",ab=X&&!/\W/.test(T),Y=X&&!ab;if(ab&&!Z){T=T.toUpperCase()}for(var W=0,V=aa.length,U;W<V;W++){if((U=aa[W])){while((U=U.previousSibling)&&U.nodeType!==1){}aa[W]=Y||U&&U.nodeName===T?U||false:U===T}}if(Y){F.filter(T,aa,true)}},">":function(Z,U,aa){var X=typeof U==="string";if(X&&!/\W/.test(U)){U=aa?U:U.toUpperCase();for(var V=0,T=Z.length;V<T;V++){var Y=Z[V];if(Y){var W=Y.parentNode;Z[V]=W.nodeName===U?W:false}}}else{for(var V=0,T=Z.length;V<T;V++){var Y=Z[V];if(Y){Z[V]=X?Y.parentNode:Y.parentNode===U}}if(X){F.filter(U,Z,true)}}},"":function(W,U,Y){var V=L++,T=S;if(!U.match(/\W/)){var X=U=Y?U:U.toUpperCase();T=P}T("parentNode",U,V,W,X,Y)},"~":function(W,U,Y){var V=L++,T=S;if(typeof U==="string"&&!U.match(/\W/)){var X=U=Y?U:U.toUpperCase();T=P}T("previousSibling",U,V,W,X,Y)}},find:{ID:function(U,V,W){if(typeof V.getElementById!=="undefined"&&!W){var T=V.getElementById(U[1]);return T?[T]:[]}},NAME:function(V,Y,Z){if(typeof Y.getElementsByName!=="undefined"){var U=[],X=Y.getElementsByName(V[1]);for(var W=0,T=X.length;W<T;W++){if(X[W].getAttribute("name")===V[1]){U.push(X[W])}}return U.length===0?null:U}},TAG:function(T,U){return U.getElementsByTagName(T[1])}},preFilter:{CLASS:function(W,U,V,T,Z,aa){W=" "+W[1].replace(/\\/g,"")+" ";if(aa){return W}for(var X=0,Y;(Y=U[X])!=null;X++){if(Y){if(Z^(Y.className&&(" "+Y.className+" ").indexOf(W)>=0)){if(!V){T.push(Y)}}else{if(V){U[X]=false}}}}return false},ID:function(T){return T[1].replace(/\\/g,"")},TAG:function(U,T){for(var V=0;T[V]===false;V++){}return T[V]&&Q(T[V])?U[1]:U[1].toUpperCase()},CHILD:function(T){if(T[1]=="nth"){var U=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(T[2]=="even"&&"2n"||T[2]=="odd"&&"2n+1"||!/\D/.test(T[2])&&"0n+"+T[2]||T[2]);T[2]=(U[1]+(U[2]||1))-0;T[3]=U[3]-0}T[0]=L++;return T},ATTR:function(X,U,V,T,Y,Z){var W=X[1].replace(/\\/g,"");if(!Z&&I.attrMap[W]){X[1]=I.attrMap[W]}if(X[2]==="~="){X[4]=" "+X[4]+" "}return X},PSEUDO:function(X,U,V,T,Y){if(X[1]==="not"){if(X[3].match(R).length>1||/^\w/.test(X[3])){X[3]=F(X[3],null,null,U)}else{var W=F.filter(X[3],U,V,true^Y);if(!V){T.push.apply(T,W)}return false}}else{if(I.match.POS.test(X[0])||I.match.CHILD.test(X[0])){return true}}return X},POS:function(T){T.unshift(true);return T}},filters:{enabled:function(T){return T.disabled===false&&T.type!=="hidden"},disabled:function(T){return T.disabled===true},checked:function(T){return T.checked===true},selected:function(T){T.parentNode.selectedIndex;return T.selected===true},parent:function(T){return !!T.firstChild},empty:function(T){return !T.firstChild},has:function(V,U,T){return !!F(T[3],V).length},header:function(T){return/h\d/i.test(T.nodeName)},text:function(T){return"text"===T.type},radio:function(T){return"radio"===T.type},checkbox:function(T){return"checkbox"===T.type},file:function(T){return"file"===T.type},password:function(T){return"password"===T.type},submit:function(T){return"submit"===T.type},image:function(T){return"image"===T.type},reset:function(T){return"reset"===T.type},button:function(T){return"button"===T.type||T.nodeName.toUpperCase()==="BUTTON"},input:function(T){return/input|select|textarea|button/i.test(T.nodeName)}},setFilters:{first:function(U,T){return T===0},last:function(V,U,T,W){return U===W.length-1},even:function(U,T){return T%2===0},odd:function(U,T){return T%2===1},lt:function(V,U,T){return U<T[3]-0},gt:function(V,U,T){return U>T[3]-0},nth:function(V,U,T){return T[3]-0==U},eq:function(V,U,T){return T[3]-0==U}},filter:{PSEUDO:function(Z,V,W,aa){var U=V[1],X=I.filters[U];if(X){return X(Z,W,V,aa)}else{if(U==="contains"){return(Z.textContent||Z.innerText||"").indexOf(V[3])>=0}else{if(U==="not"){var Y=V[3];for(var W=0,T=Y.length;W<T;W++){if(Y[W]===Z){return false}}return true}}}},CHILD:function(T,W){var Z=W[1],U=T;switch(Z){case"only":case"first":while(U=U.previousSibling){if(U.nodeType===1){return false}}if(Z=="first"){return true}U=T;case"last":while(U=U.nextSibling){if(U.nodeType===1){return false}}return true;case"nth":var V=W[2],ac=W[3];if(V==1&&ac==0){return true}var Y=W[0],ab=T.parentNode;if(ab&&(ab.sizcache!==Y||!T.nodeIndex)){var X=0;for(U=ab.firstChild;U;U=U.nextSibling){if(U.nodeType===1){U.nodeIndex=++X}}ab.sizcache=Y}var aa=T.nodeIndex-ac;if(V==0){return aa==0}else{return(aa%V==0&&aa/V>=0)}}},ID:function(U,T){return U.nodeType===1&&U.getAttribute("id")===T},TAG:function(U,T){return(T==="*"&&U.nodeType===1)||U.nodeName===T},CLASS:function(U,T){return(" "+(U.className||U.getAttribute("class"))+" ").indexOf(T)>-1},ATTR:function(Y,W){var V=W[1],T=I.attrHandle[V]?I.attrHandle[V](Y):Y[V]!=null?Y[V]:Y.getAttribute(V),Z=T+"",X=W[2],U=W[4];return T==null?X==="!=":X==="="?Z===U:X==="*="?Z.indexOf(U)>=0:X==="~="?(" "+Z+" ").indexOf(U)>=0:!U?Z&&T!==false:X==="!="?Z!=U:X==="^="?Z.indexOf(U)===0:X==="$="?Z.substr(Z.length-U.length)===U:X==="|="?Z===U||Z.substr(0,U.length+1)===U+"-":false},POS:function(X,U,V,Y){var T=U[2],W=I.setFilters[T];if(W){return W(X,V,U,Y)}}}};var M=I.match.POS;for(var O in I.match){I.match[O]=RegExp(I.match[O].source+/(?![^\[]*\])(?![^\(]*\))/.source)}var E=function(U,T){U=Array.prototype.slice.call(U);if(T){T.push.apply(T,U);return T}return U};try{Array.prototype.slice.call(document.documentElement.childNodes)}catch(N){E=function(X,W){var U=W||[];if(H.call(X)==="[object Array]"){Array.prototype.push.apply(U,X)}else{if(typeof X.length==="number"){for(var V=0,T=X.length;V<T;V++){U.push(X[V])}}else{for(var V=0;X[V];V++){U.push(X[V])}}}return U}}var G;if(document.documentElement.compareDocumentPosition){G=function(U,T){var V=U.compareDocumentPosition(T)&4?-1:U===T?0:1;if(V===0){hasDuplicate=true}return V}}else{if("sourceIndex" in document.documentElement){G=function(U,T){var V=U.sourceIndex-T.sourceIndex;if(V===0){hasDuplicate=true}return V}}else{if(document.createRange){G=function(W,U){var V=W.ownerDocument.createRange(),T=U.ownerDocument.createRange();V.selectNode(W);V.collapse(true);T.selectNode(U);T.collapse(true);var X=V.compareBoundaryPoints(Range.START_TO_END,T);if(X===0){hasDuplicate=true}return X}}}}(function(){var U=document.createElement("form"),V="script"+(new Date).getTime();U.innerHTML="<input name='"+V+"'/>";var T=document.documentElement;T.insertBefore(U,T.firstChild);if(!!document.getElementById(V)){I.find.ID=function(X,Y,Z){if(typeof Y.getElementById!=="undefined"&&!Z){var W=Y.getElementById(X[1]);return W?W.id===X[1]||typeof W.getAttributeNode!=="undefined"&&W.getAttributeNode("id").nodeValue===X[1]?[W]:g:[]}};I.filter.ID=function(Y,W){var X=typeof Y.getAttributeNode!=="undefined"&&Y.getAttributeNode("id");return Y.nodeType===1&&X&&X.nodeValue===W}}T.removeChild(U)})();(function(){var T=document.createElement("div");T.appendChild(document.createComment(""));if(T.getElementsByTagName("*").length>0){I.find.TAG=function(U,Y){var X=Y.getElementsByTagName(U[1]);if(U[1]==="*"){var W=[];for(var V=0;X[V];V++){if(X[V].nodeType===1){W.push(X[V])}}X=W}return X}}T.innerHTML="<a href='#'></a>";if(T.firstChild&&typeof T.firstChild.getAttribute!=="undefined"&&T.firstChild.getAttribute("href")!=="#"){I.attrHandle.href=function(U){return U.getAttribute("href",2)}}})();if(document.querySelectorAll){(function(){var T=F,U=document.createElement("div");U.innerHTML="<p class='TEST'></p>";if(U.querySelectorAll&&U.querySelectorAll(".TEST").length===0){return}F=function(Y,X,V,W){X=X||document;if(!W&&X.nodeType===9&&!Q(X)){try{return E(X.querySelectorAll(Y),V)}catch(Z){}}return T(Y,X,V,W)};F.find=T.find;F.filter=T.filter;F.selectors=T.selectors;F.matches=T.matches})()}if(document.getElementsByClassName&&document.documentElement.getElementsByClassName){(function(){var T=document.createElement("div");T.innerHTML="<div class='test e'></div><div class='test'></div>";if(T.getElementsByClassName("e").length===0){return}T.lastChild.className="e";if(T.getElementsByClassName("e").length===1){return}I.order.splice(1,0,"CLASS");I.find.CLASS=function(U,V,W){if(typeof V.getElementsByClassName!=="undefined"&&!W){return V.getElementsByClassName(U[1])}}})()}function P(U,Z,Y,ad,aa,ac){var ab=U=="previousSibling"&&!ac;for(var W=0,V=ad.length;W<V;W++){var T=ad[W];if(T){if(ab&&T.nodeType===1){T.sizcache=Y;T.sizset=W}T=T[U];var X=false;while(T){if(T.sizcache===Y){X=ad[T.sizset];break}if(T.nodeType===1&&!ac){T.sizcache=Y;T.sizset=W}if(T.nodeName===Z){X=T;break}T=T[U]}ad[W]=X}}}function S(U,Z,Y,ad,aa,ac){var ab=U=="previousSibling"&&!ac;for(var W=0,V=ad.length;W<V;W++){var T=ad[W];if(T){if(ab&&T.nodeType===1){T.sizcache=Y;T.sizset=W}T=T[U];var X=false;while(T){if(T.sizcache===Y){X=ad[T.sizset];break}if(T.nodeType===1){if(!ac){T.sizcache=Y;T.sizset=W}if(typeof Z!=="string"){if(T===Z){X=true;break}}else{if(F.filter(Z,[T]).length>0){X=T;break}}}T=T[U]}ad[W]=X}}}var K=document.compareDocumentPosition?function(U,T){return U.compareDocumentPosition(T)&16}:function(U,T){return U!==T&&(U.contains?U.contains(T):true)};var Q=function(T){return T.nodeType===9&&T.documentElement.nodeName!=="HTML"||!!T.ownerDocument&&Q(T.ownerDocument)};var J=function(T,aa){var W=[],X="",Y,V=aa.nodeType?[aa]:aa;while((Y=I.match.PSEUDO.exec(T))){X+=Y[0];T=T.replace(I.match.PSEUDO,"")}T=I.relative[T]?T+"*":T;for(var Z=0,U=V.length;Z<U;Z++){F(T,V[Z],W)}return F.filter(X,W)};o.find=F;o.filter=F.filter;o.expr=F.selectors;o.expr[":"]=o.expr.filters;F.selectors.filters.hidden=function(T){return T.offsetWidth===0||T.offsetHeight===0};F.selectors.filters.visible=function(T){return T.offsetWidth>0||T.offsetHeight>0};F.selectors.filters.animated=function(T){return o.grep(o.timers,function(U){return T===U.elem}).length};o.multiFilter=function(V,T,U){if(U){V=":not("+V+")"}return F.matches(V,T)};o.dir=function(V,U){var T=[],W=V[U];while(W&&W!=document){if(W.nodeType==1){T.push(W)}W=W[U]}return T};o.nth=function(X,T,V,W){T=T||1;var U=0;for(;X;X=X[V]){if(X.nodeType==1&&++U==T){break}}return X};o.sibling=function(V,U){var T=[];for(;V;V=V.nextSibling){if(V.nodeType==1&&V!=U){T.push(V)}}return T};return;l.Sizzle=F})();o.event={add:function(I,F,H,K){if(I.nodeType==3||I.nodeType==8){return}if(I.setInterval&&I!=l){I=l}if(!H.guid){H.guid=this.guid++}if(K!==g){var G=H;H=this.proxy(G);H.data=K}var E=o.data(I,"events")||o.data(I,"events",{}),J=o.data(I,"handle")||o.data(I,"handle",function(){return typeof o!=="undefined"&&!o.event.triggered?o.event.handle.apply(arguments.callee.elem,arguments):g});J.elem=I;o.each(F.split(/\s+/),function(M,N){var O=N.split(".");N=O.shift();H.type=O.slice().sort().join(".");var L=E[N];if(o.event.specialAll[N]){o.event.specialAll[N].setup.call(I,K,O)}if(!L){L=E[N]={};if(!o.event.special[N]||o.event.special[N].setup.call(I,K,O)===false){if(I.addEventListener){I.addEventListener(N,J,false)}else{if(I.attachEvent){I.attachEvent("on"+N,J)}}}}L[H.guid]=H;o.event.global[N]=true});I=null},guid:1,global:{},remove:function(K,H,J){if(K.nodeType==3||K.nodeType==8){return}var G=o.data(K,"events"),F,E;if(G){if(H===g||(typeof H==="string"&&H.charAt(0)==".")){for(var I in G){this.remove(K,I+(H||""))}}else{if(H.type){J=H.handler;H=H.type}o.each(H.split(/\s+/),function(M,O){var Q=O.split(".");O=Q.shift();var N=RegExp("(^|\\.)"+Q.slice().sort().join(".*\\.")+"(\\.|$)");if(G[O]){if(J){delete G[O][J.guid]}else{for(var P in G[O]){if(N.test(G[O][P].type)){delete G[O][P]}}}if(o.event.specialAll[O]){o.event.specialAll[O].teardown.call(K,Q)}for(F in G[O]){break}if(!F){if(!o.event.special[O]||o.event.special[O].teardown.call(K,Q)===false){if(K.removeEventListener){K.removeEventListener(O,o.data(K,"handle"),false)}else{if(K.detachEvent){K.detachEvent("on"+O,o.data(K,"handle"))}}}F=null;delete G[O]}}})}for(F in G){break}if(!F){var L=o.data(K,"handle");if(L){L.elem=null}o.removeData(K,"events");o.removeData(K,"handle")}}},trigger:function(I,K,H,E){var G=I.type||I;if(!E){I=typeof I==="object"?I[h]?I:o.extend(o.Event(G),I):o.Event(G);if(G.indexOf("!")>=0){I.type=G=G.slice(0,-1);I.exclusive=true}if(!H){I.stopPropagation();if(this.global[G]){o.each(o.cache,function(){if(this.events&&this.events[G]){o.event.trigger(I,K,this.handle.elem)}})}}if(!H||H.nodeType==3||H.nodeType==8){return g}I.result=g;I.target=H;K=o.makeArray(K);K.unshift(I)}I.currentTarget=H;var J=o.data(H,"handle");if(J){J.apply(H,K)}if((!H[G]||(o.nodeName(H,"a")&&G=="click"))&&H["on"+G]&&H["on"+G].apply(H,K)===false){I.result=false}if(!E&&H[G]&&!I.isDefaultPrevented()&&!(o.nodeName(H,"a")&&G=="click")){this.triggered=true;try{H[G]()}catch(L){}}this.triggered=false;if(!I.isPropagationStopped()){var F=H.parentNode||H.ownerDocument;if(F){o.event.trigger(I,K,F,true)}}},handle:function(K){var J,E;K=arguments[0]=o.event.fix(K||l.event);K.currentTarget=this;var L=K.type.split(".");K.type=L.shift();J=!L.length&&!K.exclusive;var I=RegExp("(^|\\.)"+L.slice().sort().join(".*\\.")+"(\\.|$)");E=(o.data(this,"events")||{})[K.type];for(var G in E){var H=E[G];if(J||I.test(H.type)){K.handler=H;K.data=H.data;var F=H.apply(this,arguments);if(F!==g){K.result=F;if(F===false){K.preventDefault();K.stopPropagation()}}if(K.isImmediatePropagationStopped()){break}}}},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(H){if(H[h]){return H}var F=H;H=o.Event(F);for(var G=this.props.length,J;G;){J=this.props[--G];H[J]=F[J]}if(!H.target){H.target=H.srcElement||document}if(H.target.nodeType==3){H.target=H.target.parentNode}if(!H.relatedTarget&&H.fromElement){H.relatedTarget=H.fromElement==H.target?H.toElement:H.fromElement}if(H.pageX==null&&H.clientX!=null){var I=document.documentElement,E=document.body;H.pageX=H.clientX+(I&&I.scrollLeft||E&&E.scrollLeft||0)-(I.clientLeft||0);H.pageY=H.clientY+(I&&I.scrollTop||E&&E.scrollTop||0)-(I.clientTop||0)}if(!H.which&&((H.charCode||H.charCode===0)?H.charCode:H.keyCode)){H.which=H.charCode||H.keyCode}if(!H.metaKey&&H.ctrlKey){H.metaKey=H.ctrlKey}if(!H.which&&H.button){H.which=(H.button&1?1:(H.button&2?3:(H.button&4?2:0)))}return H},proxy:function(F,E){E=E||function(){return F.apply(this,arguments)};E.guid=F.guid=F.guid||E.guid||this.guid++;return E},special:{ready:{setup:B,teardown:function(){}}},specialAll:{live:{setup:function(E,F){o.event.add(this,F[0],c)},teardown:function(G){if(G.length){var E=0,F=RegExp("(^|\\.)"+G[0]+"(\\.|$)");o.each((o.data(this,"events").live||{}),function(){if(F.test(this.type)){E++}});if(E<1){o.event.remove(this,G[0],c)}}}}}};o.Event=function(E){if(!this.preventDefault){return new o.Event(E)}if(E&&E.type){this.originalEvent=E;this.type=E.type}else{this.type=E}this.timeStamp=e();this[h]=true};function k(){return false}function u(){return true}o.Event.prototype={preventDefault:function(){this.isDefaultPrevented=u;var E=this.originalEvent;if(!E){return}if(E.preventDefault){E.preventDefault()}E.returnValue=false},stopPropagation:function(){this.isPropagationStopped=u;var E=this.originalEvent;if(!E){return}if(E.stopPropagation){E.stopPropagation()}E.cancelBubble=true},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=u;this.stopPropagation()},isDefaultPrevented:k,isPropagationStopped:k,isImmediatePropagationStopped:k};var a=function(F){var E=F.relatedTarget;while(E&&E!=this){try{E=E.parentNode}catch(G){E=this}}if(E!=this){F.type=F.data;o.event.handle.apply(this,arguments)}};o.each({mouseover:"mouseenter",mouseout:"mouseleave"},function(F,E){o.event.special[E]={setup:function(){o.event.add(this,F,a,E)},teardown:function(){o.event.remove(this,F,a)}}});o.fn.extend({bind:function(F,G,E){return F=="unload"?this.one(F,G,E):this.each(function(){o.event.add(this,F,E||G,E&&G)})},one:function(G,H,F){var E=o.event.proxy(F||H,function(I){o(this).unbind(I,E);return(F||H).apply(this,arguments)});return this.each(function(){o.event.add(this,G,E,F&&H)})},unbind:function(F,E){return this.each(function(){o.event.remove(this,F,E)})},trigger:function(E,F){return this.each(function(){o.event.trigger(E,F,this)})},triggerHandler:function(E,G){if(this[0]){var F=o.Event(E);F.preventDefault();F.stopPropagation();o.event.trigger(F,G,this[0]);return F.result}},toggle:function(G){var E=arguments,F=1;while(F<E.length){o.event.proxy(G,E[F++])}return this.click(o.event.proxy(G,function(H){this.lastToggle=(this.lastToggle||0)%F;H.preventDefault();return E[this.lastToggle++].apply(this,arguments)||false}))},hover:function(E,F){return this.mouseenter(E).mouseleave(F)},ready:function(E){B();if(o.isReady){E.call(document,o)}else{o.readyList.push(E)}return this},live:function(G,F){var E=o.event.proxy(F);E.guid+=this.selector+G;o(document).bind(i(G,this.selector),this.selector,E);return this},die:function(F,E){o(document).unbind(i(F,this.selector),E?{guid:E.guid+this.selector+F}:null);return this}});function c(H){var E=RegExp("(^|\\.)"+H.type+"(\\.|$)"),G=true,F=[];o.each(o.data(this,"events").live||[],function(I,J){if(E.test(J.type)){var K=o(H.target).closest(J.data)[0];if(K){F.push({elem:K,fn:J})}}});F.sort(function(J,I){return o.data(J.elem,"closest")-o.data(I.elem,"closest")});o.each(F,function(){if(this.fn.call(this.elem,H,this.fn.data)===false){return(G=false)}});return G}function i(F,E){return["live",F,E.replace(/\./g,"`").replace(/ /g,"|")].join(".")}o.extend({isReady:false,readyList:[],ready:function(){if(!o.isReady){o.isReady=true;if(o.readyList){o.each(o.readyList,function(){this.call(document,o)});o.readyList=null}o(document).triggerHandler("ready")}}});var x=false;function B(){if(x){return}x=true;if(document.addEventListener){document.addEventListener("DOMContentLoaded",function(){document.removeEventListener("DOMContentLoaded",arguments.callee,false);o.ready()},false)}else{if(document.attachEvent){document.attachEvent("onreadystatechange",function(){if(document.readyState==="complete"){document.detachEvent("onreadystatechange",arguments.callee);o.ready()}});if(document.documentElement.doScroll&&l==l.top){(function(){if(o.isReady){return}try{document.documentElement.doScroll("left")}catch(E){setTimeout(arguments.callee,0);return}o.ready()})()}}}o.event.add(l,"load",o.ready)}o.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","),function(F,E){o.fn[E]=function(G){return G?this.bind(E,G):this.trigger(E)}});o(l).bind("unload",function(){for(var E in o.cache){if(E!=1&&o.cache[E].handle){o.event.remove(o.cache[E].handle.elem)}}});(function(){o.support={};var F=document.documentElement,G=document.createElement("script"),K=document.createElement("div"),J="script"+(new Date).getTime();K.style.display="none";K.innerHTML=' <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';var H=K.getElementsByTagName("*"),E=K.getElementsByTagName("a")[0];if(!H||!H.length||!E){return}o.support={leadingWhitespace:K.firstChild.nodeType==3,tbody:!K.getElementsByTagName("tbody").length,objectAll:!!K.getElementsByTagName("object")[0].getElementsByTagName("*").length,htmlSerialize:!!K.getElementsByTagName("link").length,style:/red/.test(E.getAttribute("style")),hrefNormalized:E.getAttribute("href")==="/a",opacity:E.style.opacity==="0.5",cssFloat:!!E.style.cssFloat,scriptEval:false,noCloneEvent:true,boxModel:null};G.type="text/javascript";try{G.appendChild(document.createTextNode("window."+J+"=1;"))}catch(I){}F.insertBefore(G,F.firstChild);if(l[J]){o.support.scriptEval=true;delete l[J]}F.removeChild(G);if(K.attachEvent&&K.fireEvent){K.attachEvent("onclick",function(){o.support.noCloneEvent=false;K.detachEvent("onclick",arguments.callee)});K.cloneNode(true).fireEvent("onclick")}o(function(){var L=document.createElement("div");L.style.width=L.style.paddingLeft="1px";document.body.appendChild(L);o.boxModel=o.support.boxModel=L.offsetWidth===2;document.body.removeChild(L).style.display="none"})})();var w=o.support.cssFloat?"cssFloat":"styleFloat";o.props={"for":"htmlFor","class":"className","float":w,cssFloat:w,styleFloat:w,readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",tabindex:"tabIndex"};o.fn.extend({_load:o.fn.load,load:function(G,J,K){if(typeof G!=="string"){return this._load(G)}var I=G.indexOf(" ");if(I>=0){var E=G.slice(I,G.length);G=G.slice(0,I)}var H="GET";if(J){if(o.isFunction(J)){K=J;J=null}else{if(typeof J==="object"){J=o.param(J);H="POST"}}}var F=this;o.ajax({url:G,type:H,dataType:"html",data:J,complete:function(M,L){if(L=="success"||L=="notmodified"){F.html(E?o("<div/>").append(M.responseText.replace(/<script(.|\s)*?\/script>/g,"")).find(E):M.responseText)}if(K){F.each(K,[M.responseText,L,M])}}});return this},serialize:function(){return o.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?o.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||/select|textarea/i.test(this.nodeName)||/text|hidden|password|search/i.test(this.type))}).map(function(E,F){var G=o(this).val();return G==null?null:o.isArray(G)?o.map(G,function(I,H){return{name:F.name,value:I}}):{name:F.name,value:G}}).get()}});o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","),function(E,F){o.fn[F]=function(G){return this.bind(F,G)}});var r=e();o.extend({get:function(E,G,H,F){if(o.isFunction(G)){H=G;G=null}return o.ajax({type:"GET",url:E,data:G,success:H,dataType:F})},getScript:function(E,F){return o.get(E,null,F,"script")},getJSON:function(E,F,G){return o.get(E,F,G,"json")},post:function(E,G,H,F){if(o.isFunction(G)){H=G;G={}}return o.ajax({type:"POST",url:E,data:G,success:H,dataType:F})},ajaxSetup:function(E){o.extend(o.ajaxSettings,E)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:function(){return l.ActiveXObject?new ActiveXObject("Microsoft.XMLHTTP"):new XMLHttpRequest()},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},ajax:function(M){M=o.extend(true,M,o.extend(true,{},o.ajaxSettings,M));var W,F=/=\?(&|$)/g,R,V,G=M.type.toUpperCase();if(M.data&&M.processData&&typeof M.data!=="string"){M.data=o.param(M.data)}if(M.dataType=="jsonp"){if(G=="GET"){if(!M.url.match(F)){M.url+=(M.url.match(/\?/)?"&":"?")+(M.jsonp||"callback")+"=?"}}else{if(!M.data||!M.data.match(F)){M.data=(M.data?M.data+"&":"")+(M.jsonp||"callback")+"=?"}}M.dataType="json"}if(M.dataType=="json"&&(M.data&&M.data.match(F)||M.url.match(F))){W="jsonp"+r++;if(M.data){M.data=(M.data+"").replace(F,"="+W+"$1")}M.url=M.url.replace(F,"="+W+"$1");M.dataType="script";l[W]=function(X){V=X;I();L();l[W]=g;try{delete l[W]}catch(Y){}if(H){H.removeChild(T)}}}if(M.dataType=="script"&&M.cache==null){M.cache=false}if(M.cache===false&&G=="GET"){var E=e();var U=M.url.replace(/(\?|&)_=.*?(&|$)/,"$1_="+E+"$2");M.url=U+((U==M.url)?(M.url.match(/\?/)?"&":"?")+"_="+E:"")}if(M.data&&G=="GET"){M.url+=(M.url.match(/\?/)?"&":"?")+M.data;M.data=null}if(M.global&&!o.active++){o.event.trigger("ajaxStart")}var Q=/^(\w+:)?\/\/([^\/?#]+)/.exec(M.url);if(M.dataType=="script"&&G=="GET"&&Q&&(Q[1]&&Q[1]!=location.protocol||Q[2]!=location.host)){var H=document.getElementsByTagName("head")[0];var T=document.createElement("script");T.src=M.url;if(M.scriptCharset){T.charset=M.scriptCharset}if(!W){var O=false;T.onload=T.onreadystatechange=function(){if(!O&&(!this.readyState||this.readyState=="loaded"||this.readyState=="complete")){O=true;I();L();T.onload=T.onreadystatechange=null;H.removeChild(T)}}}H.appendChild(T);return g}var K=false;var J=M.xhr();if(M.username){J.open(G,M.url,M.async,M.username,M.password)}else{J.open(G,M.url,M.async)}try{if(M.data){J.setRequestHeader("Content-Type",M.contentType)}if(M.ifModified){J.setRequestHeader("If-Modified-Since",o.lastModified[M.url]||"Thu, 01 Jan 1970 00:00:00 GMT")}J.setRequestHeader("X-Requested-With","XMLHttpRequest");J.setRequestHeader("Accept",M.dataType&&M.accepts[M.dataType]?M.accepts[M.dataType]+", */*":M.accepts._default)}catch(S){}if(M.beforeSend&&M.beforeSend(J,M)===false){if(M.global&&!--o.active){o.event.trigger("ajaxStop")}J.abort();return false}if(M.global){o.event.trigger("ajaxSend",[J,M])}var N=function(X){if(J.readyState==0){if(P){clearInterval(P);P=null;if(M.global&&!--o.active){o.event.trigger("ajaxStop")}}}else{if(!K&&J&&(J.readyState==4||X=="timeout")){K=true;if(P){clearInterval(P);P=null}R=X=="timeout"?"timeout":!o.httpSuccess(J)?"error":M.ifModified&&o.httpNotModified(J,M.url)?"notmodified":"success";if(R=="success"){try{V=o.httpData(J,M.dataType,M)}catch(Z){R="parsererror"}}if(R=="success"){var Y;try{Y=J.getResponseHeader("Last-Modified")}catch(Z){}if(M.ifModified&&Y){o.lastModified[M.url]=Y}if(!W){I()}}else{o.handleError(M,J,R)}L();if(X){J.abort()}if(M.async){J=null}}}};if(M.async){var P=setInterval(N,13);if(M.timeout>0){setTimeout(function(){if(J&&!K){N("timeout")}},M.timeout)}}try{J.send(M.data)}catch(S){o.handleError(M,J,null,S)}if(!M.async){N()}function I(){if(M.success){M.success(V,R)}if(M.global){o.event.trigger("ajaxSuccess",[J,M])}}function L(){if(M.complete){M.complete(J,R)}if(M.global){o.event.trigger("ajaxComplete",[J,M])}if(M.global&&!--o.active){o.event.trigger("ajaxStop")}}return J},handleError:function(F,H,E,G){if(F.error){F.error(H,E,G)}if(F.global){o.event.trigger("ajaxError",[H,F,G])}},active:0,httpSuccess:function(F){try{return !F.status&&location.protocol=="file:"||(F.status>=200&&F.status<300)||F.status==304||F.status==1223}catch(E){}return false},httpNotModified:function(G,E){try{var H=G.getResponseHeader("Last-Modified");return G.status==304||H==o.lastModified[E]}catch(F){}return false},httpData:function(J,H,G){var F=J.getResponseHeader("content-type"),E=H=="xml"||!H&&F&&F.indexOf("xml")>=0,I=E?J.responseXML:J.responseText;if(E&&I.documentElement.tagName=="parsererror"){throw"parsererror"}if(G&&G.dataFilter){I=G.dataFilter(I,H)}if(typeof I==="string"){if(H=="script"){o.globalEval(I)}if(H=="json"){I=l["eval"]("("+I+")")}}return I},param:function(E){var G=[];function H(I,J){G[G.length]=encodeURIComponent(I)+"="+encodeURIComponent(J)}if(o.isArray(E)||E.jquery){o.each(E,function(){H(this.name,this.value)})}else{for(var F in E){if(o.isArray(E[F])){o.each(E[F],function(){H(F,this)})}else{H(F,o.isFunction(E[F])?E[F]():E[F])}}}return G.join("&").replace(/%20/g,"+")}});var m={},n,d=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];function t(F,E){var G={};o.each(d.concat.apply([],d.slice(0,E)),function(){G[this]=F});return G}o.fn.extend({show:function(J,L){if(J){return this.animate(t("show",3),J,L)}else{for(var H=0,F=this.length;H<F;H++){var E=o.data(this[H],"olddisplay");this[H].style.display=E||"";if(o.css(this[H],"display")==="none"){var G=this[H].tagName,K;if(m[G]){K=m[G]}else{var I=o("<"+G+" />").appendTo("body");K=I.css("display");if(K==="none"){K="block"}I.remove();m[G]=K}o.data(this[H],"olddisplay",K)}}for(var H=0,F=this.length;H<F;H++){this[H].style.display=o.data(this[H],"olddisplay")||""}return this}},hide:function(H,I){if(H){return this.animate(t("hide",3),H,I)}else{for(var G=0,F=this.length;G<F;G++){var E=o.data(this[G],"olddisplay");if(!E&&E!=="none"){o.data(this[G],"olddisplay",o.css(this[G],"display"))}}for(var G=0,F=this.length;G<F;G++){this[G].style.display="none"}return this}},_toggle:o.fn.toggle,toggle:function(G,F){var E=typeof G==="boolean";return o.isFunction(G)&&o.isFunction(F)?this._toggle.apply(this,arguments):G==null||E?this.each(function(){var H=E?G:o(this).is(":hidden");o(this)[H?"show":"hide"]()}):this.animate(t("toggle",3),G,F)},fadeTo:function(E,G,F){return this.animate({opacity:G},E,F)},animate:function(I,F,H,G){var E=o.speed(F,H,G);return this[E.queue===false?"each":"queue"](function(){var K=o.extend({},E),M,L=this.nodeType==1&&o(this).is(":hidden"),J=this;for(M in I){if(I[M]=="hide"&&L||I[M]=="show"&&!L){return K.complete.call(this)}if((M=="height"||M=="width")&&this.style){K.display=o.css(this,"display");K.overflow=this.style.overflow}}if(K.overflow!=null){this.style.overflow="hidden"}K.curAnim=o.extend({},I);o.each(I,function(O,S){var R=new o.fx(J,K,O);if(/toggle|show|hide/.test(S)){R[S=="toggle"?L?"show":"hide":S](I)}else{var Q=S.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),T=R.cur(true)||0;if(Q){var N=parseFloat(Q[2]),P=Q[3]||"px";if(P!="px"){J.style[O]=(N||1)+P;T=((N||1)/R.cur(true))*T;J.style[O]=T+P}if(Q[1]){N=((Q[1]=="-="?-1:1)*N)+T}R.custom(T,N,P)}else{R.custom(T,S,"")}}});return true})},stop:function(F,E){var G=o.timers;if(F){this.queue([])}this.each(function(){for(var H=G.length-1;H>=0;H--){if(G[H].elem==this){if(E){G[H](true)}G.splice(H,1)}}});if(!E){this.dequeue()}return this}});o.each({slideDown:t("show",1),slideUp:t("hide",1),slideToggle:t("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(E,F){o.fn[E]=function(G,H){return this.animate(F,G,H)}});o.extend({speed:function(G,H,F){var E=typeof G==="object"?G:{complete:F||!F&&H||o.isFunction(G)&&G,duration:G,easing:F&&H||H&&!o.isFunction(H)&&H};E.duration=o.fx.off?0:typeof E.duration==="number"?E.duration:o.fx.speeds[E.duration]||o.fx.speeds._default;E.old=E.complete;E.complete=function(){if(E.queue!==false){o(this).dequeue()}if(o.isFunction(E.old)){E.old.call(this)}};return E},easing:{linear:function(G,H,E,F){return E+F*G},swing:function(G,H,E,F){return((-Math.cos(G*Math.PI)/2)+0.5)*F+E}},timers:[],fx:function(F,E,G){this.options=E;this.elem=F;this.prop=G;if(!E.orig){E.orig={}}}});o.fx.prototype={update:function(){if(this.options.step){this.options.step.call(this.elem,this.now,this)}(o.fx.step[this.prop]||o.fx.step._default)(this);if((this.prop=="height"||this.prop=="width")&&this.elem.style){this.elem.style.display="block"}},cur:function(F){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null)){return this.elem[this.prop]}var E=parseFloat(o.css(this.elem,this.prop,F));return E&&E>-10000?E:parseFloat(o.curCSS(this.elem,this.prop))||0},custom:function(I,H,G){this.startTime=e();this.start=I;this.end=H;this.unit=G||this.unit||"px";this.now=this.start;this.pos=this.state=0;var E=this;function F(J){return E.step(J)}F.elem=this.elem;if(F()&&o.timers.push(F)&&!n){n=setInterval(function(){var K=o.timers;for(var J=0;J<K.length;J++){if(!K[J]()){K.splice(J--,1)}}if(!K.length){clearInterval(n);n=g}},13)}},show:function(){this.options.orig[this.prop]=o.attr(this.elem.style,this.prop);this.options.show=true;this.custom(this.prop=="width"||this.prop=="height"?1:0,this.cur());o(this.elem).show()},hide:function(){this.options.orig[this.prop]=o.attr(this.elem.style,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(H){var G=e();if(H||G>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;var E=true;for(var F in this.options.curAnim){if(this.options.curAnim[F]!==true){E=false}}if(E){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;this.elem.style.display=this.options.display;if(o.css(this.elem,"display")=="none"){this.elem.style.display="block"}}if(this.options.hide){o(this.elem).hide()}if(this.options.hide||this.options.show){for(var I in this.options.curAnim){o.attr(this.elem.style,I,this.options.orig[I])}}this.options.complete.call(this.elem)}return false}else{var J=G-this.startTime;this.state=J/this.options.duration;this.pos=o.easing[this.options.easing||(o.easing.swing?"swing":"linear")](this.state,J,0,1,this.options.duration);this.now=this.start+((this.end-this.start)*this.pos);this.update()}return true}};o.extend(o.fx,{speeds:{slow:600,fast:200,_default:400},step:{opacity:function(E){o.attr(E.elem.style,"opacity",E.now)},_default:function(E){if(E.elem.style&&E.elem.style[E.prop]!=null){E.elem.style[E.prop]=E.now+E.unit}else{E.elem[E.prop]=E.now}}}});if(document.documentElement.getBoundingClientRect){o.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return o.offset.bodyOffset(this[0])}var G=this[0].getBoundingClientRect(),J=this[0].ownerDocument,F=J.body,E=J.documentElement,L=E.clientTop||F.clientTop||0,K=E.clientLeft||F.clientLeft||0,I=G.top+(self.pageYOffset||o.boxModel&&E.scrollTop||F.scrollTop)-L,H=G.left+(self.pageXOffset||o.boxModel&&E.scrollLeft||F.scrollLeft)-K;return{top:I,left:H}}}else{o.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return o.offset.bodyOffset(this[0])}o.offset.initialized||o.offset.initialize();var J=this[0],G=J.offsetParent,F=J,O=J.ownerDocument,M,H=O.documentElement,K=O.body,L=O.defaultView,E=L.getComputedStyle(J,null),N=J.offsetTop,I=J.offsetLeft;while((J=J.parentNode)&&J!==K&&J!==H){M=L.getComputedStyle(J,null);N-=J.scrollTop,I-=J.scrollLeft;if(J===G){N+=J.offsetTop,I+=J.offsetLeft;if(o.offset.doesNotAddBorder&&!(o.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(J.tagName))){N+=parseInt(M.borderTopWidth,10)||0,I+=parseInt(M.borderLeftWidth,10)||0}F=G,G=J.offsetParent}if(o.offset.subtractsBorderForOverflowNotVisible&&M.overflow!=="visible"){N+=parseInt(M.borderTopWidth,10)||0,I+=parseInt(M.borderLeftWidth,10)||0}E=M}if(E.position==="relative"||E.position==="static"){N+=K.offsetTop,I+=K.offsetLeft}if(E.position==="fixed"){N+=Math.max(H.scrollTop,K.scrollTop),I+=Math.max(H.scrollLeft,K.scrollLeft)}return{top:N,left:I}}}o.offset={initialize:function(){if(this.initialized){return}var L=document.body,F=document.createElement("div"),H,G,N,I,M,E,J=L.style.marginTop,K='<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;" cellpadding="0" cellspacing="0"><tr><td></td></tr></table>';M={position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"};for(E in M){F.style[E]=M[E]}F.innerHTML=K;L.insertBefore(F,L.firstChild);H=F.firstChild,G=H.firstChild,I=H.nextSibling.firstChild.firstChild;this.doesNotAddBorder=(G.offsetTop!==5);this.doesAddBorderForTableAndCells=(I.offsetTop===5);H.style.overflow="hidden",H.style.position="relative";this.subtractsBorderForOverflowNotVisible=(G.offsetTop===-5);L.style.marginTop="1px";this.doesNotIncludeMarginInBodyOffset=(L.offsetTop===0);L.style.marginTop=J;L.removeChild(F);this.initialized=true},bodyOffset:function(E){o.offset.initialized||o.offset.initialize();var G=E.offsetTop,F=E.offsetLeft;if(o.offset.doesNotIncludeMarginInBodyOffset){G+=parseInt(o.curCSS(E,"marginTop",true),10)||0,F+=parseInt(o.curCSS(E,"marginLeft",true),10)||0}return{top:G,left:F}}};o.fn.extend({position:function(){var I=0,H=0,F;if(this[0]){var G=this.offsetParent(),J=this.offset(),E=/^body|html$/i.test(G[0].tagName)?{top:0,left:0}:G.offset();J.top-=j(this,"marginTop");J.left-=j(this,"marginLeft");E.top+=j(G,"borderTopWidth");E.left+=j(G,"borderLeftWidth");F={top:J.top-E.top,left:J.left-E.left}}return F},offsetParent:function(){var E=this[0].offsetParent||document.body;while(E&&(!/^body|html$/i.test(E.tagName)&&o.css(E,"position")=="static")){E=E.offsetParent}return o(E)}});o.each(["Left","Top"],function(F,E){var G="scroll"+E;o.fn[G]=function(H){if(!this[0]){return null}return H!==g?this.each(function(){this==l||this==document?l.scrollTo(!F?H:o(l).scrollLeft(),F?H:o(l).scrollTop()):this[G]=H}):this[0]==l||this[0]==document?self[F?"pageYOffset":"pageXOffset"]||o.boxModel&&document.documentElement[G]||document.body[G]:this[0][G]}});o.each(["Height","Width"],function(I,G){var E=I?"Left":"Top",H=I?"Right":"Bottom",F=G.toLowerCase();o.fn["inner"+G]=function(){return this[0]?o.css(this[0],F,false,"padding"):null};o.fn["outer"+G]=function(K){return this[0]?o.css(this[0],F,false,K?"margin":"border"):null};var J=G.toLowerCase();o.fn[J]=function(K){return this[0]==l?document.compatMode=="CSS1Compat"&&document.documentElement["client"+G]||document.body["client"+G]:this[0]==document?Math.max(document.documentElement["client"+G],document.body["scroll"+G],document.documentElement["scroll"+G],document.body["offset"+G],document.documentElement["offset"+G]):K===g?(this.length?o.css(this[0],J):null):this.css(J,typeof K==="string"?K:K+"px")}})})();
\ No newline at end of file
Deleted: svn:executable
## -1 +0,0 ##
-*
\ No newline at end of property
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/js/jqplot/reportgraph.js (revision 799)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/htdocs/js/jqplot/reportgraph.js (revision 800)
@@ -1,277 +1,249 @@
1-//reportgraph.js
1+(function(jQuery) {
2+ jQuery.fn.reportGraph = function(options) {
3+ var defaults = {
4+ 'graph': 'lines',
5+ 'stack' : false,
6+ 'legendLoc' : 'ne',
7+ 'legendXOffset' : 0,
8+ 'legendYOffset' : 0,
9+ 'xaxisType' : 'string',
10+ 'xaxisMin' : null,
11+ 'xaxisMax' : null,
12+ 'yaxisMin' : null,
13+ 'yaxisMax' : null,
14+ 'xaxisFormatString' : null,
15+ 'yaxisFormatString' : null
16+ };
217
18+ var setting = jQuery.extend(defaults, options);
19+ var id = this.attr('id');
20+
21+ var graph = _getGraph(setting);
22+ graph.draw(id);
23+
24+ return this;
25+ };
326
4-$( function() {
5- /*
6- $(".reportgraph").each(
7- function() {
8- renderGraph(this);
9- });
10- */
11-});
12-
13-function renderGraph(id) {
27+ // Factory
28+ function _getGraph(setting) {
29+ if (setting.graph == 'lines') {
30+ return new LineGraph(setting);
31+ }
32+ if (setting.graph == 'bars') {
33+ return new BarGraph(setting);
34+ }
35+ if (setting.graph == 'pie') {
36+ return new PieGraph(setting);
37+ }
38+ }
1439
15- var idstr = jQuery(id).attr('id').split("_")[1];
16- // console.log(idstr);
17-
18- // option handling
19- var title = $("#reportgraphopt_" + idstr + " .title").text();
20-
21- var opt_per = $("#reportgraphopt_" + idstr + " .per").text()
22- .toLowerCase();
23- var x_minTickSize = opt_per == "week" ? [ 7, "day" ] : [ 1, "day" ];
24-
25- var graphtype = $("#reportgraphopt_" + idstr + " .graph").text()
26- .toLowerCase();
27- var dateFormatPattern = $("#reportgraphopt_" + idstr + " .dateFormat")
28- .text();
29- var dateFormat = new DateFormat(dateFormatPattern);
30-
31- var cols = $("#reportgraphopt_" + idstr + " .cols").text().split(',');
32-
33- var isStackSeries = false;
34- if($("#reportgraphopt_" + idstr + " .stack").text().toLowerCase() == 'true') {
35- isStackSeries = true;
36- }
37-
38- var legendLoc = $("#reportgraphopt_" + idstr + " .legendLoc").text();
39- var legendXOffset = $("#reportgraphopt_" + idstr + " .legendXOffset").text();
40- var legendYOffset = $("#reportgraphopt_" + idstr + " .legendYOffset").text();
41-
42- var xaxisMin = $("#reportgraphopt_" + idstr + " .xaxisMin").text();
43- var xaxisMax = $("#reportgraphopt_" + idstr + " .xaxisMax").text();
44- var yaxisMin = $("#reportgraphopt_" + idstr + " .yaxisMin").text();
45- var yaxisMax = $("#reportgraphopt_" + idstr + " .yaxisMax").text();
46-
47- if(xaxisMin == 'null') {xaxisMin = null;}
48- if(xaxisMax == 'null') {xaxisMax = null;}
49- if(yaxisMin == 'null') {yaxisMin = null;}
50- if(yaxisMax == 'null') {yaxisMax = null;}
51-
52- var xaxisFormatString = $("#reportgraphopt_" + idstr + " .xaxisFormatString").text();
53- var yaxisFormatString = $("#reportgraphopt_" + idstr + " .yaxisFormatString").text();
54-
55- // collect label
56- var table_headers = [];
57- $("#reportgraphtable_" + idstr + " thead tr th").each( function(col_index) {
58- table_headers.push($(this).text());
59- });
60-
61- var labels = []
62- if (cols[0] == '') {
63- $.each(table_headers, function(table_headers_index, table_header) {
64- if (table_headers_index == 0) {
65- return true;
66- }
67- labels.push(table_header);
68- });
69- } else {
70- // for selected column
71- $.each(table_headers, function(table_headers_index, table_header) {
72- $.each(cols, function(col_index, col) {
73- if (col == table_header) {
74- labels.push(table_header);
75- }
76- });
77- });
78- }
79-
80- var xaxis_values = getXaxisValues(idstr, 0, dateFormat);
81-
82- var isDateAxis = false;
83- var isNumAxis = false;
84- switch (xaxis_values['type']) {
85- case 'date':
86- isDateAxis = true;
87- case 'number':
88- isNumAxis = true;
89- }
90- var datas = getTableValues(idstr, xaxis_values, table_headers, dateFormat);
91-
92- switch (graphtype) {
93- case 'bars':
94- graph_opt = {
95- type : $.jqplot.BarRenderer,
96- opts : {
97- }
98- };
99- break;
100- case 'lines':
101- default:
102- graph_opt = {
103- type : $.jqplot.LineRenderer,
104- opts : {
105- }
106- };
107- }
108-
109- var xaxis_opts = {}
110- if (isDateAxis) {
111- xaxis_opts = {
112- renderer: $.jqplot.DateAxisRenderer,
113- min: xaxisMin,
114- max: xaxisMax
115- };
116- } else if (isNumAxis) {
117- xaxis_opts = {
118- min: toNum(xaxisMin, null),
119- max: toNum(xaxisMax, null)
120- };
121- } else {
122- xaxis_opts = {
123- renderer: $.jqplot.CategoryAxisRenderer,
124- min: xaxisMin,
125- max: xaxisMax,
126- ticks: xaxis_values['values']
127- };
128- }
129- xaxis_opts.tickOptions = {formatString: xaxisFormatString};
130-
131- var yaxis_opts = {
132- tickOptions: {formatString: yaxisFormatString},
133- min: toNum(yaxisMin, null),
134- max: toNum(yaxisMax, null)
135- };
136-
137- var series = [];
138- $.each(labels, function(index, label) {
139- series.push({
140- label: label,
141- renderer: graph_opt['type']
142- })
143- });
144-
145- isFill = false;
146- if (isStackSeries && graphtype == 'lines') {
147- isFill = true;
148- }
149- plot1 = $.jqplot('placeholder_' + idstr, datas, {
150- legend: {
151- show: true,
152- location: legendLoc,
153- xoffset: Number(legendXOffset, 10),
154- yoffset: Number(legendYOffset, 10)
155- },
156- title: title,
157- stackSeries: isStackSeries,
158- series: series,
159- seriesDefaults: {
160- fill: isFill
161- },
162- axes: {
163- xaxis: xaxis_opts,
164- yaxis: yaxis_opts
165- },
166- highlighter: {
167- sizeAdjust: 10
168- },
169- cursor: {show: true}
170- });
171-}
172-
173-function toNum(str, defaultValue) {
174- if (str == null) {
175- return defaultValue;
176- }
177- num = Number(str, 10);
178- if (!isNaN(num)) {
179- return num;
180- } else {
181- return defaultValue;
40+ /**
41+ * Class: Graph
42+ */
43+ function Graph(setting) {
44+ this.setting = setting;
45+
46+ this.data = this.getData();
47+ this.title = setting.title;
48+ this.stack = setting.stack;
49+ this.seriesDefaults = this.getSeriesDefaults(setting);
50+ this.series = this.getSeries(setting);
51+ this.legendOption = {
52+ show: true,
53+ location: setting.legendLoc,
54+ xoffset: setting.legendXOffset,
55+ yoffset: setting.legendYOffset
56+ };
57+ this.xaxisOption = {
58+ renderer: this.getXAxisRenderer(setting),
59+ min: this.getXAxisMin(setting),
60+ max: this.getXAxisMax(setting),
61+ ticks: this.getTicks(setting),
62+ numberTicks: this.getNumberTicks(setting),
63+ tickOptions: {formatString: setting.xaxisFormatString}
64+ };
65+ this.yaxisOption = {
66+ min: setting.yaxisMin,
67+ max: setting.yaxisMax,
68+ tickOptions: {formatString: setting.yaxisFormatString}
69+ };
18270 }
183-}
71+
72+ Graph.prototype.draw = function(id) {
73+ jQuery.jqplot(id, this.data, {
74+ legend: this.legendOption,
75+ title: this.title,
76+ stackSeries: this.stack,
77+ seriesDefaults: this.seriesDefaults,
78+ series: this.series,
79+ axes: {
80+ xaxis: this.xaxisOption,
81+ yaxis: this.yaxisOption
82+ },
83+ highlighter: {
84+ sizeAdjust: 10
85+ },
86+ cursor: {show: true}
87+ });
88+ };
89+
90+ Graph.prototype.getSeriesDefaults = function() {
91+ var seriesDefaults = {};
92+ seriesDefaults = {
93+ renderer: this.getRenderer(this.setting),
94+ rendererOptions:{
95+ barWidth: 10
96+ },
97+ fill: this.setting.stack && this.setting.graph == 'lines'
98+ }
99+ return seriesDefaults;
100+ };
101+
102+ Graph.prototype.getRenderer = function() {
103+ return jQuery.jqplot.LineRenderer;
104+ };
105+
106+ Graph.prototype.getData = function() {
107+ if (this.setting.xaxisType == 'date' || this.setting.xaxisType == 'number') {
108+ return _getData(this.setting);
109+ }
110+ return this.setting.data;
111+ };
112+
113+ Graph.prototype.getTicks = function() {
114+ if (this.setting.xaxisType == 'date' || this.setting.xaxisType == 'number') {
115+ return []
116+ }
117+ return this.setting.ticks;
118+ };
119+
120+ Graph.prototype.getNumberTicks = function() {
121+ var number = this.setting.ticks.length;
122+ return number;
123+ };
124+
125+ Graph.prototype.getXAxisRenderer = function() {
126+ if (this.setting.xaxisType == 'number') {
127+ return jQuery.jqplot.LinerAxisRenderer;
128+ }
129+ if (this.setting.xaxisType == 'date') {
130+ return jQuery.jqplot.DateAxisRenderer;
131+ }
132+ // string
133+ return jQuery.jqplot.CategoryAxisRenderer;
134+ };
135+
136+ Graph.prototype.getXAxisMin = function() {
137+ if (this.setting.xaxisMin == null) {
138+ return this.setting.ticks[0];
139+ }
140+ return this.setting.xaxisMin;
141+ };
142+
143+ Graph.prototype.getXAxisMax = function() {
144+ if (this.setting.xaxisMax == null) {
145+ return this.setting.ticks[this.setting.ticks.length-1];
146+ }
147+ return this.setting.xaxisMax;
148+ };
149+
150+ Graph.prototype.getSeries = function() {
151+ var series = [];
152+ jQuery.each(this.setting.seriesLabel, function(index, value){
153+ // use default renderer.
154+ series.push({label: value})
155+ });
156+ return series;
157+ };
158+
159+ /**
160+ * Class: BarGraph
161+ */
162+ function BarGraph(setting) {
163+ Graph.apply(this, arguments);
164+ }
165+
166+ // extend Graph
167+ jQuery.extend(BarGraph.prototype, Graph.prototype);
168+
169+ BarGraph.prototype.getRenderer = function() {
170+ return jQuery.jqplot.BarRenderer;
171+ };
184172
185-function convertData(str, dateFormat) {
186- // try convert to date
187- date = dateFormat.parse(str);
188- if (date != null) {
189- var strDate = new DateFormat("yyyy-MM-dd").format(date);
190- return ['date', strDate];
173+ BarGraph.prototype.getSeriesDefaults = function() {
174+ var seriesDefaults = Graph.prototype.getSeriesDefaults.apply(this);
175+ seriesDefaults.rendererOptions = {
176+ barWidth: this.setting.barWidth
177+ };
178+ return seriesDefaults;
179+ };
180+
181+ /**
182+ * Class: LineGraph
183+ */
184+ function LineGraph(setting) {
185+ Graph.apply(this, arguments);
191186 }
187+
188+ // extend Graph
189+ jQuery.extend(LineGraph.prototype, Graph.prototype);
192190
193- // try convert to int
194- num = Number(str, 10);
195- if (!isNaN(num)) {
196- return ['number', num];
191+ LineGraph.prototype.getRenderer = function() {
192+ return jQuery.jqplot.LineRenderer;
193+ };
194+
195+ /**
196+ * Class: PieGraph
197+ */
198+ function PieGraph(setting) {
199+ Graph.apply(this, arguments);
197200 }
201+
202+ // extend Graph
203+ jQuery.extend(PieGraph.prototype, Graph.prototype);
198204
199- // for string. create ticks.
200- return ['str', str];
201-}
202-
203-function getTableValues(tableId, xaxis_values, table_headers, dateFormat) {
205+ PieGraph.prototype.getRenderer = function() {
206+ return jQuery.jqplot.PieRenderer;
207+ };
204208
205- var tmp = {};
209+ PieGraph.prototype.getData = function() {
210+ return _getData(this.setting);
211+ };
206212
207- $.each(table_headers, function(index, table_header) {
208- tmp[table_header] = [];
209- }
210- );
213+ PieGraph.prototype.getTicks = function() {
214+ return []
215+ };
216+
217+ PieGraph.prototype.getXAxisRenderer = function() {
218+ return jQuery.jqplot.LinerAxisRenderer;
219+ };
220+
221+ // Utility
222+ function _getData(setting) {
223+ var rtn = [];
224+ jQuery.each(setting.data, function(seriesIndex, seriesValue) {
225+ var newSeries = [];
226+
227+ // caluculate sum for pie.
228+ var sum = 0;
229+ if (setting.graph == 'pie') {
230+ jQuery.each(seriesValue, function(dataIndex, dataValue) {
231+ sum += dataValue;
232+ });
233+ }
211234
212- $("#reportgraphtable_" + tableId + " tbody tr").each(
213- function(row_index) {
214- $(this).children().each(function(col_index) {
215-
216- // for xaxis column
217- if(col_index == xaxis_values['colIndex']) {
218- return true;
235+ // create series.
236+ jQuery.each(seriesValue, function(dataIndex, dataValue) {
237+ var newTick = setting.ticks[dataIndex];
238+ if (setting.graph == 'pie') {
239+ newTick += ': ' + dataValue + ' (' + Math.round((dataValue/sum)*100*100)/100 + '%)';
219240 }
220-
221- table_header = table_headers[col_index];
222-
223- value = $(this).text();
224- if (value == '') {
225- return true;
226- }
227- value = Number(value, 10);
228-
229- if (xaxis_values['type'] == 'str') {
230- tmp[table_header].push(value);
231- } else {
232- tmp[table_header].push([xaxis_values['values'][row_index], value]);
233- }
241+ newSeries.push([newTick, dataValue])
234242 });
243+ rtn.push(newSeries);
235244 });
236-
237- var datas = [];
238- $.each(table_headers, function(index, table_header) {
239- // for xaxis column
240- if(index == xaxis_values['colIndex']) {
241- return true;
242- }
243- datas.push(tmp[table_header]);
244- }
245- );
245+ return rtn;
246+ }
246247
247- return datas;
248-}
248+})(jQuery);
249249
250-function getXaxisValues(tableId, index, dateFormat) {
251- var values = []
252- var type = 'str';
253-
254- $("#reportgraphtable_" + tableId + " tbody tr").each(
255- function(row_index) {
256- $(this).children().each( function(col_index) {
257- if (col_index == index) {
258-
259- str = $(this).text();
260- xaxis_value = convertData(str, dateFormat);
261-
262- type = xaxis_value[0];
263- values.push(xaxis_value[1]);
264- }
265- });
266- }
267- );
268-
269- var xaxis_values = {
270- colIndex: index,
271- type: type,
272- values: values
273- };
274-
275- // console.log("xaxis_values=" + xaxis_values['values'])
276- return xaxis_values;
277-}
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/macro.py (revision 799)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/macro.py (revision 800)
@@ -53,11 +53,14 @@
5353 折れ線グラフを表示します。
5454 * bars[[BR]]
5555 棒グラフを表示します。
56+ * pie[[BR]]
57+ 円グラフを表示します。
5658 * stack: グラフ表示時に、スタック(積み上げ)グラフとするかどうか指定します。コロンに続けて、以下の記載が可能です。
5759 * true[[BR]]
5860 スタック(積み上げ)グラフとして表示します。
5961 * false[[BR]]
6062 スタック(積み上げ)グラフとして表示しません。
63+ * barWidth: 棒グラフの幅サイズを指定します。
6164 * legendLoc: グラフの凡例の表示位置を指定します。コロンに続けて、方角を示す nw, n, ne, e, se, s, sw, w のいずれかを指定します。
6265 * legendXOffset: グラフの凡例位置の横方向のオフセットを指定します。未指定の場合は12となります。
6366 * legendYOffset: グラフの凡例位置の縦方向のオフセットを指定します。未指定の場合は12となります。
@@ -86,10 +89,11 @@
8689 * yaxisMax: Y軸の最大値を指定します。指定しない場合は、グラフデータより自動的に計算されます。
8790
8891 表からグラフの生成は、以下のルールに従って行われます。
89- * 一番左の列が、X軸の値になります。
92+ * グラフの種類がlines,barsの場合は、1列目がX軸の値になります。
9093 * デフォルトではyyyy-MM-dd形式の場合は日付と見なして、時系列データとして扱います。
9194 * 2列目以降がグラフのデータとなります。
9295 * ヘッダ行の値がラベルになります。
96+ * グラフの種類がpieの場合は、1列目が表示項目のラベル、2列目がその値として描画します。
9397
9498 例:
9599 * report:1 を表示する。
@@ -130,7 +134,6 @@
130134
131135 def _add_script(self, req):
132136 if not hasattr(req, '_reportinclude'):
133- add_script(req, 'reportinclude/js/dateformat.js')
134137 #add_stylesheet(req, 'reportinclude/css/reportinclude.css')
135138
136139 # add script and css for jqplot
@@ -138,6 +141,7 @@
138141 add_script(req, 'reportinclude/js/jqplot/jquery.jqplot.min.js')
139142 add_script(req, 'reportinclude/js/jqplot/jqplot.pointLabels.min.js')
140143 add_script(req, 'reportinclude/js/jqplot/jqplot.barRenderer.min.js')
144+ add_script(req, 'reportinclude/js/jqplot/jqplot.pieRenderer.min.js')
141145 add_script(req, 'reportinclude/js/jqplot/jqplot.categoryAxisRenderer.min.js')
142146 add_script(req, 'reportinclude/js/jqplot/jqplot.dateAxisRenderer.min.js')
143147 add_script(req, 'reportinclude/js/jqplot/jqplot.cursor.min.js')
--- plugins/reportincludeplugin/trunk/0.12/reportinclude/renderer.py (revision 799)
+++ plugins/reportincludeplugin/trunk/0.12/reportinclude/renderer.py (revision 800)
@@ -3,8 +3,10 @@
33 from genshi.builder import tag
44 from genshi.filters import Transformer
55
6+from trac.core import TracError
7+from trac.resource import ResourceNotFound
68 from trac.ticket.report import ReportModule
7-from trac.util.datefmt import format_datetime, format_date, format_time
9+from trac.util.datefmt import format_datetime, format_date, format_time, parse_date
810
911 class ReportRenderer(object):
1012
@@ -25,15 +27,15 @@
2527 if opts['title'] == '':
2628 opts['title'] = title
2729
28- table = self._render_table(req, id, vars, opts, title, sql, desc)
29- return self._render_graph(req, opts, table, title, desc)
30+ table, columns, table_data = self._render_table(req, id, vars, opts, title, sql, desc)
31+ table = self._render_graph(req, opts, table, columns, table_data, title, desc)
32+ return table
3033 else:
3134 raise ResourceNotFound(
3235 _('Report [%(num)] does not exist.', num=id),
3336 _('Invalid Report Number'))
34-
37+
3538 def _render_table(self, req, id, vars, opts, title, sql, desc):
36-
3739 db = self.env.get_db_cnx()
3840
3941 sql, vars , missing_vars = self._sql_sub_vars(sql, vars, db)
@@ -69,6 +71,10 @@
6971 tbody = tag.tbody()
7072 table.append(tbody)
7173
74+ table_data = {}
75+ for col in columns:
76+ table_data[col] = []
77+
7278 for idx, row in enumerate(cursor):
7379
7480 odd_or_even = (idx % 2 == 0) and 'odd' or 'even'
@@ -77,6 +83,7 @@
7783
7884 for col_idx, col in enumerate(row):
7985 column = columns[col_idx]
86+
8087 if column == '__color__' and css_class is '':
8188 css_class = 'color%s-' % col
8289 continue
@@ -83,18 +90,10 @@
8390 if column.startswith('_'):
8491 continue
8592
86- if column == 'time' or column.endswith('時刻'):
87- col = col != None and format_time(int(col)) or '--'
88- if column in ('date', 'created', 'modified') or column.endswith('日付'):
89- col = col != None and format_date(int(col)) or '--'
90- if column == 'datetime' or column.endswith('日時'):
91- col = col != None and format_datetime(int(col)) or '--'
92-
93- if column.lower() in ('ticket', 'id', u'チケット'):
94- col = tag.a('#' + str(col), title='View Ticket', class_='ticket',
95- href=req.href.ticket(str(col)))
93+ converted_col = self._convert_col(req, column, col)
9694
97- tr = tr(tag.td(col))
95+ tr = tr(tag.td(converted_col))
96+ table_data[column].append(col)
9897
9998 css_class = css_class + odd_or_even
10099 tr = tr(class_ = css_class)
@@ -101,36 +100,67 @@
101100 tbody.append(tr)
102101
103102 #add_stylesheet(req, 'wikitable/css/wikitable.css')
104- return table
103+ return table, columns, table_data
105104
106- def _render_graph(self, req, opts, table, title, desc):
107-
108- if opts['graph'] != 'lines' and opts['graph'] != 'bars':
105+ def _render_graph(self, req, opts, table, columns, table_data, title, desc):
106+ u"""TracReportsの結果をグラフで表示する。
107+ """
108+ if opts['graph'] not in ('lines', 'bars', 'pie'):
109109 return table
110+
111+ ticks = table_data[columns[0]]
112+
113+ data = '['
114+ for column in columns[1:]:
115+ #print table_data[column]
116+ values = self._to_js_array(table_data[column])
117+ data = data + values + ','
118+ data = data[:-1] + ']'
119+
120+ xaxisType = self._getXAxisType(req, ticks, opts)
110121
111- opttag = tag.div(id="reportgraphopt_%d" % (self.index),
112- style="display:none")
113-
114- for opt in opts:
115- opttag.append(tag.span(opts[opt], class_=opt))
116-
117122 script = """
118123 jQuery(document).ready(function($) {
119- renderGraph("#reportgraph_%d");
124+ $('#reportgraph_%d').reportGraph({
125+ graph: '%s',
126+ seriesLabel: %s,
127+ data: %s,
128+ ticks: %s,
129+ title: '%s',
130+ stack: %s,
131+ legendLoc: '%s',
132+ legendXOffset: %s,
133+ legendYOffset: %s,
134+ xaxisType: '%s',
135+ xaxisMin: %s,
136+ xaxisMax: %s,
137+ yaxisMin: %s,
138+ yaxisMax: %s,
139+ xaxisFormatString: '%s',
140+ yaxisFormatString: '%s',
141+ barWidth: '%s'
142+ });
120143 });
121- """ % (self.index)
144+ """ % (self.index, opts['graph'], self._to_js_array(columns[1:]),
145+ data, self._to_js_array(ticks),
146+ opts['title'], opts['stack'].lower(), opts['legendLoc'],
147+ opts['legendXOffset'], opts['legendYOffset'],
148+ xaxisType, opts['xaxisMin'], opts['xaxisMax'],
149+ opts['yaxisMin'], opts['yaxisMax'],
150+ opts['xaxisFormatString'], opts['yaxisFormatString'], opts['barWidth'])
151+
152+ self.env.log.debug(script);
122153
123154 div = tag.div(
124155 tag.div(' ',
125- id="placeholder_%d" % (self.index),
156+ id="reportgraph_%d" % (self.index),
126157 style="width:%spx;height:%spx;" %
127158 (opts["width"],opts["height"])),
128- opttag,
129159 tag.br(),
130160 table,
131161 tag.script(script, type="text/javascript"),
132162 class_="reportgraph",
133- id="reportgraph_%d" % (self.index)
163+ id="reporinclude_%d" % (self.index)
134164 )
135165 return div
136166
@@ -146,7 +176,7 @@
146176 'graph':'',
147177 'table':'inline',
148178 'dateFormat':'yyyy-MM-dd',
149- 'stack':False,
179+ 'stack':'false',
150180 'legendLoc':'ne',
151181 'legendXOffset':'12',
152182 'legendYOffset':'12',
@@ -155,7 +185,8 @@
155185 'yaxisMin':'null',
156186 'yaxisMax':'null',
157187 'xaxisFormatString':'',
158- 'yaxisFormatString':''
188+ 'yaxisFormatString':'',
189+ 'barWidth':'50'
159190 }
160191
161192 vars = {}
@@ -212,5 +243,53 @@
212243
213244 def _sql_sub_vars(self, sql, vars, db):
214245 rm = ReportModule(self.env)
215- sql, vars, missing_vars= rm.sql_sub_vars(sql, vars, db)
246+ sql, vars, missing_vars = rm.sql_sub_vars(sql, vars, db)
216247 return sql, vars, missing_vars
248+
249+ def _getXAxisType(self, req, ticks, opts):
250+ if ticks and len(ticks) > 0:
251+ try:
252+ int(ticks[0])
253+ return 'number'
254+ except ValueError:
255+ pass
256+
257+ try:
258+ parse_date(ticks[0], req.tz)
259+ return 'date'
260+ except TracError:
261+ pass
262+
263+ return 'string'
264+
265+ def _to_js_array(self, array):
266+ if array is None:
267+ return 'null'
268+ if len(array) == 0:
269+ return '[]'
270+
271+ is_number = True
272+ for value in array:
273+ try:
274+ int(value)
275+ except ValueError:
276+ is_number = False
277+ pass
278+
279+ if is_number:
280+ return "[" + ",".join(map(str, array)) + "]"
281+ else:
282+ return "['" + "','".join(map(str, array)) + "']"
283+
284+ def _convert_col(self, req, column, col):
285+ if column == 'time' or column.endswith(u'時刻'):
286+ col = col != None and format_time(int(col)) or '--'
287+ if column in ('date', 'created', 'modified') or column.endswith(u'日付'):
288+ col = col != None and format_date(int(col)) or '--'
289+ if column == 'datetime' or column.endswith(u'日時'):
290+ col = col != None and format_datetime(int(col)) or '--'
291+
292+ if column.lower() in ('ticket', 'id', u'チケット'):
293+ col = tag.a('#' + str(col), title='View Ticket', class_='ticket',
294+ href=req.href.ticket(str(col)))
295+ return col
--- plugins/reportincludeplugin/trunk/0.12/setup.py (revision 799)
+++ plugins/reportincludeplugin/trunk/0.12/setup.py (revision 800)
@@ -8,12 +8,12 @@
88 author_email='wadahiro@gmail.com',
99 url = "http://sourceforge.jp/projects/shibuya-trac/wiki/plugins%2FReportIncludePlugin",
1010 description='Trac plugin for include a report (with graph) in a wiki page',
11- version='0.4.3',
11+ version='0.5-SNAPSHOT',
1212 license='New BSD',
1313 packages=find_packages(exclude=['*.tests*']),
1414 package_data={'reportinclude': ['htdocs/css/*.css', 'htdocs/css/jqplot/*.css', 'htdocs/js/*.js',
1515 'htdocs/js/flot/*.js', 'htdocs/js/jqplot/*.js', 'htdocs/image/*.gif',
16- 'templates/*.html']},
16+ 'templates/*.html', 'htdocs/*.html']},
1717 entry_points={
1818 'trac.plugins': [
1919 'reportinclude = reportinclude'
Show on old repository browser