2008-07-03 14:59:31 +00:00
|
|
|
/*
|
|
|
|
* MIT License
|
2008-09-28 11:57:09 +00:00
|
|
|
* Copyright (c) 2008 Ishan Arora <ishan@qbittorrent.org> & Christophe Dumez <chris@qbittorrent.org>
|
2008-07-03 14:59:31 +00:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
|
|
* in the Software without restriction, including without limitation the rights
|
|
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
2014-11-22 09:35:56 +03:00
|
|
|
*
|
2008-07-03 14:59:31 +00:00
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
2014-11-22 09:35:56 +03:00
|
|
|
*
|
2008-07-03 14:59:31 +00:00
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
* THE SOFTWARE.
|
2008-07-04 07:48:15 +00:00
|
|
|
*/
|
2008-05-17 12:44:42 +00:00
|
|
|
|
|
|
|
/**************************************************************
|
|
|
|
|
2014-11-22 09:35:56 +03:00
|
|
|
Script : Dynamic Table
|
|
|
|
Version : 0.5
|
|
|
|
Authors : Ishan Arora & Christophe Dumez
|
|
|
|
Desc : Programable sortable table
|
|
|
|
Licence : Open Source MIT Licence
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2014-11-22 09:35:56 +03:00
|
|
|
**************************************************************/
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
var DynamicTable = new Class({
|
2008-12-24 11:28:02 +00:00
|
|
|
|
2014-11-22 09:35:56 +03:00
|
|
|
initialize : function () {},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2016-07-16 13:23:59 +03:00
|
|
|
setup : function (tableId, tableHeaderId, contextMenu) {
|
2015-11-11 22:50:14 +03:00
|
|
|
this.tableId = tableId;
|
|
|
|
this.tableHeaderId = tableHeaderId;
|
|
|
|
this.table = $(tableId);
|
2014-11-22 09:35:56 +03:00
|
|
|
this.rows = new Hash();
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows = new Array();
|
2014-12-24 04:39:18 +03:00
|
|
|
this.columns = new Array();
|
2016-07-16 13:23:59 +03:00
|
|
|
this.contextMenu = contextMenu;
|
2015-11-11 22:50:14 +03:00
|
|
|
this.sortedColumn = getLocalStorageItem('sorted_column_' + this.tableId, 0);
|
|
|
|
this.reverseSort = getLocalStorageItem('reverse_sort_' + this.tableId, '0');
|
2014-12-24 04:39:18 +03:00
|
|
|
this.initColumns();
|
|
|
|
this.loadColumnsOrder();
|
|
|
|
this.updateHeader();
|
|
|
|
},
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
initColumns : function () {},
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
newColumn : function (name, style, caption) {
|
|
|
|
var column = {};
|
|
|
|
column['name'] = name;
|
2015-11-11 22:50:14 +03:00
|
|
|
column['visible'] = getLocalStorageItem('column_' + name + '_visible_' + this.tableId, '1');
|
2014-12-24 04:39:18 +03:00
|
|
|
column['force_hide'] = false;
|
|
|
|
column['caption'] = caption;
|
|
|
|
column['style'] = style;
|
2015-11-11 22:50:14 +03:00
|
|
|
column['onclick'] = 'this._this.setSortedColumn(\'' + name + '\');';
|
2014-12-24 04:39:18 +03:00
|
|
|
column['dataProperties'] = [name];
|
|
|
|
column['getRowValue'] = function (row, pos) {
|
|
|
|
if (pos == undefined)
|
|
|
|
pos = 0;
|
|
|
|
return row['full_data'][this.dataProperties[pos]];
|
|
|
|
};
|
|
|
|
column['compareRows'] = function (row1, row2) {
|
|
|
|
if (this.getRowValue(row1) < this.getRowValue(row2))
|
|
|
|
return -1;
|
|
|
|
else if (this.getRowValue(row1) > this.getRowValue(row2))
|
|
|
|
return 1;
|
|
|
|
else return 0;
|
|
|
|
};
|
|
|
|
column['updateTd'] = function (td, row) {
|
|
|
|
td.innerHTML = this.getRowValue(row);
|
|
|
|
};
|
|
|
|
this.columns.push(column);
|
|
|
|
this.columns[name] = column;
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
$(this.tableHeaderId).appendChild(new Element('th'));
|
2014-12-24 04:39:18 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
loadColumnsOrder : function () {
|
|
|
|
columnsOrder = ['state_icon']; // status icon column is always the first
|
2015-11-11 22:50:14 +03:00
|
|
|
val = localStorage.getItem('columns_order_' + this.tableId);
|
2014-12-24 04:39:18 +03:00
|
|
|
if (val === null || val === undefined) return;
|
|
|
|
val.split(',').forEach(function(v) {
|
|
|
|
if ((v in this.columns) && (!columnsOrder.contains(v)))
|
|
|
|
columnsOrder.push(v);
|
|
|
|
}.bind(this));
|
|
|
|
|
|
|
|
for (i = 0; i < this.columns.length; i++)
|
|
|
|
if (!columnsOrder.contains(this.columns[i].name))
|
|
|
|
columnsOrder.push(this.columns[i].name);
|
|
|
|
|
|
|
|
for (i = 0; i < this.columns.length; i++)
|
|
|
|
this.columns[i] = this.columns[columnsOrder[i]];
|
|
|
|
},
|
|
|
|
|
|
|
|
saveColumnsOrder : function () {
|
|
|
|
val = '';
|
|
|
|
for (i = 0; i < this.columns.length; i++) {
|
|
|
|
if (i > 0)
|
|
|
|
val += ',';
|
|
|
|
val += this.columns[i].name;
|
|
|
|
}
|
2015-11-11 22:50:14 +03:00
|
|
|
localStorage.setItem('columns_order_' + this.tableId, val);
|
2014-12-24 04:39:18 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
updateHeader : function () {
|
2015-11-11 22:50:14 +03:00
|
|
|
var ths = $(this.tableHeaderId).getElements('th');
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
for (var i = 0; i < ths.length; i++) {
|
|
|
|
th = ths[i];
|
2015-11-11 22:50:14 +03:00
|
|
|
th._this = this;
|
2014-12-24 04:39:18 +03:00
|
|
|
th.setAttribute('onclick', this.columns[i].onclick);
|
|
|
|
th.innerHTML = this.columns[i].caption;
|
|
|
|
th.setAttribute('style', this.columns[i].style);
|
|
|
|
if ((this.columns[i].visible == '0') || this.columns[i].force_hide)
|
|
|
|
th.addClass('invisible');
|
|
|
|
else
|
|
|
|
th.removeClass('invisible');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
getColumnPos : function (columnName) {
|
|
|
|
for (var i = 0; i < this.columns.length; i++)
|
|
|
|
if (this.columns[i].name == columnName)
|
|
|
|
return i;
|
|
|
|
return -1;
|
|
|
|
},
|
|
|
|
|
|
|
|
updateColumn : function (columnName) {
|
|
|
|
var pos = this.getColumnPos(columnName);
|
|
|
|
var visible = ((this.columns[pos].visible != '0') && !this.columns[pos].force_hide);
|
2015-11-11 22:50:14 +03:00
|
|
|
var ths = $(this.tableHeaderId).getElements('th');
|
2014-12-24 04:39:18 +03:00
|
|
|
if (visible)
|
|
|
|
ths[pos].removeClass('invisible');
|
|
|
|
else
|
|
|
|
ths[pos].addClass('invisible');
|
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
for (var i = 0; i < trs.length; i++)
|
|
|
|
if (visible)
|
|
|
|
trs[i].getElements('td')[pos].removeClass('invisible');
|
|
|
|
else
|
|
|
|
trs[i].getElements('td')[pos].addClass('invisible');
|
2014-11-22 09:35:56 +03:00
|
|
|
},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2014-11-26 12:45:09 +03:00
|
|
|
setSortedColumn : function (column) {
|
2014-12-24 04:39:18 +03:00
|
|
|
if (column != this.sortedColumn) {
|
|
|
|
this.sortedColumn = column;
|
|
|
|
this.reverseSort = '0';
|
|
|
|
}
|
|
|
|
else {
|
2014-11-22 09:35:56 +03:00
|
|
|
// Toggle sort order
|
2014-12-24 04:39:18 +03:00
|
|
|
this.reverseSort = this.reverseSort == '0' ? '1' : '0';
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2015-11-11 22:50:14 +03:00
|
|
|
localStorage.setItem('sorted_column_' + this.tableId, column);
|
|
|
|
localStorage.setItem('reverse_sort_' + this.tableId, this.reverseSort);
|
|
|
|
this.updateTable(false);
|
2014-11-22 09:35:56 +03:00
|
|
|
},
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
getSelectedRowId : function () {
|
2016-07-16 13:23:59 +03:00
|
|
|
if (this.selectedRows.length > 0)
|
|
|
|
return this.selectedRows[0];
|
2014-11-22 09:35:56 +03:00
|
|
|
return '';
|
|
|
|
},
|
|
|
|
|
|
|
|
altRow : function () {
|
2014-11-11 15:26:20 +01:00
|
|
|
if (!MUI.ieLegacySupport)
|
|
|
|
return;
|
|
|
|
|
2014-11-22 09:35:56 +03:00
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
trs.each(function (el, i) {
|
|
|
|
if (i % 2) {
|
|
|
|
el.addClass('alt');
|
|
|
|
} else {
|
|
|
|
el.removeClass('alt');
|
|
|
|
}
|
|
|
|
}.bind(this));
|
|
|
|
},
|
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
selectAll : function () {
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows.empty();
|
2014-12-24 04:39:18 +03:00
|
|
|
|
2014-11-22 09:35:56 +03:00
|
|
|
var trs = this.table.getElements('tr');
|
2014-12-24 04:39:18 +03:00
|
|
|
for (var i = 0; i < trs.length; i++) {
|
|
|
|
var tr = trs[i];
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows.push(tr.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
if (!tr.hasClass('selected'))
|
|
|
|
tr.addClass('selected');
|
|
|
|
}
|
2014-11-22 09:35:56 +03:00
|
|
|
},
|
2008-12-29 23:04:45 +00:00
|
|
|
|
2016-01-10 12:00:29 +03:00
|
|
|
deselectAll : function () {
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows.empty();
|
2016-01-10 12:00:29 +03:00
|
|
|
},
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
selectRow : function (rowId) {
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows.empty();
|
|
|
|
this.selectedRows.push(rowId);
|
2014-11-22 09:35:56 +03:00
|
|
|
var trs = this.table.getElements('tr');
|
2014-12-24 04:39:18 +03:00
|
|
|
for (var i = 0; i < trs.length; i++) {
|
|
|
|
var tr = trs[i];
|
2015-11-11 22:50:14 +03:00
|
|
|
if (tr.rowId == rowId) {
|
2014-12-24 04:39:18 +03:00
|
|
|
if (!tr.hasClass('selected'))
|
|
|
|
tr.addClass('selected');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
if (tr.hasClass('selected'))
|
|
|
|
tr.removeClass('selected');
|
|
|
|
}
|
2016-01-20 12:13:27 +03:00
|
|
|
this.onSelectedRowChanged();
|
2014-11-22 09:35:56 +03:00
|
|
|
},
|
|
|
|
|
2016-01-20 12:13:27 +03:00
|
|
|
onSelectedRowChanged : function () {},
|
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
updateRowData : function (data) {
|
2015-11-11 22:50:14 +03:00
|
|
|
var rowId = data['rowId'];
|
2014-12-24 04:39:18 +03:00
|
|
|
var row;
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
if (!this.rows.has(rowId)) {
|
2014-12-24 04:39:18 +03:00
|
|
|
row = {};
|
2015-11-11 22:50:14 +03:00
|
|
|
this.rows.set(rowId, row);
|
2014-12-24 04:39:18 +03:00
|
|
|
row['full_data'] = {};
|
2015-11-11 22:50:14 +03:00
|
|
|
row['rowId'] = rowId;
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
else
|
2015-11-11 22:50:14 +03:00
|
|
|
row = this.rows.get(rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
row['data'] = data;
|
|
|
|
|
|
|
|
for(var x in data)
|
|
|
|
row['full_data'][x] = data[x];
|
|
|
|
},
|
|
|
|
|
|
|
|
getFilteredAndSortedRows : function () {
|
|
|
|
var filteredRows = new Array();
|
|
|
|
|
|
|
|
var rows = this.rows.getValues();
|
|
|
|
|
|
|
|
for (i = 0; i < rows.length; i++)
|
2015-11-11 22:50:14 +03:00
|
|
|
{
|
|
|
|
filteredRows.push(rows[i]);
|
|
|
|
filteredRows[rows[i].rowId] = rows[i];
|
|
|
|
}
|
2014-11-22 09:35:56 +03:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
filteredRows.sort(function (row1, row2) {
|
2015-11-11 22:50:14 +03:00
|
|
|
var column = this.columns[this.sortedColumn];
|
2014-12-24 04:39:18 +03:00
|
|
|
res = column.compareRows(row1, row2);
|
|
|
|
if (this.reverseSort == '0')
|
|
|
|
return res;
|
|
|
|
else
|
|
|
|
return -res;
|
2014-11-22 09:35:56 +03:00
|
|
|
}.bind(this));
|
2014-12-24 04:39:18 +03:00
|
|
|
return filteredRows;
|
|
|
|
},
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
getTrByRowId : function (rowId) {
|
2014-12-24 04:39:18 +03:00
|
|
|
trs = this.table.getElements('tr');
|
|
|
|
for (var i = 0; i < trs.length; i++)
|
2015-11-11 22:50:14 +03:00
|
|
|
if (trs[i].rowId == rowId)
|
2014-12-24 04:39:18 +03:00
|
|
|
return trs[i];
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
|
|
|
updateTable : function (fullUpdate) {
|
|
|
|
if (fullUpdate == undefined)
|
|
|
|
fullUpdate = false;
|
|
|
|
|
|
|
|
var rows = this.getFilteredAndSortedRows();
|
|
|
|
|
2016-07-16 13:23:59 +03:00
|
|
|
for (var i = 0; i < this.selectedRows.length; i++)
|
|
|
|
if (!(this.selectedRows[i] in rows)) {
|
|
|
|
this.selectedRows.splice(i, 1);
|
2014-12-24 04:39:18 +03:00
|
|
|
i--;
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
|
|
|
|
for (var rowPos = 0; rowPos < rows.length; rowPos++) {
|
2015-11-11 22:50:14 +03:00
|
|
|
var rowId = rows[rowPos]['rowId'];
|
2014-12-24 04:39:18 +03:00
|
|
|
tr_found = false;
|
|
|
|
for (j = rowPos; j < trs.length; j++)
|
2015-11-11 22:50:14 +03:00
|
|
|
if (trs[j]['rowId'] == rowId) {
|
2014-12-24 04:39:18 +03:00
|
|
|
trs[rowPos].removeClass('over');
|
|
|
|
tr_found = true;
|
|
|
|
if (rowPos == j)
|
|
|
|
break;
|
|
|
|
trs[j].inject(trs[rowPos], 'before');
|
|
|
|
var tmpTr = trs[j];
|
|
|
|
trs.splice(j, 1);
|
|
|
|
trs.splice(rowPos, 0, tmpTr);
|
|
|
|
break;
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
if (tr_found) // row already exists in the table
|
|
|
|
this.updateRow(trs[rowPos], fullUpdate);
|
|
|
|
else { // else create a new row in the table
|
|
|
|
var tr = new Element('tr');
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
tr['rowId'] = rows[rowPos]['rowId'];
|
2014-12-24 04:39:18 +03:00
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
tr._this = this;
|
2014-12-24 04:39:18 +03:00
|
|
|
tr.addEvent('contextmenu', function (e) {
|
2016-07-16 13:23:59 +03:00
|
|
|
if (!this._this.selectedRows.contains(this.rowId))
|
2015-11-11 22:50:14 +03:00
|
|
|
this._this.selectRow(this.rowId);
|
2015-01-30 00:16:28 +03:00
|
|
|
return true;
|
|
|
|
});
|
2014-12-24 04:39:18 +03:00
|
|
|
tr.addEvent('click', function (e) {
|
|
|
|
e.stop();
|
|
|
|
if (e.control) {
|
|
|
|
// CTRL key was pressed
|
2016-07-16 13:23:59 +03:00
|
|
|
if (this._this.selectedRows.contains(this.rowId)) {
|
2014-12-24 04:39:18 +03:00
|
|
|
// remove it
|
2016-07-16 13:23:59 +03:00
|
|
|
this._this.selectedRows.erase(this.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
// Remove selected style
|
|
|
|
this.removeClass('selected');
|
|
|
|
}
|
|
|
|
else {
|
2016-07-16 13:23:59 +03:00
|
|
|
this._this.selectedRows.push(this.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
// Add selected style
|
|
|
|
this.addClass('selected');
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
else {
|
2016-07-16 13:23:59 +03:00
|
|
|
if (e.shift && this._this.selectedRows.length == 1) {
|
2014-12-24 04:39:18 +03:00
|
|
|
// Shift key was pressed
|
2016-07-16 13:23:59 +03:00
|
|
|
var first_row_id = this._this.selectedRows[0];
|
2015-11-11 22:50:14 +03:00
|
|
|
var last_row_id = this.rowId;
|
2016-07-16 13:23:59 +03:00
|
|
|
this._this.selectedRows.empty();
|
2015-11-11 22:50:14 +03:00
|
|
|
var trs = this._this.table.getElements('tr');
|
2014-12-24 04:39:18 +03:00
|
|
|
var select = false;
|
|
|
|
for (var i = 0; i < trs.length; i++) {
|
|
|
|
var tr = trs[i];
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
if ((tr.rowId == first_row_id) || (tr.rowId == last_row_id)) {
|
2016-07-16 13:23:59 +03:00
|
|
|
this._this.selectedRows.push(tr.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
tr.addClass('selected');
|
|
|
|
select = !select;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (select) {
|
2016-07-16 13:23:59 +03:00
|
|
|
this._this.selectedRows.push(tr.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
tr.addClass('selected');
|
|
|
|
}
|
|
|
|
else
|
|
|
|
tr.removeClass('selected')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// Simple selection
|
2015-11-11 22:50:14 +03:00
|
|
|
this._this.selectRow(this.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
}
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
this.setupTr(tr);
|
2015-11-11 22:50:14 +03:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
for (var j = 0 ; j < this.columns.length; j++) {
|
|
|
|
var td = new Element('td');
|
|
|
|
if ((this.columns[j].visible == '0') || this.columns[j].force_hide)
|
|
|
|
td.addClass('invisible');
|
|
|
|
td.injectInside(tr);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Insert
|
|
|
|
if (rowPos >= trs.length) {
|
|
|
|
tr.inject(this.table);
|
|
|
|
trs.push(tr);
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
else {
|
|
|
|
tr.inject(trs[rowPos], 'before');
|
|
|
|
trs.splice(rowPos, 0, tr);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update context menu
|
2016-07-16 13:23:59 +03:00
|
|
|
if (this.contextMenu)
|
|
|
|
this.contextMenu.addTarget(tr);
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
this.updateRow(tr, true);
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2014-12-24 04:39:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
rowPos = rows.length;
|
2014-11-22 10:23:51 +03:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
while ((rowPos < trs.length) && (trs.length > 0)) {
|
|
|
|
trs[trs.length - 1].dispose();
|
|
|
|
trs.pop();
|
2014-11-22 09:35:56 +03:00
|
|
|
}
|
2008-12-29 23:04:45 +00:00
|
|
|
},
|
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
setupTr : function (tr) {},
|
2015-11-11 22:50:14 +03:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
updateRow : function (tr, fullUpdate) {
|
2015-11-11 22:50:14 +03:00
|
|
|
var row = this.rows.get(tr.rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
data = row[fullUpdate ? 'full_data' : 'data'];
|
2014-11-22 09:35:56 +03:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
tds = tr.getElements('td');
|
2015-07-20 02:13:44 +02:00
|
|
|
for (var i = 0; i < this.columns.length; i++) {
|
|
|
|
if (data.hasOwnProperty(this.columns[i].dataProperties[0]))
|
|
|
|
this.columns[i].updateTd(tds[i], row);
|
|
|
|
}
|
|
|
|
row['data'] = {};
|
2014-11-22 09:35:56 +03:00
|
|
|
},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
removeRow : function (rowId) {
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows.erase(rowId);
|
2015-11-11 22:50:14 +03:00
|
|
|
var tr = this.getTrByRowId(rowId);
|
2014-12-24 04:39:18 +03:00
|
|
|
if (tr != null) {
|
2014-11-22 09:35:56 +03:00
|
|
|
tr.dispose();
|
2015-11-11 22:50:14 +03:00
|
|
|
this.rows.erase(rowId);
|
2014-11-22 09:35:56 +03:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2015-11-13 15:02:38 +03:00
|
|
|
clear : function () {
|
2016-07-16 13:23:59 +03:00
|
|
|
this.selectedRows.empty();
|
2015-11-13 15:02:38 +03:00
|
|
|
this.rows.empty();
|
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
while (trs.length > 0) {
|
|
|
|
trs[trs.length - 1].dispose();
|
|
|
|
trs.pop();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
selectedRowsIds : function () {
|
2016-07-16 13:23:59 +03:00
|
|
|
return this.selectedRows.slice();
|
2014-11-22 09:35:56 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
getRowIds : function () {
|
|
|
|
return this.rows.getKeys();
|
2014-12-24 04:39:18 +03:00
|
|
|
},
|
2015-11-11 22:50:14 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
var TorrentsTable = new Class({
|
|
|
|
Extends: DynamicTable,
|
|
|
|
|
|
|
|
initColumns : function () {
|
2016-01-20 12:43:32 +03:00
|
|
|
this.newColumn('priority', 'width: 30px', '#');
|
|
|
|
this.newColumn('state_icon', 'width: 16px; cursor: default', '');
|
|
|
|
this.newColumn('name', 'min-width: 200px', 'QBT_TR(Name)QBT_TR');
|
|
|
|
this.newColumn('size', 'width: 100px', 'QBT_TR(Size)QBT_TR');
|
|
|
|
this.newColumn('progress', 'width: 80px', 'QBT_TR(Done)QBT_TR');
|
|
|
|
this.newColumn('num_seeds', 'width: 100px', 'QBT_TR(Seeds)QBT_TR');
|
|
|
|
this.newColumn('num_leechs', 'width: 100px', 'QBT_TR(Peers)QBT_TR');
|
|
|
|
this.newColumn('dlspeed', 'width: 100px', 'QBT_TR(Down Speed)QBT_TR');
|
|
|
|
this.newColumn('upspeed', 'width: 100px', 'QBT_TR(Up Speed)QBT_TR');
|
|
|
|
this.newColumn('eta', 'width: 100px', 'QBT_TR(ETA)QBT_TR');
|
|
|
|
this.newColumn('ratio', 'width: 100px', 'QBT_TR(Ratio)QBT_TR');
|
2016-02-09 11:56:48 +03:00
|
|
|
this.newColumn('category', 'width: 100px', 'QBT_TR(Category)QBT_TR');
|
2016-04-27 22:51:20 +00:00
|
|
|
this.newColumn('added_on', 'width: 100px', 'QBT_TR(Added on)QBT_TR');
|
2015-11-11 22:50:14 +03:00
|
|
|
|
|
|
|
this.columns['state_icon'].onclick = '';
|
|
|
|
this.columns['state_icon'].dataProperties[0] = 'state';
|
|
|
|
|
|
|
|
this.columns['num_seeds'].dataProperties.push('num_complete');
|
|
|
|
|
|
|
|
this.columns['num_leechs'].dataProperties.push('num_incomplete');
|
|
|
|
|
|
|
|
this.initColumnsFunctions();
|
|
|
|
},
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
initColumnsFunctions : function () {
|
|
|
|
|
|
|
|
// state_icon
|
|
|
|
|
|
|
|
this.columns['state_icon'].updateTd = function (td, row) {
|
|
|
|
var state = this.getRowValue(row);
|
|
|
|
|
2015-07-04 01:04:10 +02:00
|
|
|
if (state == "forcedDL" || state == "metaDL")
|
2015-06-17 01:00:59 +02:00
|
|
|
state = "downloading";
|
2015-07-04 01:04:10 +02:00
|
|
|
else if (state == "allocating")
|
|
|
|
state = "stalledDL";
|
2015-06-17 01:00:59 +02:00
|
|
|
else if (state == "forcedUP")
|
|
|
|
state = "uploading";
|
2015-07-04 01:04:10 +02:00
|
|
|
else if (state == "pausedDL")
|
|
|
|
state = "paused";
|
|
|
|
else if (state == "pausedUP")
|
|
|
|
state = "completed";
|
|
|
|
else if (state == "queuedDL" || state == "queuedUP")
|
|
|
|
state = "queued";
|
|
|
|
else if (state == "checkingDL" || state == "checkingUP" ||
|
|
|
|
state == "queuedForChecking" || state == "checkingResumeData")
|
|
|
|
state = "checking";
|
2015-12-07 04:05:52 +03:00
|
|
|
else if (state == "unknown" || state == "error" || state == "missingFiles")
|
2015-07-04 01:04:10 +02:00
|
|
|
state = "error";
|
2014-12-24 04:39:18 +03:00
|
|
|
|
|
|
|
var img_path = 'images/skin/' + state + '.png';
|
|
|
|
|
|
|
|
if (td.getChildren('img').length) {
|
|
|
|
var img = td.getChildren('img')[0];
|
|
|
|
if (img.src.indexOf(img_path) < 0)
|
|
|
|
img.set('src', img_path);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
td.adopt(new Element('img', {
|
|
|
|
'src' : img_path,
|
|
|
|
'class' : 'statusIcon'
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
|
|
|
|
// priority
|
|
|
|
|
|
|
|
this.columns['priority'].updateTd = function (td, row) {
|
|
|
|
var priority = this.getRowValue(row);
|
2015-07-14 01:46:08 +02:00
|
|
|
td.set('html', priority < 1 ? '*' : priority);
|
2014-12-24 04:39:18 +03:00
|
|
|
};
|
2015-07-14 01:46:08 +02:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
this.columns['priority'].compareRows = function (row1, row2) {
|
|
|
|
var row1_val = this.getRowValue(row1);
|
|
|
|
var row2_val = this.getRowValue(row2);
|
2015-07-14 01:46:08 +02:00
|
|
|
if (row1_val < 1)
|
2014-12-24 04:39:18 +03:00
|
|
|
row1_val = 1000000;
|
2015-07-14 01:46:08 +02:00
|
|
|
if (row2_val < 1)
|
2014-12-24 04:39:18 +03:00
|
|
|
row2_val = 1000000;
|
|
|
|
if (row1_val < row2_val)
|
|
|
|
return -1;
|
|
|
|
else if (row1_val > row2_val)
|
|
|
|
return 1;
|
|
|
|
else return 0;
|
|
|
|
};
|
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
// name, category
|
2015-06-17 01:00:59 +02:00
|
|
|
|
|
|
|
this.columns['name'].updateTd = function (td, row) {
|
|
|
|
td.set('html', escapeHtml(this.getRowValue(row)));
|
|
|
|
};
|
2016-01-20 16:13:54 +03:00
|
|
|
this.columns['category'].updateTd = this.columns['name'].updateTd;
|
2015-06-17 01:00:59 +02:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
// size
|
|
|
|
|
|
|
|
this.columns['size'].updateTd = function (td, row) {
|
|
|
|
var size = this.getRowValue(row);
|
|
|
|
td.set('html', friendlyUnit(size, false));
|
|
|
|
};
|
|
|
|
|
|
|
|
// progress
|
|
|
|
|
|
|
|
this.columns['progress'].updateTd = function (td, row) {
|
|
|
|
var progress = this.getRowValue(row);
|
|
|
|
var progressFormated = (progress * 100).round(1);
|
|
|
|
if (progressFormated == 100.0 && progress != 1.0)
|
|
|
|
progressFormated = 99.9;
|
|
|
|
|
|
|
|
if (td.getChildren('div').length) {
|
|
|
|
var div = td.getChildren('div')[0];
|
|
|
|
if (div.getValue() != progressFormated)
|
|
|
|
div.setValue(progressFormated);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
td.adopt(new ProgressBar(progressFormated.toFloat(), {
|
|
|
|
'width' : 80
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
|
|
|
|
// num_seeds
|
|
|
|
|
|
|
|
this.columns['num_seeds'].updateTd = function (td, row) {
|
|
|
|
var num_seeds = this.getRowValue(row, 0);
|
|
|
|
var num_complete = this.getRowValue(row, 1);
|
|
|
|
var html = num_seeds;
|
|
|
|
if (num_complete != -1)
|
|
|
|
html += ' (' + num_complete + ')';
|
|
|
|
td.set('html', html);
|
|
|
|
};
|
|
|
|
this.columns['num_seeds'].compareRows = function (row1, row2) {
|
|
|
|
var num_seeds1 = this.getRowValue(row1, 0);
|
|
|
|
var num_complete1 = this.getRowValue(row1, 1);
|
|
|
|
|
|
|
|
var num_seeds2 = this.getRowValue(row2, 0);
|
|
|
|
var num_complete2 = this.getRowValue(row2, 1);
|
|
|
|
|
|
|
|
if (num_complete1 < num_complete2)
|
|
|
|
return -1;
|
|
|
|
else if (num_complete1 > num_complete2)
|
|
|
|
return 1;
|
|
|
|
else if (num_seeds1 < num_seeds2)
|
|
|
|
return -1;
|
|
|
|
else if (num_seeds1 > num_seeds2)
|
|
|
|
return 1;
|
|
|
|
else return 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
// num_leechs
|
|
|
|
|
|
|
|
this.columns['num_leechs'].updateTd = this.columns['num_seeds'].updateTd;
|
|
|
|
this.columns['num_leechs'].compareRows = this.columns['num_seeds'].compareRows;
|
|
|
|
|
|
|
|
// dlspeed
|
|
|
|
|
|
|
|
this.columns['dlspeed'].updateTd = function (td, row) {
|
|
|
|
var speed = this.getRowValue(row);
|
|
|
|
td.set('html', friendlyUnit(speed, true));
|
|
|
|
};
|
|
|
|
|
|
|
|
// upspeed
|
|
|
|
|
|
|
|
this.columns['upspeed'].updateTd = this.columns['dlspeed'].updateTd;
|
|
|
|
|
|
|
|
// eta
|
|
|
|
|
|
|
|
this.columns['eta'].updateTd = function (td, row) {
|
|
|
|
var eta = this.getRowValue(row);
|
|
|
|
td.set('html', friendlyDuration(eta, true));
|
|
|
|
};
|
|
|
|
|
|
|
|
// ratio
|
|
|
|
|
|
|
|
this.columns['ratio'].updateTd = function (td, row) {
|
|
|
|
var ratio = this.getRowValue(row);
|
|
|
|
var html = null;
|
|
|
|
if (ratio == -1)
|
|
|
|
html = '∞';
|
|
|
|
else
|
|
|
|
html = (Math.floor(100 * ratio) / 100).toFixed(2); //Don't round up
|
|
|
|
td.set('html', html);
|
|
|
|
};
|
2016-04-27 22:51:20 +00:00
|
|
|
|
|
|
|
// added on
|
|
|
|
|
|
|
|
this.columns['added_on'].updateTd = function (td, row) {
|
|
|
|
var date = new Date(this.getRowValue(row) * 1000).toLocaleString();
|
|
|
|
td.set('html', date);
|
|
|
|
};
|
2015-11-11 22:50:14 +03:00
|
|
|
},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2016-01-21 18:58:08 +03:00
|
|
|
applyFilter : function (row, filterName, categoryHash) {
|
2015-11-11 22:50:14 +03:00
|
|
|
var state = row['full_data'].state;
|
2015-12-27 09:22:45 +03:00
|
|
|
var inactive = false;
|
|
|
|
var r;
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
switch(filterName) {
|
|
|
|
case 'downloading':
|
|
|
|
if (state != 'downloading' && !~state.indexOf('DL'))
|
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
case 'seeding':
|
|
|
|
if (state != 'uploading' && state != 'forcedUP' && state != 'stalledUP' && state != 'queuedUP' && state != 'checkingUP')
|
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
case 'completed':
|
|
|
|
if (state != 'uploading' && !~state.indexOf('UP'))
|
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
case 'paused':
|
2015-12-27 09:22:45 +03:00
|
|
|
if (!~state.indexOf('paused'))
|
2015-11-11 22:50:14 +03:00
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
case 'resumed':
|
|
|
|
if (~state.indexOf('paused'))
|
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
case 'inactive':
|
2015-12-27 09:22:45 +03:00
|
|
|
inactive = true;
|
|
|
|
case 'active':
|
|
|
|
if (state == 'stalledDL')
|
|
|
|
r = (row['full_data'].upspeed > 0)
|
|
|
|
else
|
|
|
|
r = state == 'metaDL' || state == 'downloading' || state == 'forcedDL' || state == 'uploading' || state == 'forcedUP';
|
|
|
|
if (r == inactive)
|
2015-11-11 22:50:14 +03:00
|
|
|
return false;
|
|
|
|
break;
|
2015-12-07 04:05:52 +03:00
|
|
|
case 'errored':
|
|
|
|
if (state != 'error' && state != "unknown" && state != "missingFiles")
|
|
|
|
return false;
|
|
|
|
break;
|
2015-11-11 22:50:14 +03:00
|
|
|
}
|
|
|
|
|
2016-01-21 18:58:08 +03:00
|
|
|
if (categoryHash == CATEGORIES_ALL)
|
2015-11-11 22:50:14 +03:00
|
|
|
return true;
|
|
|
|
|
2016-01-21 18:58:08 +03:00
|
|
|
if (categoryHash == CATEGORIES_UNCATEGORIZED && row['full_data'].category.length === 0)
|
2015-11-11 22:50:14 +03:00
|
|
|
return true;
|
|
|
|
|
2016-01-21 18:58:08 +03:00
|
|
|
if (categoryHash != genHash(row['full_data'].category))
|
2015-11-11 22:50:14 +03:00
|
|
|
return false;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
2016-01-21 18:58:08 +03:00
|
|
|
getFilteredTorrentsNumber : function (filterName, categoryHash) {
|
2015-12-07 04:05:52 +03:00
|
|
|
var cnt = 0;
|
|
|
|
var rows = this.rows.getValues();
|
|
|
|
|
|
|
|
for (i = 0; i < rows.length; i++)
|
2016-01-21 18:58:08 +03:00
|
|
|
if (this.applyFilter(rows[i], filterName, categoryHash)) cnt++;
|
2015-12-07 04:05:52 +03:00
|
|
|
return cnt;
|
|
|
|
},
|
|
|
|
|
2016-01-22 08:43:07 +03:00
|
|
|
getFilteredTorrentsHashes : function (filterName, categoryHash) {
|
|
|
|
var rowsHashes = [];
|
|
|
|
var rows = this.rows.getValues();
|
|
|
|
|
|
|
|
for (i = 0; i < rows.length; i++)
|
|
|
|
if (this.applyFilter(rows[i], filterName, categoryHash))
|
|
|
|
rowsHashes.push(rows[i]['rowId']);
|
|
|
|
|
|
|
|
return rowsHashes;
|
|
|
|
},
|
|
|
|
|
2015-11-11 22:50:14 +03:00
|
|
|
getFilteredAndSortedRows : function () {
|
|
|
|
var filteredRows = new Array();
|
|
|
|
|
|
|
|
var rows = this.rows.getValues();
|
|
|
|
|
|
|
|
for (i = 0; i < rows.length; i++)
|
2016-02-09 11:56:48 +03:00
|
|
|
if (this.applyFilter(rows[i], selected_filter, selected_category)) {
|
2015-11-11 22:50:14 +03:00
|
|
|
filteredRows.push(rows[i]);
|
|
|
|
filteredRows[rows[i].rowId] = rows[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
filteredRows.sort(function (row1, row2) {
|
|
|
|
var column = this.columns[this.sortedColumn];
|
|
|
|
res = column.compareRows(row1, row2);
|
|
|
|
if (this.reverseSort == '0')
|
|
|
|
return res;
|
|
|
|
else
|
|
|
|
return -res;
|
|
|
|
}.bind(this));
|
|
|
|
return filteredRows;
|
|
|
|
},
|
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
setupTr : function (tr) {
|
2015-11-11 22:50:14 +03:00
|
|
|
tr.addEvent('dblclick', function (e) {
|
|
|
|
e.stop();
|
|
|
|
this._this.selectRow(this.rowId);
|
|
|
|
var row = this._this.rows.get(this.rowId);
|
|
|
|
var state = row['full_data'].state;
|
|
|
|
if (~state.indexOf('paused'))
|
|
|
|
startFN();
|
|
|
|
else
|
|
|
|
pauseFN();
|
|
|
|
return true;
|
|
|
|
});
|
2016-01-20 16:13:54 +03:00
|
|
|
tr.addClass("torrentsTableContextMenuTarget");
|
2015-11-11 22:50:14 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
getCurrentTorrentHash : function () {
|
|
|
|
return this.getSelectedRowId();
|
2016-01-20 12:13:27 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
onSelectedRowChanged : function () {
|
|
|
|
updatePropertiesPanel();
|
2015-11-11 22:50:14 +03:00
|
|
|
}
|
2014-11-22 09:35:56 +03:00
|
|
|
});
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2015-11-13 15:02:38 +03:00
|
|
|
var TorrentPeersTable = new Class({
|
|
|
|
Extends: DynamicTable,
|
|
|
|
|
|
|
|
initColumns : function () {
|
|
|
|
this.newColumn('country', 'width: 4px', '');
|
|
|
|
this.newColumn('ip', 'width: 80px', 'QBT_TR(IP)QBT_TR');
|
|
|
|
this.newColumn('port', 'width: 35px', 'QBT_TR(Port)QBT_TR');
|
|
|
|
this.newColumn('client', 'width: 110px', 'QBT_TR(Client)QBT_TR');
|
|
|
|
this.newColumn('progress', 'width: 30px', 'QBT_TR(Progress)QBT_TR');
|
|
|
|
this.newColumn('dl_speed', 'width: 30px', 'QBT_TR(Down Speed)QBT_TR');
|
|
|
|
this.newColumn('up_speed', 'width: 30px', 'QBT_TR(Up Speed)QBT_TR');
|
2016-01-08 13:07:35 +03:00
|
|
|
this.newColumn('downloaded', 'width: 30px', 'QBT_TR(Downloaded)QBT_TR[CONTEXT=PeerListWidget]');
|
|
|
|
this.newColumn('uploaded', 'width: 30px', 'QBT_TR(Uploaded)QBT_TR[CONTEXT=PeerListWidget]');
|
2015-11-13 15:02:38 +03:00
|
|
|
this.newColumn('connection', 'width: 30px', 'QBT_TR(Connection)QBT_TR');
|
|
|
|
this.newColumn('flags', 'width: 30px', 'QBT_TR(Flags)QBT_TR');
|
|
|
|
this.newColumn('relevance', 'min-width: 30px', 'QBT_TR(Relevance)QBT_TR');
|
|
|
|
|
|
|
|
this.columns['country'].dataProperties.push('country_code');
|
|
|
|
this.columns['flags'].dataProperties.push('flags_desc');
|
|
|
|
this.initColumnsFunctions();
|
|
|
|
},
|
|
|
|
|
|
|
|
initColumnsFunctions : function () {
|
|
|
|
|
|
|
|
// country
|
|
|
|
|
|
|
|
this.columns['country'].updateTd = function (td, row) {
|
|
|
|
var country = this.getRowValue(row, 0);
|
|
|
|
var country_code = this.getRowValue(row, 1);
|
|
|
|
|
|
|
|
if (!country_code) {
|
|
|
|
if (td.getChildren('img').length)
|
|
|
|
td.getChildren('img')[0].dispose();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var img_path = 'images/flags/' + country_code + '.png';
|
|
|
|
|
|
|
|
if (td.getChildren('img').length) {
|
|
|
|
var img = td.getChildren('img')[0];
|
|
|
|
img.set('src', img_path);
|
|
|
|
img.set('alt', country);
|
|
|
|
img.set('title', country);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
td.adopt(new Element('img', {
|
|
|
|
'src' : img_path,
|
|
|
|
'alt' : country,
|
|
|
|
'title' : country
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
|
|
|
|
// ip
|
|
|
|
|
|
|
|
this.columns['ip'].compareRows = function (row1, row2) {
|
|
|
|
var ip1 = this.getRowValue(row1);
|
|
|
|
var ip2 = this.getRowValue(row2);
|
|
|
|
|
|
|
|
var a = ip1.split(".");
|
|
|
|
var b = ip2.split(".");
|
|
|
|
|
|
|
|
for (var i = 0; i < 4; i++){
|
|
|
|
if (a[i] != b[i])
|
|
|
|
return a[i] - b[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
// progress, relevance
|
|
|
|
|
|
|
|
this.columns['progress'].updateTd = function (td, row) {
|
|
|
|
var progress = this.getRowValue(row);
|
|
|
|
var progressFormated = (progress * 100).round(1);
|
|
|
|
if (progressFormated == 100.0 && progress != 1.0)
|
|
|
|
progressFormated = 99.9;
|
|
|
|
progressFormated += "%";
|
|
|
|
td.set('html', progressFormated);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.columns['relevance'].updateTd = this.columns['progress'].updateTd;
|
|
|
|
|
|
|
|
// dl_speed, up_speed
|
|
|
|
|
|
|
|
this.columns['dl_speed'].updateTd = function (td, row) {
|
|
|
|
var speed = this.getRowValue(row);
|
|
|
|
if (speed == 0)
|
|
|
|
td.set('html', '');
|
|
|
|
else
|
|
|
|
td.set('html', friendlyUnit(speed, true));
|
|
|
|
};
|
|
|
|
|
|
|
|
this.columns['up_speed'].updateTd = this.columns['dl_speed'].updateTd;
|
|
|
|
|
|
|
|
// downloaded, uploaded
|
|
|
|
|
|
|
|
this.columns['downloaded'].updateTd = function (td, row) {
|
|
|
|
var downloaded = this.getRowValue(row);
|
|
|
|
td.set('html', friendlyUnit(downloaded, false));
|
|
|
|
};
|
|
|
|
|
|
|
|
this.columns['uploaded'].updateTd = this.columns['downloaded'].updateTd;
|
|
|
|
|
|
|
|
// flags
|
|
|
|
|
|
|
|
this.columns['flags'].updateTd = function (td, row) {
|
|
|
|
td.innerHTML = this.getRowValue(row, 0);
|
|
|
|
td.title = this.getRowValue(row, 1);
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2008-05-17 12:44:42 +00:00
|
|
|
/*************************************************************/
|