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

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 if (message_strings.empty())
85 message_label->SetMultiLine(true); 85 message_strings.push_back(error_->GetBubbleViewMessage());
86 message_label->SizeToFit(kMaxBubbleViewWidth); 86 std::vector<views::Label*> message_labels;
87 message_label->SetHorizontalAlignment(gfx::ALIGN_LEFT); 87 for (size_t i = 0; i < message_strings.size(); ++i) {
88 views::Label* message_label = new views::Label(message_strings[i]);
89 message_label->SetMultiLine(true);
90 message_label->SizeToFit(kMaxBubbleViewWidth);
91 message_label->SetHorizontalAlignment(gfx::ALIGN_LEFT);
92 message_labels.push_back(message_label);
93 }
88 94
89 string16 accept_string(error_->GetBubbleViewAcceptButtonLabel()); 95 string16 accept_string(error_->GetBubbleViewAcceptButtonLabel());
90 scoped_ptr<views::LabelButton> accept_button( 96 scoped_ptr<views::LabelButton> accept_button(
91 new views::LabelButton(this, accept_string)); 97 new views::LabelButton(this, accept_string));
92 accept_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON); 98 accept_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON);
93 accept_button->SetIsDefault(true); 99 accept_button->SetIsDefault(true);
94 accept_button->set_tag(TAG_ACCEPT_BUTTON); 100 accept_button->set_tag(TAG_ACCEPT_BUTTON);
95 101
96 string16 cancel_string(error_->GetBubbleViewCancelButtonLabel()); 102 string16 cancel_string(error_->GetBubbleViewCancelButtonLabel());
97 scoped_ptr<views::LabelButton> cancel_button; 103 scoped_ptr<views::LabelButton> cancel_button;
98 if (!cancel_string.empty()) { 104 if (!cancel_string.empty()) {
99 cancel_button.reset(new views::LabelButton(this, cancel_string)); 105 cancel_button.reset(new views::LabelButton(this, cancel_string));
100 cancel_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON); 106 cancel_button->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON);
101 cancel_button->set_tag(TAG_CANCEL_BUTTON); 107 cancel_button->set_tag(TAG_CANCEL_BUTTON);
102 } 108 }
103 109
104 views::GridLayout* layout = new views::GridLayout(this); 110 views::GridLayout* layout = new views::GridLayout(this);
105 SetLayoutManager(layout); 111 SetLayoutManager(layout);
106 layout->SetInsets(0, 0, kLayoutBottomPadding, 0); 112 layout->SetInsets(0, 0, kLayoutBottomPadding, 0);
107 113
108 // Top row, icon and title. 114 // Top row, icon and title.
109 views::ColumnSet* cs = layout->AddColumnSet(0); 115 views::ColumnSet* cs = layout->AddColumnSet(0);
110 cs->AddColumn(views::GridLayout::LEADING, views::GridLayout::LEADING, 116 cs->AddColumn(views::GridLayout::LEADING, views::GridLayout::LEADING,
111 0, views::GridLayout::USE_PREF, 0, 0); 117 0, views::GridLayout::USE_PREF, 0, 0);
112 cs->AddPaddingColumn(0, kTitleHorizontalPadding); 118 cs->AddPaddingColumn(0, kTitleHorizontalPadding);
113 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 119 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL,
114 1, views::GridLayout::USE_PREF, 0, 0); 120 1, views::GridLayout::USE_PREF, 0, 0);
115 121
116 // Middle row, message label. 122 // Middle rows, message labels.
117 cs = layout->AddColumnSet(1); 123 cs = layout->AddColumnSet(1);
118 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL, 124 cs->AddColumn(views::GridLayout::FILL, views::GridLayout::FILL,
119 1, views::GridLayout::USE_PREF, 0, 0); 125 1, views::GridLayout::USE_PREF, 0, 0);
120 126
121 // Bottom row, accept and cancel button. 127 // Bottom row, accept and cancel button.
122 cs = layout->AddColumnSet(2); 128 cs = layout->AddColumnSet(2);
123 cs->AddPaddingColumn(1, views::kRelatedControlHorizontalSpacing); 129 cs->AddPaddingColumn(1, views::kRelatedControlHorizontalSpacing);
124 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING, 130 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING,
125 0, views::GridLayout::USE_PREF, 0, 0); 131 0, views::GridLayout::USE_PREF, 0, 0);
126 if (cancel_button.get()) { 132 if (cancel_button.get()) {
127 cs->AddPaddingColumn(0, views::kRelatedButtonHSpacing); 133 cs->AddPaddingColumn(0, views::kRelatedButtonHSpacing);
128 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING, 134 cs->AddColumn(views::GridLayout::TRAILING, views::GridLayout::LEADING,
129 0, views::GridLayout::USE_PREF, 0, 0); 135 0, views::GridLayout::USE_PREF, 0, 0);
130 } 136 }
131 137
132 layout->StartRow(1, 0); 138 layout->StartRow(1, 0);
133 layout->AddView(image_view.release()); 139 layout->AddView(image_view.release());
134 layout->AddView(title_label.release()); 140 layout->AddView(title_label.release());
135 layout->AddPaddingRow(0, views::kRelatedControlSmallVerticalSpacing); 141 layout->AddPaddingRow(0, views::kRelatedControlSmallVerticalSpacing);
136 142
137 layout->StartRow(1, 1); 143 for (size_t i = 0; i < message_labels.size(); ++i) {
138 layout->AddView(message_label); 144 layout->StartRow(1, 1);
145 layout->AddView(message_labels[i]);
146 if (i < message_labels.size() - 1)
147 layout->AddPaddingRow(0, views::kRelatedControlVerticalSpacing);
148 }
139 layout->AddPaddingRow(0, views::kLabelToControlVerticalSpacing); 149 layout->AddPaddingRow(0, views::kLabelToControlVerticalSpacing);
140 150
141 layout->StartRow(0, 2); 151 layout->StartRow(0, 2);
142 layout->AddView(accept_button.release()); 152 layout->AddView(accept_button.release());
143 if (cancel_button.get()) 153 if (cancel_button.get())
144 layout->AddView(cancel_button.release()); 154 layout->AddView(cancel_button.release());
145 155
146 // Adjust the message label size in case buttons are too long. 156 // Adjust the message label size in case buttons are too long.
147 message_label->SizeToFit(layout->GetPreferredSize(this).width()); 157 for (size_t i = 0; i < message_labels.size(); ++i)
158 message_labels[i]->SizeToFit(layout->GetPreferredSize(this).width());
148 } 159 }
149 160
150 GlobalErrorBubbleView::~GlobalErrorBubbleView() { 161 GlobalErrorBubbleView::~GlobalErrorBubbleView() {
151 } 162 }
152 163
153 void GlobalErrorBubbleView::ButtonPressed(views::Button* sender, 164 void GlobalErrorBubbleView::ButtonPressed(views::Button* sender,
154 const ui::Event& event) { 165 const ui::Event& event) {
155 if (error_) { 166 if (error_) {
156 if (sender->tag() == TAG_ACCEPT_BUTTON) 167 if (sender->tag() == TAG_ACCEPT_BUTTON)
157 error_->BubbleViewAcceptButtonPressed(browser_); 168 error_->BubbleViewAcceptButtonPressed(browser_);
158 else if (sender->tag() == TAG_CANCEL_BUTTON) 169 else if (sender->tag() == TAG_CANCEL_BUTTON)
159 error_->BubbleViewCancelButtonPressed(browser_); 170 error_->BubbleViewCancelButtonPressed(browser_);
160 else 171 else
161 NOTREACHED(); 172 NOTREACHED();
162 } 173 }
163 GetWidget()->Close(); 174 GetWidget()->Close();
164 } 175 }
165 176
166 void GlobalErrorBubbleView::WindowClosing() { 177 void GlobalErrorBubbleView::WindowClosing() {
167 if (error_) 178 if (error_)
168 error_->BubbleViewDidClose(browser_); 179 error_->BubbleViewDidClose(browser_);
169 } 180 }
170 181
171 void GlobalErrorBubbleView::CloseBubbleView() { 182 void GlobalErrorBubbleView::CloseBubbleView() {
172 GetWidget()->Close(); 183 GetWidget()->Close();
173 } 184 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698