// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef COMPONENTS_WEB_MODAL_POPUP_MANAGER_H_ #define COMPONENTS_WEB_MODAL_POPUP_MANAGER_H_ #include "base/memory/scoped_ptr.h" #include "base/memory/weak_ptr.h" #include "components/web_modal/single_popup_manager.h" namespace content { class WebContents; } namespace gfx { class Size; } namespace web_modal { class WebContentsModalDialogHost; // Per-Browser class to manage popups (bubbles, web-modal dialogs). class PopupManager : public SinglePopupManagerDelegate { public: // |host| may be null. PopupManager(WebContentsModalDialogHost* host); ~PopupManager() override; // Returns the native view which will be the parent of managed popups. virtual gfx::NativeView GetHostView() const; // Schedules a popup governed by the |manager| to be shown. The popup // may be shown inline with this call, at a later time, or not at all. virtual void ShowPopup(scoped_ptr manager); // Temporary method: Provides compatibility with existing // WebContentsModalDialogManager code. virtual void ShowModalDialog(gfx::NativeWindow popup, content::WebContents* web_contents); // Returns true if a web modal dialog is active and not closed in the // given |web_contents|. Note: this is intended for legacy use only; it will // be deleted at some point -- new code shouldn't use it. virtual bool IsWebModalDialogActive( const content::WebContents* web_contents) const; // Called when a native popup we own is about to be closed. void WillClose(gfx::NativeWindow popup) override; // Called by views code to re-activate popups anchored to a particular tab // when that tab gets focus. Note that depending on the situation, more than // one popup may actually be shown (depending on overlappability). The // semantics are that the popups that would have been displayed had the tab // never lost focus are re-focused when tab focus is regained. virtual void WasFocused(const content::WebContents* web_contents); // WebContentsUserData-alike API for retrieving the associated window // PopupManager from a |web_contents|. Any window which doesn't have a popup // manager associated will return null -- popups should not be issued against // that window. static PopupManager* FromWebContents(content::WebContents* web_contents); // Should not be called except by WebContents-owning class; not by clients. void RegisterWith(content::WebContents* web_contents); void UnregisterWith(content::WebContents* web_contents); // DEPRECATED. virtual void CloseAllDialogsForTesting(content::WebContents* web_contents); private: WebContentsModalDialogHost* host_; base::WeakPtrFactory weak_factory_; DISALLOW_COPY_AND_ASSIGN(PopupManager); }; } // namespace web_modal #endif // COMPONENTS_WEB_MODAL_POPUP_MANAGER_H_