webui-aria2/js/script.js

500 lines
13 KiB
JavaScript
Raw Normal View History

2012-06-04 16:08:46 +02:00
var modals = {
err_connect: undefined,
change_conf: undefined,
newDownload_modal: undefined,
global_settings_modal: undefined
2012-06-04 16:08:46 +02:00
};
2012-06-05 07:25:57 +02:00
var clear_dialogs = function() {
modals.err_connect.modal('hide');
modals.change_conf.modal('hide');
modals.newDownload_modal.modal('hide');
2012-06-06 14:08:24 +02:00
modals.global_settings_modal.modal('hide');
2012-06-05 07:25:57 +02:00
};
2012-06-04 16:08:46 +02:00
var server_conf = {
host: 'localhost',
port: 6800,
user: "",
pass: ""
2012-06-04 16:08:46 +02:00
};
var custom_aria2_connect = function() {
2012-06-06 14:08:24 +02:00
clear_dialogs();
2012-06-04 16:08:46 +02:00
modals.change_conf.modal('show');
};
var update_server_conf = function() {
var host = $('#input_host').val().trim();
var port = $('#input_port').val().trim();
server_conf.user = $('#input_user').val().trim();
server_conf.pass = $('#input_pass').val().trim();
if(host.length !== 0) {
server_conf.host = host;
}
if(port.length !== 0) {
server_conf.port = port;
}
2012-06-05 07:25:57 +02:00
clear_dialogs();
2012-06-04 16:08:46 +02:00
update_ui();
};
2012-06-05 11:44:54 +02:00
function param_encode(param) {
if(param) {
param = base64.btoa(JSON.stringify(param));
}
return param;
}
var aria_syscall = function(conf, multicall) {
$.ajax({
url: 'http://' + server_conf.host + ':' + server_conf.port + '/jsonrpc',
2012-06-05 11:44:54 +02:00
timeout: 1000,
data: {
jsonrpc: 2.0,
2012-06-04 16:08:46 +02:00
id: 'webui',
2012-06-05 11:44:54 +02:00
method: multicall? conf.func:'aria2.' + conf.func,
params: param_encode(conf.params)
},
success: conf.success,
error: function() {
if(server_conf.user.length) {
var url = 'http://' +
server_conf.user + ":" +
server_conf.pass + "@" +
server_conf.host + ':' +
server_conf.port + '/jsonrpc';
/* hack for http authentication */
var img = $('<img/>').attr("src", url);
$('body').append(img);
img.remove();
setTimeout(function() {
$.ajax({
url: url,
timeout: 1000,
data: {
jsonrpc: 2.0,
id: 'webui',
method: multicall? conf.func:'aria2.' + conf.func,
params: param_encode(conf.params)
},
success: conf.success,
error: conf.error,
dataType: 'jsonp',
jsonp: 'jsoncallback'
});
}, 1000);
}
else if(conf.error) {
conf.error();
}
},
2012-06-04 16:08:46 +02:00
dataType: 'jsonp',
jsonp: 'jsoncallback'
});
}
var update_ui = function() {
2012-06-05 11:44:54 +02:00
updateDownloads();
2012-06-04 16:08:46 +02:00
};
$(function() {
var modal_conf = {
show: false
};
modals.err_connect = $('#error_connect').modal(modal_conf);
modals.change_conf = $('#change_conf').modal(modal_conf);
modals.newDownload_modal = $('#newDownload_modal').modal(modal_conf);
2012-06-06 14:08:24 +02:00
modals.global_settings_modal = $('#global_settings_modal').modal(modal_conf);
2012-06-04 16:08:46 +02:00
update_ui();
$('#newDownload').click(function() {
$('#newDownload_url').val("");
$('.download_urls').html("");
2012-06-04 16:08:46 +02:00
modals.newDownload_modal.modal('show');
});
$('#multiple_uris').click(function() {
var url = $('#newDownload_url').val();
var html = '<li>';
html += '<span class="uris">';
html += url;
html += '</span>';
html += ' ';
html += '<a href="#"><i class="icon-trash"></i></a></li>';
$(html).appendTo('.download_urls');
$('#newDownload_url').val("");
$('.download_urls a').unbind('click').click(function() {
$(this).parents('li').remove();
});
});
2012-06-04 16:08:46 +02:00
$('#addNewDownload').click(newDownload);
});
function check_global(name) {
for(var i = 0; i < global_settings_exclude.length; i++) {
if(global_settings_exclude[i] === name) {
return false;
}
}
return true;
}
function get_global_settings(cb) {
var sets = [];
var tmp_set = [];
for(var i = 0; i < input_file_settings.length; i++) {
tmp_set = $.extend(true, {}, input_file_settings[i]);
if(check_global(tmp_set)) {
sets.push(tmp_set);
}
}
for(var i = 0; i < global_settings.length; i++) {
tmp_set = $.extend(true, {}, global_settings[i]);
if(check_global(tmp_set)) {
sets.push(tmp_set);
}
}
aria_syscall({
func: 'getGlobalOption',
success: function(data) {
var res = data.result;
for(var i in res) {
for(var j = 0; j < sets.length; j++) {
if(sets[j].name === i) {
sets[j].value = res[i].trim();
sets[j].has_value = true;
if(sets[j].option) {
for(var k = 0; k < sets[j].options.length; k++) {
var tmp = {
val: sets[j].options[k],
disp: sets[j].options[k]
};
if(sets[j].options[k] === sets[j].value) {
tmp.val = sets[j].value + '" selected="true';
}
sets[j].options[k] = tmp;
}
}
}
}
}
cb(sets);
},
error: function() {
alert("Connection to aria server failed");
}
});
}
function custom_global_settings() {
var gen = function(name) {
return { name: name, values: [] };
};
var general_settings = gen("General Settings");
var torrent_settings = gen("Bit-Torrent Settings");
var ftp_settings = gen("FTP Settings");
var http_settings = gen("HTTP(S) Settings");
var metalink_settings = gen("Metalink Settings");
get_global_settings(function(sets) {
for(var i = 0; i < sets.length; i++) {
var set = sets[i];
if(set.name.indexOf("bt") !== -1 || set.name.indexOf("torrent") !== -1) {
torrent_settings.values.push(set);
}
else if(set.name.indexOf("metalink") !== -1) {
metalink_settings.values.push(set);
}
else if(set.name.indexOf("http") !== -1) {
http_settings.values.push(set);
}
else if(set.name.indexOf("ftp") !== -1) {
ftp_settings.values.push(set);
}
else
general_settings.values.push(set);
}
var templ = $('#global_general_settings_template').text();
var item = Mustache.render(templ, {
settings: [
general_settings,
http_settings,
ftp_settings,
torrent_settings,
metalink_settings
]
});
$('#dynamic_global_settings').html(item);
modals.global_settings_modal.modal('show');
$("#save_global_settings").one('click',function() {
var settings = {};
for(var i = 0; i < sets.length; i++) {
var elem = $("#input_settings_" + sets[i].name);
if(sets[i].value) {
if(elem.val() !== sets[i].value) {
settings[sets[i].name] = elem.val();
}
}
else if(elem.val() !== "no_val" && elem.val() !== "") {
settings[sets[i].name] = elem.val();
}
}
console.log(settings);
if(!$.isEmptyObject(settings)) {
aria_syscall({
func: 'changeGlobalOption',
params: [settings],
success: function(data) {
console.log(data);
clear_dialogs();
}
});
clear_dialogs();
}
else {
clear_dialogs();
}
});
2012-06-06 14:08:24 +02:00
});
}
function addDownload(uris) {
console.log("adding download:");
console.log(uris);
2012-06-04 16:08:46 +02:00
aria_syscall({
func: 'addUri',
params: uris,
success: function() {
2012-06-05 07:25:57 +02:00
clear_dialogs();
2012-06-04 16:08:46 +02:00
update_ui();
}
});
}
function newDownload() {
var li = $('.download_urls li');
var urls = [];
for(var i = 0; i < li.length; i++) {
urls.push($(li[i]).text().trim());
}
2012-06-06 07:17:39 +02:00
var inp_url = $('#newDownload_url').val().trim();
if(inp_url.length > 0) urls.push(inp_url);
addDownload([urls]);
}
2012-06-05 11:44:54 +02:00
var d_files = {
active: [],
waiting: [],
stopped: []
};
2012-06-05 14:53:52 +02:00
function changeLength(len, pref) {
len = parseInt(len);
if(len <= 1000) return len + " " + pref;
else if(len <= 1000000) return (len/1000).toFixed(1) + " k" + pref;
else if(len <= 1000000000) return (len/1000000).toFixed(1) + " m" + pref;
else if(len <= 1000000000000) return (len/1000000000).toFixed(1) + " g" + pref;
2012-06-05 19:55:59 +02:00
}
function changeTime(time) {
2012-06-06 07:17:39 +02:00
time = parseInt(time);
2012-06-06 10:09:48 +02:00
if(!time) return "infinite";
2012-06-06 07:17:39 +02:00
if(time < 60) return time + " s";
else if(time < 60*60) return (time/60).toFixed(2) + " min";
else if(time < 60*60*24) return (time/(60*60)).toFixed(2) + " hours";
else return (time/(60*60*24)).toFixed(2) + " days!!";
2012-06-05 19:55:59 +02:00
2012-06-05 14:53:52 +02:00
}
function getTemplateCtx(data) {
var percentage =(data.completedLength / data.totalLength)*100;
percentage = percentage.toFixed(2);
if(!percentage) percentage = 0;
var name;
if(data.files[0].uris.length) {
name = data.files[0].uris[0].uri.replace(/^.*[\\\/]/, '');
}
else {
name = data.files[0].path.replace(/^.*[\\\/\]]/, '');
}
var eta = changeTime((data.totalLength-data.completedLength)/data.downloadSpeed);
return {
name: name,
status: data.status,
percentage:percentage,
gid: data.gid,
size: changeLength(data.totalLength, "b"),
down: changeLength(data.downloadSpeed, "b/s"),
remaining: changeLength(data.totalLength - data.completedLength, "b"),
eta: eta,
downloaded: changeLength(data.completedLength, "b")
};
}
2012-06-05 11:44:54 +02:00
function updateActiveDownloads(data) {
var down_template = $('#download_active_template').text();
$('#active_downloads').html("");
if(!data || (data && data.length === 0)) {
$('#active_downloads').append('no active downloads yet!!!!');
2012-06-05 11:44:54 +02:00
}
for(var i = 0; i < data.length; i++) {
var ctx = getTemplateCtx(data[i]);
2012-06-05 11:44:54 +02:00
var item = Mustache.render(down_template, ctx);
$('#active_downloads').append(item);
}
$('.download_active_item .download_pause').click(function() {
var gid = $(this).parents('.download_active_item').attr('data-gid');
aria_syscall({
func: 'pause',
params: [gid],
success: function() {
2012-06-05 11:44:54 +02:00
update_ui();
},
error: function(err) {
console.log("error pausing active download!!!");
console.log(err);
}
});
});
$('.download_active_item .download_remove').click(function() {
var gid = $(this).parents('.download_active_item').attr('data-gid');
aria_syscall({
func: 'remove',
params: [gid],
success: function() {
update_ui();
},
error: function(err) {
console.log("error removing active download!!!");
console.log(err);
}
});
});
2012-06-05 11:44:54 +02:00
}
function updateWaitingDownloads(data) {
var down_template = $('#download_waiting_template').text();
$('#waiting_downloads').html("");
if(!data || (data && data.length === 0)) {
$('#waiting_downloads').append('no waiting downloads yet!!!!');
2012-06-05 11:44:54 +02:00
}
for(var i = 0; i < data.length; i++) {
var ctx = getTemplateCtx(data[i]);
2012-06-05 11:44:54 +02:00
var item = Mustache.render(down_template, ctx);
$('#waiting_downloads').append(item);
}
$('.download_waiting_item .download_play').click(function() {
var gid = $(this).parents('.download_waiting_item').attr('data-gid');
aria_syscall({
func: 'unpause',
params: [gid],
success: function(data) {
2012-06-05 11:44:54 +02:00
update_ui();
},
error: function(err) {
console.log("error playing waiting download!!!");
console.log(err);
}
});
});
$('.download_waiting_item .download_remove').click(function() {
var gid = $(this).parents('.download_waiting_item').attr('data-gid');
aria_syscall({
func: 'remove',
params: [gid],
success: function() {
update_ui();
},
error: function(err) {
console.log("error removing waiting download!!!");
console.log(err);
}
});
});
2012-06-05 11:44:54 +02:00
}
2012-06-05 14:53:52 +02:00
2012-06-05 11:44:54 +02:00
function updateStoppedDownloads(data) {
var down_template = $('#download_stopped_template').text();
$('#stopped_downloads').html("");
if(!data || (data && data.length === 0)) {
$('#stopped_downloads').append('no stopped downloads yet!!!!');
2012-06-05 11:44:54 +02:00
}
for(var i = 0; i < data.length; i++) {
var ctx = getTemplateCtx(data[i]);
2012-06-05 11:44:54 +02:00
var item = Mustache.render(down_template, ctx);
$('#stopped_downloads').append(item);
}
$('.download_stopped_item .download_remove').click(function() {
2012-06-05 11:44:54 +02:00
var gid = $(this).parents('.download_stopped_item').attr('data-gid');
aria_syscall({
func: 'removeDownloadResult',
params: [gid],
success: function() {
update_ui();
},
error: function(err) {
console.log("error removing stopped download!!!");
console.log(err);
}
});
});
$('.download_stopped_item .download_restart').click(function() {
var gid = $(this).parents('.download_stopped_item').attr('data-gid');
var files;
var uris = [];
for(var i = 0; i < d_files.stopped.length; i++) {
if(d_files.stopped[i].gid === gid) {
files = d_files.stopped[i].files;
break;
}
}
for(var i = 0; i < files.length; i++) {
var tmp_uris = [];
for(var j = 0; j < files[i].uris.length; j++) {
tmp_uris.push(files[i].uris[j].uri);
}
uris.push(tmp_uris);
}
addDownload(uris);
aria_syscall({
func: 'removeDownloadResult',
2012-06-05 11:44:54 +02:00
params: [gid],
success: function() {
2012-06-05 11:44:54 +02:00
update_ui();
},
error: function(err) {
console.log("error removing stopped download!!!");
2012-06-05 11:44:54 +02:00
console.log(err);
}
});
});
}
function mergeDownloads(data) {
d_files.active = data[0][0];
d_files.waiting = data[1][0];
d_files.stopped = data[2][0];
}
function updateDownloads() {
2012-06-04 16:08:46 +02:00
aria_syscall({
2012-06-05 11:44:54 +02:00
func: 'system.multicall',
params:[[{
methodName: 'aria2.tellActive'
}, {
methodName: 'aria2.tellWaiting',
params: [0,100]
2012-06-05 11:44:54 +02:00
}, {
methodName: 'aria2.tellStopped',
params: [0, 100]
2012-06-05 11:44:54 +02:00
}]],
success: function(data) {
2012-06-05 11:44:54 +02:00
mergeDownloads(data.result);
updateActiveDownloads(d_files.active);
updateWaitingDownloads(d_files.waiting);
updateStoppedDownloads(d_files.stopped);
2012-06-04 16:08:46 +02:00
},
error: function() {
modals.err_connect.modal('show');
}
2012-06-05 11:44:54 +02:00
}, true);
}
2012-06-05 07:25:57 +02:00
setInterval(update_ui, 1000);