OLD | NEW |
(Empty) | |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef COMPONENTS_WEB_MODAL_POPUP_MANAGER_H_ |
| 6 #define COMPONENTS_WEB_MODAL_POPUP_MANAGER_H_ |
| 7 |
| 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/memory/weak_ptr.h" |
| 10 #include "components/web_modal/single_popup_manager.h" |
| 11 |
| 12 namespace content { |
| 13 class WebContents; |
| 14 } |
| 15 |
| 16 namespace gfx { |
| 17 class Size; |
| 18 } |
| 19 |
| 20 namespace web_modal { |
| 21 |
| 22 class WebContentsModalDialogHost; |
| 23 |
| 24 // Per-Browser class to manage popups (bubbles, web-modal dialogs). |
| 25 class PopupManager : public SinglePopupManagerDelegate { |
| 26 public: |
| 27 // |host| may be null. |
| 28 PopupManager(WebContentsModalDialogHost* host); |
| 29 |
| 30 virtual ~PopupManager(); |
| 31 |
| 32 // Returns the native view which will be the parent of managed popups. |
| 33 virtual gfx::NativeView GetHostView() const; |
| 34 |
| 35 // Schedules a popup governed by the |manager| to be shown. The popup |
| 36 // may be shown inline with this call, at a later time, or not at all. |
| 37 virtual void ShowPopup(scoped_ptr<SinglePopupManager> manager); |
| 38 |
| 39 // Temporary method: Provides compatibility with existing |
| 40 // WebContentsModalDialogManager code. |
| 41 virtual void ShowModalDialog(NativePopup popup, |
| 42 content::WebContents* web_contents); |
| 43 |
| 44 // Returns true if a web modal dialog is active and not closed in the |
| 45 // given |web_contents|. Note: this is intended for legacy use only; it will |
| 46 // be deleted at some point -- new code shouldn't use it. |
| 47 virtual bool IsWebModalDialogActive( |
| 48 const content::WebContents* web_contents) const; |
| 49 |
| 50 // Called when a NativePopup we own is about to be closed. |
| 51 virtual void WillClose(NativePopup popup) OVERRIDE; |
| 52 |
| 53 // Called by views code to re-activate popups anchored to a particular tab |
| 54 // when that tab gets focus. Note that depending on the situation, more than |
| 55 // one popup may actually be shown (depending on overlappability). The |
| 56 // semantics are that the popups that would have been displayed had the tab |
| 57 // never lost focus are re-focused when tab focus is regained. |
| 58 virtual void WasFocused(const content::WebContents* web_contents); |
| 59 |
| 60 // WebContentsUserData-alike API for retrieving the associated window |
| 61 // PopupManager from a |web_contents|. Any window which doesn't have a popup |
| 62 // manager associated will return null -- popups should not be issued against |
| 63 // that window. |
| 64 static PopupManager* FromWebContents(content::WebContents* web_contents); |
| 65 |
| 66 // Should not be called except by WebContents-owning class; not by clients. |
| 67 void RegisterWith(content::WebContents* web_contents); |
| 68 void UnregisterWith(content::WebContents* web_contents); |
| 69 |
| 70 // DEPRECATED. |
| 71 virtual void CloseAllDialogsForTesting(content::WebContents* web_contents); |
| 72 |
| 73 private: |
| 74 WebContentsModalDialogHost* host_; |
| 75 |
| 76 base::WeakPtrFactory<PopupManager> weak_factory_; |
| 77 |
| 78 DISALLOW_COPY_AND_ASSIGN(PopupManager); |
| 79 }; |
| 80 |
| 81 } // namespace web_modal |
| 82 |
| 83 #endif // COMPONENTS_WEB_MODAL_POPUP_MANAGER_H_ |
OLD | NEW |