Browse Source

Merge pull request #10931 from Piccirello/webui-mobile-longpress

Add WebUI support for triggering context menus on mobile
adaptive-webui-19844
Mike Tzou 5 years ago committed by GitHub
parent
commit
937c5be4a9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 80
      src/webui/www/private/scripts/contextmenu.js
  2. 7
      src/webui/www/private/scripts/dynamicTable.js

80
src/webui/www/private/scripts/contextmenu.js

@ -39,7 +39,6 @@ var ContextMenu = new Class({
menu: 'menu_id', menu: 'menu_id',
stopEvent: true, stopEvent: true,
targets: 'body', targets: 'body',
trigger: 'contextmenu',
offsets: { offsets: {
x: 0, x: 0,
y: 0 y: 0
@ -47,7 +46,8 @@ var ContextMenu = new Class({
onShow: $empty, onShow: $empty,
onHide: $empty, onHide: $empty,
onClick: $empty, onClick: $empty,
fadeSpeed: 200 fadeSpeed: 200,
touchTimer: 600
}, },
//initialization //initialization
@ -142,50 +142,56 @@ var ContextMenu = new Class({
} }
}, },
addTarget: function(t) { setupEventListeners: function(elem) {
this.targets[this.targets.length] = t; elem.addEvent('contextmenu', function(e) {
t.addEvent(this.options.trigger, function(e) { this.triggerMenu(e, elem);
//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);
this.adjustMenuPosition(e);
//show the menu
this.show();
}
}.bind(this)); }.bind(this));
t.addEvent('click', function(e) { elem.addEvent('click', function(e) {
this.hide(); this.hide();
}.bind(this)); }.bind(this));
elem.addEvent('touchstart', function(e) {
e.preventDefault();
clearTimeout(this.touchstartTimer);
this.hide();
const touchstartEvent = e;
this.touchstartTimer = setTimeout(function() {
this.triggerMenu(touchstartEvent, elem);
}.bind(this), this.options.touchTimer);
}.bind(this));
elem.addEvent('touchend', function(e) {
e.preventDefault();
clearTimeout(this.touchstartTimer);
}.bind(this));
},
addTarget: function(t) {
this.targets[this.targets.length] = t;
this.setupEventListeners(t);
},
triggerMenu: function(e, el) {
if (this.options.disabled)
return;
//prevent default, if told to
if (this.options.stopEvent) {
e.stop();
}
//record this as the trigger
this.options.element = $(el);
this.adjustMenuPosition(e);
//show the menu
this.show();
}, },
//get things started //get things started
startListener: function() { startListener: function() {
/* all elements */ /* all elements */
this.targets.each(function(el) { this.targets.each(function(el) {
/* show the menu */ this.setupEventListeners(el);
el.addEvent(this.options.trigger, function(e) { }.bind(this), this);
//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);
this.adjustMenuPosition(e);
//show the menu
this.show();
}
}.bind(this));
el.addEvent('click', function(e) {
this.hide();
}.bind(this));
}, this);
/* menu items */ /* menu items */
this.menu.getElements('a').each(function(item) { this.menu.getElements('a').each(function(item) {

7
src/webui/www/private/scripts/dynamicTable.js

@ -706,6 +706,13 @@ var DynamicTable = new Class({
} }
return false; return false;
}); });
tr.addEvent('touchstart', function(e) {
if (!this._this.isRowSelected(this.rowId)) {
this._this.deselectAll();
this._this.selectRow(this.rowId);
}
return false;
});
this.setupTr(tr); this.setupTr(tr);

Loading…
Cancel
Save