1 // Copyright (c) 2012 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 CHROME_BROWSER_INFOBARS_INFOBAR_H_
6 #define CHROME_BROWSER_INFOBARS_INFOBAR_H_
10 #include "base/basictypes.h"
11 #include "base/compiler_specific.h"
12 #include "build/build_config.h"
13 #include "chrome/browser/infobars/infobar_delegate.h"
14 #include "third_party/skia/include/core/SkColor.h"
15 #include "ui/base/animation/animation_delegate.h"
16 #include "ui/base/animation/slide_animation.h"
17 #include "ui/gfx/size.h"
19 // TODO(sail): These functions should be static methods in the InfoBar class
20 // below once all platforms use that class.
21 SkColor
GetInfoBarTopColor(InfoBarDelegate::Type infobar_type
);
22 SkColor
GetInfoBarBottomColor(InfoBarDelegate::Type infobar_type
);
24 // TODO(pkasting): Same with these notification-related typedefs.
25 typedef InfoBarDelegate InfoBarAddedDetails
;
26 typedef std::pair
<InfoBarDelegate
*, bool> InfoBarRemovedDetails
;
27 typedef std::pair
<InfoBarDelegate
*, InfoBarDelegate
*> InfoBarReplacedDetails
;
29 // TODO(pkasting): Port Mac to use this.
30 #if defined(TOOLKIT_VIEWS) || defined(TOOLKIT_GTK)
32 class InfoBarContainer
;
35 class InfoBar
: public ui::AnimationDelegate
{
37 InfoBar(InfoBarService
* owner
, InfoBarDelegate
* delegate
);
40 // Platforms must define these.
41 static const int kDefaultBarTargetHeight
;
42 static const int kSeparatorLineHeight
;
43 static const int kDefaultArrowTargetHeight
;
44 static const int kMaximumArrowTargetHeight
;
45 // The half-width (see comments on |arrow_half_width_| below) scales to its
46 // default and maximum values proportionally to how the height scales to its.
47 static const int kDefaultArrowTargetHalfWidth
;
48 static const int kMaximumArrowTargetHalfWidth
;
50 InfoBarDelegate
* delegate() { return delegate_
; }
51 void set_container(InfoBarContainer
* container
) { container_
= container
; }
53 // Makes the infobar visible. If |animate| is true, the infobar is then
54 // animated to full size.
55 void Show(bool animate
);
57 // Makes the infobar hidden. If |animate| is true, the infobar is first
58 // animated to zero size. Once the infobar is hidden, it is removed from its
59 // container (triggering its deletion), and its delegate is closed.
60 void Hide(bool animate
);
62 // Changes the target height of the arrow portion of the infobar. This has no
63 // effect once the infobar is animating closed.
64 void SetArrowTargetHeight(int height
);
66 // Notifies the infobar that it is no longer owned and should close its
67 // delegate once it is invisible.
70 const ui::SlideAnimation
& animation() const { return animation_
; }
71 int arrow_height() const { return arrow_height_
; }
72 int arrow_target_height() const { return arrow_target_height_
; }
73 int arrow_half_width() const { return arrow_half_width_
; }
74 int total_height() const { return arrow_height_
+ bar_height_
; }
77 // ui::AnimationDelegate:
78 virtual void AnimationProgressed(const ui::Animation
* animation
) OVERRIDE
;
80 // Forwards a close request to our owner.
81 // NOTE: Subclasses should not call this if we're already unowned.
84 // Changes the target height of the main ("bar") portion of the infobar.
85 void SetBarTargetHeight(int height
);
87 // Given a control with size |prefsize|, returns the centered y position
88 // within us, taking into account animation so the control "slides in" (or
89 // out) as we animate open and closed.
90 int OffsetY(const gfx::Size
& prefsize
) const;
92 bool owned() const { return !!owner_
; }
93 const InfoBarContainer
* container() const { return container_
; }
94 InfoBarContainer
* container() { return container_
; }
95 ui::SlideAnimation
* animation() { return &animation_
; }
96 int bar_height() const { return bar_height_
; }
97 int bar_target_height() const { return bar_target_height_
; }
99 // Platforms may optionally override these if they need to do work during
100 // processing of the given calls.
101 virtual void PlatformSpecificShow(bool animate
) {}
102 virtual void PlatformSpecificHide(bool animate
) {}
103 virtual void PlatformSpecificOnCloseSoon() {}
104 virtual void PlatformSpecificOnHeightsRecalculated() {}
107 // ui::AnimationDelegate:
108 virtual void AnimationEnded(const ui::Animation
* animation
) OVERRIDE
;
110 // Finds the new desired arrow and bar heights, and if they differ from the
111 // current ones, calls PlatformSpecificOnHeightRecalculated(). Informs our
112 // container our state has changed if either the heights have changed or
113 // |force_notify| is set.
114 void RecalculateHeights(bool force_notify
);
116 // Checks whether we're closed. If so, notifies the container that it should
117 // remove us (which will cause the platform-specific code to asynchronously
118 // delete us) and closes the delegate.
121 InfoBarService
* owner_
;
122 InfoBarDelegate
* delegate_
;
123 InfoBarContainer
* container_
;
124 ui::SlideAnimation animation_
;
126 // The current and target heights of the arrow and bar portions, and half the
127 // current arrow width. (It's easier to work in half-widths as we draw the
128 // arrow as two halves on either side of a center point.)
129 int arrow_height_
; // Includes both fill and top stroke.
130 int arrow_target_height_
;
131 int arrow_half_width_
; // Includes only fill.
132 int bar_height_
; // Includes both fill and bottom separator.
133 int bar_target_height_
;
135 DISALLOW_COPY_AND_ASSIGN(InfoBar
);
138 #elif defined(OS_MACOSX)
139 #include "chrome/browser/ui/cocoa/infobars/infobar.h"
142 #endif // CHROME_BROWSER_INFOBARS_INFOBAR_H_