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

Side by Side Diff: chrome/browser/ui/views/global_error_bubble_view.cc

Issue 14262009: Add support for multi-line GlobalError messages to Views. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/global_error_bubble_view.h" 5 #include "chrome/browser/ui/views/global_error_bubble_view.h"
6 6
7 #include "base/utf_string_conversions.h" 7 #include "base/utf_string_conversions.h"
8 #include "chrome/browser/ui/global_error/global_error.h" 8 #include "chrome/browser/ui/global_error/global_error.h"
9 #include "chrome/browser/ui/global_error/global_error_service.h" 9 #include "chrome/browser/ui/global_error/global_error_service.h"
10 #include "chrome/browser/ui/global_error/global_error_service_factory.h" 10 #include "chrome/browser/ui/global_error/global_error_service_factory.h"
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
73 int resource_id = error_->GetBubbleViewIconResourceID(); 73 int resource_id = error_->GetBubbleViewIconResourceID();
74 scoped_ptr<views::ImageView> image_view(new views::ImageView()); 74 scoped_ptr<views::ImageView> image_view(new views::ImageView());
75 image_view->SetImage(rb.GetImageNamed(resource_id).ToImageSkia()); 75 image_view->SetImage(rb.GetImageNamed(resource_id).ToImageSkia());
76 76
77 string16 title_string(error_->GetBubbleViewTitle()); 77 string16 title_string(error_->GetBubbleViewTitle());
78 scoped_ptr<views::Label> title_label(new views::Label(title_string)); 78 scoped_ptr<views::Label> title_label(new views::Label(title_string));
79 title_label->SetMultiLine(true); 79 title_label->SetMultiLine(true);
80 title_label->SetHorizontalAlignment(gfx::ALIGN_LEFT); 80 title_label->SetHorizontalAlignment(gfx::ALIGN_LEFT);
81 title_label->SetFont(rb.GetFont(ui::ResourceBundle::MediumFont)); 81 title_label->SetFont(rb.GetFont(ui::ResourceBundle::MediumFont));
82 82
83 string16 message_string(error_->GetBubbleViewMessage()); 83 std::vector<string16> message_strings(error_->GetBubbleViewMessages());
84 views::Label* message_label = new views::Label(message_string); 84 std::vector<views::Label*> message_labels;
85 message_label->SetMultiLine(true); 85 for (size_t i = 0; i < message_strings.size(); ++i) {
86 message_label->SizeToFit(kMaxBubbleViewWidth); 86 views::Label* message_label = new views::Label(message_strings[i]);
87 message_label->SetHorizontalAlignment(gfx::ALIGN_LEFT); 87 message_label->SetMultiLine(true);
88 message_label->SizeToFit(kMaxBubbleViewWidth);
89 message_label->SetHorizontalAlignment(gfx::ALIGN_LEFT);
90 message_labels.push_back(message_label);
91 }
88 92
89 string16 accept_string(error_->GetBubbleViewAcceptButtonLabel()); 93 string16 accept_string(error_->GetBubbleViewAcceptButtonLabel());
90 scoped_ptr<views::LabelButton> accept_button( 94 scoped_ptr<views::LabelButton> accept_button(
91 new views::LabelButton(this, accept_string)); 95 new views::LabelButton(this, accept_string));
92 accept_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON); 96 accept_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON);
93 accept_button->SetIsDefault(true); 97 accept_button->SetIsDefault(true);
94 accept_button->set_tag(TAG_ACCEPT_BUTTON); 98 accept_button->set_tag(TAG_ACCEPT_BUTTON);
95 99
96 string16 cancel_string(error_->GetBubbleViewCancelButtonLabel()); 100 string16 cancel_string(error_->GetBubbleViewCancelButtonLabel());
97 scoped_ptr<views::LabelButton> cancel_button; 101 scoped_ptr<views::LabelButton> cancel_button;
98 if (!cancel_string.empty()) { 102 if (!cancel_string.empty()) {
99 cancel_button.reset(new views::LabelButton(this, cancel_string)); 103 cancel_button.reset(new views::LabelButton(this, cancel_string));
100 cancel_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON); 104 cancel_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON);
101 cancel_button->set_tag(TAG_CANCEL_BUTTON); 105 cancel_button->set_tag(TAG_CANCEL_BUTTON);
102 } 106 }
103 107
104 views::GridLayout* layout = new views::GridLayout(this); 108 views::GridLayout* layout = new views::GridLayout(this);
105 SetLayoutManager(layout); 109 SetLayoutManager(layout);
106 layout->SetInsets(0, 0, kLayoutBottomPadding, 0); 110 layout->SetInsets(0, 0, kLayoutBottomPadding, 0);
107 111
108 // Top row, icon and title. 112 // Top row, icon and title.
109 views::ColumnSet* cs = layout->AddColumnSet(0); 113 views::ColumnSet* cs = layout->AddColumnSet(0);
110 cs->AddColumn(views::GridLayout::LEADING, views::GridLayout::LEADING, 114 cs->AddColumn(views::GridLayout::LEADING, views::GridLayout::LEADING,
111 0, views::GridLayout::USE_PREF, 0, 0); 115 0, views::GridLayout::USE_PREF, 0, 0);
112 cs->AddPaddingColumn(0, kTitleHorizontalPadding); 116 cs->AddPaddingColumn(0, kTitleHorizontalPadding);
113 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 117 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL,
114 1, views::GridLayout::USE_PREF, 0, 0); 118 1, views::GridLayout::USE_PREF, 0, 0);
115 119
116 // Middle row, message label. 120 // Middle rows, message labels.
117 cs = layout->AddColumnSet(1); 121 cs = layout->AddColumnSet(1);
118 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 122 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL,
119 1, views::GridLayout::USE_PREF, 0, 0); 123 1, views::GridLayout::USE_PREF, 0, 0);
120 124
121 // Bottom row, accept and cancel button. 125 // Bottom row, accept and cancel button.
122 cs = layout->AddColumnSet(2); 126 cs = layout->AddColumnSet(2);
123 cs->AddPaddingColumn(1, views::kRelatedControlHorizontalSpacing); 127 cs->AddPaddingColumn(1, views::kRelatedControlHorizontalSpacing);
124 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING, 128 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING,
125 0, views::GridLayout::USE_PREF, 0, 0); 129 0, views::GridLayout::USE_PREF, 0, 0);
126 if (cancel_button.get()) { 130 if (cancel_button.get()) {
127 cs->AddPaddingColumn(0, views::kRelatedButtonHSpacing); 131 cs->AddPaddingColumn(0, views::kRelatedButtonHSpacing);
128 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING, 132 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING,
129 0, views::GridLayout::USE_PREF, 0, 0); 133 0, views::GridLayout::USE_PREF, 0, 0);
130 } 134 }
131 135
132 layout->StartRow(1, 0); 136 layout->StartRow(1, 0);
133 layout->AddView(image_view.release()); 137 layout->AddView(image_view.release());
134 layout->AddView(title_label.release()); 138 layout->AddView(title_label.release());
135 layout->AddPaddingRow(0, views::kRelatedControlSmallVerticalSpacing); 139 layout->AddPaddingRow(0, views::kRelatedControlSmallVerticalSpacing);
136 140
137 layout->StartRow(1, 1); 141 for (size_t i = 0; i < message_labels.size(); ++i) {
138 layout->AddView(message_label); 142 layout->StartRow(1, 1);
143 layout->AddView(message_labels[i]);
144 if (i < message_labels.size() - 1)
145 layout->AddPaddingRow(0, views::kRelatedControlVerticalSpacing);
146 }
139 layout->AddPaddingRow(0, views::kLabelToControlVerticalSpacing); 147 layout->AddPaddingRow(0, views::kLabelToControlVerticalSpacing);
140 148
141 layout->StartRow(0, 2); 149 layout->StartRow(0, 2);
142 layout->AddView(accept_button.release()); 150 layout->AddView(accept_button.release());
143 if (cancel_button.get()) 151 if (cancel_button.get())
144 layout->AddView(cancel_button.release()); 152 layout->AddView(cancel_button.release());
145 153
146 // Adjust the message label size in case buttons are too long. 154 // Adjust the message label size in case buttons are too long.
147 message_label->SizeToFit(layout->GetPreferredSize(this).width()); 155 for (size_t i = 0; i < message_labels.size(); ++i)
156 message_labels[i]->SizeToFit(layout->GetPreferredSize(this).width());
148 } 157 }
149 158
150 GlobalErrorBubbleView::~GlobalErrorBubbleView() { 159 GlobalErrorBubbleView::~GlobalErrorBubbleView() {
151 } 160 }
152 161
153 void GlobalErrorBubbleView::ButtonPressed(views::Button* sender, 162 void GlobalErrorBubbleView::ButtonPressed(views::Button* sender,
154 const ui::Event& event) { 163 const ui::Event& event) {
155 if (error_) { 164 if (error_) {
156 if (sender->tag() == TAG_ACCEPT_BUTTON) 165 if (sender->tag() == TAG_ACCEPT_BUTTON)
157 error_->BubbleViewAcceptButtonPressed(browser_); 166 error_->BubbleViewAcceptButtonPressed(browser_);
158 else if (sender->tag() == TAG_CANCEL_BUTTON) 167 else if (sender->tag() == TAG_CANCEL_BUTTON)
159 error_->BubbleViewCancelButtonPressed(browser_); 168 error_->BubbleViewCancelButtonPressed(browser_);
160 else 169 else
161 NOTREACHED(); 170 NOTREACHED();
162 } 171 }
163 GetWidget()->Close(); 172 GetWidget()->Close();
164 } 173 }
165 174
166 void GlobalErrorBubbleView::WindowClosing() { 175 void GlobalErrorBubbleView::WindowClosing() {
167 if (error_) 176 if (error_)
168 error_->BubbleViewDidClose(browser_); 177 error_->BubbleViewDidClose(browser_);
169 } 178 }
170 179
171 void GlobalErrorBubbleView::CloseBubbleView() { 180 void GlobalErrorBubbleView::CloseBubbleView() {
172 GetWidget()->Close(); 181 GetWidget()->Close();
173 } 182 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698