OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_UI_EXTENSIONS_APPLICATION_LAUNCH_H_ | 5 #ifndef CHROME_BROWSER_UI_EXTENSIONS_APPLICATION_LAUNCH_H_ |
6 #define CHROME_BROWSER_UI_EXTENSIONS_APPLICATION_LAUNCH_H_ | 6 #define CHROME_BROWSER_UI_EXTENSIONS_APPLICATION_LAUNCH_H_ |
7 | 7 |
8 #include "base/command_line.h" | 8 #include "chrome/browser/ui/extensions/app_launch_params.h" |
9 #include "base/files/file_path.h" | |
10 #include "chrome/browser/ui/host_desktop.h" | |
11 #include "chrome/common/extensions/extension_constants.h" | |
12 #include "ui/base/window_open_disposition.h" | |
13 #include "ui/gfx/rect.h" | |
14 #include "url/gurl.h" | 9 #include "url/gurl.h" |
15 | 10 |
16 class Browser; | |
17 class Profile; | 11 class Profile; |
18 | 12 |
19 namespace base { | |
20 class CommandLine; | |
21 } | |
22 | |
23 namespace content { | 13 namespace content { |
24 class WebContents; | 14 class WebContents; |
25 } | 15 } |
26 | 16 |
27 namespace extensions { | 17 namespace extensions { |
28 class Extension; | 18 class Extension; |
29 } | 19 } |
30 | 20 |
31 struct AppLaunchParams { | |
32 AppLaunchParams(Profile* profile, | |
33 const extensions::Extension* extension, | |
34 extensions::LaunchContainer container, | |
35 WindowOpenDisposition disposition); | |
36 | |
37 // Helper to create AppLaunchParams using extensions::GetLaunchContainer with | |
38 // LAUNCH_TYPE_REGULAR to check for a user-configured container. | |
39 AppLaunchParams(Profile* profile, | |
40 const extensions::Extension* extension, | |
41 WindowOpenDisposition disposition); | |
42 | |
43 // Helper to create AppLaunchParams using event flags that allows user to | |
44 // override the user-configured container using modifier keys, falling back to | |
45 // extensions::GetLaunchContainer() with no modifiers. |desktop_type| | |
46 // indicates the desktop upon which to launch (Ash or Native). | |
47 AppLaunchParams(Profile* profile, | |
48 const extensions::Extension* extension, | |
49 int event_flags, | |
50 chrome::HostDesktopType desktop_type); | |
51 | |
52 ~AppLaunchParams(); | |
53 | |
54 // The profile to load the application from. | |
55 Profile* profile; | |
56 | |
57 // The extension to load. | |
58 std::string extension_id; | |
59 | |
60 // The container type to launch the application in. | |
61 extensions::LaunchContainer container; | |
62 | |
63 // If container is TAB, this field controls how the tab is opened. | |
64 WindowOpenDisposition disposition; | |
65 | |
66 // The desktop type to launch on. Uses GetActiveDesktop() if unspecified. | |
67 chrome::HostDesktopType desktop_type; | |
68 | |
69 // If non-empty, use override_url in place of the application's launch url. | |
70 GURL override_url; | |
71 | |
72 // If non-empty, use override_boudns in place of the application's default | |
73 // position and dimensions. | |
74 gfx::Rect override_bounds; | |
75 | |
76 // If non-empty, information from the command line may be passed on to the | |
77 // application. | |
78 base::CommandLine command_line; | |
79 | |
80 // If non-empty, the current directory from which any relative paths on the | |
81 // command line should be expanded from. | |
82 base::FilePath current_directory; | |
83 }; | |
84 | |
85 // Opens the application, possibly prompting the user to re-enable it. | 21 // Opens the application, possibly prompting the user to re-enable it. |
86 void OpenApplicationWithReenablePrompt(const AppLaunchParams& params); | 22 void OpenApplicationWithReenablePrompt(const AppLaunchParams& params); |
87 | 23 |
88 // Open the application in a way specified by |params|. | 24 // Open the application in a way specified by |params|. |
89 content::WebContents* OpenApplication(const AppLaunchParams& params); | 25 content::WebContents* OpenApplication(const AppLaunchParams& params); |
90 | 26 |
91 // Open |url| in an app shortcut window. | 27 // Open |url| in an app shortcut window. |
92 // There are two kinds of app shortcuts: Shortcuts to a URL, | 28 // There are two kinds of app shortcuts: Shortcuts to a URL, |
93 // and shortcuts that open an installed application. This function | 29 // and shortcuts that open an installed application. This function |
94 // is used to open the former. To open the latter, use | 30 // is used to open the former. To open the latter, use |
95 // application_launch::OpenApplication(). | 31 // application_launch::OpenApplication(). |
96 content::WebContents* OpenAppShortcutWindow(Profile* profile, | 32 content::WebContents* OpenAppShortcutWindow(Profile* profile, |
97 const GURL& url); | 33 const GURL& url); |
98 | 34 |
99 // Whether the extension can be launched by sending a | 35 // Whether the extension can be launched by sending a |
100 // chrome.app.runtime.onLaunched event. | 36 // chrome.app.runtime.onLaunched event. |
101 bool CanLaunchViaEvent(const extensions::Extension* extension); | 37 bool CanLaunchViaEvent(const extensions::Extension* extension); |
102 | 38 |
103 // Get the launch URL for a given extension, with optional override/fallback. | |
104 // |override_url|, if non-empty, will be preferred over the extension's | |
105 // launch url. | |
106 GURL UrlForExtension(const extensions::Extension* extension, | |
107 const GURL& override_url); | |
108 | |
109 #endif // CHROME_BROWSER_UI_EXTENSIONS_APPLICATION_LAUNCH_H_ | 39 #endif // CHROME_BROWSER_UI_EXTENSIONS_APPLICATION_LAUNCH_H_ |
OLD | NEW |