Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(93)

Side by Side Diff: chrome/browser/ui/ash/launcher/app_shortcut_launcher_item_controller.cc

Issue 22887015: Remove PerBrowser launcher (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix nit Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 #include "chrome/browser/ui/ash/launcher/app_shortcut_launcher_item_controller.h " 5 #include "chrome/browser/ui/ash/launcher/app_shortcut_launcher_item_controller.h "
6 6
7 #include "apps/native_app_window.h" 7 #include "apps/native_app_window.h"
8 #include "ash/wm/window_util.h" 8 #include "ash/wm/window_util.h"
9 #include "chrome/browser/extensions/extension_process_manager.h" 9 #include "chrome/browser/extensions/extension_process_manager.h"
10 #include "chrome/browser/extensions/extension_system.h" 10 #include "chrome/browser/extensions/extension_system.h"
11 #include "chrome/browser/favicon/favicon_tab_helper.h" 11 #include "chrome/browser/favicon/favicon_tab_helper.h"
12 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item.h" 12 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item.h"
13 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item_tab.h" 13 #include "chrome/browser/ui/ash/launcher/chrome_launcher_app_menu_item_tab.h"
14 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h" 14 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h"
15 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller_per_app.h"
16 #include "chrome/browser/ui/ash/launcher/launcher_item_controller.h" 15 #include "chrome/browser/ui/ash/launcher/launcher_item_controller.h"
17 #include "chrome/browser/ui/browser.h" 16 #include "chrome/browser/ui/browser.h"
18 #include "chrome/browser/ui/browser_finder.h" 17 #include "chrome/browser/ui/browser_finder.h"
19 #include "chrome/browser/ui/browser_list.h" 18 #include "chrome/browser/ui/browser_list.h"
20 #include "chrome/browser/ui/browser_window.h" 19 #include "chrome/browser/ui/browser_window.h"
21 #include "chrome/browser/ui/host_desktop.h" 20 #include "chrome/browser/ui/host_desktop.h"
22 #include "chrome/browser/ui/tabs/tab_strip_model.h" 21 #include "chrome/browser/ui/tabs/tab_strip_model.h"
23 #include "chrome/common/extensions/manifest_handlers/app_launch_info.h" 22 #include "chrome/common/extensions/manifest_handlers/app_launch_info.h"
24 #include "content/public/browser/web_contents.h" 23 #include "content/public/browser/web_contents.h"
25 #include "ui/aura/window.h" 24 #include "ui/aura/window.h"
26 #include "ui/base/events/event.h" 25 #include "ui/base/events/event.h"
27 #include "ui/views/corewm/window_animations.h" 26 #include "ui/views/corewm/window_animations.h"
28 27
29 using extensions::Extension; 28 using extensions::Extension;
30 29
31 namespace { 30 namespace {
32 31
33 // The time delta between clicks in which clicks to launch V2 apps are ignored. 32 // The time delta between clicks in which clicks to launch V2 apps are ignored.
34 const int kClickSuppressionInMS = 1000; 33 const int kClickSuppressionInMS = 1000;
35 34
36 } // namespace 35 } // namespace
37 36
38 // Item controller for an app shortcut. Shortcuts track app and launcher ids, 37 // Item controller for an app shortcut. Shortcuts track app and launcher ids,
39 // but do not have any associated windows (opening a shortcut will replace the 38 // but do not have any associated windows (opening a shortcut will replace the
40 // item with the appropriate LauncherItemController type). 39 // item with the appropriate LauncherItemController type).
41 AppShortcutLauncherItemController::AppShortcutLauncherItemController( 40 AppShortcutLauncherItemController::AppShortcutLauncherItemController(
42 const std::string& app_id, 41 const std::string& app_id,
43 ChromeLauncherControllerPerApp* controller) 42 ChromeLauncherController* controller)
44 : LauncherItemController(TYPE_SHORTCUT, app_id, controller), 43 : LauncherItemController(TYPE_SHORTCUT, app_id, controller),
45 app_controller_(controller) { 44 chrome_launcher_controller_(controller) {
46 // To detect V1 applications we use their domain and match them against the 45 // To detect V1 applications we use their domain and match them against the
47 // used URL. This will also work with applications like Google Drive. 46 // used URL. This will also work with applications like Google Drive.
48 const Extension* extension = 47 const Extension* extension =
49 launcher_controller()->GetExtensionForAppID(app_id); 48 launcher_controller()->GetExtensionForAppID(app_id);
50 // Some unit tests have no real extension. 49 // Some unit tests have no real extension.
51 if (extension) { 50 if (extension) {
52 set_refocus_url(GURL( 51 set_refocus_url(GURL(
53 extensions::AppLaunchInfo::GetLaunchWebURL(extension).spec() + "*")); 52 extensions::AppLaunchInfo::GetLaunchWebURL(extension).spec() + "*"));
54 } 53 }
55 } 54 }
56 55
57 AppShortcutLauncherItemController::~AppShortcutLauncherItemController() { 56 AppShortcutLauncherItemController::~AppShortcutLauncherItemController() {
58 } 57 }
59 58
60 string16 AppShortcutLauncherItemController::GetTitle() { 59 string16 AppShortcutLauncherItemController::GetTitle() {
61 return GetAppTitle(); 60 return GetAppTitle();
62 } 61 }
63 62
64 bool AppShortcutLauncherItemController::IsCurrentlyShownInWindow( 63 bool AppShortcutLauncherItemController::IsCurrentlyShownInWindow(
65 aura::Window* window) const { 64 aura::Window* window) const {
66 Browser* browser = chrome::FindBrowserWithWindow(window); 65 Browser* browser = chrome::FindBrowserWithWindow(window);
67 content::WebContents* active_content_of_window = 66 content::WebContents* active_content_of_window =
68 browser ? browser->tab_strip_model()->GetActiveWebContents() : NULL; 67 browser ? browser->tab_strip_model()->GetActiveWebContents() : NULL;
69 68
70 std::vector<content::WebContents*> content = 69 std::vector<content::WebContents*> content =
71 app_controller_->GetV1ApplicationsFromAppId(app_id()); 70 chrome_launcher_controller_->GetV1ApplicationsFromAppId(app_id());
72 71
73 std::vector<content::WebContents*>::const_iterator iter = 72 std::vector<content::WebContents*>::const_iterator iter =
74 std::find(content.begin(), content.end(), active_content_of_window); 73 std::find(content.begin(), content.end(), active_content_of_window);
75 74
76 return iter != content.end() ? true : false; 75 return iter != content.end() ? true : false;
77 } 76 }
78 77
79 bool AppShortcutLauncherItemController::IsOpen() const { 78 bool AppShortcutLauncherItemController::IsOpen() const {
80 return !app_controller_->GetV1ApplicationsFromAppId(app_id()).empty(); 79 return !chrome_launcher_controller_->
80 GetV1ApplicationsFromAppId(app_id()).empty();
81 } 81 }
82 82
83 bool AppShortcutLauncherItemController::IsVisible() const { 83 bool AppShortcutLauncherItemController::IsVisible() const {
84 // Return true if any browser window associated with the app is visible. 84 // Return true if any browser window associated with the app is visible.
85 std::vector<content::WebContents*> content = 85 std::vector<content::WebContents*> content =
86 app_controller_->GetV1ApplicationsFromAppId(app_id()); 86 chrome_launcher_controller_->GetV1ApplicationsFromAppId(app_id());
87 for (size_t i = 0; i < content.size(); i++) { 87 for (size_t i = 0; i < content.size(); i++) {
88 Browser* browser = chrome::FindBrowserWithWebContents(content[i]); 88 Browser* browser = chrome::FindBrowserWithWebContents(content[i]);
89 if (browser && browser->window()->GetNativeWindow()->IsVisible()) 89 if (browser && browser->window()->GetNativeWindow()->IsVisible())
90 return true; 90 return true;
91 } 91 }
92 return false; 92 return false;
93 } 93 }
94 94
95 void AppShortcutLauncherItemController::Launch(int event_flags) { 95 void AppShortcutLauncherItemController::Launch(int event_flags) {
96 app_controller_->LaunchApp(app_id(), event_flags); 96 launcher_controller()->LaunchApp(app_id(), event_flags);
97 } 97 }
98 98
99 void AppShortcutLauncherItemController::Activate() { 99 void AppShortcutLauncherItemController::Activate() {
100 content::WebContents* content = GetLRUApplication(); 100 content::WebContents* content = GetLRUApplication();
101 if (!content) { 101 if (!content) {
102 if (IsV2App()) { 102 if (IsV2App()) {
103 // Ideally we come here only once. After that ShellLauncherItemController 103 // Ideally we come here only once. After that ShellLauncherItemController
104 // will take over when the shell window gets opened. However there are 104 // will take over when the shell window gets opened. However there are
105 // apps which take a lot of time for pre-processing (like the files app) 105 // apps which take a lot of time for pre-processing (like the files app)
106 // before they open a window. Since there is currently no other way to 106 // before they open a window. Since there is currently no other way to
107 // detect if an app was started we suppress any further clicks within a 107 // detect if an app was started we suppress any further clicks within a
108 // special time out. 108 // special time out.
109 if (!AllowNextLaunchAttempt()) 109 if (!AllowNextLaunchAttempt())
110 return; 110 return;
111 } 111 }
112 Launch(ui::EF_NONE); 112 Launch(ui::EF_NONE);
113 return; 113 return;
114 } 114 }
115 ActivateContent(content); 115 ActivateContent(content);
116 } 116 }
117 117
118 void AppShortcutLauncherItemController::Close() { 118 void AppShortcutLauncherItemController::Close() {
119 // Close all running 'programs' of this type. 119 // Close all running 'programs' of this type.
120 std::vector<content::WebContents*> content = 120 std::vector<content::WebContents*> content =
121 app_controller_->GetV1ApplicationsFromAppId(app_id()); 121 launcher_controller()->GetV1ApplicationsFromAppId(app_id());
122 for (size_t i = 0; i < content.size(); i++) { 122 for (size_t i = 0; i < content.size(); i++) {
123 Browser* browser = chrome::FindBrowserWithWebContents(content[i]); 123 Browser* browser = chrome::FindBrowserWithWebContents(content[i]);
124 if (!browser) 124 if (!browser)
125 continue; 125 continue;
126 TabStripModel* tab_strip = browser->tab_strip_model(); 126 TabStripModel* tab_strip = browser->tab_strip_model();
127 int index = tab_strip->GetIndexOfWebContents(content[i]); 127 int index = tab_strip->GetIndexOfWebContents(content[i]);
128 DCHECK(index != TabStripModel::kNoTab); 128 DCHECK(index != TabStripModel::kNoTab);
129 tab_strip->CloseWebContentsAt(index, TabStripModel::CLOSE_NONE); 129 tab_strip->CloseWebContentsAt(index, TabStripModel::CLOSE_NONE);
130 } 130 }
131 } 131 }
(...skipping 22 matching lines...) Expand all
154 AppShortcutLauncherItemController::GetApplicationList(int event_flags) { 154 AppShortcutLauncherItemController::GetApplicationList(int event_flags) {
155 ChromeLauncherAppMenuItems items; 155 ChromeLauncherAppMenuItems items;
156 // Add the application name to the menu. 156 // Add the application name to the menu.
157 items.push_back(new ChromeLauncherAppMenuItem(GetTitle(), NULL, false)); 157 items.push_back(new ChromeLauncherAppMenuItem(GetTitle(), NULL, false));
158 158
159 std::vector<content::WebContents*> content_list = GetRunningApplications(); 159 std::vector<content::WebContents*> content_list = GetRunningApplications();
160 160
161 for (size_t i = 0; i < content_list.size(); i++) { 161 for (size_t i = 0; i < content_list.size(); i++) {
162 content::WebContents* web_contents = content_list[i]; 162 content::WebContents* web_contents = content_list[i];
163 // Get the icon. 163 // Get the icon.
164 gfx::Image app_icon = app_controller_->GetAppListIcon(web_contents); 164 gfx::Image app_icon = launcher_controller()->GetAppListIcon(web_contents);
165 string16 title = app_controller_->GetAppListTitle(web_contents); 165 string16 title = launcher_controller()->GetAppListTitle(web_contents);
166 items.push_back(new ChromeLauncherAppMenuItemTab( 166 items.push_back(new ChromeLauncherAppMenuItemTab(
167 title, &app_icon, web_contents, i == 0)); 167 title, &app_icon, web_contents, i == 0));
168 } 168 }
169 return items.Pass(); 169 return items.Pass();
170 } 170 }
171 171
172 std::vector<content::WebContents*> 172 std::vector<content::WebContents*>
173 AppShortcutLauncherItemController::GetRunningApplications() { 173 AppShortcutLauncherItemController::GetRunningApplications() {
174 std::vector<content::WebContents*> items; 174 std::vector<content::WebContents*> items;
175 175
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
258 const GURL tab_url = web_contents->GetURL(); 258 const GURL tab_url = web_contents->GetURL();
259 // There are three ways to identify the association of a URL with this 259 // There are three ways to identify the association of a URL with this
260 // extension: 260 // extension:
261 // - The refocus pattern is matched (needed for apps like drive). 261 // - The refocus pattern is matched (needed for apps like drive).
262 // - The extension's origin + extent gets matched. 262 // - The extension's origin + extent gets matched.
263 // - The launcher controller knows that the tab got created for this app. 263 // - The launcher controller knows that the tab got created for this app.
264 return ((!refocus_pattern.match_all_urls() && 264 return ((!refocus_pattern.match_all_urls() &&
265 refocus_pattern.MatchesURL(tab_url)) || 265 refocus_pattern.MatchesURL(tab_url)) ||
266 (extension->OverlapsWithOrigin(tab_url) && 266 (extension->OverlapsWithOrigin(tab_url) &&
267 extension->web_extent().MatchesURL(tab_url)) || 267 extension->web_extent().MatchesURL(tab_url)) ||
268 launcher_controller()->GetPerAppInterface()-> 268 launcher_controller()->IsWebContentHandledByApplication(web_contents,
269 IsWebContentHandledByApplication(web_contents, app_id())); 269 app_id()));
270 } 270 }
271 271
272 void AppShortcutLauncherItemController::ActivateContent( 272 void AppShortcutLauncherItemController::ActivateContent(
273 content::WebContents* content) { 273 content::WebContents* content) {
274 Browser* browser = chrome::FindBrowserWithWebContents(content); 274 Browser* browser = chrome::FindBrowserWithWebContents(content);
275 TabStripModel* tab_strip = browser->tab_strip_model(); 275 TabStripModel* tab_strip = browser->tab_strip_model();
276 int index = tab_strip->GetIndexOfWebContents(content); 276 int index = tab_strip->GetIndexOfWebContents(content);
277 DCHECK_NE(TabStripModel::kNoTab, index); 277 DCHECK_NE(TabStripModel::kNoTab, index);
278 278
279 int old_index = tab_strip->active_index(); 279 int old_index = tab_strip->active_index();
280 if (index != old_index) 280 if (index != old_index)
281 tab_strip->ActivateTabAt(index, false); 281 tab_strip->ActivateTabAt(index, false);
282 app_controller_->ActivateWindowOrMinimizeIfActive(browser->window(), 282 launcher_controller()->ActivateWindowOrMinimizeIfActive(
283 browser->window(),
283 index == old_index && GetRunningApplications().size() == 1); 284 index == old_index && GetRunningApplications().size() == 1);
284 } 285 }
285 286
286 bool AppShortcutLauncherItemController::AdvanceToNextApp() { 287 bool AppShortcutLauncherItemController::AdvanceToNextApp() {
287 std::vector<content::WebContents*> items = GetRunningApplications(); 288 std::vector<content::WebContents*> items = GetRunningApplications();
288 if (items.size() >= 1) { 289 if (items.size() >= 1) {
289 Browser* browser = chrome::FindBrowserWithWindow( 290 Browser* browser = chrome::FindBrowserWithWindow(
290 ash::wm::GetActiveWindow()); 291 ash::wm::GetActiveWindow());
291 if (browser) { 292 if (browser) {
292 TabStripModel* tab_strip = browser->tab_strip_model(); 293 TabStripModel* tab_strip = browser->tab_strip_model();
(...skipping 12 matching lines...) Expand all
305 ActivateContent(items[index]); 306 ActivateContent(items[index]);
306 } 307 }
307 return true; 308 return true;
308 } 309 }
309 } 310 }
310 } 311 }
311 return false; 312 return false;
312 } 313 }
313 314
314 bool AppShortcutLauncherItemController::IsV2App() { 315 bool AppShortcutLauncherItemController::IsV2App() {
315 const Extension* extension = app_controller_->GetExtensionForAppID(app_id()); 316 const Extension* extension =
317 launcher_controller()->GetExtensionForAppID(app_id());
316 return extension && extension->is_platform_app(); 318 return extension && extension->is_platform_app();
317 } 319 }
318 320
319 bool AppShortcutLauncherItemController::AllowNextLaunchAttempt() { 321 bool AppShortcutLauncherItemController::AllowNextLaunchAttempt() {
320 if (last_launch_attempt_.is_null() || 322 if (last_launch_attempt_.is_null() ||
321 last_launch_attempt_ + base::TimeDelta::FromMilliseconds( 323 last_launch_attempt_ + base::TimeDelta::FromMilliseconds(
322 kClickSuppressionInMS) < base::Time::Now()) { 324 kClickSuppressionInMS) < base::Time::Now()) {
323 last_launch_attempt_ = base::Time::Now(); 325 last_launch_attempt_ = base::Time::Now();
324 return true; 326 return true;
325 } 327 }
326 return false; 328 return false;
327 } 329 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698