mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-11 09:50:27 +00:00
Cancel non-ancestor popups when showing a new popup (#3490)
Addresses GH #3484 As far as I can tell, the popup level checks in this module are meant to handle nested popups. It seems to me that the goal is for at most a single hierarchy of popups to exist at any given time - bearing that in mind, this change checks any popups currently tracked by the module, canceling any that don't share an element hierarchy with the new popup.
This commit is contained in:
parent
2e7faf3439
commit
09ea59240a
@ -110,10 +110,32 @@ Popup.prototype.popupInfo = function(domNode) {
|
||||
Display a popup by adding it to the stack
|
||||
*/
|
||||
Popup.prototype.show = function(options) {
|
||||
// Find out what was clicked on
|
||||
var info = this.popupInfo(options.domNode);
|
||||
// Cancel any higher level popups
|
||||
this.cancel(info.popupLevel);
|
||||
var cancelLevel;
|
||||
// Cancel any popups who aren't an ancestor of the current node
|
||||
for(var t=0; t<this.popups.length; t++) {
|
||||
var popup = this.popups[t];
|
||||
|
||||
var node = options.domNode;
|
||||
var isFound = false;
|
||||
|
||||
while(node) {
|
||||
if(node == popup.domNode) {
|
||||
isFound = true;
|
||||
break;
|
||||
}
|
||||
node = node.parentNode;
|
||||
}
|
||||
|
||||
if(!isFound) {
|
||||
cancelLevel = t;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if(cancelLevel !== undefined) {
|
||||
this.cancel(cancelLevel);
|
||||
}
|
||||
|
||||
// Store the popup details if not already there
|
||||
if(!options.floating && this.findPopup(options.title) === -1) {
|
||||
this.popups.push({
|
||||
|
Loading…
Reference in New Issue
Block a user