1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_INSTALL_PROMPT_SHOW_PARAMS_H_
#define CHROME_BROWSER_EXTENSIONS_EXTENSION_INSTALL_PROMPT_SHOW_PARAMS_H_
#include <memory>
#include "base/memory/raw_ptr.h"
#include "base/memory/weak_ptr.h"
#include "extensions/buildflags/buildflags.h"
#include "ui/gfx/native_widget_types.h"
static_assert(BUILDFLAG(ENABLE_EXTENSIONS_CORE));
class Profile;
namespace content {
class WebContents;
}
namespace views {
class NativeWindowTracker;
}
// Parameters to show an install prompt dialog. The parameters control:
// - The dialog's parent window
// - The browser window to use to open a new tab if a user clicks a link in the
// dialog.
//
// This can either be created with a content::WebContents or a
// gfx::NativeWindow. If this is created for WebContents, GetParentWindow() will
// return the outermost window hosting the WebContents.
class ExtensionInstallPromptShowParams {
public:
explicit ExtensionInstallPromptShowParams(content::WebContents* web_contents);
// The most recently active browser window (or a new browser window if there
// are no browser windows) is used if a new tab needs to be opened.
ExtensionInstallPromptShowParams(Profile* profile, gfx::NativeWindow window);
ExtensionInstallPromptShowParams(const ExtensionInstallPromptShowParams&) =
delete;
ExtensionInstallPromptShowParams& operator=(
const ExtensionInstallPromptShowParams&) = delete;
virtual ~ExtensionInstallPromptShowParams();
Profile* profile() {
return profile_;
}
// The parent web contents for the dialog. Returns NULL if the web contents
// have been destroyed.
content::WebContents* GetParentWebContents();
// The parent window for the dialog. Returns NULL if the window has been
// destroyed.
gfx::NativeWindow GetParentWindow();
// Returns true if either the parent web contents or the parent window were
// destroyed.
bool WasParentDestroyed();
private:
// Returns trues if the current object was configured for WebContents.
bool WasConfiguredForWebContents();
raw_ptr<Profile, DanglingUntriaged> profile_;
// Only one of these will be non-null.
base::WeakPtr<content::WebContents> parent_web_contents_;
gfx::NativeWindow parent_window_;
#if !BUILDFLAG(IS_ANDROID)
// Used to track the parent_window_'s lifetime. We need to explicitly track it
// because aura::Window does not expose a WeakPtr like WebContents.
std::unique_ptr<views::NativeWindowTracker> native_window_tracker_;
#endif
};
namespace test {
// Unit test may use this to disable root window checking in
// ExtensionInstallPromptShowParams.
class ScopedDisableRootChecking {
public:
ScopedDisableRootChecking();
~ScopedDisableRootChecking();
};
} // namespace test
#endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_INSTALL_PROMPT_SHOW_PARAMS_H_
|