1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COMPONENTS_INFOBARS_CORE_INFOBAR_DELEGATE_H_
6 #define COMPONENTS_INFOBARS_CORE_INFOBAR_DELEGATE_H_
8 #include "base/basictypes.h"
9 #include "base/strings/string16.h"
10 #include "ui/base/window_open_disposition.h"
12 class AutoLoginInfoBarDelegate
;
13 class ConfirmInfoBarDelegate
;
14 class ExtensionInfoBarDelegate
;
15 class InsecureContentInfoBarDelegate
;
16 class MediaStreamInfoBarDelegate
;
17 class PopupBlockedInfoBarDelegate
;
18 class RegisterProtocolHandlerInfoBarDelegate
;
19 class ScreenCaptureInfoBarDelegate
;
20 class ThemeInstalledInfoBarDelegate
;
21 class ThreeDAPIInfoBarDelegate
;
24 class TranslateInfoBarDelegate
;
35 // An interface implemented by objects wishing to control an InfoBar.
36 // Implementing this interface is not sufficient to use an InfoBar, since it
37 // does not map to a specific InfoBar type. Instead, you must implement
38 // ConfirmInfoBarDelegate, or override with your own delegate for your own
40 class InfoBarDelegate
{
42 // The type of the infobar. It controls its appearance, such as its background
49 enum InfoBarAutomationType
{
56 // Describes navigation events, used to decide whether infobars should be
58 struct NavigationDetails
{
59 // Unique identifier for the entry.
61 // True if it is a navigation to a different page (as opposed to in-page).
62 bool is_navigation_to_different_page
;
63 // True if the entry replaced the existing one.
64 bool did_replace_entry
;
65 // True for the main frame, false for a sub-frame.
71 // Value to use when the InfoBar has no icon to show.
72 static const int kNoIconID
;
74 // Called when the InfoBar that owns this delegate is being destroyed. At
75 // this point nothing is visible onscreen.
76 virtual ~InfoBarDelegate();
78 virtual InfoBarAutomationType
GetInfoBarAutomationType() const;
80 // Returns true if the supplied |delegate| is equal to this one. Equality is
81 // left to the implementation to define. This function is called by the
82 // InfoBarManager when determining whether or not a delegate should be
83 // added because a matching one already exists. If this function returns true,
84 // the InfoBarManager will not add the new delegate because it considers
85 // one to already be present.
86 virtual bool EqualsDelegate(InfoBarDelegate
* delegate
) const;
88 // Returns true if the InfoBar should be closed automatically after the page
89 // is navigated. By default this returns true if the navigation is to a new
90 // page (not including reloads). Subclasses wishing to change this behavior
91 // can override either this function or ShouldExpireInternal(), depending on
92 // what level of control they need.
93 virtual bool ShouldExpire(const NavigationDetails
& details
) const;
95 // Called when the user clicks on the close button to dismiss the infobar.
96 virtual void InfoBarDismissed();
98 // Return the resource ID of the icon to be shown for this InfoBar. If the
99 // value is equal to |kNoIconID|, no icon is shown.
100 virtual int GetIconID() const;
102 // Returns the type of the infobar. The type determines the appearance (such
103 // as background color) of the infobar.
104 virtual Type
GetInfoBarType() const;
106 // Type-checking downcast routines:
107 virtual AutoLoginInfoBarDelegate
* AsAutoLoginInfoBarDelegate();
108 virtual ConfirmInfoBarDelegate
* AsConfirmInfoBarDelegate();
109 virtual ExtensionInfoBarDelegate
* AsExtensionInfoBarDelegate();
110 virtual InsecureContentInfoBarDelegate
* AsInsecureContentInfoBarDelegate();
111 virtual MediaStreamInfoBarDelegate
* AsMediaStreamInfoBarDelegate();
112 virtual PopupBlockedInfoBarDelegate
* AsPopupBlockedInfoBarDelegate();
113 virtual RegisterProtocolHandlerInfoBarDelegate
*
114 AsRegisterProtocolHandlerInfoBarDelegate();
115 virtual ScreenCaptureInfoBarDelegate
* AsScreenCaptureInfoBarDelegate();
116 virtual ThemeInstalledInfoBarDelegate
* AsThemePreviewInfobarDelegate();
117 virtual translate::TranslateInfoBarDelegate
* AsTranslateInfoBarDelegate();
119 void set_infobar(InfoBar
* infobar
) { infobar_
= infobar
; }
121 // Store the unique id for the active entry, to be used later upon navigation
122 // to determine if this InfoBarDelegate should be expired.
123 void StoreActiveEntryUniqueID();
125 // Return the icon to be shown for this InfoBar. If the returned Image is
126 // empty, no icon is shown.
127 virtual gfx::Image
GetIcon() const;
132 // Returns true if the navigation is to a new URL or a reload occured.
133 virtual bool ShouldExpireInternal(const NavigationDetails
& details
) const;
135 int contents_unique_id() const { return contents_unique_id_
; }
136 InfoBar
* infobar() { return infobar_
; }
139 // The unique id of the active NavigationEntry of the WebContents that we were
140 // opened for. Used to help expire on navigations.
141 int contents_unique_id_
;
143 // The InfoBar associated with us.
146 DISALLOW_COPY_AND_ASSIGN(InfoBarDelegate
);
149 } // namespace infobars
151 #endif // COMPONENTS_INFOBARS_CORE_INFOBAR_DELEGATE_H_