3 Copyright (C) 2006-2010 Jonathan Zarate
4 http://www.polarcloud.com/tomato/
6 For use with Tomato Firmware only.
7 No part of this file may be used without permission.
27 ['Green & Blue', '#118811', '#6495ed'], ['Blue & Orange', '#003EBA', '#FF9000'],
28 ['Blue & Red', '#003EDD', '#CC4040'], ['Blue', '#22f', '#225'], ['Gray', '#000', '#999'],
29 ['Red & Black', '#d00', '#000']];
38 return (byt / 125).toFixed(2) + ' <small>kbit/s</small><br>(' + (byt / 1024).toFixed(2) + ' <small>KB/s</small>)';
43 showTab('speed-tab-' + ifname);
46 function showSelectedOption(prefix, prev, now)
50 elem.removeClass(prefix + prev, 'selected'); // safe if prev doesn't exist
51 if ((e = E(prefix + now)) != null) {
52 elem.addClass(e, 'selected');
59 if (drawLast == drawMode) return;
60 showSelectedOption('draw', drawLast, drawMode);
64 function switchDraw(n)
66 if ((!svgReady) || (updating)) return;
70 cookie.set(cprefix + 'draw', drawMode);
75 E('drawcolor').innerHTML = colors[drawColor][0] + ' »';
76 E('rx-name').style.borderBottom = '2px dashed ' + colors[drawColor][1 + colorX];
77 E('tx-name').style.borderBottom = '2px dashed ' + colors[drawColor][1 + (colorX ^ 1)];
80 function switchColor(rev)
82 if ((!svgReady) || (updating)) return;
84 else drawColor = (drawColor + 1) % colors.length;
87 cookie.set(cprefix + 'color', drawColor + ',' + colorX);
92 if (scaleMode == scaleLast) return;
93 showSelectedOption('scale', scaleLast, scaleMode);
94 scaleLast = scaleMode;
97 function switchScale(n)
101 showTab('speed-tab-' + ifname);
102 cookie.set(cprefix + 'scale', scaleMode);
107 if (avgMode == avgLast) return;
108 showSelectedOption('avg', avgLast, avgMode);
112 function switchAvg(n)
114 if ((!svgReady) || (updating)) return;
118 cookie.set(cprefix + 'avg', avgMode);
121 function tabSelect(name)
123 if (!updating) showTab(name);
126 function showTab(name)
134 ifname = name.replace('speed-tab-', '');
135 cookie.set(cprefix + 'tab', ifname, 14);
138 h = speed_history[ifname];
141 E('rx-current').innerHTML = xpsb(h.rx[h.rx.length - 1] / updateDiv);
142 E('rx-avg').innerHTML = xpsb(h.rx_avg);
143 E('rx-max').innerHTML = xpsb(h.rx_max);
145 E('tx-current').innerHTML = xpsb(h.tx[h.tx.length - 1] / updateDiv);
146 E('tx-avg').innerHTML = xpsb(h.tx_avg);
147 E('tx-max').innerHTML = xpsb(h.tx_max);
149 E('rx-total').innerHTML = scaleSize(h.rx_total);
150 E('tx-total').innerHTML = scaleSize(h.tx_total);
153 max = scaleMode ? MAX(h.rx_max, h.tx_max) : xx_max
154 if (max > 12500) max = Math.round((max + 12499) / 12500) * 12500;
156 updateSVG(h.rx, h.tx, max, drawMode,
157 colors[drawColor][1 + colorX], colors[drawColor][1 + (colorX ^ 1)],
158 updateInt, updateMaxL, updateDiv, avgMode, clock);
175 if (!speed_history) {
179 for (var i in speed_history) {
180 var h = speed_history[i];
181 if ((typeof(h.rx) == 'undefined') || (typeof(h.tx) == 'undefined')) {
182 delete speed_history[i];
185 if ((h.rx_total == 0) && (h.tx_total == 0) && (h.up == 0)) {
186 delete speed_history[i];
190 if (typeof(h.hide) != 'undefined') {
191 if (h.hide == 1) continue;
195 h.rx_total = h.rx_max = 0;
196 h.tx_total = h.tx_max = 0;
197 for (j = (h.rx.length - updateMaxL); j < h.rx.length; ++j) {
199 if (t > h.rx_max) h.rx_max = t;
202 if (t > h.tx_max) h.tx_max = t;
205 h.rx_avg = h.rx_total / h.count;
206 h.tx_avg = h.tx_total / h.count;
210 h.rx_max /= updateDiv;
211 h.tx_max /= updateDiv;
212 h.rx_avg /= updateDiv;
213 h.tx_avg /= updateDiv;
215 if (h.rx_max > xx_max) xx_max = h.rx_max;
216 if (h.tx_max > xx_max) xx_max = h.tx_max;
218 t = i; // by default, show only the IP address (or IF name)
219 if ((typeof(hostnamecache) != 'undefined') && (hostnamecache[i] != null)) {
220 if (nvram['cstats_labels'] != null ) {
221 if (nvram['cstats_labels'] == '1') { // if known, show only the hostname
222 t = hostnamecache[i];
224 if (nvram['cstats_labels'] == '0') { // show hostname and IP
225 t = hostnamecache[i] + ' <small>(' + i + ')</small>';
229 else if (wl_ifidx(i) >= 0) {
231 // else if (i == nvram.wl_ifname) {
233 t = 'WL <small>(' + i + ')</small>';
237 t = 'Lim. OUT <small>(' + i + ')</small>';
241 t = 'Lim. IN <small>(' + i + ')</small>';
244 else if ((nvram.wan_proto == 'pptp') || (nvram.wan_proto == 'pppoe') || (nvram.wan_proto == 'l2tp') || (nvram.wan_proto == 'ppp3g')) {
245 if (nvram.wan_iface == i) t = 'WAN <small>(' + i + ')</small>';
246 else if (nvram.wan_ifname == i && ((nvram.wan_proto != 'pppoe') && (nvram.wan_proto != 'ppp3g'))) t = 'MAN <small>(' + i + ')</small>';
248 else if (nvram.wan_proto != 'disabled') {
249 if (nvram.wan_ifname == i) t = 'WAN <small>(' + i + ')</small>';
251 tabs.push(['speed-tab-' + i, t]);
256 if (a[1] < b[1]) return -1;
257 if (a[1] > b[1]) return 1;
262 if (tabs.length == old.length) {
263 for (i = tabs.length - 1; i >= 0; --i)
264 if (tabs[i][0] != old[i][0]) break;
270 E('tab-area').innerHTML = _tabCreate.apply(this, tabs);
272 if (((name = cookie.get(cprefix + 'tab')) != null) && ((speed_history[name] != undefined))) {
273 showTab('speed-tab-' + name);
276 if (tabs.length) showTab(tabs[0][0]);
284 E('graph').style.visibility = 'visible';
285 E('bwm-controls').style.visibility = 'visible';
290 function initCommon(defAvg, defDrawMode, defDrawColor)
292 drawMode = fixInt(cookie.get(cprefix + 'draw'), 0, 1, defDrawMode);
295 if (nvram['rstats_colors'] != null)
296 var c = nvram.rstats_colors.split(',');
297 else if (nvram['cstats_colors'] != null)
298 var c = nvram.cstats_colors.split(',');
299 while (c.length >= 3) {
300 c[0] = escapeHTML(c[0]);
301 colors.push(c.splice(0, 3));
304 c = (cookie.get(cprefix + 'color') || '').split(',');
306 drawColor = fixInt(c[0], 0, colors.length - 1, defDrawColor);
307 colorX = fixInt(c[1], 0, 1, 0);
310 drawColor = defDrawColor;
314 scaleMode = fixInt(cookie.get(cprefix + 'scale'), 0, 1, 0);
317 avgMode = fixInt(cookie.get(cprefix + 'avg'), 1, 10, defAvg);
321 if ((nvram.wan_proto == 'disabled') || (nvram.wan_proto == 'wet')) {
322 nvram.wan_ifname = '';
327 E('refresh-spinner').style.visibility = 'hidden';
330 function populateCache() {
333 if (nvram['dhcpd_static'] != null ) {
334 s = nvram.dhcpd_static.split('>');
335 for (var i = 0; i < s.length; ++i) {
336 var t = s[i].split('<');
337 if ((t.length == 3) || (t.length == 4)) {
339 hostnamecache[t[1]] = t[2].split(' ').splice(0,1);
344 if (typeof(dhcpd_lease) != 'undefined') {
345 for (var j=0; j<dhcpd_lease.length; ++j) {
346 if (dhcpd_lease[j][0] != '') {
347 hostnamecache[dhcpd_lease[j][1]] = dhcpd_lease[j][0].split(' ').splice(0,1);
352 for (var i = 0 ; i <= MAX_BRIDGE_ID ; i++) {
353 var j = (i == 0) ? '' : i.toString();
354 if (nvram['lan' + j + '_ipaddr'] != null)
355 if (nvram['lan' + j + '_netmask'] != null)
356 if (nvram['lan' + j + '_ipaddr'] != '')
357 if (nvram['lan' + j + '_netmask'] != '') {
358 hostnamecache[getNetworkAddress(nvram['lan' + j + '_ipaddr'], nvram['lan' + j + '_netmask'])] = 'LAN' + j;