summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch')
-rw-r--r--www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch249
1 files changed, 0 insertions, 249 deletions
diff --git a/www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch b/www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch
deleted file mode 100644
index 02140bd5e8f7..000000000000
--- a/www-client/seamonkey/files/seamonkey-2.53.10.2-ownertab.patch
+++ /dev/null
@@ -1,249 +0,0 @@
-# HG changeset patch
-# User Dmitry Butskoy <dmitry@butskoy.name>
-# Date 1628960364 -7200
-# Parent 45d5ea1452b1c406303ff3be289df08cde3d5a04
-Bug 1623054 - Set owner tab for proper tab focus handling after close. r=IanN a=IanN
-Upstream bug-report: https://bugzilla.mozilla.org/show_bug.cgi?id=1623054
-
-diff --git seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js
---- seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js
-+++ seamonkey-2.53.10.2/comm/suite/app/profile/suite-prefs.js
-@@ -224,16 +224,17 @@ pref("browser.tabs.autoHide", false);
- pref("browser.tabs.forceHide", false);
- pref("browser.tabs.closeWindowWithLastTab", true);
- pref("browser.tabs.warnOnClose", true);
- pref("browser.tabs.warnOnCloseOther", true);
- pref("browser.tabs.warnOnOpen", true);
- pref("browser.tabs.maxOpenBeforeWarn", 15);
- pref("browser.tabs.insertRelatedAfterCurrent", true);
- pref("browser.tabs.insertAllTabsAfterCurrent", false);
-+pref("browser.tabs.selectOwnerOnClose", true);
- pref("browser.tabs.avoidBrowserFocus", false);
-
- // For future use
- pref("browser.tabs.loadBookmarksInBackground", false);
-
- // how many browsers can be saved in the DOM (by the tabbed browser)
- pref("browser.tabs.max_tabs_undo", 3);
- // should popups by saved in the DOM (by the tabbed browser)
-diff --git seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js
---- seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js
-+++ seamonkey-2.53.10.2/comm/suite/base/content/utilityOverlay.js
-@@ -1637,16 +1637,17 @@ function openLinkIn(url, where, params)
- // fall through
- case "tab":
- var browser = w.getBrowser();
- var tab = browser.addTab(url, {
- referrerURI: aReferrerURI,
- referrerPolicy: aReferrerPolicy,
- charset: aCharset,
- postData: aPostData,
-+ ownerTab: loadInBackground ? null : browser.selectedTab,
- allowThirdPartyFixup: aAllowThirdPartyFixup,
- relatedToCurrent: aRelatedToCurrent,
- allowMixedContent: aAllowMixedContent,
- noReferrer: aNoReferrer,
- userContextId: aUserContextId,
- originPrincipal: aPrincipal,
- triggeringPrincipal: aTriggeringPrincipal,
- });
-diff --git seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml
---- seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml
-+++ seamonkey-2.53.10.2/comm/suite/browser/tabbrowser.xml
-@@ -1152,16 +1152,27 @@
- newBrowser.docShellIsActive = this.mCurrentTab.linkedBrowser.docShellIsActive;
- if (this.mCurrentBrowser) {
- this.mCurrentBrowser.droppedLinkHandler = null;
- this.mCurrentBrowser.docShellIsActive = false;
- this.mCurrentBrowser.removeAttribute("primary");
- this.finder.mListeners.forEach(l => this.mCurrentBrowser.finder.removeResultListener(l));
- }
-
-+ let oldTab = this.mCurrentTab;
-+
-+ // Preview mode should not reset the owner.
-+ if (!this._previewMode && !oldTab.selected)
-+ oldTab.owner = null;
-+
-+ let lastRelatedTab = this.mLastRelatedIndex ? this.tabs[this.mLastRelatedIndex] : null;
-+ if (lastRelatedTab && !lastRelatedTab.selected) {
-+ lastRelatedTab.owner = null;
-+ }
-+
- newBrowser.setAttribute("primary", "true");
- this.mCurrentBrowser = newBrowser;
- this.mCurrentTab = this.selectedTab;
- this.mCurrentTab.removeAttribute("unread");
- this.finder.mListeners.forEach(l => this.mCurrentBrowser.finder.addResultListener(l));
-
- var tabListener = this.mTabListeners[this.tabContainer.selectedIndex];
-
-@@ -1445,16 +1456,19 @@
- opener: null,
- };
- }
-
- params.focusNewTab = params.inBackground != null ?
- !params.inBackground :
- !Services.prefs.getBoolPref("browser.tabs.loadInBackground");
-
-+ if (params.focusNewTab)
-+ params.ownerTab = this.selectedTab;
-+
- return this.addTab(aURI, params);
- ]]>
- </body>
- </method>
-
- <method name="loadTabs">
- <parameter name="aURIs"/>
- <parameter name="aLoadInBackground"/>
-@@ -1556,43 +1570,49 @@
- <parameter name="aPostData"/>
- <parameter name="aFocusNewTab"/>
- <parameter name="aAllowThirdPartyFixup"/>
- <body>
- <![CDATA[
- var aTriggeringPrincipal;
- var aReferrerPolicy;
- var aFromExternal;
-+ var aOwner;
- var aRelatedToCurrent;
- var aAllowMixedContent;
- var aNoReferrer;
- var aUserContextId;
- var aOriginPrincipal;
- var aOpener;
- if (arguments.length == 2 &&
- arguments[1] != null &&
- typeof arguments[1] == "object" &&
- !(arguments[1] instanceof Ci.nsIURI)) {
- let params = arguments[1];
- aTriggeringPrincipal = params.triggeringPrincipal;
- aReferrerURI = params.referrerURI;
- aReferrerPolicy = params.referrerPolicy;
- aCharset = params.charset;
- aPostData = params.postData;
-+ aOwner = params.ownerTab;
- aFocusNewTab = params.focusNewTab;
- aAllowThirdPartyFixup = params.allowThirdPartyFixup;
- aFromExternal = params.fromExternal;
- aRelatedToCurrent = params.relatedToCurrent;
- aAllowMixedContent = params.allowMixedContent;
- aNoReferrer = params.noReferrer;
- aUserContextId = params.userContextId;
- aOriginPrincipal = params.originPrincipal;
- aOpener = params.opener;
- }
-
-+ // If we're adding tabs, we're past interrupt mode, ditch the owner.
-+ if (this.mCurrentTab.owner)
-+ this.mCurrentTab.owner = null;
-+
- this._browsers = null; // invalidate cache
-
- var t = this.referenceTab.cloneNode(true);
-
- var blank = !aURI || aURI == "about:blank";
-
- if (!blank)
- t.setAttribute("label", aURI);
-@@ -1650,16 +1670,20 @@
-
- // We start our browsers out as inactive.
- b.docShellIsActive = false;
-
- this.mStrip.collapsed = false;
-
- Services.prefs.setBoolPref("browser.tabs.forceHide", false);
-
-+ // If this new tab is owned by another, assert that relationship.
-+ if (aOwner)
-+ t.owner = aOwner;
-+
- // wire up a progress listener for the new browser object.
- var position = this.tabs.length - 1;
- var tabListener = this.mTabProgressListener(t, b, blank);
- const filter = Cc["@mozilla.org/appshell/component/browser-status-filter;1"]
- .createInstance(Ci.nsIWebProgress);
- filter.addProgressListener(tabListener, Ci.nsIWebProgress.NOTIFY_ALL);
- b.webProgress.addProgressListener(filter, Ci.nsIWebProgress.NOTIFY_ALL);
- this.mTabListeners[position] = tabListener;
-@@ -1699,16 +1723,20 @@
- // aReferrerURI is null or undefined if the tab is opened from
- // an external application or bookmark, i.e. somewhere other
- // than the current tab.
- if ((aRelatedToCurrent || aReferrerURI ||
- Services.prefs.getBoolPref("browser.tabs.insertAllTabsAfterCurrent")) &&
- Services.prefs.getBoolPref("browser.tabs.insertRelatedAfterCurrent")) {
- var lastRelatedIndex = this.mLastRelatedIndex ||
- this.tabContainer.selectedIndex;
-+ if (this.mLastRelatedIndex)
-+ this.tabs[this.mLastRelatedIndex].owner = null;
-+ else
-+ t.owner = this.selectedTab;
- this.moveTabTo(t, ++lastRelatedIndex);
- this.mLastRelatedIndex = lastRelatedIndex;
- }
-
- if (aFocusNewTab) {
- var parentTab = this.selectedTab;
- this.selectedTab = t;
- this.mPreviousTab = parentTab;
-@@ -2037,16 +2065,23 @@
- oldBrowser.webProgress.removeProgressListener(filter);
- filter.removeProgressListener(this.mTabListeners[index]);
- this.mTabFilters.splice(index, 1);
- this.mTabListeners.splice(index, 1);
-
- // We are no longer the primary content area
- oldBrowser.removeAttribute("primary");
-
-+ // Remove this tab as the owner of any other tabs, since it's going away.
-+ for (let tab of this.tabs) {
-+ if ("owner" in tab && tab.owner == aTab)
-+ // |tab| is a child of the tab we're removing, make it an orphan.
-+ tab.owner = null;
-+ }
-+
- // Now select the new tab before nuking the old one.
- var currentIndex = this.tabContainer.selectedIndex;
-
- var newIndex = -1;
- if (currentIndex > index)
- newIndex = currentIndex - 1;
- else if (currentIndex < index)
- newIndex = currentIndex;
-@@ -2057,23 +2092,30 @@
-
- if (oldBrowser == this.mCurrentBrowser)
- this.mCurrentBrowser = null;
-
- // Invalidate browsers cache, as the tab is removed from the
- // tab container.
- this._browsers = null;
-
-- // Clean up before/afterselected attributes before removing the tab
-+ let owner = ("owner" in aTab) ? aTab.owner : null;
-+
-+ // Clean up before/after selected attributes before removing the
-+ // tab.
- aTab._selected = false;
- aTab.remove();
-
- // When the current tab is removed select a new tab
- // and fire select events on tabpanels and tabs
-- if (this.mPreviousTab && (aTab == this.mCurrentTab))
-+ if (owner && !owner.hidden && !owner.closing &&
-+ Services.prefs.getBoolPref("browser.tabs.selectOwnerOnClose")) {
-+ this.selectedTab = owner;
-+ }
-+ else if (this.mPreviousTab && (aTab == this.mCurrentTab))
- this.selectedTab = this.mPreviousTab;
- else {
- this.tabContainer.selectedIndex = newIndex;
-
- // We need to explicitly clear this, because updateCurrentBrowser
- // doesn't get called for a background tab
- this.mPreviousTab = null;
- }