Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(204)

Unified Diff: chrome/browser/ui/views/infobars/infobar_container.cc

Issue 6989001: Misc. infobar stuff: (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/views/infobars/infobar_container.cc
===================================================================
--- chrome/browser/ui/views/infobars/infobar_container.cc (revision 86331)
+++ chrome/browser/ui/views/infobars/infobar_container.cc (working copy)
@@ -1,198 +0,0 @@
-// Copyright (c) 2011 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.
-
-#include "chrome/browser/ui/views/infobars/infobar_container.h"
-
-#include "chrome/browser/tab_contents/infobar_delegate.h"
-#include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h"
-#include "chrome/browser/ui/views/infobars/infobar.h"
-#include "content/common/notification_details.h"
-#include "content/common/notification_source.h"
-#include "ui/base/animation/slide_animation.h"
-
-InfoBarContainer::Delegate::~Delegate() {
-}
-
-InfoBarContainer::InfoBarContainer(Delegate* delegate)
- : delegate_(delegate),
- tab_contents_(NULL),
- top_arrow_target_height_(InfoBar::kDefaultArrowTargetHeight) {
-}
-
-InfoBarContainer::~InfoBarContainer() {
- // RemoveAllInfoBarsForDestruction() should have already cleared our infobars.
- DCHECK(infobars_.empty());
-}
-
-void InfoBarContainer::ChangeTabContents(TabContentsWrapper* contents) {
- registrar_.RemoveAll();
-
- while (!infobars_.empty()) {
- InfoBar* infobar = infobars_.front();
- // NULL the container pointer first so that if the infobar is currently
- // animating, OnInfoBarAnimated() won't get called; we'll manually trigger
- // this once for the whole set of changes below. This also prevents
- // InfoBar::MaybeDelete() from calling RemoveInfoBar() a second time if the
- // infobar happens to be at zero height (dunno if this can actually happen).
- infobar->set_container(NULL);
- RemoveInfoBar(infobar);
- }
-
- tab_contents_ = contents;
- if (tab_contents_) {
- Source<TabContents> tc_source(tab_contents_->tab_contents());
- registrar_.Add(this, NotificationType::TAB_CONTENTS_INFOBAR_ADDED,
- tc_source);
- registrar_.Add(this, NotificationType::TAB_CONTENTS_INFOBAR_REMOVED,
- tc_source);
- registrar_.Add(this, NotificationType::TAB_CONTENTS_INFOBAR_REPLACED,
- tc_source);
-
- for (size_t i = 0; i < contents->infobar_count(); ++i) {
- // As when we removed the infobars above, we prevent callbacks to
- // OnInfoBarAnimated() for each infobar.
- AddInfoBar(tab_contents_->GetInfoBarDelegateAt(i)->CreateInfoBar(), false,
- NO_CALLBACK);
- }
- }
-
- // Now that everything is up to date, signal the delegate to re-layout.
- OnInfoBarStateChanged(false);
-}
-
-int InfoBarContainer::GetVerticalOverlap(int* total_height) {
- // Our |total_height| is the sum of the preferred heights of the InfoBars
- // contained within us plus the |vertical_overlap|.
- int vertical_overlap = 0;
- int next_infobar_y = 0;
-
- for (InfoBars::iterator i(infobars_.begin()); i != infobars_.end(); ++i) {
- InfoBar* infobar = *i;
- next_infobar_y -= infobar->arrow_height();
- vertical_overlap = std::max(vertical_overlap, -next_infobar_y);
- next_infobar_y += infobar->total_height();
- }
-
- if (total_height)
- *total_height = next_infobar_y + vertical_overlap;
- return vertical_overlap;
-}
-
-void InfoBarContainer::SetMaxTopArrowHeight(int height) {
- // Decrease the height by the arrow stroke thickness, which is the separator
- // line height, because the infobar arrow target heights are without-stroke.
- top_arrow_target_height_ = std::min(
- std::max(height - InfoBar::kSeparatorLineHeight, 0),
- InfoBar::kMaximumArrowTargetHeight);
- UpdateInfoBarArrowTargetHeights();
-}
-
-void InfoBarContainer::OnInfoBarStateChanged(bool is_animating) {
- if (delegate_)
- delegate_->InfoBarContainerStateChanged(is_animating);
-}
-
-void InfoBarContainer::RemoveDelegate(InfoBarDelegate* delegate) {
- tab_contents_->RemoveInfoBar(delegate);
-}
-
-void InfoBarContainer::RemoveInfoBar(InfoBar* infobar) {
- InfoBars::iterator infobar_iterator(std::find(infobars_.begin(),
- infobars_.end(), infobar));
- DCHECK(infobar_iterator != infobars_.end());
- PlatformSpecificRemoveInfoBar(infobar);
- infobars_.erase(infobar_iterator);
-}
-
-void InfoBarContainer::RemoveAllInfoBarsForDestruction() {
- // Before we remove any children, we reset |delegate_|, so that no removals
- // will result in us trying to call
- // delegate_->InfoBarContainerStateChanged(). This is important because at
- // this point |delegate_| may be shutting down, and it's at best unimportant
- // and at worst disastrous to call that.
- delegate_ = NULL;
- ChangeTabContents(NULL);
-}
-
-void InfoBarContainer::Observe(NotificationType type,
- const NotificationSource& source,
- const NotificationDetails& details) {
- switch (type.value) {
- case NotificationType::TAB_CONTENTS_INFOBAR_ADDED:
- AddInfoBar(Details<InfoBarDelegate>(details)->CreateInfoBar(), true,
- WANT_CALLBACK);
- break;
-
- case NotificationType::TAB_CONTENTS_INFOBAR_REMOVED:
- RemoveInfoBar(Details<InfoBarDelegate>(details).ptr(), true);
- break;
-
- case NotificationType::TAB_CONTENTS_INFOBAR_REPLACED: {
- typedef std::pair<InfoBarDelegate*, InfoBarDelegate*> InfoBarPair;
- InfoBarPair* infobar_pair = Details<InfoBarPair>(details).ptr();
- RemoveInfoBar(infobar_pair->first, false);
- AddInfoBar(infobar_pair->second->CreateInfoBar(), false, WANT_CALLBACK);
- break;
- }
-
- default:
- NOTREACHED();
- break;
- }
-}
-
-void InfoBarContainer::RemoveInfoBar(InfoBarDelegate* delegate,
- bool use_animation) {
- // Search for the infobar associated with |delegate|. We cannot search for
- // |delegate| in |tab_contents_|, because an InfoBar remains alive until its
- // close animation completes, while the delegate is removed from the tab
- // immediately.
- for (InfoBars::iterator i(infobars_.begin()); i != infobars_.end(); ++i) {
- InfoBar* infobar = *i;
- if (infobar->delegate() == delegate) {
- // We merely need hide the infobar; it will call back to RemoveInfoBar()
- // itself once it's hidden.
- infobar->Hide(use_animation);
- UpdateInfoBarArrowTargetHeights();
- break;
- }
- }
-}
-
-void InfoBarContainer::AddInfoBar(InfoBar* infobar,
- bool animate,
- CallbackStatus callback_status) {
- DCHECK(std::find(infobars_.begin(), infobars_.end(), infobar) ==
- infobars_.end());
- infobars_.push_back(infobar);
- UpdateInfoBarArrowTargetHeights();
- PlatformSpecificAddInfoBar(infobar);
- if (callback_status == WANT_CALLBACK)
- infobar->set_container(this);
- infobar->Show(animate);
- if (callback_status == NO_CALLBACK)
- infobar->set_container(this);
-}
-
-void InfoBarContainer::UpdateInfoBarArrowTargetHeights() {
- for (size_t i = 0; i < infobars_.size(); ++i)
- infobars_[i]->SetArrowTargetHeight(ArrowTargetHeightForInfoBar(i));
-}
-
-int InfoBarContainer::ArrowTargetHeightForInfoBar(size_t infobar_index) const {
- if (!delegate_->DrawInfoBarArrows(NULL))
- return 0;
- if (infobar_index == 0)
- return top_arrow_target_height_;
- const ui::SlideAnimation* first_infobar_animation =
- const_cast<const InfoBar*>(infobars_.front())->animation();
- if ((infobar_index > 1) || first_infobar_animation->IsShowing())
- return InfoBar::kDefaultArrowTargetHeight;
- // When the first infobar is animating closed, we animate the second infobar's
- // arrow target height from the default to the top target height. Note that
- // the animation values here are going from 1.0 -> 0.0 as the top bar closes.
- return top_arrow_target_height_ + static_cast<int>(
- (InfoBar::kDefaultArrowTargetHeight - top_arrow_target_height_) *
- first_infobar_animation->GetCurrentValue());
-}
« no previous file with comments | « chrome/browser/ui/views/infobars/infobar_container.h ('k') | chrome/browser/ui/views/infobars/infobar_container_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698