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
|
// Copyright (c) 2009 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_GTK_EXTENSION_INSTALLED_BUBBLE_GTK_H_
#define CHROME_BROWSER_GTK_EXTENSION_INSTALLED_BUBBLE_GTK_H_
#pragma once
#include "base/ref_counted.h"
#include "base/scoped_ptr.h"
#include "chrome/browser/gtk/custom_button.h"
#include "chrome/browser/gtk/info_bubble_gtk.h"
#include "chrome/common/notification_observer.h"
#include "chrome/common/notification_registrar.h"
#include "third_party/skia/include/core/SkBitmap.h"
class Browser;
class BrowserWindowGtk;
class Extension;
class SkBitmap;
// Provides feedback to the user upon successful installation of an
// extension. Depending on the type of extension, the InfoBubble will
// point to:
// BROWSER_ACTION -> The browserAction icon in the toolbar.
// PAGE_ACTION -> A preview of the page action icon in the location
// bar which is shown while the InfoBubble is shown.
// GENERIC -> The wrench menu. This case includes page actions that
// don't specify a default icon.
//
// ExtensionInstallBubble manages its own lifetime.
class ExtensionInstalledBubbleGtk
: public InfoBubbleGtkDelegate,
public NotificationObserver,
public base::RefCountedThreadSafe<ExtensionInstalledBubbleGtk> {
public:
// The behavior and content of this InfoBubble comes in three varieties.
enum BubbleType {
BROWSER_ACTION,
PAGE_ACTION,
GENERIC
};
// Creates the ExtensionInstalledBubble and schedules it to be shown once
// the extension has loaded. |extension| is the installed extension. |browser|
// is the browser window which will host the bubble. |icon| is the install
// icon of the extension.
static void Show(Extension *extension, Browser *browser, SkBitmap icon);
private:
friend class base::RefCountedThreadSafe<ExtensionInstalledBubbleGtk>;
// Private ctor. Registers a listener for EXTENSION_LOADED.
ExtensionInstalledBubbleGtk(Extension *extension, Browser *browser,
SkBitmap icon);
virtual ~ExtensionInstalledBubbleGtk();
// Shows the bubble. Called internally via PostTask.
void ShowInternal();
// NotificationObserver
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
// InfoBubbleDelegate
virtual void InfoBubbleClosing(InfoBubbleGtk* info_bubble,
bool closed_by_escape);
// Calls Release() internally. Called internally via PostTask.
void Close();
static void OnButtonClick(GtkWidget* button,
ExtensionInstalledBubbleGtk* toolbar);
Extension *extension_;
Browser *browser_;
SkBitmap icon_;
NotificationRegistrar registrar_;
BubbleType type_;
// The number of times to retry showing the bubble if the browser action
// toolbar is animating.
int animation_wait_retries_;
// The 'x' that the user can press to hide the info bubble shelf.
scoped_ptr<CustomDrawButton> close_button_;
InfoBubbleGtk* info_bubble_;
DISALLOW_COPY_AND_ASSIGN(ExtensionInstalledBubbleGtk);
};
#endif // CHROME_BROWSER_GTK_EXTENSION_INSTALLED_BUBBLE_GTK_H_
|