window.open()で開かれたタブを親子関係に組み入れるようにした

git-svn-id: http://www.cozmixng.org/repos/piro/treestyletab/trunk@1218 599a83e7-65a4-db11-8015-0010dcdd6dc2
This commit is contained in:
piro 2007-10-17 16:07:43 +00:00
parent 33de904ff8
commit a1622ea528
5 changed files with 62 additions and 9 deletions

View File

@ -15,24 +15,24 @@
<prefpane id="prefpane-general" label="&config.tabs.general;"> <prefpane id="prefpane-general" label="&config.tabs.general;">
<preferences> <preferences>
<preference id="extensions.treestyletab." <preference id="browser.link.open_newwindow.restriction"
name="extensions.treestyletab." name="browser.link.open_newwindow.restriction"
type="int"/> type="int"/>
</preferences> </preferences>
<groupbox> <groupbox>
<caption label="&config..caption;"/> <caption label="&config.jsopen.caption;"/>
<vbox> <vbox>
<radiogroup id="extensions.treestyletab.-radiogroup" <radiogroup id="browser.link.open_newwindow.restriction-radiogroup"
preference="extensions.treestyletab." preference="browser.link.open_newwindow.restriction"
orient="vertical"> orient="vertical">
<radio value="0" label="&config..default;"/> <radio value="2" label="&config.jsopen.default;"/>
<radio value="1" label="&config..;"/> <radio value="0" label="&config.jsopen.forcetab;"/>
<radio value="2" label="&config..;"/>
</radiogroup> </radiogroup>
</vbox> </vbox>
</groupbox> </groupbox>
</prefpane> </prefpane>
<!--
<prefpane id="prefpane-selection-menu" label="&config.tabs.selectionMenu;"> <prefpane id="prefpane-selection-menu" label="&config.tabs.selectionMenu;">
<preferences id="prefpane-selection-menu-preferences"> <preferences id="prefpane-selection-menu-preferences">
<preference id="extensions.treestyletab." <preference id="extensions.treestyletab."
@ -48,6 +48,7 @@
</vbox> </vbox>
</groupbox> </groupbox>
</prefpane> </prefpane>
-->
</prefwindow> </prefwindow>

View File

@ -4,7 +4,7 @@ var TreeStyleTabService = {
kID : 'treestyletab-id', kID : 'treestyletab-id',
kCHILDREN : 'treestyletab-children', kCHILDREN : 'treestyletab-children',
levelMargin : 16, levelMargin : 12,
NSResolver : { NSResolver : {
lookupNamespaceURI : function(aPrefix) lookupNamespaceURI : function(aPrefix)
@ -78,8 +78,26 @@ var TreeStyleTabService = {
return (target.localName == 'tab') ? target : null ; return (target.localName == 'tab') ? target : null ;
}, },
getTabFromFrame : function(aFrame, aTabBrowser)
{
var b = aTabBrowser || this.browser;
var docShell = aFrame.top
.QueryInterface(Components.interfaces.nsIInterfaceRequestor)
.getInterface(Components.interfaces.nsIWebNavigation)
.QueryInterface(Components.interfaces.nsIDocShell);
var tabs = b.mTabContainer.childNodes;
for (var i = 0, maxi = tabs.length; i < maxi; i++)
{
if (tabs[i].linkedBrowser.docShell == docShell)
return tabs[i];
}
return null;
},
getTabBrowserFromChildren : function(aTab) getTabBrowserFromChildren : function(aTab)
{ {
if (!aTab) return null;
if (aTab.__treestyletab__linkedTabBrowser) if (aTab.__treestyletab__linkedTabBrowser)
return aTab.__treestyletab__linkedTabBrowser; return aTab.__treestyletab__linkedTabBrowser;
@ -180,6 +198,27 @@ var TreeStyleTabService = {
this.addPrefListener(this); this.addPrefListener(this);
this.observe(null, 'nsPref:changed', 'extensions.treestyletab.'); this.observe(null, 'nsPref:changed', 'extensions.treestyletab.');
eval('window.nsBrowserAccess.prototype.openURI = '+
window.nsBrowserAccess.prototype.openURI.toSource().replace(
/switch\s*\(aWhere\)/,
<><![CDATA[
if (aOpener &&
aWhere == Components.interfaces.nsIBrowserDOMWindow.OPEN_NEWTAB) {
var ownerBrowser = ('SplitBrowser' in window) ? TreeStyleTabService.getTabBrowserFromChildren(SplitBrowser.getSubBrowserAndBrowserFromFrame(aOpener.top).browser) : gBrowser ;
var parentTab = TreeStyleTabService.getTabFromFrame(aOpener, ownerBrowser);
ownerBrowser.__treestyletab__readyToAdoptNewTab = true;
ownerBrowser.__treestyletab__parentTab = parentTab.getAttribute(TreeStyleTabService.kID);
}
switch(aWhere)
]]></>
)
);
window.QueryInterface(Components.interfaces.nsIDOMChromeWindow).browserDOMWindow = null;
window.QueryInterface(Components.interfaces.nsIDOMChromeWindow).browserDOMWindow = new nsBrowserAccess();
this.initTabBrowser(gBrowser); this.initTabBrowser(gBrowser);
}, },
@ -261,6 +300,8 @@ var TreeStyleTabService = {
this.destroyTabBrowser(gBrowser); this.destroyTabBrowser(gBrowser);
window.removeEventListener('unload', this, false); window.removeEventListener('unload', this, false);
var appcontent = document.getElementById('appcontent');
appcontent.removeEventListener('SubBrowserAdded', this, false); appcontent.removeEventListener('SubBrowserAdded', this, false);
appcontent.removeEventListener('SubBrowserRemoveRequest', this, false); appcontent.removeEventListener('SubBrowserRemoveRequest', this, false);

View File

@ -1,2 +1,5 @@
pref("browser.link.open_newwindow.restriction", 0);
pref("extensions.treestyletab@piro.sakura.ne.jp.name", "chrome://treestyletab/locale/treestyletab.properties"); pref("extensions.treestyletab@piro.sakura.ne.jp.name", "chrome://treestyletab/locale/treestyletab.properties");
pref("extensions.treestyletab@piro.sakura.ne.jp.description", "chrome://treestyletab/locale/treestyletab.properties"); pref("extensions.treestyletab@piro.sakura.ne.jp.description", "chrome://treestyletab/locale/treestyletab.properties");

View File

@ -2,3 +2,7 @@
<!ENTITY config.tabs.general "General"> <!ENTITY config.tabs.general "General">
<!ENTITY config.jsopen.caption "New Window opened from Scripts in Webpages">
<!ENTITY config.jsopen.default "Open as Window when it have special width, height, etc. (default)">
<!ENTITY config.jsopen.forcetab "Open as Tab instead of Window anyway">

View File

@ -1,3 +1,7 @@
<!ENTITY config.title "ツリー型タブの設定"> <!ENTITY config.title "ツリー型タブの設定">
<!ENTITY config.tabs.general "全般"> <!ENTITY config.tabs.general "全般">
<!ENTITY config.jsopen.caption "スクリプトで開かれるウィンドウの制御">
<!ENTITY config.jsopen.default "大きさや位置を指定されたウィンドウはウィンドウとして開く(初期値)">
<!ENTITY config.jsopen.forcetab "スクリプトで開かれるウィンドウはすべてタブで開く">