1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-16 01:30:09 +00:00

400 lines
13 KiB
JavaScript
Raw Normal View History

var lastShownContexMenu = null;
var ContextMenu = new Class({
//implements
Implements: [Options, Events],
//options
options: {
actions: {},
2016-01-20 16:13:54 +03:00
menu: 'menu_id',
stopEvent: true,
targets: 'body',
trigger: 'contextmenu',
offsets: {
x: 0,
y: 0
},
onShow: $empty,
onHide: $empty,
onClick: $empty,
fadeSpeed: 200
},
//initialization
initialize: function(options) {
//set options
this.setOptions(options);
//option diffs menu
this.menu = $(this.options.menu);
this.targets = $$(this.options.targets);
//fx
this.fx = new Fx.Tween(this.menu, {
property: 'opacity',
duration: this.options.fadeSpeed,
onComplete: function() {
if (this.getStyle('opacity')) {
this.setStyle('visibility', 'visible');
}
else {
this.setStyle('visibility', 'hidden');
}
}.bind(this.menu)
});
//hide and begin the listener
this.hide().startListener();
//hide the menu
this.menu.setStyles({
'position': 'absolute',
'top': '-900000px',
'display': 'block'
});
},
2016-01-22 20:10:32 +03:00
adjustMenuPosition: function(e) {
this.updateMenuItems();
2016-07-18 22:33:16 +03:00
var scrollableMenuMaxHeight = document.documentElement.clientHeight * 0.75;
if (this.menu.hasClass('scrollableMenu'))
this.menu.setStyle('max-height', scrollableMenuMaxHeight);
2018-03-14 23:15:51 +08:00
// draw the menu off-screen to know the menu dimensions
2016-01-22 20:10:32 +03:00
this.menu.setStyles({
left: '-999em',
top: '-999em'
});
// position the menu
var xPosMenu = e.page.x + this.options.offsets.x;
var yPosMenu = e.page.y + this.options.offsets.y;
if (xPosMenu + this.menu.offsetWidth > document.documentElement.clientWidth)
xPosMenu -= this.menu.offsetWidth;
if (yPosMenu + this.menu.offsetHeight > document.documentElement.clientHeight)
yPosMenu = document.documentElement.clientHeight - this.menu.offsetHeight;
if (xPosMenu < 0)
xPosMenu = 0;
if (yPosMenu < 0)
yPosMenu = 0;
2016-01-22 20:10:32 +03:00
this.menu.setStyles({
left: xPosMenu,
top: yPosMenu,
2016-01-22 20:10:32 +03:00
position: 'absolute',
'z-index': '2000'
});
// position the sub-menu
var uls = this.menu.getElementsByTagName('ul');
for (var i = 0; i < uls.length; ++i) {
2016-01-22 20:10:32 +03:00
var ul = uls[i];
2016-07-18 22:33:16 +03:00
if (ul.hasClass('scrollableMenu'))
ul.setStyle('max-height', scrollableMenuMaxHeight);
2016-01-22 20:10:32 +03:00
var rectParent = ul.parentNode.getBoundingClientRect();
var xPosOrigin = rectParent.left;
var yPosOrigin = rectParent.bottom;
var xPos = xPosOrigin + rectParent.width - 1;
var yPos = yPosOrigin - rectParent.height - 1;
if (xPos + ul.offsetWidth > document.documentElement.clientWidth)
xPos -= (ul.offsetWidth + rectParent.width - 2);
if (yPos + ul.offsetHeight > document.documentElement.clientHeight)
2016-07-18 22:33:16 +03:00
yPos = document.documentElement.clientHeight - ul.offsetHeight;
2016-01-22 20:10:32 +03:00
if (xPos < 0)
xPos = 0;
if (yPos < 0)
yPos = 0;
ul.setStyles({
'margin-left': xPos - xPosOrigin,
'margin-top': yPos - yPosOrigin
});
}
},
addTarget: function(t) {
this.targets[this.targets.length] = t;
t.addEvent(this.options.trigger, function(e) {
//enabled?
if (!this.options.disabled) {
//prevent default, if told to
if (this.options.stopEvent) {
e.stop();
}
//record this as the trigger
this.options.element = $(t);
2016-01-22 20:10:32 +03:00
this.adjustMenuPosition(e);
//show the menu
this.show();
}
}.bind(this));
t.addEvent('click', function(e) {
this.hide();
}.bind(this));
},
//get things started
startListener: function() {
/* all elements */
this.targets.each(function(el) {
/* show the menu */
el.addEvent(this.options.trigger, function(e) {
//enabled?
if (!this.options.disabled) {
//prevent default, if told to
if (this.options.stopEvent) {
e.stop();
}
//record this as the trigger
this.options.element = $(el);
2016-01-22 20:10:32 +03:00
this.adjustMenuPosition(e);
//show the menu
this.show();
}
}.bind(this));
el.addEvent('click', function(e) {
this.hide();
}.bind(this));
}, this);
/* menu items */
this.menu.getElements('a').each(function(item) {
item.addEvent('click', function(e) {
e.preventDefault();
if (!item.hasClass('disabled')) {
this.execute(item.get('href').split('#')[1], $(this.options.element));
this.fireEvent('click', [item, e]);
}
}.bind(this));
}, this);
//hide on body click
$(document.body).addEvent('click', function() {
this.hide();
}.bind(this));
},
2018-04-05 11:59:31 +08:00
updateMenuItems: function() {},
2016-01-20 16:13:54 +03:00
//show menu
2018-04-05 11:59:31 +08:00
show: function(trigger) {
if (lastShownContexMenu && lastShownContexMenu != this)
lastShownContexMenu.hide();
2016-01-20 16:13:54 +03:00
this.fx.start(1);
this.fireEvent('show');
this.shown = true;
lastShownContexMenu = this;
2016-01-20 16:13:54 +03:00
return this;
},
//hide the menu
2018-04-05 11:59:31 +08:00
hide: function(trigger) {
2016-01-20 16:13:54 +03:00
if (this.shown) {
this.fx.start(0);
//this.menu.fade('out');
this.fireEvent('hide');
this.shown = false;
}
return this;
},
2018-04-05 11:59:31 +08:00
setItemChecked: function(item, checked) {
2016-01-20 16:13:54 +03:00
this.menu.getElement('a[href$=' + item + ']').firstChild.style.opacity =
2018-04-05 11:59:31 +08:00
checked ? '1' : '0';
2016-01-20 16:13:54 +03:00
return this;
},
2018-04-05 11:59:31 +08:00
getItemChecked: function(item) {
2016-01-20 16:13:54 +03:00
return '0' != this.menu.getElement('a[href$=' + item + ']').firstChild.style.opacity;
},
//hide an item
2018-04-05 11:59:31 +08:00
hideItem: function(item) {
2016-01-20 16:13:54 +03:00
this.menu.getElement('a[href$=' + item + ']').parentNode.addClass('invisible');
return this;
},
//show an item
2018-04-05 11:59:31 +08:00
showItem: function(item) {
2016-01-20 16:13:54 +03:00
this.menu.getElement('a[href$=' + item + ']').parentNode.removeClass('invisible');
return this;
},
//disable the entire menu
2018-04-05 11:59:31 +08:00
disable: function() {
2016-01-20 16:13:54 +03:00
this.options.disabled = true;
return this;
},
//enable the entire menu
2018-04-05 11:59:31 +08:00
enable: function() {
2016-01-20 16:13:54 +03:00
this.options.disabled = false;
return this;
},
//execute an action
2018-04-05 11:59:31 +08:00
execute: function(action, element) {
2016-01-20 16:13:54 +03:00
if (this.options.actions[action]) {
2016-07-18 18:58:16 +03:00
this.options.actions[action](element, this, action);
2016-01-20 16:13:54 +03:00
}
return this;
}
});
var TorrentsTableContextMenu = new Class({
Extends: ContextMenu,
2018-04-05 11:59:31 +08:00
updateMenuItems: function() {
2018-09-26 23:10:51 -04:00
var all_are_seq_dl = true;
var there_are_seq_dl = false;
var all_are_f_l_piece_prio = true;
var there_are_f_l_piece_prio = false;
var all_are_downloaded = true;
var all_are_paused = true;
var there_are_paused = false;
var all_are_force_start = true;
var there_are_force_start = false;
var all_are_super_seeding = true;
var all_are_auto_tmm = true;
var there_are_auto_tmm = false;
2014-12-09 19:54:35 +03:00
var h = torrentsTable.selectedRowsIds();
2018-04-05 11:59:31 +08:00
h.each(function(item, index) {
var data = torrentsTable.rows.get(item).full_data;
if (data['seq_dl'] !== true)
2014-12-09 19:54:35 +03:00
all_are_seq_dl = false;
else
there_are_seq_dl = true;
if (data['f_l_piece_prio'] !== true)
2014-12-09 19:54:35 +03:00
all_are_f_l_piece_prio = false;
else
there_are_f_l_piece_prio = true;
if (data['progress'] != 1.0) // not downloaded
2014-12-09 19:54:35 +03:00
all_are_downloaded = false;
else if (data['super_seeding'] !== true)
all_are_super_seeding = false;
if (data['state'] != 'pausedUP' && data['state'] != 'pausedDL')
all_are_paused = false;
else
there_are_paused = true;
if (data['force_start'] !== true)
all_are_force_start = false;
else
there_are_force_start = true;
if (data['auto_tmm'] === true)
there_are_auto_tmm = true;
else
all_are_auto_tmm = false;
2014-12-09 19:54:35 +03:00
});
2018-09-26 23:10:51 -04:00
var show_seq_dl = true;
if (!all_are_seq_dl && there_are_seq_dl)
show_seq_dl = false;
2018-09-26 23:10:51 -04:00
var show_f_l_piece_prio = true;
if (!all_are_f_l_piece_prio && there_are_f_l_piece_prio)
show_f_l_piece_prio = false;
2014-12-09 19:54:35 +03:00
if (all_are_downloaded) {
this.hideItem('DownloadLimit');
this.menu.getElement('a[href$=UploadLimit]').parentNode.addClass('separator');
2014-12-09 19:54:35 +03:00
this.hideItem('SequentialDownload');
this.hideItem('FirstLastPiecePrio');
this.showItem('SuperSeeding');
this.setItemChecked('SuperSeeding', all_are_super_seeding);
2018-04-05 11:59:31 +08:00
}
else {
if (!show_seq_dl && show_f_l_piece_prio)
this.menu.getElement('a[href$=FirstLastPiecePrio]').parentNode.addClass('separator');
else
this.menu.getElement('a[href$=FirstLastPiecePrio]').parentNode.removeClass('separator');
if (show_seq_dl)
this.showItem('SequentialDownload');
else
this.hideItem('SequentialDownload');
if (show_f_l_piece_prio)
this.showItem('FirstLastPiecePrio');
else
this.hideItem('FirstLastPiecePrio');
2014-12-09 19:54:35 +03:00
this.setItemChecked('SequentialDownload', all_are_seq_dl);
this.setItemChecked('FirstLastPiecePrio', all_are_f_l_piece_prio);
this.showItem('DownloadLimit');
this.menu.getElement('a[href$=UploadLimit]').parentNode.removeClass('separator');
this.hideItem('SuperSeeding');
2014-12-09 19:54:35 +03:00
}
this.showItem('Start');
this.showItem('Pause');
this.showItem('ForceStart');
if (all_are_paused)
this.hideItem('Pause');
else if (all_are_force_start)
this.hideItem('ForceStart');
else if (!there_are_paused && !there_are_force_start)
this.hideItem('Start');
if (!all_are_auto_tmm && there_are_auto_tmm)
this.hideItem('AutoTorrentManagement');
else
this.setItemChecked('AutoTorrentManagement', all_are_auto_tmm);
},
2018-04-05 11:59:31 +08:00
updateCategoriesSubMenu: function(category_list) {
2016-01-20 16:13:54 +03:00
var categoryList = $('contextCategoryList');
categoryList.empty();
2018-04-05 11:59:31 +08:00
categoryList.appendChild(new Element('li', {
2018-07-23 12:28:14 +08:00
html: '<a href="javascript:torrentNewCategoryFN();"><img src="images/qbt-theme/list-add.svg" alt="QBT_TR(New...)QBT_TR[CONTEXT=TransferListWidget]"/> QBT_TR(New...)QBT_TR[CONTEXT=TransferListWidget]</a>'
2018-04-05 11:59:31 +08:00
}));
categoryList.appendChild(new Element('li', {
2018-07-23 12:28:14 +08:00
html: '<a href="javascript:torrentSetCategoryFN(0);"><img src="images/qbt-theme/edit-clear.svg" alt="QBT_TR(Reset)QBT_TR[CONTEXT=TransferListWidget]"/> QBT_TR(Reset)QBT_TR[CONTEXT=TransferListWidget]</a>'
2018-04-05 11:59:31 +08:00
}));
var sortedCategories = [];
2018-04-05 11:59:31 +08:00
Object.each(category_list, function(category) {
2016-01-20 16:13:54 +03:00
sortedCategories.push(category.name);
});
sortedCategories.sort();
var first = true;
2018-04-05 11:59:31 +08:00
Object.each(sortedCategories, function(categoryName) {
2016-01-20 16:13:54 +03:00
var categoryHash = genHash(categoryName);
2018-04-05 11:59:31 +08:00
var el = new Element('li', {
2018-07-23 12:28:14 +08:00
html: '<a href="javascript:torrentSetCategoryFN(\'' + categoryHash + '\');"><img src="images/qbt-theme/inode-directory.svg"/> ' + escapeHtml(categoryName) + '</a>'
2018-04-05 11:59:31 +08:00
});
2016-01-20 16:13:54 +03:00
if (first) {
el.addClass('separator');
first = false;
}
categoryList.appendChild(el);
});
}
});
var CategoriesFilterContextMenu = new Class({
2016-01-21 16:42:20 +03:00
Extends: ContextMenu,
2018-04-05 11:59:31 +08:00
updateMenuItems: function() {
2016-01-21 16:42:20 +03:00
var id = this.options.element.id;
if ((id != CATEGORIES_ALL) && (id != CATEGORIES_UNCATEGORIZED)) {
this.showItem('EditCategory');
2016-01-21 16:42:20 +03:00
this.showItem('DeleteCategory');
}
else {
this.hideItem('EditCategory');
2016-01-21 16:42:20 +03:00
this.hideItem('DeleteCategory');
}
2016-01-21 16:42:20 +03:00
}
});