Chromium Code Reviews| Index: chrome/browser/android/banners/app_banner_manager.cc |
| diff --git a/chrome/browser/android/banners/app_banner_manager.cc b/chrome/browser/android/banners/app_banner_manager.cc |
| index 316a036d4277724cd41664d716715645e759c14c..6819b3f6a9286bfff2f16c075c6464ef041eb543 100644 |
| --- a/chrome/browser/android/banners/app_banner_manager.cc |
| +++ b/chrome/browser/android/banners/app_banner_manager.cc |
| @@ -9,9 +9,12 @@ |
| #include "base/bind.h" |
| #include "base/command_line.h" |
| #include "base/metrics/histogram.h" |
| +#include "base/threading/worker_pool.h" |
| #include "chrome/browser/android/banners/app_banner_infobar_delegate.h" |
| #include "chrome/browser/android/banners/app_banner_metrics_ids.h" |
| #include "chrome/browser/android/banners/app_banner_utilities.h" |
| +#include "chrome/browser/android/shortcut_helper.h" |
| +#include "chrome/browser/android/shortcut_info.h" |
| #include "chrome/browser/banners/app_banner_settings_helper.h" |
| #include "chrome/browser/bitmap_fetcher/bitmap_fetcher.h" |
| #include "chrome/browser/infobars/infobar_service.h" |
| @@ -75,7 +78,7 @@ void AppBannerManager::Install() const { |
| return; |
| if (!manifest_.IsEmpty()) { |
| - // TODO(dfalcantara): Trigger shortcut creation. |
| + InstallManifestApp(manifest_, *app_icon_.get()); |
| } |
| } |
| @@ -268,6 +271,20 @@ int AppBannerManager::GetPreferredIconSize() { |
| return Java_AppBannerManager_getPreferredIconSize(env, jobj.obj()); |
| } |
| +// static |
| +void AppBannerManager::InstallManifestApp(const content::Manifest& manifest, |
| + const SkBitmap& icon) { |
| + ShortcutInfo info; |
| + info.UpdateFromManifest(manifest); |
|
mlamouri (slow - plz ping)
2015/02/03 17:40:24
You might want to set some default values like Sho
gone
2015/02/03 19:48:23
Changed a bit of the logic to prevent the infobar
|
| + |
| + base::WorkerPool::PostTask( |
| + FROM_HERE, |
| + base::Bind(&ShortcutHelper::AddShortcutInBackgroundWithSkBitmap, |
| + info, |
| + icon), |
| + true); |
| +} |
| + |
| void RecordDismissEvent(JNIEnv* env, jclass clazz, jint metric) { |
| banners::TrackDismissEvent(metric); |
| } |