blob: f38534404a2867682ab0b812b37d31204dd90d4a [file] [log] [blame]
Carsten Ziegelerd524ac92008-10-23 16:44:07 +00001/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements. See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000017function renderStatusLine() {
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000018 document.write( "<div class='fullwidth'>");
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000019 document.write( "<div class='statusline'></div>" );
20 document.write( "</div>" );
21}
22
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000023function renderView( /* Array of String */ columns, /* Array of String */ buttons ) {
24 renderStatusLine();
25 renderButtons(buttons);
Carsten Ziegeler7876ef92008-10-26 17:47:51 +000026 document.write( "<div class='table'>");
27 document.write( "<table id='events' class='tablelayout'>" );
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000028
Carsten Ziegeler7876ef92008-10-26 17:47:51 +000029 document.write( "<thead><tr>" );
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000030 for ( var name in columns ) {
31 document.write( "<th>" + columns[name] + "</th>" );
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000032 }
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000033 document.write( "</tr></thead><tbody>" );
Carsten Ziegeler7876ef92008-10-26 17:47:51 +000034 document.write( "</tbody></table>" );
35 document.write( "</div>");
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000036 renderButtons(buttons);
37 renderStatusLine();
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000038}
39
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000040function renderButtons( buttons ) {
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000041 document.write( "<div class='fullwidth'>");
42 document.write( "<div class='buttons'>" );
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000043 for( var b in buttons ) {
44 document.write( "<div class='button'>");
45 document.write(buttons[b]);
46 document.write( "</div>");
47 }
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000048 document.write( "</div>" );
49 document.write( "</div>" );
50}
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000051
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000052function renderData( eventData ) {
53 $(".statusline").empty().append(eventData.status);
54 $("#events > tbody > tr").remove();
55 for ( var idx in eventData.data ) {
56 entry( eventData.data[idx] );
57 }
58}
59
60function entry( /* Object */ dataEntry ) {
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000061 var trElement = tr( null, { id: "entry" + dataEntry.id } );
Carsten Ziegeler7876ef92008-10-26 17:47:51 +000062 entryInternal( trElement, dataEntry );
63 $("#events > tbody").append(trElement);
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000064}
65
66
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000067function entryInternal( /* Element */ parent, /* Object */ dataEntry ) {
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000068 var id = dataEntry.id;
69 var topic = dataEntry.topic;
70 var properties = dataEntry.properties;
71
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000072 parent.appendChild( td( null, null, [ text( printDate(dataEntry.received) ) ] ) );
Carsten Ziegeler7876ef92008-10-26 17:47:51 +000073 parent.appendChild( td( null, null, [ text( topic ) ] ) );
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000074
Carsten Ziegeler0f77a572008-10-27 16:30:38 +000075 var propE;
76 if ( dataEntry.info ) {
77 propE = text(dataEntry.info);
78 } else {
79 var tableE = createElement("table");
80 var bodyE = createElement("tbody");
81 tableE.appendChild(bodyE);
82
83 for( var p in dataEntry.properties ) {
84 bodyE.appendChild(tr(null, null, [td(null, null, [text(p)] ),
85 td(null, null, [text(dataEntry.properties[p])])]));
86 }
87 propE = tableE;
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000088 }
89
Carsten Ziegeler0f77a572008-10-27 16:30:38 +000090 parent.appendChild( td( null, null, [propE] ) );
Carsten Ziegelerd524ac92008-10-23 16:44:07 +000091}
92
Carsten Ziegelerc75546e2008-11-12 05:20:15 +000093/* displays a date in the user's local timezone */
94function printDate(time) {
95 var date = time ? new Date(time) : new Date();
96 return date.toLocaleString();
97}
98
Carsten Ziegeler94ccb532008-10-27 11:36:46 +000099function loadData() {
Carsten Ziegeler7876ef92008-10-26 17:47:51 +0000100 $.get(pluginRoot + "/data.json", null, function(data) {
101 renderData(data);
102 }, "json");
103}
Carsten Ziegelerd524ac92008-10-23 16:44:07 +0000104
Carsten Ziegeler94ccb532008-10-27 11:36:46 +0000105function renderEvents() {
Carsten Ziegelerc75546e2008-11-12 05:20:15 +0000106 renderView( ["Received", "Topic", "Properties"],
107 ["<button id='reloadButton' type='button' name='reload'>Reload</button>",
108 "<button id='clearButton' type='button' name='clear'>Clear List</button>"]);
Carsten Ziegeler94ccb532008-10-27 11:36:46 +0000109
Carsten Ziegeler7876ef92008-10-26 17:47:51 +0000110 loadData();
111
112 $("#events").tablesorter();
113 $("#reloadButton").click(loadData);
114 $("#clearButton").click(function () {
115 $("#events > tbody > tr").remove();
116 $.post(pluginRoot, { "action":"clear" }, function(data) {
117 renderData(data);
118 }, "json");
119 });
Carsten Ziegelerd524ac92008-10-23 16:44:07 +0000120}