OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #import "chrome/browser/ui/cocoa/extensions/extension_action_context_menu.h" | 5 #import "chrome/browser/ui/cocoa/extensions/extension_action_context_menu.h" |
6 | 6 |
7 #include "base/sys_string_conversions.h" | 7 #include "base/sys_string_conversions.h" |
8 #include "base/task.h" | 8 #include "base/task.h" |
9 #include "chrome/browser/browser_list.h" | 9 #include "chrome/browser/browser_list.h" |
10 #include "chrome/browser/extensions/extension_install_ui.h" | |
11 #include "chrome/browser/extensions/extension_service.h" | 10 #include "chrome/browser/extensions/extension_service.h" |
12 #include "chrome/browser/extensions/extension_tabs_module.h" | 11 #include "chrome/browser/extensions/extension_tabs_module.h" |
| 12 #include "chrome/browser/extensions/extension_uninstall_dialog.h" |
13 #include "chrome/browser/prefs/pref_change_registrar.h" | 13 #include "chrome/browser/prefs/pref_change_registrar.h" |
14 #include "chrome/browser/prefs/pref_service.h" | 14 #include "chrome/browser/prefs/pref_service.h" |
15 #include "chrome/browser/profiles/profile.h" | 15 #include "chrome/browser/profiles/profile.h" |
16 #include "chrome/browser/ui/cocoa/browser_window_cocoa.h" | 16 #include "chrome/browser/ui/cocoa/browser_window_cocoa.h" |
17 #include "chrome/browser/ui/cocoa/browser_window_controller.h" | 17 #include "chrome/browser/ui/cocoa/browser_window_controller.h" |
18 #include "chrome/browser/ui/cocoa/extensions/browser_actions_controller.h" | 18 #include "chrome/browser/ui/cocoa/extensions/browser_actions_controller.h" |
19 #include "chrome/browser/ui/cocoa/extensions/extension_popup_controller.h" | 19 #include "chrome/browser/ui/cocoa/extensions/extension_popup_controller.h" |
20 #include "chrome/browser/ui/cocoa/info_bubble_view.h" | 20 #include "chrome/browser/ui/cocoa/info_bubble_view.h" |
21 #import "chrome/browser/ui/cocoa/location_bar/location_bar_view_mac.h" | 21 #import "chrome/browser/ui/cocoa/location_bar/location_bar_view_mac.h" |
22 #include "chrome/browser/ui/cocoa/toolbar/toolbar_controller.h" | 22 #include "chrome/browser/ui/cocoa/toolbar/toolbar_controller.h" |
23 #include "chrome/common/extensions/extension.h" | 23 #include "chrome/common/extensions/extension.h" |
24 #include "chrome/common/extensions/extension_action.h" | 24 #include "chrome/common/extensions/extension_action.h" |
25 #include "chrome/common/extensions/extension_constants.h" | 25 #include "chrome/common/extensions/extension_constants.h" |
26 #include "chrome/common/pref_names.h" | 26 #include "chrome/common/pref_names.h" |
27 #include "chrome/common/url_constants.h" | 27 #include "chrome/common/url_constants.h" |
28 #include "content/common/notification_details.h" | 28 #include "content/common/notification_details.h" |
29 #include "content/common/notification_observer.h" | 29 #include "content/common/notification_observer.h" |
30 #include "content/common/notification_source.h" | 30 #include "content/common/notification_source.h" |
31 #include "content/common/notification_type.h" | 31 #include "content/common/notification_type.h" |
32 #include "grit/generated_resources.h" | 32 #include "grit/generated_resources.h" |
33 #include "ui/base/l10n/l10n_util_mac.h" | 33 #include "ui/base/l10n/l10n_util_mac.h" |
34 | 34 |
35 // A class that loads the extension icon on the I/O thread before showing the | 35 // A class that loads the extension icon on the I/O thread before showing the |
36 // confirmation dialog to uninstall the given extension. | 36 // confirmation dialog to uninstall the given extension. |
37 // Also acts as the extension's UI delegate in order to display the dialog. | 37 // Also acts as the extension's UI delegate in order to display the dialog. |
38 class AsyncUninstaller : public ExtensionInstallUI::Delegate { | 38 class AsyncUninstaller : public ExtensionUninstallDialog::Delegate { |
39 public: | 39 public: |
40 AsyncUninstaller(const Extension* extension, Profile* profile) | 40 AsyncUninstaller(const Extension* extension, Profile* profile) |
41 : extension_(extension), | 41 : extension_(extension), |
42 profile_(profile) { | 42 profile_(profile) { |
43 install_ui_.reset(new ExtensionInstallUI(profile)); | 43 extension_uninstall_dialog_.reset(new ExtensionUninstallDialog(profile)); |
44 install_ui_->ConfirmUninstall(this, extension_); | 44 extension_uninstall_dialog_->ConfirmUninstall(this, extension_); |
45 } | 45 } |
46 | 46 |
47 ~AsyncUninstaller() {} | 47 ~AsyncUninstaller() {} |
48 | 48 |
49 // Overridden by ExtensionInstallUI::Delegate. | 49 // ExtensionUninstallDialog::Delegate: |
50 virtual void InstallUIProceed() { | 50 virtual void ExtensionDialogAccepted() { |
51 profile_->GetExtensionService()-> | 51 profile_->GetExtensionService()-> |
52 UninstallExtension(extension_->id(), false); | 52 UninstallExtension(extension_->id(), false); |
53 } | 53 } |
54 | 54 virtual void ExtensionDialogCanceled() {} |
55 virtual void InstallUIAbort() {} | |
56 | 55 |
57 private: | 56 private: |
58 // The extension that we're loading the icon for. Weak. | 57 // The extension that we're loading the icon for. Weak. |
59 const Extension* extension_; | 58 const Extension* extension_; |
60 | 59 |
61 // The current profile. Weak. | 60 // The current profile. Weak. |
62 Profile* profile_; | 61 Profile* profile_; |
63 | 62 |
64 scoped_ptr<ExtensionInstallUI> install_ui_; | 63 scoped_ptr<ExtensionUninstallDialog> extension_uninstall_dialog_; |
65 | 64 |
66 DISALLOW_COPY_AND_ASSIGN(AsyncUninstaller); | 65 DISALLOW_COPY_AND_ASSIGN(AsyncUninstaller); |
67 }; | 66 }; |
68 | 67 |
69 namespace extension_action_context_menu { | 68 namespace extension_action_context_menu { |
70 | 69 |
71 class DevmodeObserver : public NotificationObserver { | 70 class DevmodeObserver : public NotificationObserver { |
72 public: | 71 public: |
73 DevmodeObserver(ExtensionActionContextMenu* menu, | 72 DevmodeObserver(ExtensionActionContextMenu* menu, |
74 PrefService* service) | 73 PrefService* service) |
(...skipping 248 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
323 } | 322 } |
324 return YES; | 323 return YES; |
325 } | 324 } |
326 | 325 |
327 - (void)invalidateProfile { | 326 - (void)invalidateProfile { |
328 observer_.reset(); | 327 observer_.reset(); |
329 profile_ = NULL; | 328 profile_ = NULL; |
330 } | 329 } |
331 | 330 |
332 @end | 331 @end |
OLD | NEW |