OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/ui/views/infobars/link_infobar.h" | 5 #include "chrome/browser/ui/views/infobars/alternate_nav_infobar_view.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "chrome/browser/api/infobars/link_infobar_delegate.h" | |
9 #include "chrome/browser/event_disposition.h" | 8 #include "chrome/browser/event_disposition.h" |
| 9 #include "chrome/browser/infobars/alternate_nav_infobar_delegate.h" |
10 #include "ui/views/controls/label.h" | 10 #include "ui/views/controls/label.h" |
11 #include "ui/views/controls/link.h" | 11 #include "ui/views/controls/link.h" |
12 | 12 |
13 // LinkInfoBarDelegate -------------------------------------------------------- | 13 // AlternateNavInfoBarDelegate ------------------------------------------------- |
14 | 14 |
15 InfoBar* LinkInfoBarDelegate::CreateInfoBar(InfoBarService* owner) { | 15 InfoBar* AlternateNavInfoBarDelegate::CreateInfoBar(InfoBarService* owner) { |
16 return new LinkInfoBar(owner, this); | 16 return new AlternateNavInfoBarView(owner, this); |
17 } | 17 } |
18 | 18 |
19 // LinkInfoBar ---------------------------------------------------------------- | 19 // AlternateNavInfoBarView ----------------------------------------------------- |
20 | 20 |
21 LinkInfoBar::LinkInfoBar(InfoBarService* owner, | 21 AlternateNavInfoBarView::AlternateNavInfoBarView( |
22 LinkInfoBarDelegate* delegate) | 22 InfoBarService* owner, |
| 23 AlternateNavInfoBarDelegate* delegate) |
23 : InfoBarView(owner, delegate), | 24 : InfoBarView(owner, delegate), |
24 label_1_(NULL), | 25 label_1_(NULL), |
25 link_(NULL), | 26 link_(NULL), |
26 label_2_(NULL) { | 27 label_2_(NULL) { |
27 } | 28 } |
28 | 29 |
29 LinkInfoBar::~LinkInfoBar() { | 30 AlternateNavInfoBarView::~AlternateNavInfoBarView() { |
30 } | 31 } |
31 | 32 |
32 void LinkInfoBar::Layout() { | 33 void AlternateNavInfoBarView::Layout() { |
33 InfoBarView::Layout(); | 34 InfoBarView::Layout(); |
34 | 35 |
35 // TODO(pkasting): This isn't perfect; there are points when we should elide a | 36 // TODO(pkasting): This isn't perfect; there are points when we should elide a |
36 // view because its subsequent view will be too small to show an ellipsis. | 37 // view because its subsequent view will be too small to show an ellipsis. |
37 gfx::Size label_1_size = label_1_->GetPreferredSize(); | 38 gfx::Size label_1_size = label_1_->GetPreferredSize(); |
38 int available_width = EndX() - StartX(); | 39 int available_width = EndX() - StartX(); |
39 label_1_->SetBounds(StartX(), OffsetY(label_1_size), | 40 label_1_->SetBounds(StartX(), OffsetY(label_1_size), |
40 std::min(label_1_size.width(), available_width), label_1_size.height()); | 41 std::min(label_1_size.width(), available_width), label_1_size.height()); |
41 available_width = std::max(0, available_width - label_1_size.width()); | 42 available_width = std::max(0, available_width - label_1_size.width()); |
42 | 43 |
43 gfx::Size link_size = link_->GetPreferredSize(); | 44 gfx::Size link_size = link_->GetPreferredSize(); |
44 link_->SetBounds(label_1_->bounds().right(), OffsetY(link_size), | 45 link_->SetBounds(label_1_->bounds().right(), OffsetY(link_size), |
45 std::min(link_size.width(), available_width), link_size.height()); | 46 std::min(link_size.width(), available_width), link_size.height()); |
46 available_width = std::max(0, available_width - link_size.width()); | 47 available_width = std::max(0, available_width - link_size.width()); |
47 | 48 |
48 gfx::Size label_2_size = label_2_->GetPreferredSize(); | 49 gfx::Size label_2_size = label_2_->GetPreferredSize(); |
49 label_2_->SetBounds(link_->bounds().right(), OffsetY(label_2_size), | 50 label_2_->SetBounds(link_->bounds().right(), OffsetY(label_2_size), |
50 std::min(label_2_size.width(), available_width), label_2_size.height()); | 51 std::min(label_2_size.width(), available_width), label_2_size.height()); |
51 } | 52 } |
52 | 53 |
53 void LinkInfoBar::ViewHierarchyChanged(bool is_add, View* parent, View* child) { | 54 void AlternateNavInfoBarView::ViewHierarchyChanged(bool is_add, |
| 55 View* parent, |
| 56 View* child) { |
54 if (is_add && (child == this) && (label_1_ == NULL)) { | 57 if (is_add && (child == this) && (label_1_ == NULL)) { |
55 LinkInfoBarDelegate* delegate = GetDelegate(); | 58 AlternateNavInfoBarDelegate* delegate = GetDelegate(); |
56 size_t offset; | 59 size_t offset; |
57 string16 message_text = delegate->GetMessageTextWithOffset(&offset); | 60 string16 message_text = delegate->GetMessageTextWithOffset(&offset); |
58 DCHECK_NE(string16::npos, offset); | 61 DCHECK_NE(string16::npos, offset); |
59 label_1_ = CreateLabel(message_text.substr(0, offset)); | 62 label_1_ = CreateLabel(message_text.substr(0, offset)); |
60 AddChildView(label_1_); | 63 AddChildView(label_1_); |
61 | 64 |
62 link_ = CreateLink(delegate->GetLinkText(), this); | 65 link_ = CreateLink(delegate->GetLinkText(), this); |
63 AddChildView(link_); | 66 AddChildView(link_); |
64 | 67 |
65 label_2_ = CreateLabel(message_text.substr(offset)); | 68 label_2_ = CreateLabel(message_text.substr(offset)); |
66 AddChildView(label_2_); | 69 AddChildView(label_2_); |
67 } | 70 } |
68 | 71 |
69 // This must happen after adding all other children so InfoBarView can ensure | 72 // This must happen after adding all other children so InfoBarView can ensure |
70 // the close button is the last child. | 73 // the close button is the last child. |
71 InfoBarView::ViewHierarchyChanged(is_add, parent, child); | 74 InfoBarView::ViewHierarchyChanged(is_add, parent, child); |
72 } | 75 } |
73 | 76 |
74 void LinkInfoBar::LinkClicked(views::Link* source, int event_flags) { | 77 void AlternateNavInfoBarView::LinkClicked(views::Link* source, |
| 78 int event_flags) { |
75 if (!owned()) | 79 if (!owned()) |
76 return; // We're closing; don't call anything, it might access the owner. | 80 return; // We're closing; don't call anything, it might access the owner. |
77 DCHECK(link_ != NULL); | 81 DCHECK(link_ != NULL); |
78 DCHECK_EQ(link_, source); | 82 DCHECK_EQ(link_, source); |
79 if (GetDelegate()->LinkClicked( | 83 if (GetDelegate()->LinkClicked( |
80 chrome::DispositionFromEventFlags(event_flags))) | 84 chrome::DispositionFromEventFlags(event_flags))) |
81 RemoveSelf(); | 85 RemoveSelf(); |
82 } | 86 } |
83 | 87 |
84 LinkInfoBarDelegate* LinkInfoBar::GetDelegate() { | 88 AlternateNavInfoBarDelegate* AlternateNavInfoBarView::GetDelegate() { |
85 return delegate()->AsLinkInfoBarDelegate(); | 89 return delegate()->AsAlternateNavInfoBarDelegate(); |
86 } | 90 } |
OLD | NEW |