1 /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* vim: set ts=8 sts=2 et sw=2 tw=80: */
3 /* This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
7 #ifndef nsDocShellTreeOwner_h__
8 #define nsDocShellTreeOwner_h__
15 #include "nsIBaseWindow.h"
16 #include "nsIDocShellTreeOwner.h"
17 #include "nsIInterfaceRequestor.h"
18 #include "nsIInterfaceRequestorUtils.h"
19 #include "nsIWebBrowserChrome.h"
20 #include "nsIDOMEventListener.h"
21 #include "nsIEmbeddingSiteWindow.h"
22 #include "nsIWebProgressListener.h"
23 #include "nsWeakReference.h"
25 #include "nsIPrompt.h"
26 #include "nsIAuthPrompt.h"
27 #include "nsITooltipTextProvider.h"
28 #include "nsCTooltipTextProvider.h"
35 } // namespace mozilla
37 class nsIDocShellTreeItem
;
39 class ChromeTooltipListener
;
41 class nsDocShellTreeOwner final
: public nsIDocShellTreeOwner
,
43 public nsIInterfaceRequestor
,
44 public nsIWebProgressListener
,
45 public nsIDOMEventListener
,
46 public nsSupportsWeakReference
{
47 friend class nsWebBrowser
;
53 NS_DECL_NSIDOCSHELLTREEOWNER
54 NS_DECL_NSIDOMEVENTLISTENER
55 NS_DECL_NSIINTERFACEREQUESTOR
56 NS_DECL_NSIWEBPROGRESSLISTENER
59 nsDocShellTreeOwner();
60 virtual ~nsDocShellTreeOwner();
62 void WebBrowser(nsWebBrowser
* aWebBrowser
);
64 nsWebBrowser
* WebBrowser();
65 NS_IMETHOD
SetTreeOwner(nsIDocShellTreeOwner
* aTreeOwner
);
66 NS_IMETHOD
SetWebBrowserChrome(nsIWebBrowserChrome
* aWebBrowserChrome
);
68 NS_IMETHOD
AddChromeListeners();
69 NS_IMETHOD
RemoveChromeListeners();
71 void EnsurePrompter();
72 void EnsureAuthPrompter();
75 void RemoveFromWatcher();
77 void EnsureContentTreeOwner();
79 // These helper functions return the correct instances of the requested
80 // interfaces. If the object passed to SetWebBrowserChrome() implements
81 // nsISupportsWeakReference, then these functions call QueryReferent on
82 // that object. Otherwise, they return an addrefed pointer. If the
83 // WebBrowserChrome object doesn't exist, they return nullptr.
84 already_AddRefed
<nsIWebBrowserChrome
> GetWebBrowserChrome();
85 already_AddRefed
<nsIEmbeddingSiteWindow
> GetOwnerWin();
86 already_AddRefed
<nsIInterfaceRequestor
> GetOwnerRequestor();
90 nsWebBrowser
* mWebBrowser
;
91 nsIDocShellTreeOwner
* mTreeOwner
;
92 nsIDocShellTreeItem
* mPrimaryContentShell
;
94 nsIWebBrowserChrome
* mWebBrowserChrome
;
95 nsIEmbeddingSiteWindow
* mOwnerWin
;
96 nsIInterfaceRequestor
* mOwnerRequestor
;
98 nsWeakPtr mWebBrowserChromeWeak
; // nsIWebBrowserChrome
100 // the objects that listen for chrome events like context menus and tooltips.
101 // They are separate objects to avoid circular references between |this|
103 RefPtr
<ChromeTooltipListener
> mChromeTooltipListener
;
105 RefPtr
<nsDocShellTreeOwner
> mContentTreeOwner
;
107 nsCOMPtr
<nsIPrompt
> mPrompter
;
108 nsCOMPtr
<nsIAuthPrompt
> mAuthPrompter
;
109 nsCOMPtr
<nsIRemoteTab
> mPrimaryRemoteTab
;
112 #endif /* nsDocShellTreeOwner_h__ */