OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/chrome_launcher_controller_mus.h" | 5 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller_mus.h" |
6 | 6 |
| 7 #include "base/strings/string_util.h" |
7 #include "chrome/browser/profiles/profile.h" | 8 #include "chrome/browser/profiles/profile.h" |
8 #include "chrome/browser/profiles/profile_manager.h" | 9 #include "chrome/browser/profiles/profile_manager.h" |
9 #include "chrome/browser/ui/ash/chrome_launcher_prefs.h" | 10 #include "chrome/browser/ui/ash/chrome_launcher_prefs.h" |
10 #include "chrome/browser/ui/ash/launcher/launcher_controller_helper.h" | 11 #include "chrome/browser/ui/ash/launcher/launcher_controller_helper.h" |
11 #include "extensions/grit/extensions_browser_resources.h" | 12 #include "extensions/grit/extensions_browser_resources.h" |
12 #include "mojo/common/common_type_converters.h" | 13 #include "mojo/common/common_type_converters.h" |
13 #include "ui/base/resource/resource_bundle.h" | 14 #include "ui/base/resource/resource_bundle.h" |
14 | 15 |
15 class ChromeShelfItemDelegate : public ash::mojom::ShelfItemDelegate { | 16 class ChromeShelfItemDelegate : public ash::mojom::ShelfItemDelegate { |
16 public: | 17 public: |
(...skipping 244 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
261 void ChromeLauncherControllerMus::OnUserProfileReadyToSwitch(Profile* profile) { | 262 void ChromeLauncherControllerMus::OnUserProfileReadyToSwitch(Profile* profile) { |
262 NOTIMPLEMENTED(); | 263 NOTIMPLEMENTED(); |
263 } | 264 } |
264 | 265 |
265 ArcAppDeferredLauncherController* | 266 ArcAppDeferredLauncherController* |
266 ChromeLauncherControllerMus::GetArcDeferredLauncher() { | 267 ChromeLauncherControllerMus::GetArcDeferredLauncher() { |
267 NOTIMPLEMENTED(); | 268 NOTIMPLEMENTED(); |
268 return nullptr; | 269 return nullptr; |
269 } | 270 } |
270 | 271 |
| 272 const std::string& ChromeLauncherControllerMus::GetLaunchIDForShelfID( |
| 273 ash::ShelfID id) { |
| 274 NOTIMPLEMENTED(); |
| 275 return base::EmptyString(); |
| 276 } |
| 277 |
271 void ChromeLauncherControllerMus::OnAppImageUpdated( | 278 void ChromeLauncherControllerMus::OnAppImageUpdated( |
272 const std::string& app_id, | 279 const std::string& app_id, |
273 const gfx::ImageSkia& image) { | 280 const gfx::ImageSkia& image) { |
274 if (ConnectToShelfController()) | 281 if (ConnectToShelfController()) |
275 shelf_controller()->SetItemImage(app_id, *image.bitmap()); | 282 shelf_controller()->SetItemImage(app_id, *image.bitmap()); |
276 } | 283 } |
277 | 284 |
278 void ChromeLauncherControllerMus::PinAppsFromPrefs() { | 285 void ChromeLauncherControllerMus::PinAppsFromPrefs() { |
279 if (!ConnectToShelfController()) | 286 if (!ConnectToShelfController()) |
280 return; | 287 return; |
281 | 288 |
282 std::vector<ash::launcher::AppLauncherId> pinned_apps = | 289 std::vector<ash::launcher::AppLauncherId> pinned_apps = |
283 ash::launcher::GetPinnedAppsFromPrefs(profile()->GetPrefs(), | 290 ash::launcher::GetPinnedAppsFromPrefs(profile()->GetPrefs(), |
284 launcher_controller_helper()); | 291 launcher_controller_helper()); |
285 | 292 |
286 for (const auto& app_launcher_id : pinned_apps) { | 293 for (const auto& app_launcher_id : pinned_apps) { |
287 const std::string app_launcher_id_str = app_launcher_id.ToString(); | 294 const std::string app_id = app_launcher_id.app_id(); |
288 if (app_launcher_id_str == ash::launcher::kPinnedAppsPlaceholder) | 295 if (app_launcher_id.ToString() == ash::launcher::kPinnedAppsPlaceholder) |
289 continue; | 296 continue; |
290 | 297 |
291 ash::mojom::ShelfItemPtr item(ash::mojom::ShelfItem::New()); | 298 ash::mojom::ShelfItemPtr item(ash::mojom::ShelfItem::New()); |
292 item->app_id = app_launcher_id_str; | 299 item->app_id = app_id; |
293 item->app_title = | 300 item->app_title = mojo::String::From( |
294 mojo::String::From(launcher_controller_helper()->GetAppTitle( | 301 launcher_controller_helper()->GetAppTitle(profile(), app_id)); |
295 profile(), app_launcher_id_str)); | |
296 ResourceBundle& rb = ResourceBundle::GetSharedInstance(); | 302 ResourceBundle& rb = ResourceBundle::GetSharedInstance(); |
297 const gfx::Image& image = rb.GetImageNamed(IDR_APP_DEFAULT_ICON); | 303 const gfx::Image& image = rb.GetImageNamed(IDR_APP_DEFAULT_ICON); |
298 item->image = *image.ToSkBitmap(); | 304 item->image = *image.ToSkBitmap(); |
299 std::unique_ptr<ChromeShelfItemDelegate> delegate( | 305 std::unique_ptr<ChromeShelfItemDelegate> delegate( |
300 new ChromeShelfItemDelegate(app_launcher_id_str, this)); | 306 new ChromeShelfItemDelegate(app_id, this)); |
301 shelf_controller()->PinItem(std::move(item), | 307 shelf_controller()->PinItem(std::move(item), |
302 delegate->CreateInterfacePtrInfoAndBind( | 308 delegate->CreateInterfacePtrInfoAndBind( |
303 shelf_controller().associated_group())); | 309 shelf_controller().associated_group())); |
304 app_id_to_item_delegate_.insert( | 310 app_id_to_item_delegate_.insert( |
305 std::make_pair(app_launcher_id_str, std::move(delegate))); | 311 std::make_pair(app_id, std::move(delegate))); |
306 | 312 |
307 AppIconLoader* app_icon_loader = | 313 AppIconLoader* app_icon_loader = GetAppIconLoaderForApp(app_id); |
308 GetAppIconLoaderForApp(app_launcher_id_str); | |
309 if (app_icon_loader) { | 314 if (app_icon_loader) { |
310 app_icon_loader->FetchImage(app_launcher_id_str); | 315 app_icon_loader->FetchImage(app_id); |
311 app_icon_loader->UpdateImage(app_launcher_id_str); | 316 app_icon_loader->UpdateImage(app_id); |
312 } | 317 } |
313 } | 318 } |
314 } | 319 } |
OLD | NEW |