2014-12-08 21:00:00 +01:00
|
|
|
var is_seed = true;
|
|
|
|
var current_hash = "";
|
|
|
|
|
|
|
|
if (!(Browser.name == "ie" && Browser.version < 9)) {
|
|
|
|
$("all_files_cb").removeClass("tristate");
|
|
|
|
$("all_files_cb").removeClass("partial");
|
|
|
|
$("all_files_cb").removeClass("checked");
|
|
|
|
$("tristate_cb").style.display = "inline";
|
|
|
|
}
|
|
|
|
|
|
|
|
var setCBState = function(state) {
|
|
|
|
if (Browser.name == "ie" && Browser.version < 9) {
|
|
|
|
if (state == "partial") {
|
|
|
|
if (!$("all_files_cb").hasClass("partial")) {
|
|
|
|
$("all_files_cb").removeClass("checked");
|
|
|
|
$("all_files_cb").addClass("partial");
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (state == "checked") {
|
|
|
|
if (!$("all_files_cb").hasClass("checked")) {
|
|
|
|
$("all_files_cb").removeClass("partial");
|
|
|
|
$("all_files_cb").addClass("checked");
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
$("all_files_cb").removeClass("partial");
|
|
|
|
$("all_files_cb").removeClass("checked");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (state == "partial") {
|
|
|
|
$("tristate_cb").indeterminate = true;
|
|
|
|
}
|
|
|
|
else if (state == "checked") {
|
|
|
|
$("tristate_cb").indeterminate = false;
|
|
|
|
$("tristate_cb").checked = true;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$("tristate_cb").indeterminate = false;
|
|
|
|
$("tristate_cb").checked = false;
|
|
|
|
}
|
|
|
|
}
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var switchCBState = function() {
|
|
|
|
// Uncheck
|
|
|
|
if ($("all_files_cb").hasClass("partial")) {
|
|
|
|
$("all_files_cb").removeClass("partial");
|
|
|
|
// Uncheck all checkboxes
|
2018-10-21 19:00:38 -04:00
|
|
|
var indexes = [];
|
2014-12-08 21:00:00 +01:00
|
|
|
$$('input.DownloadedCB').each(function(item, index) {
|
|
|
|
item.erase("checked");
|
2018-10-21 19:00:38 -04:00
|
|
|
indexes.push(index);
|
2014-12-08 21:00:00 +01:00
|
|
|
});
|
2018-10-21 19:00:38 -04:00
|
|
|
setFilePriority(indexes, 0);
|
2014-12-08 21:00:00 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if ($("all_files_cb").hasClass("checked")) {
|
|
|
|
$("all_files_cb").removeClass("checked");
|
|
|
|
// Uncheck all checkboxes
|
2018-10-21 19:00:38 -04:00
|
|
|
var indexes = [];
|
2014-12-08 21:00:00 +01:00
|
|
|
$$('input.DownloadedCB').each(function(item, index) {
|
|
|
|
item.erase("checked");
|
2018-10-21 19:00:38 -04:00
|
|
|
indexes.push(index);
|
2014-12-08 21:00:00 +01:00
|
|
|
});
|
2018-10-21 19:00:38 -04:00
|
|
|
setFilePriority(indexes, 0);
|
2014-12-08 21:00:00 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Check
|
|
|
|
$("all_files_cb").addClass("checked");
|
|
|
|
// Check all checkboxes
|
2018-10-21 19:00:38 -04:00
|
|
|
var indexes = [];
|
2014-12-08 21:00:00 +01:00
|
|
|
$$('input.DownloadedCB').each(function(item, index) {
|
|
|
|
item.set("checked", "checked");
|
2018-10-21 19:00:38 -04:00
|
|
|
indexes.push(index);
|
2014-12-08 21:00:00 +01:00
|
|
|
});
|
2018-10-21 19:00:38 -04:00
|
|
|
setFilePriority(indexes, 1);
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var allCBChecked = function() {
|
|
|
|
var CBs = $$('input.DownloadedCB');
|
|
|
|
for (var i = 0; i < CBs.length; i += 1) {
|
|
|
|
var item = CBs[i];
|
|
|
|
if (!$defined(item.get('checked')) || !item.get('checked'))
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var allCBUnchecked = function() {
|
|
|
|
var CBs = $$('input.DownloadedCB');
|
|
|
|
for (var i = 0; i < CBs.length; i += 1) {
|
|
|
|
var item = CBs[i];
|
|
|
|
if ($defined(item.get('checked')) && item.get('checked'))
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var setFilePriority = function(id, priority) {
|
2017-07-01 00:42:20 -04:00
|
|
|
if (current_hash === "") return;
|
2018-10-21 19:00:38 -04:00
|
|
|
var ids = Array.isArray(id) ? id : [id];
|
|
|
|
|
2014-12-08 21:00:00 +01:00
|
|
|
new Request({
|
2017-10-14 16:27:21 +03:00
|
|
|
url: 'api/v2/torrents/filePrio',
|
2014-12-08 21:00:00 +01:00
|
|
|
method: 'post',
|
|
|
|
data: {
|
|
|
|
'hash': current_hash,
|
2018-10-21 19:00:38 -04:00
|
|
|
'id': ids.join('|'),
|
2014-12-08 21:00:00 +01:00
|
|
|
'priority': priority
|
|
|
|
}
|
|
|
|
}).send();
|
|
|
|
// Display or add combobox
|
|
|
|
if (priority > 0) {
|
2018-10-21 19:00:38 -04:00
|
|
|
ids.forEach(function(_id) {
|
|
|
|
if ($('comboPrio' + _id).hasClass("invisible")) {
|
|
|
|
$('comboPrio' + _id).set("value", priority);
|
|
|
|
$('comboPrio' + _id).removeClass("invisible");
|
|
|
|
}
|
|
|
|
});
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
|
|
|
else {
|
2018-10-21 19:00:38 -04:00
|
|
|
ids.forEach(function(_id) {
|
|
|
|
if (!$('comboPrio' + _id).hasClass("invisible"))
|
|
|
|
$('comboPrio' + _id).addClass("invisible");
|
|
|
|
});
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var createDownloadedCB = function(id, downloaded) {
|
|
|
|
var CB = new Element('input');
|
|
|
|
CB.set('type', 'checkbox');
|
|
|
|
if (downloaded)
|
|
|
|
CB.set('checked', 'checked');
|
|
|
|
CB.set('id', 'cbPrio' + id);
|
|
|
|
CB.set('class', 'DownloadedCB');
|
|
|
|
CB.addEvent('change', function(e) {
|
|
|
|
var checked = 0;
|
|
|
|
if ($defined($('cbPrio' + id).get('checked')) && $('cbPrio' + id).get('checked'))
|
|
|
|
checked = 1;
|
|
|
|
setFilePriority(id, checked);
|
|
|
|
if (allCBChecked()) {
|
|
|
|
setCBState("checked");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (allCBUnchecked()) {
|
|
|
|
setCBState("unchecked");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
setCBState("partial");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return CB;
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var createPriorityCombo = function(id, selected_prio) {
|
|
|
|
var select = new Element('select');
|
|
|
|
select.set('id', 'comboPrio' + id);
|
|
|
|
select.addEvent('change', function(e) {
|
|
|
|
var new_prio = $('comboPrio' + id).get('value');
|
|
|
|
setFilePriority(id, new_prio);
|
|
|
|
});
|
2018-10-21 19:00:38 -04:00
|
|
|
|
|
|
|
function createOptionElement(priority, html) {
|
|
|
|
var elem = new Element("option");
|
|
|
|
elem.set('value', priority.toString());
|
|
|
|
elem.set('html', html);
|
|
|
|
if (selected_prio == priority)
|
|
|
|
elem.setAttribute('selected', 'true');
|
|
|
|
return elem;
|
|
|
|
}
|
|
|
|
|
|
|
|
var normal = createOptionElement(1, "QBT_TR(Normal)QBT_TR[CONTEXT=PropListDelegate]");
|
|
|
|
if (selected_prio <= 0)
|
|
|
|
normal.setAttribute('selected', '');
|
|
|
|
normal.injectInside(select);
|
|
|
|
|
|
|
|
var high = createOptionElement(2, "QBT_TR(High)QBT_TR[CONTEXT=PropListDelegate]");
|
|
|
|
high.injectInside(select);
|
|
|
|
|
|
|
|
var maximum = createOptionElement(7, "QBT_TR(Maximum)QBT_TR[CONTEXT=PropListDelegate]");
|
|
|
|
maximum.injectInside(select);
|
|
|
|
|
2014-12-08 21:00:00 +01:00
|
|
|
if (is_seed || selected_prio < 1) {
|
|
|
|
select.addClass("invisible");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
select.removeClass("invisible");
|
|
|
|
}
|
|
|
|
select.addClass("combo_priority");
|
|
|
|
return select;
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
|
|
|
var filesDynTable = new Class({
|
|
|
|
|
|
|
|
initialize: function() {},
|
|
|
|
|
|
|
|
setup: function(table) {
|
|
|
|
this.table = $(table);
|
|
|
|
this.rows = new Hash();
|
|
|
|
},
|
|
|
|
|
|
|
|
removeRow: function(id) {
|
|
|
|
if (this.rows.has(id)) {
|
|
|
|
var tr = this.rows.get(id);
|
|
|
|
tr.dispose();
|
|
|
|
this.rows.erase(id);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
|
|
|
|
removeAllRows: function() {
|
|
|
|
this.rows.each(function(tr, id) {
|
|
|
|
this.removeRow(id);
|
|
|
|
}.bind(this));
|
|
|
|
},
|
|
|
|
|
|
|
|
updateRow: function(tr, row, id) {
|
|
|
|
var tds = tr.getElements('td');
|
2018-05-31 01:06:28 +08:00
|
|
|
for (var i = 0; i < row.length; ++i) {
|
2015-03-04 20:00:00 +01:00
|
|
|
switch (i) {
|
2018-10-21 19:00:38 -04:00
|
|
|
case 0: // checkbox
|
2018-04-05 11:59:31 +08:00
|
|
|
if (row[i] > 0)
|
|
|
|
tds[i].getChildren('input')[0].set('checked', 'checked');
|
|
|
|
else
|
|
|
|
tds[i].getChildren('input')[0].removeProperty('checked');
|
|
|
|
break;
|
2018-10-21 19:00:38 -04:00
|
|
|
case 3: // progress bar
|
2018-04-05 11:59:31 +08:00
|
|
|
$('pbf_' + id).setValue(row[i].toFloat());
|
|
|
|
break;
|
2018-10-21 19:00:38 -04:00
|
|
|
case 4: // download priority
|
2018-04-05 11:59:31 +08:00
|
|
|
if (!is_seed && row[i] > 0) {
|
|
|
|
tds[i].getChildren('select').set('value', row[i]);
|
2018-10-21 19:00:38 -04:00
|
|
|
if ($('comboPrio' + id).hasClass("invisible"))
|
|
|
|
$('comboPrio' + id).removeClass("invisible");
|
2018-04-05 11:59:31 +08:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (!$('comboPrio' + id).hasClass("invisible"))
|
|
|
|
$('comboPrio' + id).addClass("invisible");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
tds[i].set('html', row[i]);
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
|
|
|
|
insertRow: function(id, row) {
|
|
|
|
if (this.rows.has(id)) {
|
2017-07-01 00:42:20 -04:00
|
|
|
var tableRow = this.rows.get(id);
|
|
|
|
this.updateRow(tableRow, row, id);
|
2014-12-08 21:00:00 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
//this.removeRow(id);
|
|
|
|
var tr = new Element('tr');
|
|
|
|
this.rows.set(id, tr);
|
2018-05-31 01:06:28 +08:00
|
|
|
for (var i = 0; i < row.length; ++i) {
|
2014-12-08 21:00:00 +01:00
|
|
|
var td = new Element('td');
|
2015-03-04 20:00:00 +01:00
|
|
|
switch (i) {
|
2018-04-05 11:59:31 +08:00
|
|
|
case 0:
|
|
|
|
var tree_img = new Element('img', {
|
|
|
|
src: 'images/L.gif',
|
|
|
|
style: 'margin-bottom: -2px'
|
|
|
|
});
|
|
|
|
td.adopt(tree_img, createDownloadedCB(id, row[i]));
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
td.set('html', row[i]);
|
|
|
|
td.set('title', row[i]);
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
td.adopt(new ProgressBar(row[i].toFloat(), {
|
|
|
|
'id': 'pbf_' + id,
|
|
|
|
'width': 80
|
|
|
|
}));
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
td.adopt(createPriorityCombo(id, row[i]));
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
td.set('html', row[i]);
|
|
|
|
break;
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
|
|
|
td.injectInside(tr);
|
|
|
|
}
|
|
|
|
tr.injectInside(this.table);
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2014-12-11 00:01:04 +01:00
|
|
|
var loadTorrentFilesDataTimer;
|
2014-12-08 21:00:00 +01:00
|
|
|
var loadTorrentFilesData = function() {
|
2018-04-05 11:59:31 +08:00
|
|
|
if ($('prop_files').hasClass('invisible')
|
|
|
|
|| $('propertiesPanel_collapseToggle').hasClass('panel-expand')) {
|
2014-12-08 21:00:00 +01:00
|
|
|
// Tab changed, don't do anything
|
|
|
|
return;
|
|
|
|
}
|
2015-11-11 22:58:30 +03:00
|
|
|
var new_hash = torrentsTable.getCurrentTorrentHash();
|
2017-07-01 00:42:20 -04:00
|
|
|
if (new_hash === "") {
|
2014-12-08 21:00:00 +01:00
|
|
|
fTable.removeAllRows();
|
2014-12-11 21:22:23 +01:00
|
|
|
clearTimeout(loadTorrentFilesDataTimer);
|
2014-12-08 22:00:00 +01:00
|
|
|
loadTorrentFilesDataTimer = loadTorrentFilesData.delay(5000);
|
2014-12-08 21:00:00 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (new_hash != current_hash) {
|
|
|
|
fTable.removeAllRows();
|
|
|
|
current_hash = new_hash;
|
|
|
|
}
|
2017-10-14 16:27:21 +03:00
|
|
|
var url = new URI('api/v2/torrents/files?hash=' + current_hash);
|
2018-09-26 23:10:51 -04:00
|
|
|
new Request.JSON({
|
2014-12-11 00:01:04 +01:00
|
|
|
url: url,
|
|
|
|
noCache: true,
|
|
|
|
method: 'get',
|
|
|
|
onFailure: function() {
|
2017-05-01 01:45:02 +03:00
|
|
|
$('error_div').set('html', 'QBT_TR(qBittorrent client is not reachable)QBT_TR[CONTEXT=HttpServer]');
|
2014-12-11 21:22:23 +01:00
|
|
|
clearTimeout(loadTorrentFilesDataTimer);
|
2014-12-08 22:00:00 +01:00
|
|
|
loadTorrentFilesDataTimer = loadTorrentFilesData.delay(10000);
|
2014-12-11 00:01:04 +01:00
|
|
|
},
|
|
|
|
onSuccess: function(files) {
|
|
|
|
$('error_div').set('html', '');
|
|
|
|
if (files) {
|
|
|
|
// Update Trackers data
|
|
|
|
var i = 0;
|
|
|
|
files.each(function(file) {
|
2017-07-01 00:42:20 -04:00
|
|
|
if (i === 0) {
|
2014-12-11 00:01:04 +01:00
|
|
|
is_seed = file.is_seed;
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
2017-07-01 00:42:20 -04:00
|
|
|
var row = [];
|
2014-12-11 00:01:04 +01:00
|
|
|
row.length = 4;
|
|
|
|
row[0] = file.priority;
|
2017-02-11 15:06:15 +08:00
|
|
|
row[1] = escapeHtml(file.name);
|
2014-12-11 00:01:04 +01:00
|
|
|
row[2] = friendlyUnit(file.size, false);
|
|
|
|
row[3] = (file.progress * 100).round(1);
|
|
|
|
if (row[3] == 100.0 && file.progress < 1.0)
|
2017-07-01 00:42:20 -04:00
|
|
|
row[3] = 99.9;
|
2014-12-11 00:01:04 +01:00
|
|
|
row[4] = file.priority;
|
2017-12-07 01:07:37 -05:00
|
|
|
row[5] = friendlyUnit(file.size * (1.0 - file.progress));
|
|
|
|
row[6] = friendlyPercentage(file.availability);
|
|
|
|
|
2014-12-11 00:01:04 +01:00
|
|
|
fTable.insertRow(i, row);
|
2018-05-31 01:06:28 +08:00
|
|
|
++i;
|
2014-12-11 00:01:04 +01:00
|
|
|
}.bind(this));
|
|
|
|
// Set global CB state
|
|
|
|
if (allCBChecked()) {
|
|
|
|
setCBState("checked");
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-12-11 00:01:04 +01:00
|
|
|
if (allCBUnchecked()) {
|
|
|
|
setCBState("unchecked");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
setCBState("partial");
|
|
|
|
}
|
2014-12-08 21:00:00 +01:00
|
|
|
}
|
|
|
|
}
|
2014-12-11 00:01:04 +01:00
|
|
|
else {
|
|
|
|
fTable.removeAllRows();
|
|
|
|
}
|
2014-12-11 21:22:23 +01:00
|
|
|
clearTimeout(loadTorrentFilesDataTimer);
|
2014-12-08 22:00:00 +01:00
|
|
|
loadTorrentFilesDataTimer = loadTorrentFilesData.delay(5000);
|
2014-12-11 00:01:04 +01:00
|
|
|
}
|
|
|
|
}).send();
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-08 21:00:00 +01:00
|
|
|
|
2014-12-11 00:01:04 +01:00
|
|
|
var updateTorrentFilesData = function() {
|
|
|
|
clearTimeout(loadTorrentFilesDataTimer);
|
|
|
|
loadTorrentFilesData();
|
2017-07-01 00:42:20 -04:00
|
|
|
};
|
2014-12-11 00:01:04 +01:00
|
|
|
|
2014-12-08 21:00:00 +01:00
|
|
|
fTable = new filesDynTable();
|
2015-06-13 14:15:49 +02:00
|
|
|
fTable.setup($('filesTable'));
|