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/extensions/extension_uninstall_dialog.h" | 5 #include "chrome/browser/extensions/extension_uninstall_dialog.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" |
11 #include "chrome/browser/chrome_notification_types.h" | 11 #include "chrome/browser/chrome_notification_types.h" |
msw
2014/07/24 19:20:56
Remove this.
sashab
2014/07/25 02:44:33
Done.
| |
12 #include "chrome/browser/extensions/extension_util.h" | 12 #include "chrome/browser/extensions/extension_util.h" |
13 #include "chrome/browser/profiles/profile.h" | 13 #include "chrome/browser/profiles/profile.h" |
14 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" |
msw
2014/07/24 19:20:56
Remove this.
sashab
2014/07/25 02:44:33
Done.
| |
15 #include "content/public/browser/notification_service.h" | 15 #include "content/public/browser/notification_service.h" |
msw
2014/07/24 19:20:56
Remove this.
sashab
2014/07/25 02:44:33
Done.
| |
16 #include "content/public/browser/notification_source.h" | 16 #include "content/public/browser/notification_source.h" |
msw
2014/07/24 19:20:56
Remove this.
sashab
2014/07/25 02:44:33
Done. Thanks for that :)
| |
17 #include "extensions/browser/extension_registry.h" | 17 #include "extensions/browser/extension_registry.h" |
18 #include "extensions/browser/image_loader.h" | 18 #include "extensions/browser/image_loader.h" |
19 #include "extensions/common/constants.h" | 19 #include "extensions/common/constants.h" |
20 #include "extensions/common/extension.h" | 20 #include "extensions/common/extension.h" |
21 #include "extensions/common/extension_icon_set.h" | 21 #include "extensions/common/extension_icon_set.h" |
22 #include "extensions/common/extension_resource.h" | 22 #include "extensions/common/extension_resource.h" |
23 #include "extensions/common/manifest_handlers/icons_handler.h" | 23 #include "extensions/common/manifest_handlers/icons_handler.h" |
24 #include "grit/generated_resources.h" | 24 #include "grit/generated_resources.h" |
25 #include "grit/theme_resources.h" | 25 #include "grit/theme_resources.h" |
26 #include "ui/base/l10n/l10n_util.h" | 26 #include "ui/base/l10n/l10n_util.h" |
(...skipping 11 matching lines...) Expand all Loading... | |
38 const gfx::ImageSkia& image = | 38 const gfx::ImageSkia& image = |
39 is_app ? util::GetDefaultAppIcon() : util::GetDefaultExtensionIcon(); | 39 is_app ? util::GetDefaultAppIcon() : util::GetDefaultExtensionIcon(); |
40 return image.GetRepresentation( | 40 return image.GetRepresentation( |
41 gfx::ImageSkia::GetMaxSupportedScale()).sk_bitmap(); | 41 gfx::ImageSkia::GetMaxSupportedScale()).sk_bitmap(); |
42 } | 42 } |
43 | 43 |
44 } // namespace | 44 } // namespace |
45 | 45 |
46 ExtensionUninstallDialog::ExtensionUninstallDialog( | 46 ExtensionUninstallDialog::ExtensionUninstallDialog( |
47 Profile* profile, | 47 Profile* profile, |
48 Browser* browser, | 48 gfx::NativeWindow parent, |
49 ExtensionUninstallDialog::Delegate* delegate) | 49 ExtensionUninstallDialog::Delegate* delegate) |
50 : profile_(profile), | 50 : profile_(profile), |
51 browser_(browser), | 51 parent_(parent), |
52 delegate_(delegate), | 52 delegate_(delegate), |
53 extension_(NULL), | 53 extension_(NULL), |
54 triggering_extension_(NULL), | 54 triggering_extension_(NULL), |
55 state_(kImageIsLoading), | |
56 ui_loop_(base::MessageLoop::current()) { | 55 ui_loop_(base::MessageLoop::current()) { |
57 if (browser) { | |
58 registrar_.Add(this, | |
59 chrome::NOTIFICATION_BROWSER_CLOSED, | |
60 content::Source<Browser>(browser)); | |
61 } | |
62 } | 56 } |
63 | 57 |
64 ExtensionUninstallDialog::~ExtensionUninstallDialog() { | 58 ExtensionUninstallDialog::~ExtensionUninstallDialog() { |
65 } | 59 } |
66 | 60 |
67 void ExtensionUninstallDialog::ConfirmProgrammaticUninstall( | 61 void ExtensionUninstallDialog::ConfirmProgrammaticUninstall( |
68 const Extension* extension, | 62 const Extension* extension, |
69 const Extension* triggering_extension) { | 63 const Extension* triggering_extension) { |
70 triggering_extension_ = triggering_extension; | 64 triggering_extension_ = triggering_extension; |
71 ConfirmUninstall(extension); | 65 ConfirmUninstall(extension); |
72 } | 66 } |
73 | 67 |
74 void ExtensionUninstallDialog::ConfirmUninstall(const Extension* extension) { | 68 void ExtensionUninstallDialog::ConfirmUninstall(const Extension* extension) { |
75 DCHECK(ui_loop_ == base::MessageLoop::current()); | 69 DCHECK(ui_loop_ == base::MessageLoop::current()); |
76 extension_ = extension; | 70 extension_ = extension; |
77 // Bookmark apps may not have 128x128 icons so accept 64x64 icons. | 71 // Bookmark apps may not have 128x128 icons so accept 64x64 icons. |
78 const int icon_size = extension_->from_bookmark() | 72 const int icon_size = extension_->from_bookmark() |
79 ? extension_misc::EXTENSION_ICON_SMALL * 2 | 73 ? extension_misc::EXTENSION_ICON_SMALL * 2 |
80 : extension_misc::EXTENSION_ICON_LARGE; | 74 : extension_misc::EXTENSION_ICON_LARGE; |
81 ExtensionResource image = IconsInfo::GetIconResource( | 75 ExtensionResource image = IconsInfo::GetIconResource( |
82 extension_, icon_size, ExtensionIconSet::MATCH_BIGGER); | 76 extension_, icon_size, ExtensionIconSet::MATCH_BIGGER); |
83 | 77 |
84 // Load the image asynchronously. The response will be sent to OnImageLoaded. | 78 // Load the image asynchronously. The response will be sent to OnImageLoaded. |
85 state_ = kImageIsLoading; | |
86 ImageLoader* loader = ImageLoader::Get(profile_); | 79 ImageLoader* loader = ImageLoader::Get(profile_); |
87 | 80 |
81 SetIcon(gfx::Image()); | |
88 std::vector<ImageLoader::ImageRepresentation> images_list; | 82 std::vector<ImageLoader::ImageRepresentation> images_list; |
89 images_list.push_back(ImageLoader::ImageRepresentation( | 83 images_list.push_back(ImageLoader::ImageRepresentation( |
90 image, | 84 image, |
91 ImageLoader::ImageRepresentation::NEVER_RESIZE, | 85 ImageLoader::ImageRepresentation::NEVER_RESIZE, |
92 gfx::Size(), | 86 gfx::Size(), |
93 ui::SCALE_FACTOR_100P)); | 87 ui::SCALE_FACTOR_100P)); |
94 loader->LoadImagesAsync(extension_, | 88 loader->LoadImagesAsync(extension_, |
95 images_list, | 89 images_list, |
96 base::Bind(&ExtensionUninstallDialog::OnImageLoaded, | 90 base::Bind(&ExtensionUninstallDialog::OnImageLoaded, |
97 AsWeakPtr(), | 91 AsWeakPtr(), |
(...skipping 18 matching lines...) Expand all Loading... | |
116 const gfx::Image& image) { | 110 const gfx::Image& image) { |
117 const Extension* target_extension = | 111 const Extension* target_extension = |
118 ExtensionRegistry::Get(profile_) | 112 ExtensionRegistry::Get(profile_) |
119 ->GetExtensionById(extension_id, ExtensionRegistry::EVERYTHING); | 113 ->GetExtensionById(extension_id, ExtensionRegistry::EVERYTHING); |
120 if (!target_extension) { | 114 if (!target_extension) { |
121 delegate_->ExtensionUninstallCanceled(); | 115 delegate_->ExtensionUninstallCanceled(); |
122 return; | 116 return; |
123 } | 117 } |
124 | 118 |
125 SetIcon(image); | 119 SetIcon(image); |
126 | 120 Show(); |
127 // Show the dialog unless the browser has been closed while we were waiting | |
128 // for the image. | |
129 DCHECK(state_ == kImageIsLoading || state_ == kBrowserIsClosing); | |
130 if (state_ == kImageIsLoading) { | |
131 state_ = kDialogIsShowing; | |
132 Show(); | |
133 } | |
134 } | |
135 | |
136 void ExtensionUninstallDialog::Observe( | |
137 int type, | |
138 const content::NotificationSource& source, | |
139 const content::NotificationDetails& details) { | |
140 DCHECK(type == chrome::NOTIFICATION_BROWSER_CLOSED); | |
141 | |
142 browser_ = NULL; | |
143 // If the browser is closed while waiting for the image, we need to send a | |
144 // "cancel" event here, because there will not be another opportunity to | |
145 // notify the delegate of the cancellation as we won't open the dialog. | |
146 if (state_ == kImageIsLoading) { | |
147 state_ = kBrowserIsClosing; | |
148 delegate_->ExtensionUninstallCanceled(); | |
149 } | |
150 } | 121 } |
151 | 122 |
152 std::string ExtensionUninstallDialog::GetHeadingText() { | 123 std::string ExtensionUninstallDialog::GetHeadingText() { |
153 if (triggering_extension_) { | 124 if (triggering_extension_) { |
154 return l10n_util::GetStringFUTF8( | 125 return l10n_util::GetStringFUTF8( |
155 IDS_EXTENSION_PROGRAMMATIC_UNINSTALL_PROMPT_HEADING, | 126 IDS_EXTENSION_PROGRAMMATIC_UNINSTALL_PROMPT_HEADING, |
156 base::UTF8ToUTF16(triggering_extension_->name()), | 127 base::UTF8ToUTF16(triggering_extension_->name()), |
157 base::UTF8ToUTF16(extension_->name())); | 128 base::UTF8ToUTF16(extension_->name())); |
158 } | 129 } |
159 return l10n_util::GetStringFUTF8(IDS_EXTENSION_UNINSTALL_PROMPT_HEADING, | 130 return l10n_util::GetStringFUTF8(IDS_EXTENSION_UNINSTALL_PROMPT_HEADING, |
160 base::UTF8ToUTF16(extension_->name())); | 131 base::UTF8ToUTF16(extension_->name())); |
161 } | 132 } |
162 | 133 |
163 } // namespace extensions | 134 } // namespace extensions |
OLD | NEW |