Chromium Code Reviews| 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 #include "chrome/browser/ui/views/create_application_shortcut_view.h" | 5 #include "chrome/browser/ui/views/create_application_shortcut_view.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 358 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 369 string16 CreateApplicationShortcutView::GetWindowTitle() const { | 369 string16 CreateApplicationShortcutView::GetWindowTitle() const { |
| 370 return l10n_util::GetStringUTF16(IDS_CREATE_SHORTCUTS_TITLE); | 370 return l10n_util::GetStringUTF16(IDS_CREATE_SHORTCUTS_TITLE); |
| 371 } | 371 } |
| 372 | 372 |
| 373 bool CreateApplicationShortcutView::Accept() { | 373 bool CreateApplicationShortcutView::Accept() { |
| 374 if (!IsDialogButtonEnabled(ui::DIALOG_BUTTON_OK)) | 374 if (!IsDialogButtonEnabled(ui::DIALOG_BUTTON_OK)) |
| 375 return false; | 375 return false; |
| 376 | 376 |
| 377 ShellIntegration::ShortcutLocations creation_locations; | 377 ShellIntegration::ShortcutLocations creation_locations; |
| 378 creation_locations.on_desktop = desktop_check_box_->checked(); | 378 creation_locations.on_desktop = desktop_check_box_->checked(); |
| 379 creation_locations.in_applications_menu = menu_check_box_ == NULL ? false : | 379 if (menu_check_box_ != NULL && menu_check_box_->checked()) { |
|
Matt Giuca
2013/05/15 05:19:45
You will need to make this change in chrome/browse
| |
| 380 menu_check_box_->checked(); | 380 if (create_in_chrome_apps_subdir_) |
| 381 creation_locations.applications_menu_subdir = shortcut_menu_subdir_; | 381 creation_locations.in_applications_menu_chrome_apps_subdir = true; |
| 382 | 382 else |
| 383 creation_locations.in_applications_menu = true; | |
| 384 } | |
| 383 #if defined(OS_WIN) | 385 #if defined(OS_WIN) |
| 384 creation_locations.in_quick_launch_bar = quick_launch_check_box_ == NULL ? | 386 creation_locations.in_quick_launch_bar = quick_launch_check_box_ == NULL ? |
| 385 NULL : quick_launch_check_box_->checked(); | 387 NULL : quick_launch_check_box_->checked(); |
| 386 #elif defined(OS_POSIX) | 388 #elif defined(OS_POSIX) |
| 387 // Create shortcut in Mac dock or as Linux (gnome/kde) application launcher | 389 // Create shortcut in Mac dock or as Linux (gnome/kde) application launcher |
| 388 // are not implemented yet. | 390 // are not implemented yet. |
| 389 creation_locations.in_quick_launch_bar = false; | 391 creation_locations.in_quick_launch_bar = false; |
| 390 #endif | 392 #endif |
| 391 | 393 |
| 392 web_app::CreateShortcuts(shortcut_info_, creation_locations); | 394 web_app::CreateShortcuts(shortcut_info_, creation_locations); |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 426 pending_download_id_(-1) { | 428 pending_download_id_(-1) { |
| 427 | 429 |
| 428 web_app::GetShortcutInfoForTab(web_contents_, &shortcut_info_); | 430 web_app::GetShortcutInfoForTab(web_contents_, &shortcut_info_); |
| 429 const WebApplicationInfo& app_info = | 431 const WebApplicationInfo& app_info = |
| 430 extensions::TabHelper::FromWebContents(web_contents_)->web_app_info(); | 432 extensions::TabHelper::FromWebContents(web_contents_)->web_app_info(); |
| 431 if (!app_info.icons.empty()) { | 433 if (!app_info.icons.empty()) { |
| 432 web_app::GetIconsInfo(app_info, &unprocessed_icons_); | 434 web_app::GetIconsInfo(app_info, &unprocessed_icons_); |
| 433 FetchIcon(); | 435 FetchIcon(); |
| 434 } | 436 } |
| 435 | 437 |
| 436 // NOTE: Leave shortcut_menu_subdir_ blank to create URL app shortcuts in the | 438 // Create URL app shortcuts in the top-level menu. |
| 437 // top-level menu. | 439 create_in_chrome_apps_subdir_ = false; |
|
Matt Giuca
2013/05/15 05:19:45
I'm glad this comment came in handy :)
| |
| 438 | 440 |
| 439 InitControls(); | 441 InitControls(); |
| 440 } | 442 } |
| 441 | 443 |
| 442 CreateUrlApplicationShortcutView::~CreateUrlApplicationShortcutView() { | 444 CreateUrlApplicationShortcutView::~CreateUrlApplicationShortcutView() { |
| 443 } | 445 } |
| 444 | 446 |
| 445 bool CreateUrlApplicationShortcutView::Accept() { | 447 bool CreateUrlApplicationShortcutView::Accept() { |
| 446 if (!CreateApplicationShortcutView::Accept()) | 448 if (!CreateApplicationShortcutView::Accept()) |
| 447 return false; | 449 return false; |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 509 Profile* profile, | 511 Profile* profile, |
| 510 const extensions::Extension* app) : | 512 const extensions::Extension* app) : |
| 511 CreateApplicationShortcutView(profile), | 513 CreateApplicationShortcutView(profile), |
| 512 app_(app), | 514 app_(app), |
| 513 weak_ptr_factory_(this) { | 515 weak_ptr_factory_(this) { |
| 514 // Required by InitControls(). | 516 // Required by InitControls(). |
| 515 shortcut_info_.title = UTF8ToUTF16(app->name()); | 517 shortcut_info_.title = UTF8ToUTF16(app->name()); |
| 516 shortcut_info_.description = UTF8ToUTF16(app->description()); | 518 shortcut_info_.description = UTF8ToUTF16(app->description()); |
| 517 | 519 |
| 518 // Place Chrome app shortcuts in the "Chrome Apps" submenu. | 520 // Place Chrome app shortcuts in the "Chrome Apps" submenu. |
| 519 shortcut_menu_subdir_ = web_app::GetAppShortcutsSubdirName(); | 521 create_in_chrome_apps_subdir_ = true; |
| 520 | 522 |
| 521 InitControls(); | 523 InitControls(); |
| 522 | 524 |
| 523 // Get shortcut information and icon now; they are needed for our UI. | 525 // Get shortcut information and icon now; they are needed for our UI. |
| 524 web_app::UpdateShortcutInfoAndIconForApp( | 526 web_app::UpdateShortcutInfoAndIconForApp( |
| 525 *app, profile, | 527 *app, profile, |
| 526 base::Bind(&CreateChromeApplicationShortcutView::OnShortcutInfoLoaded, | 528 base::Bind(&CreateChromeApplicationShortcutView::OnShortcutInfoLoaded, |
| 527 weak_ptr_factory_.GetWeakPtr())); | 529 weak_ptr_factory_.GetWeakPtr())); |
| 528 } | 530 } |
| 529 | 531 |
| 530 CreateChromeApplicationShortcutView::~CreateChromeApplicationShortcutView() {} | 532 CreateChromeApplicationShortcutView::~CreateChromeApplicationShortcutView() {} |
| 531 | 533 |
| 532 // Called when the app's ShortcutInfo (with icon) is loaded. | 534 // Called when the app's ShortcutInfo (with icon) is loaded. |
| 533 void CreateChromeApplicationShortcutView::OnShortcutInfoLoaded( | 535 void CreateChromeApplicationShortcutView::OnShortcutInfoLoaded( |
| 534 const ShellIntegration::ShortcutInfo& shortcut_info) { | 536 const ShellIntegration::ShortcutInfo& shortcut_info) { |
| 535 shortcut_info_ = shortcut_info; | 537 shortcut_info_ = shortcut_info; |
| 536 | 538 |
| 537 CHECK(app_info_); | 539 CHECK(app_info_); |
| 538 static_cast<AppInfoView*>(app_info_)->UpdateIcon(shortcut_info_.favicon); | 540 static_cast<AppInfoView*>(app_info_)->UpdateIcon(shortcut_info_.favicon); |
| 539 } | 541 } |
| OLD | NEW |