2016-01-23 12:14:05 +03:00
|
|
|
var lastShownContexMenu = null;
|
2009-11-24 22:41:31 +03:00
|
|
|
var ContextMenu = new Class({
|
2014-11-30 16:14:09 +03:00
|
|
|
//implements
|
|
|
|
Implements: [Options, Events],
|
|
|
|
|
|
|
|
//options
|
|
|
|
options: {
|
|
|
|
actions: {},
|
2016-01-20 16:13:54 +03:00
|
|
|
menu: 'menu_id',
|
2014-11-30 16:14:09 +03:00
|
|
|
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);
|
|
|
|
|
2016-01-22 20:10:32 +03:00
|
|
|
// draw the menu off-screen to know the menu dimentions
|
|
|
|
this.menu.setStyles({
|
|
|
|
left: '-999em',
|
|
|
|
top: '-999em'
|
|
|
|
});
|
|
|
|
|
|
|
|
// position the menu
|
|
|
|
var xPos = e.page.x + this.options.offsets.x;
|
|
|
|
var yPos = e.page.y + this.options.offsets.y;
|
|
|
|
if (xPos + this.menu.offsetWidth > document.documentElement.clientWidth)
|
|
|
|
xPos -= this.menu.offsetWidth;
|
|
|
|
if (yPos + this.menu.offsetHeight > document.documentElement.clientHeight)
|
2016-07-18 22:33:16 +03:00
|
|
|
yPos = document.documentElement.clientHeight - this.menu.offsetHeight;
|
2016-01-22 20:10:32 +03:00
|
|
|
if (xPos < 0)
|
|
|
|
xPos = 0;
|
|
|
|
if (yPos < 0)
|
|
|
|
yPos = 0;
|
|
|
|
this.menu.setStyles({
|
|
|
|
left: xPos,
|
|
|
|
top: yPos,
|
|
|
|
position: 'absolute',
|
|
|
|
'z-index': '2000'
|
|
|
|
});
|
|
|
|
|
|
|
|
// position the sub-menu
|
|
|
|
var uls = this.menu.getElementsByTagName('ul');
|
|
|
|
for (var i = 0; i < uls.length; i++) {
|
|
|
|
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
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2014-11-30 16:14:09 +03:00
|
|
|
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);
|
2014-11-30 16:14:09 +03:00
|
|
|
//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);
|
2014-11-30 16:14:09 +03:00
|
|
|
//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) {
|
2014-12-14 12:00:00 +03:00
|
|
|
e.preventDefault();
|
2014-11-30 16:14:09 +03:00
|
|
|
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));
|
|
|
|
},
|
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
updateMenuItems: function () {},
|
|
|
|
|
|
|
|
//show menu
|
|
|
|
show: function (trigger) {
|
2016-01-23 12:14:05 +03:00
|
|
|
if (lastShownContexMenu && lastShownContexMenu != this)
|
|
|
|
lastShownContexMenu.hide();
|
2016-01-20 16:13:54 +03:00
|
|
|
this.fx.start(1);
|
|
|
|
this.fireEvent('show');
|
|
|
|
this.shown = true;
|
2016-01-23 12:14:05 +03:00
|
|
|
lastShownContexMenu = this;
|
2016-01-20 16:13:54 +03:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
//hide the menu
|
|
|
|
hide: function (trigger) {
|
|
|
|
if (this.shown) {
|
|
|
|
this.fx.start(0);
|
|
|
|
//this.menu.fade('out');
|
|
|
|
this.fireEvent('hide');
|
|
|
|
this.shown = false;
|
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
setItemChecked: function (item, checked) {
|
|
|
|
this.menu.getElement('a[href$=' + item + ']').firstChild.style.opacity =
|
|
|
|
checked ? '1' : '0';
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
getItemChecked: function (item) {
|
|
|
|
return '0' != this.menu.getElement('a[href$=' + item + ']').firstChild.style.opacity;
|
|
|
|
},
|
|
|
|
|
|
|
|
//hide an item
|
|
|
|
hideItem: function (item) {
|
|
|
|
this.menu.getElement('a[href$=' + item + ']').parentNode.addClass('invisible');
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
//show an item
|
|
|
|
showItem: function (item) {
|
|
|
|
this.menu.getElement('a[href$=' + item + ']').parentNode.removeClass('invisible');
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
//disable the entire menu
|
|
|
|
disable: function () {
|
|
|
|
this.options.disabled = true;
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
//enable the entire menu
|
|
|
|
enable: function () {
|
|
|
|
this.options.disabled = false;
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
//execute an action
|
|
|
|
execute: function (action, element) {
|
|
|
|
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,
|
|
|
|
|
2014-12-09 19:54:35 +03:00
|
|
|
updateMenuItems: function () {
|
|
|
|
all_are_seq_dl = true;
|
2014-12-09 21:03:14 +03:00
|
|
|
there_are_seq_dl = false;
|
2014-12-09 19:54:35 +03:00
|
|
|
all_are_f_l_piece_prio = true;
|
2014-12-09 21:03:14 +03:00
|
|
|
there_are_f_l_piece_prio = false;
|
2014-12-09 19:54:35 +03:00
|
|
|
all_are_downloaded = true;
|
2014-12-09 21:03:14 +03:00
|
|
|
all_are_paused = true;
|
|
|
|
there_are_paused = false;
|
2015-04-15 20:13:18 +03:00
|
|
|
all_are_force_start = true;
|
2015-07-14 04:06:34 +03:00
|
|
|
there_are_force_start = false;
|
|
|
|
all_are_super_seeding = true;
|
2014-12-09 19:54:35 +03:00
|
|
|
|
2015-11-11 22:58:30 +03:00
|
|
|
var h = torrentsTable.selectedRowsIds();
|
2014-12-09 19:54:35 +03:00
|
|
|
h.each(function(item, index){
|
2015-11-11 22:58:30 +03:00
|
|
|
var data = torrentsTable.rows.get(item).full_data;
|
2014-12-09 21:03:14 +03:00
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
if (data['seq_dl'] != true)
|
2014-12-09 19:54:35 +03:00
|
|
|
all_are_seq_dl = false;
|
2014-12-09 21:03:14 +03:00
|
|
|
else
|
|
|
|
there_are_seq_dl = true;
|
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
if (data['f_l_piece_prio'] != true)
|
2014-12-09 19:54:35 +03:00
|
|
|
all_are_f_l_piece_prio = false;
|
2014-12-09 21:03:14 +03:00
|
|
|
else
|
|
|
|
there_are_f_l_piece_prio = true;
|
|
|
|
|
2014-12-24 04:39:18 +03:00
|
|
|
if (data['progress'] != 1.0) // not downloaded
|
2014-12-09 19:54:35 +03:00
|
|
|
all_are_downloaded = false;
|
2015-01-30 23:58:27 +03:00
|
|
|
else if (data['super_seeding'] != true)
|
|
|
|
all_are_super_seeding = false;
|
2014-12-09 21:03:14 +03:00
|
|
|
|
2015-07-14 04:06:34 +03:00
|
|
|
if (data['state'] != 'pausedUP' && data['state'] != 'pausedDL')
|
2014-12-09 21:03:14 +03:00
|
|
|
all_are_paused = false;
|
|
|
|
else
|
|
|
|
there_are_paused = true;
|
2015-07-14 04:06:34 +03:00
|
|
|
|
|
|
|
if (data['force_start'] != true)
|
|
|
|
all_are_force_start = false;
|
|
|
|
else
|
|
|
|
there_are_force_start = true;
|
2014-12-09 19:54:35 +03:00
|
|
|
});
|
|
|
|
|
2014-12-09 21:03:14 +03:00
|
|
|
show_seq_dl = true;
|
|
|
|
|
|
|
|
if (!all_are_seq_dl && there_are_seq_dl)
|
|
|
|
show_seq_dl = false;
|
|
|
|
|
|
|
|
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) {
|
2016-01-10 12:11:54 +03:00
|
|
|
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');
|
2015-01-30 23:58:27 +03:00
|
|
|
this.showItem('SuperSeeding');
|
|
|
|
this.setItemChecked('SuperSeeding', all_are_super_seeding);
|
2014-12-09 19:54:35 +03:00
|
|
|
} else {
|
2014-12-09 21:03:14 +03:00
|
|
|
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);
|
2015-01-30 23:58:27 +03:00
|
|
|
|
2016-01-10 12:11:54 +03:00
|
|
|
this.showItem('DownloadLimit');
|
|
|
|
this.menu.getElement('a[href$=UploadLimit]').parentNode.removeClass('separator');
|
2015-01-30 23:58:27 +03:00
|
|
|
this.hideItem('SuperSeeding');
|
2014-12-09 19:54:35 +03:00
|
|
|
}
|
2014-12-09 21:03:14 +03:00
|
|
|
|
2015-07-14 04:06:34 +03:00
|
|
|
this.showItem('Start');
|
|
|
|
this.showItem('Pause');
|
|
|
|
this.showItem('ForceStart');
|
|
|
|
if (all_are_paused)
|
2014-12-09 21:03:14 +03:00
|
|
|
this.hideItem('Pause');
|
2015-07-14 04:06:34 +03:00
|
|
|
else if (all_are_force_start)
|
|
|
|
this.hideItem('ForceStart');
|
|
|
|
else if (!there_are_paused && !there_are_force_start)
|
|
|
|
this.hideItem('Start');
|
2015-01-30 23:58:27 +03:00
|
|
|
},
|
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
updateCategoriesSubMenu : function (category_list) {
|
|
|
|
var categoryList = $('contextCategoryList');
|
|
|
|
categoryList.empty();
|
2017-05-01 01:45:02 +03:00
|
|
|
categoryList.appendChild(new Element('li', {html: '<a href="javascript:torrentNewCategoryFN();"><img src="theme/list-add" alt="QBT_TR(New...)QBT_TR[CONTEXT=TransferListWidget]"/> QBT_TR(New...)QBT_TR[CONTEXT=TransferListWidget]</a>'}));
|
|
|
|
categoryList.appendChild(new Element('li', {html: '<a href="javascript:torrentSetCategoryFN(0);"><img src="theme/edit-clear" alt="QBT_TR(Reset)QBT_TR[CONTEXT=TransferListWidget]"/> QBT_TR(Reset)QBT_TR[CONTEXT=TransferListWidget]</a>'}));
|
2014-11-30 16:14:09 +03:00
|
|
|
|
2016-01-20 16:13:54 +03:00
|
|
|
var sortedCategories = []
|
|
|
|
Object.each(category_list, function (category) {
|
|
|
|
sortedCategories.push(category.name);
|
|
|
|
});
|
|
|
|
sortedCategories.sort();
|
|
|
|
|
|
|
|
var first = true;
|
|
|
|
Object.each(sortedCategories, function (categoryName) {
|
|
|
|
var categoryHash = genHash(categoryName);
|
2016-01-21 15:32:13 +03:00
|
|
|
var el = new Element('li', {html: '<a href="javascript:torrentSetCategoryFN(\'' + categoryHash + '\');"><img src="theme/inode-directory"/> ' + escapeHtml(categoryName) + '</a>'});
|
2016-01-20 16:13:54 +03:00
|
|
|
if (first) {
|
|
|
|
el.addClass('separator');
|
|
|
|
first = false;
|
|
|
|
}
|
|
|
|
categoryList.appendChild(el);
|
|
|
|
});
|
2014-11-30 16:14:09 +03:00
|
|
|
}
|
2015-07-14 04:06:34 +03:00
|
|
|
});
|
2016-01-20 22:57:42 +03:00
|
|
|
|
|
|
|
var CategoriesFilterContextMenu = new Class({
|
2016-01-21 16:42:20 +03:00
|
|
|
Extends: ContextMenu,
|
|
|
|
updateMenuItems: function () {
|
|
|
|
var id = this.options.element.id;
|
|
|
|
if (id != CATEGORIES_ALL && id != CATEGORIES_UNCATEGORIZED)
|
|
|
|
this.showItem('DeleteCategory');
|
|
|
|
else
|
|
|
|
this.hideItem('DeleteCategory');
|
|
|
|
}
|
2016-01-20 22:57:42 +03:00
|
|
|
});
|