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:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
|
|
|
/**************************************************************
|
|
|
|
|
|
|
|
Script : Dynamic Table
|
2008-09-28 11:57:09 +00:00
|
|
|
Version : 0.5
|
|
|
|
Authors : Ishan Arora & Christophe Dumez
|
2008-05-17 12:44:42 +00:00
|
|
|
Desc : Programable sortable table
|
|
|
|
Licence : Open Source MIT Licence
|
|
|
|
|
|
|
|
**************************************************************/
|
|
|
|
|
|
|
|
var dynamicTable = new Class ({
|
2008-12-24 11:28:02 +00:00
|
|
|
|
|
|
|
initialize: function(){
|
|
|
|
},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2009-11-24 19:41:31 +00:00
|
|
|
setup: function(table, progressIndex, context_menu){
|
2008-05-17 12:44:42 +00:00
|
|
|
this.table = $(table);
|
2009-11-24 11:14:02 +00:00
|
|
|
this.rows = new Hash();
|
2008-09-27 10:08:07 +00:00
|
|
|
this.cur = new Array();
|
2008-12-29 23:04:45 +00:00
|
|
|
this.priority_hidden = false;
|
2008-12-30 11:23:18 +00:00
|
|
|
this.progressIndex = progressIndex;
|
2009-12-04 21:03:50 +00:00
|
|
|
this.filter = Cookie.read('selected_filter');
|
|
|
|
if(!$defined(this.filter)) {
|
|
|
|
this.filter = 'all';
|
|
|
|
}
|
2009-11-24 19:41:31 +00:00
|
|
|
this.context_menu = context_menu;
|
2009-11-27 15:48:45 +00:00
|
|
|
this.table.sortedIndex = 1; // Default is NAME
|
2009-11-28 08:48:35 +00:00
|
|
|
this.table.reverseSort = false;
|
2009-11-27 15:48:45 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
sortfunction: function(tr1, tr2) {
|
|
|
|
var i = tr2.getParent().sortedIndex;
|
2009-11-28 08:48:35 +00:00
|
|
|
var reverseSort = tr2.getParent().reverseSort;
|
2009-11-27 15:48:45 +00:00
|
|
|
switch(i) {
|
|
|
|
case 1: // Name
|
2009-11-28 08:48:35 +00:00
|
|
|
if(!reverseSort) {
|
2009-11-27 15:48:45 +00:00
|
|
|
if(tr1.getElements('td')[i].get('html') > tr2.getElements('td')[i].get('html'))
|
|
|
|
return 1;
|
|
|
|
return -1;
|
|
|
|
} else {
|
|
|
|
if(tr1.getElements('td')[i].get('html') < tr2.getElements('td')[i].get('html'))
|
|
|
|
return 1;
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
case 2: // Prio
|
2009-11-28 08:48:35 +00:00
|
|
|
var prio1 = tr1.getElements('td')[i].get('html');
|
|
|
|
if(prio1 == '*') prio1 = '-1';
|
|
|
|
var prio2 = tr2.getElements('td')[i].get('html');
|
|
|
|
if(prio2 == '*') prio2 = '-1';
|
|
|
|
if(!reverseSort)
|
|
|
|
return (prio1.toInt() - prio2.toInt());
|
2009-11-27 15:48:45 +00:00
|
|
|
else
|
2009-11-28 08:48:35 +00:00
|
|
|
return (prio2.toInt() - prio1.toInt());
|
2009-11-27 15:48:45 +00:00
|
|
|
case 3: // Size
|
|
|
|
case 7: // Up Speed
|
|
|
|
case 8: // Down Speed
|
|
|
|
var sizeStrToFloat = function(mystr) {
|
|
|
|
var val1 = mystr.split(' ');
|
2014-08-08 03:03:57 +03:00
|
|
|
var val1num = val1[0].toFloat()
|
|
|
|
var unit = val1[1];
|
2014-01-25 22:30:22 +04:00
|
|
|
switch(unit) {
|
|
|
|
case '_(TiB)':
|
|
|
|
return val1num*1099511627776;
|
|
|
|
case '_(GiB)':
|
2009-11-27 15:48:45 +00:00
|
|
|
return val1num*1073741824;
|
2014-01-25 22:30:22 +04:00
|
|
|
case '_(MiB)':
|
2009-11-27 15:48:45 +00:00
|
|
|
return val1num*1048576;
|
2014-01-25 22:30:22 +04:00
|
|
|
case '_(KiB)':
|
2009-11-27 15:48:45 +00:00
|
|
|
return val1num*1024;
|
|
|
|
default:
|
|
|
|
return val1num;
|
|
|
|
}
|
|
|
|
};
|
2009-11-28 08:48:35 +00:00
|
|
|
if(!reverseSort)
|
2009-11-27 15:48:45 +00:00
|
|
|
return (sizeStrToFloat(tr1.getElements('td')[i].get('html')) - sizeStrToFloat(tr2.getElements('td')[i].get('html')));
|
|
|
|
else
|
|
|
|
return (sizeStrToFloat(tr2.getElements('td')[i].get('html')) - sizeStrToFloat(tr1.getElements('td')[i].get('html')));
|
|
|
|
case 4: // Progress
|
2009-11-28 08:48:35 +00:00
|
|
|
if(!reverseSort)
|
2009-11-27 15:48:45 +00:00
|
|
|
return (tr1.getElements('td')[i].getChildren()[0].getValue() - tr2.getElements('td')[i].getChildren()[0].getValue());
|
|
|
|
else
|
|
|
|
return (tr2.getElements('td')[i].getChildren()[0].getValue() - tr1.getElements('td')[i].getChildren()[0].getValue());
|
|
|
|
case 5: // Seeds
|
|
|
|
case 6: // Peers
|
2009-11-28 08:48:35 +00:00
|
|
|
if(!reverseSort)
|
2009-11-27 15:48:45 +00:00
|
|
|
return (tr1.getElements('td')[i].get('html').split(' ')[0].toInt() - tr2.getElements('td')[i].get('html').split(' ')[0].toInt());
|
|
|
|
else
|
|
|
|
return (tr2.getElements('td')[i].get('html').split(' ')[0].toInt() - tr1.getElements('td')[i].get('html').split(' ')[0].toInt());
|
|
|
|
default: // Ratio
|
2009-11-27 15:59:49 +00:00
|
|
|
var ratio1 = tr1.getElements('td')[i].get('html');
|
|
|
|
if(ratio1 == '∞')
|
|
|
|
ratio1 = '101.0';
|
|
|
|
var ratio2 = tr2.getElements('td')[i].get('html');
|
|
|
|
if(ratio2 == '∞')
|
|
|
|
ratio2 = '101.0';
|
2009-11-28 08:48:35 +00:00
|
|
|
if(!reverseSort)
|
2009-11-27 15:59:49 +00:00
|
|
|
return (ratio1.toFloat() - ratio2.toFloat());
|
2009-11-27 15:48:45 +00:00
|
|
|
else
|
2009-11-27 15:59:49 +00:00
|
|
|
return (ratio2.toFloat() - ratio1.toFloat());
|
2009-11-27 15:48:45 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
updateSort: function() {
|
|
|
|
var trs = this.table.getChildren('tr');
|
|
|
|
trs.sort(this.sortfunction);
|
|
|
|
this.table.set('html', '');
|
|
|
|
this.table.adopt(trs);
|
|
|
|
},
|
|
|
|
|
|
|
|
setSortedColumn: function(index) {
|
|
|
|
if(index != this.table.sortedIndex) {
|
|
|
|
this.table.sortedIndex = index;
|
2009-11-28 08:48:35 +00:00
|
|
|
this.table.reverseSort = false;
|
2009-11-27 15:48:45 +00:00
|
|
|
} else {
|
|
|
|
// Toggle sort order
|
2009-11-28 08:48:35 +00:00
|
|
|
this.table.reverseSort = !this.table.reverseSort;
|
2009-11-27 15:48:45 +00:00
|
|
|
}
|
|
|
|
this.updateSort();
|
|
|
|
this.altRow();
|
2009-11-24 08:53:14 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
getCurrentTorrentHash: function() {
|
|
|
|
if(this.cur.length > 0)
|
|
|
|
return this.cur[0];
|
|
|
|
return '';
|
2008-05-17 12:44:42 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
altRow: function()
|
|
|
|
{
|
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
trs.each(function(el,i){
|
|
|
|
if(i % 2){
|
2008-12-24 11:28:02 +00:00
|
|
|
el.addClass('alt');
|
2008-05-17 12:44:42 +00:00
|
|
|
}else{
|
2008-12-24 11:28:02 +00:00
|
|
|
el.removeClass('alt');
|
2008-05-17 12:44:42 +00:00
|
|
|
}
|
|
|
|
}.bind(this));
|
|
|
|
},
|
|
|
|
|
2008-12-29 23:04:45 +00:00
|
|
|
hidePriority: function(){
|
|
|
|
if(this.priority_hidden) return;
|
|
|
|
$('prioHeader').addClass('invisible');
|
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
trs.each(function(tr,i){
|
|
|
|
var tds = tr.getElements('td');
|
2009-11-23 10:37:55 +00:00
|
|
|
tds[2].addClass('invisible');
|
2008-12-29 23:04:45 +00:00
|
|
|
}.bind(this));
|
|
|
|
this.priority_hidden = true;
|
|
|
|
},
|
2009-11-23 09:16:32 +00:00
|
|
|
|
|
|
|
setFilter: function(f) {
|
|
|
|
this.filter = f;
|
|
|
|
},
|
2008-12-29 23:04:45 +00:00
|
|
|
|
|
|
|
showPriority: function(){
|
|
|
|
if(!this.priority_hidden) return;
|
|
|
|
$('prioHeader').removeClass('invisible');
|
|
|
|
var trs = this.table.getElements('tr');
|
|
|
|
trs.each(function(tr,i){
|
|
|
|
var tds = tr.getElements('td');
|
2009-11-23 13:35:46 +00:00
|
|
|
tds[2].removeClass('invisible');
|
2008-12-29 23:04:45 +00:00
|
|
|
}.bind(this));
|
|
|
|
this.priority_hidden = false;
|
|
|
|
},
|
2009-11-23 09:16:32 +00:00
|
|
|
|
|
|
|
applyFilterOnRow: function(tr, status) {
|
|
|
|
switch(this.filter) {
|
|
|
|
case 'all':
|
|
|
|
tr.removeClass("invisible");
|
2009-11-26 11:01:21 +00:00
|
|
|
break;
|
2009-11-23 09:16:32 +00:00
|
|
|
case 'downloading':
|
|
|
|
if(status == "downloading" || status == "stalledDL" || status == "checkingDL" || status == "pausedDL" || status == "queuedDL") {
|
|
|
|
tr.removeClass("invisible");
|
|
|
|
} else {
|
|
|
|
tr.addClass("invisible");
|
|
|
|
}
|
2009-11-26 11:01:21 +00:00
|
|
|
break;
|
2009-11-23 09:16:32 +00:00
|
|
|
case 'completed':
|
2009-11-30 21:30:14 +00:00
|
|
|
if(status == "uploading" || status == "stalledUP" || status == "checkingUP" || status == "pausedUP" || status == "queuedUP") {
|
2009-11-23 09:16:32 +00:00
|
|
|
tr.removeClass("invisible");
|
|
|
|
} else {
|
|
|
|
tr.addClass("invisible");
|
|
|
|
}
|
2009-11-26 11:01:21 +00:00
|
|
|
break;
|
2010-05-24 19:05:07 +00:00
|
|
|
case 'paused':
|
|
|
|
if(status == "pausedDL" || status == "pausedUP") {
|
|
|
|
tr.removeClass("invisible");
|
|
|
|
} else {
|
|
|
|
tr.addClass("invisible");
|
|
|
|
}
|
|
|
|
break;
|
2009-11-23 09:16:32 +00:00
|
|
|
case 'active':
|
2009-11-30 21:30:14 +00:00
|
|
|
if(status == "downloading" || status == "uploading") {
|
2009-11-23 09:16:32 +00:00
|
|
|
tr.removeClass("invisible");
|
|
|
|
} else {
|
|
|
|
tr.addClass("invisible");
|
|
|
|
}
|
2009-11-26 11:01:21 +00:00
|
|
|
break;
|
2009-11-23 09:16:32 +00:00
|
|
|
case 'inactive':
|
2009-11-30 21:30:14 +00:00
|
|
|
if(status != "downloading" && status != "uploading") {
|
2009-11-23 09:16:32 +00:00
|
|
|
tr.removeClass("invisible");
|
|
|
|
} else {
|
|
|
|
tr.addClass("invisible");
|
|
|
|
}
|
|
|
|
}
|
2009-11-26 11:01:21 +00:00
|
|
|
return !tr.hasClass('invisible');
|
2009-11-23 09:16:32 +00:00
|
|
|
},
|
2008-12-29 23:04:45 +00:00
|
|
|
|
2009-11-23 09:16:32 +00:00
|
|
|
insertRow: function(id, row, status){
|
2009-11-24 11:14:02 +00:00
|
|
|
if(this.rows.has(id)) {
|
|
|
|
return;
|
|
|
|
}
|
2008-05-17 12:44:42 +00:00
|
|
|
var tr = new Element('tr');
|
2009-11-24 19:41:31 +00:00
|
|
|
tr.addClass("menu-target");
|
2009-11-24 11:14:02 +00:00
|
|
|
this.rows.set(id, tr);
|
2008-05-17 12:44:42 +00:00
|
|
|
for(var i=0; i<row.length; i++)
|
|
|
|
{
|
|
|
|
var td = new Element('td');
|
2008-12-30 11:23:18 +00:00
|
|
|
if(i==this.progressIndex) {
|
2009-11-25 12:27:00 +00:00
|
|
|
td.adopt(new ProgressBar(row[i].toFloat(), {'id': 'pb_'+id, 'width':80}));
|
2008-12-30 11:23:18 +00:00
|
|
|
} else {
|
2009-11-25 12:09:10 +00:00
|
|
|
if(i==0) {
|
2009-11-29 14:44:30 +00:00
|
|
|
td.adopt(new Element('img', {'src':row[i], 'class': 'statusIcon'}));
|
2009-11-25 12:09:10 +00:00
|
|
|
} else {
|
2009-12-06 14:26:50 +00:00
|
|
|
if(i==2) {
|
|
|
|
// Priority
|
|
|
|
if(this.priority_hidden)
|
|
|
|
td.addClass('invisible');
|
|
|
|
}
|
2009-11-25 12:09:10 +00:00
|
|
|
td.set('html', row[i]);
|
|
|
|
}
|
2008-12-30 11:23:18 +00:00
|
|
|
}
|
2008-05-17 12:44:42 +00:00
|
|
|
td.injectInside(tr);
|
|
|
|
};
|
|
|
|
|
2008-09-15 05:27:56 +00:00
|
|
|
tr.addEvent('mouseover', function(e){
|
2008-12-24 11:28:02 +00:00
|
|
|
tr.addClass('over');
|
2008-05-17 12:44:42 +00:00
|
|
|
}.bind(this));
|
2008-09-15 05:27:56 +00:00
|
|
|
tr.addEvent('mouseout', function(e){
|
2008-12-24 11:28:02 +00:00
|
|
|
tr.removeClass('over');
|
2008-05-17 12:44:42 +00:00
|
|
|
}.bind(this));
|
2009-11-24 19:41:31 +00:00
|
|
|
tr.addEvent('contextmenu', function(e) {
|
|
|
|
if(!this.cur.contains(id)) {
|
|
|
|
// Remove selected style from previous ones
|
|
|
|
for(i=0; i<this.cur.length; i++) {
|
|
|
|
if(this.rows.has(this.cur[i])) {
|
|
|
|
var temptr = this.rows.get(this.cur[i]);
|
|
|
|
temptr.removeClass('selected');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.cur.empty();
|
|
|
|
this.cur[this.cur.length] = id;
|
|
|
|
temptr = this.rows.get(id);
|
|
|
|
temptr.addClass("selected");
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}.bind(this));
|
2008-09-15 05:27:56 +00:00
|
|
|
tr.addEvent('click', function(e){
|
2008-09-28 16:39:39 +00:00
|
|
|
e.stop();
|
2008-09-27 10:08:07 +00:00
|
|
|
if(e.control) {
|
2008-09-27 10:18:27 +00:00
|
|
|
// CTRL key was pressed
|
2008-09-27 10:08:07 +00:00
|
|
|
if(this.cur.contains(id)) {
|
|
|
|
// remove it
|
|
|
|
this.cur.erase(id);
|
|
|
|
// Remove selected style
|
2009-11-24 11:14:02 +00:00
|
|
|
if(this.rows.has(id)) {
|
|
|
|
temptr = this.rows.get(id);
|
|
|
|
temptr.removeClass('selected');
|
|
|
|
}
|
2008-09-27 10:08:07 +00:00
|
|
|
} else {
|
|
|
|
this.cur[this.cur.length] = id;
|
|
|
|
// Add selected style
|
2009-11-24 11:14:02 +00:00
|
|
|
if(this.rows.has(id)) {
|
|
|
|
temptr = this.rows.get(id);
|
2008-12-24 11:28:02 +00:00
|
|
|
temptr.addClass('selected');
|
2008-09-27 10:08:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
2008-09-27 10:18:27 +00:00
|
|
|
if(e.shift && this.cur.length == 1) {
|
|
|
|
// Shift key was pressed
|
2009-12-06 15:29:37 +00:00
|
|
|
var first_id = this.cur[0];
|
|
|
|
var first_tr = this.rows.get(first_id);
|
|
|
|
var last_id = id;
|
|
|
|
var last_tr = this.rows.get(last_id);
|
|
|
|
var all_trs = this.table.getChildren('tr');
|
|
|
|
var index_first_tr = all_trs.indexOf(first_tr);
|
|
|
|
var index_last_tr = all_trs.indexOf(last_tr);
|
|
|
|
var trs_to_select = all_trs.filter(function(item, index){
|
|
|
|
if(index_first_tr < index_last_tr)
|
|
|
|
return (index > index_first_tr) && (index <= index_last_tr);
|
|
|
|
else
|
|
|
|
return (index < index_first_tr) && (index >= index_last_tr);
|
|
|
|
});
|
|
|
|
trs_to_select.each(function(item, index){
|
|
|
|
// Add to selection
|
|
|
|
this.cur[this.cur.length] = this.getRowId(item);
|
|
|
|
// Select it visually
|
|
|
|
item.addClass('selected');
|
|
|
|
}.bind(this));
|
2008-09-27 10:18:27 +00:00
|
|
|
} else {
|
|
|
|
// Simple selection
|
|
|
|
// Remove selected style from previous ones
|
|
|
|
for(i=0; i<this.cur.length; i++) {
|
2009-11-24 11:14:02 +00:00
|
|
|
if(this.rows.has(this.cur[i])) {
|
|
|
|
var temptr = this.rows.get(this.cur[i]);
|
2008-12-24 11:28:02 +00:00
|
|
|
temptr.removeClass('selected');
|
2008-09-27 10:18:27 +00:00
|
|
|
}
|
|
|
|
}
|
2008-09-28 16:23:08 +00:00
|
|
|
this.cur.empty();
|
2008-09-27 10:18:27 +00:00
|
|
|
// Add selected style to new one
|
2009-11-24 11:14:02 +00:00
|
|
|
if(this.rows.has(id)) {
|
|
|
|
temptr = this.rows.get(id);
|
2008-12-24 11:28:02 +00:00
|
|
|
temptr.addClass('selected');
|
2008-09-27 10:08:07 +00:00
|
|
|
}
|
2008-09-27 10:18:27 +00:00
|
|
|
this.cur[0] = id;
|
2009-11-24 08:53:14 +00:00
|
|
|
// TODO: Warn Properties panel
|
2008-09-27 10:08:07 +00:00
|
|
|
}
|
2008-05-17 12:44:42 +00:00
|
|
|
}
|
2008-09-28 16:39:39 +00:00
|
|
|
return false;
|
2008-05-17 12:44:42 +00:00
|
|
|
}.bind(this));
|
2009-11-24 11:14:02 +00:00
|
|
|
// Apply filter
|
|
|
|
this.applyFilterOnRow(tr, status);
|
|
|
|
// Insert
|
2009-11-27 15:48:45 +00:00
|
|
|
var trs = this.table.getChildren('tr');
|
|
|
|
var i=0;
|
|
|
|
while(i<trs.length && this.sortfunction(tr, trs[i]) > 0) {
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if(i==trs.length) {
|
|
|
|
tr.inject(this.table);
|
|
|
|
} else {
|
|
|
|
tr.inject(trs[i], 'before');
|
|
|
|
}
|
|
|
|
//tr.injectInside(this.table);
|
2008-05-17 12:44:42 +00:00
|
|
|
this.altRow();
|
2009-11-24 19:41:31 +00:00
|
|
|
// Update context menu
|
|
|
|
this.context_menu.addTarget(tr);
|
2008-05-17 12:44:42 +00:00
|
|
|
},
|
2008-09-28 16:23:08 +00:00
|
|
|
|
|
|
|
selectAll: function() {
|
|
|
|
this.cur.empty();
|
2009-11-24 11:14:02 +00:00
|
|
|
this.rows.each(function(tr, id){
|
2008-09-28 16:23:08 +00:00
|
|
|
this.cur[this.cur.length] = id;
|
2009-11-24 11:14:02 +00:00
|
|
|
if(!tr.hasClass('selected')) {
|
|
|
|
tr.addClass('selected');
|
2008-09-28 16:23:08 +00:00
|
|
|
}
|
2010-03-20 15:45:14 +00:00
|
|
|
}, this);
|
2008-09-28 16:23:08 +00:00
|
|
|
},
|
2008-05-17 12:44:42 +00:00
|
|
|
|
2009-11-23 09:16:32 +00:00
|
|
|
updateRow: function(id, row, status){
|
2009-11-24 11:14:02 +00:00
|
|
|
if(!this.rows.has(id)) {
|
|
|
|
return false;
|
2008-05-17 12:44:42 +00:00
|
|
|
}
|
2009-11-24 11:14:02 +00:00
|
|
|
var tr = this.rows.get(id);
|
|
|
|
// Apply filter
|
2009-11-26 11:01:21 +00:00
|
|
|
if(this.applyFilterOnRow(tr, status)) {
|
|
|
|
var tds = tr.getElements('td');
|
|
|
|
for(var i=0; i<row.length; i++) {
|
|
|
|
if(i==1) continue; // Do not refresh name
|
|
|
|
if(i==this.progressIndex) {
|
2011-09-21 21:10:12 +03:00
|
|
|
$('pb_'+id).setValue(row[i]);
|
2009-11-25 12:09:10 +00:00
|
|
|
} else {
|
2009-11-26 11:01:21 +00:00
|
|
|
if(i==0) {
|
|
|
|
tds[i].getChildren('img')[0].set('src', row[i]);
|
|
|
|
} else {
|
|
|
|
tds[i].set('html', row[i]);
|
|
|
|
}
|
2009-11-25 12:09:10 +00:00
|
|
|
}
|
2009-11-26 11:01:21 +00:00
|
|
|
};
|
2009-12-04 20:45:16 +00:00
|
|
|
} else {
|
|
|
|
// Row was hidden, check if it was selected
|
|
|
|
// and unselect it if it was
|
|
|
|
if(this.cur.contains(id)) {
|
|
|
|
// Remove from selection
|
|
|
|
this.cur.erase(id);
|
|
|
|
// Remove selected style
|
|
|
|
tr.removeClass('selected');
|
|
|
|
}
|
2009-11-26 11:01:21 +00:00
|
|
|
}
|
2009-11-24 11:14:02 +00:00
|
|
|
return true;
|
2008-05-17 12:44:42 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
removeRow: function(id){
|
2008-09-27 10:08:07 +00:00
|
|
|
if(this.cur.contains(id))
|
2008-05-17 12:44:42 +00:00
|
|
|
{
|
2008-09-27 10:08:07 +00:00
|
|
|
this.cur.erase(id);
|
2008-05-17 12:44:42 +00:00
|
|
|
}
|
2009-11-24 11:14:02 +00:00
|
|
|
if(this.rows.has(id)) {
|
|
|
|
var tr = this.rows.get(id);
|
2008-09-14 10:14:54 +00:00
|
|
|
tr.dispose();
|
2008-05-17 12:44:42 +00:00
|
|
|
this.altRow();
|
2009-11-24 11:14:02 +00:00
|
|
|
this.rows.erase(id);
|
2008-05-17 12:44:42 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
|
2008-09-27 10:08:07 +00:00
|
|
|
selectedIds: function(){
|
2008-05-17 12:44:42 +00:00
|
|
|
return this.cur;
|
|
|
|
},
|
|
|
|
|
2009-12-06 15:29:37 +00:00
|
|
|
getRowId: function(tr){
|
|
|
|
return this.rows.keyOf(tr);
|
|
|
|
},
|
|
|
|
|
2008-05-17 12:44:42 +00:00
|
|
|
getRowIds: function(){
|
2009-12-06 15:29:37 +00:00
|
|
|
return this.rows.getKeys();
|
2008-05-17 12:44:42 +00:00
|
|
|
}
|
2009-12-06 15:29:37 +00:00
|
|
|
|
2008-05-17 12:44:42 +00:00
|
|
|
});
|
2008-12-24 11:28:02 +00:00
|
|
|
//dynamicTable.implement(new Options);
|
|
|
|
//dynamicTable.implement(new Events);
|
2008-05-17 12:44:42 +00:00
|
|
|
|
|
|
|
/*************************************************************/
|