Home | History | Annotate | Download | only in core
      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.
      4 
      5 #ifndef COMPONENTS_INFOBARS_CORE_INFOBAR_DELEGATE_H_
      6 #define COMPONENTS_INFOBARS_CORE_INFOBAR_DELEGATE_H_
      7 
      8 #include "base/basictypes.h"
      9 #include "base/strings/string16.h"
     10 #include "ui/base/window_open_disposition.h"
     11 
     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;
     22 
     23 namespace translate {
     24 class TranslateInfoBarDelegate;
     25 }
     26 
     27 namespace gfx {
     28 class Image;
     29 }
     30 
     31 namespace infobars {
     32 
     33 class InfoBar;
     34 
     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
     39 // InfoBar variety.
     40 class InfoBarDelegate {
     41  public:
     42   // The type of the infobar. It controls its appearance, such as its background
     43   // color.
     44   enum Type {
     45     WARNING_TYPE,
     46     PAGE_ACTION_TYPE,
     47   };
     48 
     49   enum InfoBarAutomationType {
     50     CONFIRM_INFOBAR,
     51     PASSWORD_INFOBAR,
     52     RPH_INFOBAR,
     53     UNKNOWN_INFOBAR,
     54   };
     55 
     56   // Describes navigation events, used to decide whether infobars should be
     57   // dismissed.
     58   struct NavigationDetails {
     59     // Unique identifier for the entry.
     60     int entry_id;
     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.
     66     bool is_main_frame;
     67     bool is_reload;
     68     bool is_redirect;
     69   };
     70 
     71   // Value to use when the InfoBar has no icon to show.
     72   static const int kNoIconID;
     73 
     74   // Called when the InfoBar that owns this delegate is being destroyed.  At
     75   // this point nothing is visible onscreen.
     76   virtual ~InfoBarDelegate();
     77 
     78   virtual InfoBarAutomationType GetInfoBarAutomationType() const;
     79 
     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;
     87 
     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;
     94 
     95   // Called when the user clicks on the close button to dismiss the infobar.
     96   virtual void InfoBarDismissed();
     97 
     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;
    101 
    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;
    105 
    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();
    118 
    119   void set_infobar(InfoBar* infobar) { infobar_ = infobar; }
    120 
    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();
    124 
    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;
    128 
    129  protected:
    130   InfoBarDelegate();
    131 
    132   // Returns true if the navigation is to a new URL or a reload occured.
    133   virtual bool ShouldExpireInternal(const NavigationDetails& details) const;
    134 
    135   int contents_unique_id() const { return contents_unique_id_; }
    136   InfoBar* infobar() { return infobar_; }
    137 
    138  private:
    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_;
    142 
    143   // The InfoBar associated with us.
    144   InfoBar* infobar_;
    145 
    146   DISALLOW_COPY_AND_ASSIGN(InfoBarDelegate);
    147 };
    148 
    149 }  // namespace infobars
    150 
    151 #endif  // COMPONENTS_INFOBARS_CORE_INFOBAR_DELEGATE_H_
    152