blob: 9f7c8dcdec0aa4b5f65c03d0cd62cdbc9f73eeea (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_UNINSTALL_DIALOG_H_
#define CHROME_BROWSER_EXTENSIONS_EXTENSION_UNINSTALL_DIALOG_H_
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/weak_ptr.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
#include "ui/gfx/image/image_skia.h"
class Browser;
class Profile;
namespace base {
class MessageLoop;
}
namespace extensions {
class Extension;
}
namespace gfx {
class Image;
}
class ExtensionUninstallDialog
: public content::NotificationObserver,
public base::SupportsWeakPtr<ExtensionUninstallDialog> {
public:
class Delegate {
public:
// We call this method to signal that the uninstallation should continue.
virtual void ExtensionUninstallAccepted() = 0;
// We call this method to signal that the uninstallation should stop.
virtual void ExtensionUninstallCanceled() = 0;
protected:
virtual ~Delegate() {}
};
// Creates a platform specific implementation of ExtensionUninstallDialog.
// |profile| and |delegate| can never be NULL.
// |browser| can be NULL only for Ash when this is used with the applist
// window.
static ExtensionUninstallDialog* Create(Profile* profile,
Browser* browser,
Delegate* delegate);
virtual ~ExtensionUninstallDialog();
// This is called to verify whether the uninstallation should proceed.
// Starts the process of showing a confirmation UI, which is split into two.
// 1) Set off a 'load icon' task.
// 2) Handle the load icon response and show the UI (OnImageLoaded).
void ConfirmUninstall(const extensions::Extension* extension);
protected:
// Constructor used by the derived classes.
ExtensionUninstallDialog(Profile* profile,
Browser* browser,
Delegate* delegate);
Profile* const profile_;
Browser* browser_;
// The delegate we will call Accepted/Canceled on after confirmation dialog.
Delegate* delegate_;
// The extension we are showing the dialog for.
const extensions::Extension* extension_;
// The extensions icon.
gfx::ImageSkia icon_;
private:
// Sets the icon that will be used in the dialog. If |icon| contains an empty
// image, then we use a default icon instead.
void SetIcon(const gfx::Image& image);
void OnImageLoaded(const gfx::Image& image);
// content::NotificationObserver implementation.
virtual void Observe(int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) OVERRIDE;
// Displays the prompt. This should only be called after loading the icon.
// The implementations of this method are platform-specific.
virtual void Show() = 0;
// Keeps track of whether we're still waiting for an image to load before
// we show the dialog.
enum State {
kImageIsLoading, // Image is loading asynchronously.
kDialogIsShowing, // Dialog is shown after image is loaded.
kBrowserIsClosing // Browser is closed while image is still loading.
};
State state_;
base::MessageLoop* ui_loop_;
content::NotificationRegistrar registrar_;
DISALLOW_COPY_AND_ASSIGN(ExtensionUninstallDialog);
};
#endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_UNINSTALL_DIALOG_H_
|