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

Side by Side Diff: chrome/browser/ui/views/extensions/extension_message_bubble_view.cc

Issue 95133002: Add an extension bubble explaining which extensions are in dev mode. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: l upload Created 7 years 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) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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/extensions/suspicious_extension_bubble_view.h" 5 #include "chrome/browser/ui/views/extensions/extension_message_bubble_view.h"
6 6
7 #include "base/strings/string_number_conversions.h" 7 #include "base/strings/string_number_conversions.h"
8 #include "base/strings/string_util.h" 8 #include "base/strings/string_util.h"
9 #include "base/strings/utf_string_conversions.h" 9 #include "base/strings/utf_string_conversions.h"
10 #include "chrome/browser/extensions/dev_mode_bubble_controller.h"
11 #include "chrome/browser/extensions/extension_action_manager.h"
10 #include "chrome/browser/extensions/extension_prefs.h" 12 #include "chrome/browser/extensions/extension_prefs.h"
11 #include "chrome/browser/extensions/extension_service.h" 13 #include "chrome/browser/extensions/extension_service.h"
12 #include "chrome/browser/extensions/extension_system.h" 14 #include "chrome/browser/extensions/extension_system.h"
13 #include "chrome/browser/extensions/suspicious_extension_bubble_controller.h" 15 #include "chrome/browser/extensions/suspicious_extension_bubble_controller.h"
14 #include "chrome/browser/profiles/profile.h" 16 #include "chrome/browser/profiles/profile.h"
15 #include "chrome/browser/ui/browser.h" 17 #include "chrome/browser/ui/browser.h"
18 #include "chrome/browser/ui/views/frame/browser_view.h"
19 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h"
20 #include "chrome/browser/ui/views/toolbar/toolbar_view.h"
16 #include "grit/locale_settings.h" 21 #include "grit/locale_settings.h"
17 #include "ui/base/accessibility/accessible_view_state.h" 22 #include "ui/base/accessibility/accessible_view_state.h"
18 #include "ui/base/resource/resource_bundle.h" 23 #include "ui/base/resource/resource_bundle.h"
19 #include "ui/views/controls/button/label_button.h" 24 #include "ui/views/controls/button/label_button.h"
20 #include "ui/views/controls/label.h" 25 #include "ui/views/controls/label.h"
21 #include "ui/views/controls/link.h" 26 #include "ui/views/controls/link.h"
22 #include "ui/views/layout/grid_layout.h" 27 #include "ui/views/layout/grid_layout.h"
28 #include "ui/views/view.h"
23 #include "ui/views/widget/widget.h" 29 #include "ui/views/widget/widget.h"
24 30
25 namespace { 31 namespace {
26 32
27 // Layout constants. 33 // Layout constants.
28 const int kExtensionListPadding = 10; 34 const int kExtensionListPadding = 10;
29 const int kInsetBottomRight = 13; 35 const int kInsetBottomRight = 13;
30 const int kInsetLeft = 14; 36 const int kInsetLeft = 14;
31 const int kInsetTop = 9; 37 const int kInsetTop = 9;
32 const int kHeadlineMessagePadding = 4; 38 const int kHeadlineMessagePadding = 4;
33 const int kHeadlineRowPadding = 10; 39 const int kHeadlineRowPadding = 10;
34 const int kMessageBubblePadding = 11; 40 const int kMessageBubblePadding = 11;
35 41
36 // How many extensions to show in the bubble (max). 42 // How many extensions to show in the bubble (max).
37 const size_t kMaxExtensionsToShow = 7; 43 const size_t kMaxExtensionsToShow = 7;
38 44
39 // How long to wait until showing the bubble (in seconds). 45 // How long to wait until showing the bubble (in seconds).
40 const int kBubbleAppearanceWaitTime = 5; 46 const int kBubbleAppearanceWaitTime = 5;
41 47
42 } // namespace 48 } // namespace
43 49
44 //////////////////////////////////////////////////////////////////////////////// 50 ////////////////////////////////////////////////////////////////////////////////
45 // SuspiciousExtensionBubbleView 51 // ExtensionMessageBubbleView
46 52
47 namespace extensions { 53 namespace extensions {
48 54
49 SuspiciousExtensionBubbleView::SuspiciousExtensionBubbleView( 55 ExtensionMessageBubbleView::ExtensionMessageBubbleView(
50 views::View* anchor_view, 56 views::View* anchor_view,
51 SuspiciousExtensionBubbleController* controller) 57 ExtensionMessageBubbleController::Delegate* delegate)
52 : BubbleDelegateView(anchor_view, views::BubbleBorder::TOP_RIGHT), 58 : BubbleDelegateView(anchor_view, views::BubbleBorder::TOP_RIGHT),
53 weak_factory_(this), 59 weak_factory_(this),
54 controller_(controller), 60 delegate_(delegate),
55 headline_(NULL), 61 headline_(NULL),
56 learn_more_(NULL), 62 learn_more_(NULL),
57 dismiss_button_(NULL), 63 dismiss_button_(NULL),
58 link_clicked_(false) { 64 link_clicked_(false),
65 action_taken_(false) {
59 DCHECK(anchor_view->GetWidget()); 66 DCHECK(anchor_view->GetWidget());
60 set_close_on_deactivate(false); 67 set_close_on_deactivate(false);
61 set_move_with_anchor(true); 68 set_move_with_anchor(true);
62 set_close_on_esc(true); 69 set_close_on_esc(true);
63 70
64 // Compensate for built-in vertical padding in the anchor view's image. 71 // Compensate for built-in vertical padding in the anchor view's image.
65 set_anchor_view_insets(gfx::Insets(5, 0, 5, 0)); 72 set_anchor_view_insets(gfx::Insets(5, 0, 5, 0));
66 } 73 }
67 74
68 // static 75 // static
69 void SuspiciousExtensionBubbleView::MaybeShow( 76 void ExtensionMessageBubbleView::MaybeShow(
70 Browser* browser, 77 Browser* browser,
78 ToolbarView* toolbar_view,
71 views::View* anchor_view) { 79 views::View* anchor_view) {
72 SuspiciousExtensionBubbleController* controller = 80 // The list of suspicious extensions takes priority over the dev mode bubble,
81 // since that needs to be shown as soon as we disable something. The dev mode
82 // bubble is not as time sensitive so we'll catch the dev mode extensions on
83 // the next startup/next window that opens. That way, we're not too spammy
84 // with the bubbles.
85 SuspiciousExtensionBubbleController* suspicious_extensions =
73 extensions::SuspiciousExtensionBubbleController::Get( 86 extensions::SuspiciousExtensionBubbleController::Get(
74 browser->profile()); 87 browser->profile());
75 if (controller->HasSuspiciousExtensions()) { 88 if (suspicious_extensions->ShouldShow()) {
76 SuspiciousExtensionBubbleView* bubble_delegate = 89 ExtensionMessageBubbleView* bubble_delegate =
77 new SuspiciousExtensionBubbleView(anchor_view, controller); 90 new ExtensionMessageBubbleView(anchor_view, suspicious_extensions);
78 views::BubbleDelegateView::CreateBubble(bubble_delegate); 91 views::BubbleDelegateView::CreateBubble(bubble_delegate);
79 controller->Show(bubble_delegate); 92 suspicious_extensions->Show(bubble_delegate);
93 return;
94 }
95
96 DevModeBubbleController* dev_mode_extensions =
97 extensions::DevModeBubbleController::Get(
98 browser->profile());
99 if (dev_mode_extensions->ShouldShow()) {
100 views::View* reference_view = NULL;
101 BrowserActionsContainer* container = toolbar_view->browser_actions();
102 if (container->animating())
103 return;
104
105 ExtensionService* service = extensions::ExtensionSystem::Get(
106 browser->profile())->extension_service();
107 extensions::ExtensionActionManager* extension_action_manager =
108 extensions::ExtensionActionManager::Get(browser->profile());
109
110 const ExtensionIdList extension_list =
111 dev_mode_extensions->extension_id_list();
112 for (size_t i = 0; i < extension_list.size(); ++i) {
113 const Extension* extension =
114 service->GetExtensionById(extension_list[i], false);
115 if (!extension)
116 continue;
117 reference_view = container->GetBrowserActionView(
118 extension_action_manager->GetBrowserAction(*extension));
119 if (reference_view && reference_view->visible())
120 break; // Found a good candidate.
121 }
122 if (reference_view) {
123 // If we have a view, it means we found a browser action and we want to
124 // point to the chevron, not the hotdog menu.
125 if (!reference_view->visible())
126 reference_view = container->chevron(); // It's hidden, use the chevron.
127 }
128 if (reference_view && reference_view->visible())
129 anchor_view = reference_view; // Catch-all is the hotdog menu.
130
131 // Show the bubble.
132 ExtensionMessageBubbleView* bubble_delegate =
133 new ExtensionMessageBubbleView(anchor_view, dev_mode_extensions);
134 views::BubbleDelegateView::CreateBubble(bubble_delegate);
135 dev_mode_extensions->Show(bubble_delegate);
80 } 136 }
81 } 137 }
82 138
83 void SuspiciousExtensionBubbleView::OnButtonClicked( 139 void ExtensionMessageBubbleView::OnActionButtonClicked(
84 const base::Closure& callback) { 140 const base::Closure& callback) {
85 button_callback_ = callback; 141 action_callback_ = callback;
86 } 142 }
87 143
88 void SuspiciousExtensionBubbleView::OnLinkClicked( 144 void ExtensionMessageBubbleView::OnDismissButtonClicked(
145 const base::Closure& callback) {
146 dismiss_callback_ = callback;
147 }
148
149 void ExtensionMessageBubbleView::OnLinkClicked(
89 const base::Closure& callback) { 150 const base::Closure& callback) {
90 link_callback_ = callback; 151 link_callback_ = callback;
91 } 152 }
92 153
93 void SuspiciousExtensionBubbleView::Show() { 154 void ExtensionMessageBubbleView::Show() {
94 // Not showing the bubble right away (during startup) has a few benefits: 155 // Not showing the bubble right away (during startup) has a few benefits:
95 // We don't have to worry about focus being lost due to the Omnibox (or to 156 // We don't have to worry about focus being lost due to the Omnibox (or to
96 // other things that want focus at startup). This allows Esc to work to close 157 // other things that want focus at startup). This allows Esc to work to close
97 // the bubble and also solves the keyboard accessibility problem that comes 158 // the bubble and also solves the keyboard accessibility problem that comes
98 // with focus being lost (we don't have a good generic mechanism of injecting 159 // with focus being lost (we don't have a good generic mechanism of injecting
99 // bubbles into the focus cycle). Another benefit of delaying the show is 160 // bubbles into the focus cycle). Another benefit of delaying the show is
100 // that fade-in works (the fade-in isn't apparent if the the bubble appears at 161 // that fade-in works (the fade-in isn't apparent if the the bubble appears at
101 // startup). 162 // startup).
102 base::MessageLoop::current()->PostDelayedTask( 163 base::MessageLoop::current()->PostDelayedTask(
103 FROM_HERE, 164 FROM_HERE,
104 base::Bind(&SuspiciousExtensionBubbleView::ShowBubble, 165 base::Bind(&ExtensionMessageBubbleView::ShowBubble,
105 weak_factory_.GetWeakPtr()), 166 weak_factory_.GetWeakPtr()),
106 base::TimeDelta::FromSeconds(kBubbleAppearanceWaitTime)); 167 base::TimeDelta::FromSeconds(kBubbleAppearanceWaitTime));
107 } 168 }
108 169
109 void SuspiciousExtensionBubbleView::OnWidgetDestroying(views::Widget* widget) { 170 void ExtensionMessageBubbleView::OnWidgetDestroying(views::Widget* widget) {
110 // To catch Esc, we monitor destroy message. Unless the link has been clicked, 171 // To catch Esc, we monitor destroy message. Unless the link has been clicked,
111 // we assume Dismiss was the action taken. 172 // we assume Dismiss was the action taken.
112 if (!link_clicked_) 173 if (!link_clicked_ && !action_taken_)
113 button_callback_.Run(); 174 dismiss_callback_.Run();
114 } 175 }
115 176
116 //////////////////////////////////////////////////////////////////////////////// 177 ////////////////////////////////////////////////////////////////////////////////
117 // SuspiciousExtensionBubbleView - private. 178 // ExtensionMessageBubbleView - private.
118 179
119 SuspiciousExtensionBubbleView::~SuspiciousExtensionBubbleView() { 180 ExtensionMessageBubbleView::~ExtensionMessageBubbleView() {
120 } 181 }
121 182
122 void SuspiciousExtensionBubbleView::ShowBubble() { 183 void ExtensionMessageBubbleView::ShowBubble() {
123 StartFade(true); 184 StartFade(true);
124 } 185 }
125 186
126 void SuspiciousExtensionBubbleView::Init() { 187 void ExtensionMessageBubbleView::Init() {
127 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); 188 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance();
128 189
129 views::GridLayout* layout = views::GridLayout::CreatePanel(this); 190 views::GridLayout* layout = views::GridLayout::CreatePanel(this);
130 layout->SetInsets(kInsetTop, kInsetLeft, 191 layout->SetInsets(kInsetTop, kInsetLeft,
131 kInsetBottomRight, kInsetBottomRight); 192 kInsetBottomRight, kInsetBottomRight);
132 SetLayoutManager(layout); 193 SetLayoutManager(layout);
133 194
134 const int headline_column_set_id = 0; 195 const int headline_column_set_id = 0;
135 views::ColumnSet* top_columns = layout->AddColumnSet(headline_column_set_id); 196 views::ColumnSet* top_columns = layout->AddColumnSet(headline_column_set_id);
136 top_columns->AddColumn(views::GridLayout::LEADING, views::GridLayout::CENTER, 197 top_columns->AddColumn(views::GridLayout::LEADING, views::GridLayout::CENTER,
137 0, views::GridLayout::USE_PREF, 0, 0); 198 0, views::GridLayout::USE_PREF, 0, 0);
138 top_columns->AddPaddingColumn(1, 0); 199 top_columns->AddPaddingColumn(1, 0);
139 layout->StartRow(0, headline_column_set_id); 200 layout->StartRow(0, headline_column_set_id);
140 201
141 headline_ = new views::Label(); 202 headline_ = new views::Label();
142 headline_->SetFont(rb.GetFont(ui::ResourceBundle::MediumFont)); 203 headline_->SetFont(rb.GetFont(ui::ResourceBundle::MediumFont));
143 headline_->SetText(controller_->GetTitle()); 204 headline_->SetText(delegate_->GetTitle());
144 layout->AddView(headline_); 205 layout->AddView(headline_);
145 206
146 layout->AddPaddingRow(0, kHeadlineRowPadding); 207 layout->AddPaddingRow(0, kHeadlineRowPadding);
147 208
148 const int text_column_set_id = 1; 209 const int text_column_set_id = 1;
149 views::ColumnSet* upper_columns = layout->AddColumnSet(text_column_set_id); 210 views::ColumnSet* upper_columns = layout->AddColumnSet(text_column_set_id);
150 upper_columns->AddColumn( 211 upper_columns->AddColumn(
151 views::GridLayout::LEADING, views::GridLayout::LEADING, 212 views::GridLayout::LEADING, views::GridLayout::LEADING,
152 0, views::GridLayout::USE_PREF, 0, 0); 213 0, views::GridLayout::USE_PREF, 0, 0);
153 layout->StartRow(0, text_column_set_id); 214 layout->StartRow(0, text_column_set_id);
154 215
155 views::Label* message = new views::Label(); 216 views::Label* message = new views::Label();
156 message->SetMultiLine(true); 217 message->SetMultiLine(true);
157 message->SetHorizontalAlignment(gfx::ALIGN_LEFT); 218 message->SetHorizontalAlignment(gfx::ALIGN_LEFT);
158 message->SetText(controller_->GetMessageBody()); 219 message->SetText(delegate_->GetMessageBody());
159 message->SizeToFit(views::Widget::GetLocalizedContentsWidth( 220 message->SizeToFit(views::Widget::GetLocalizedContentsWidth(
160 IDS_EXTENSION_WIPEOUT_BUBBLE_WIDTH_CHARS)); 221 IDS_EXTENSION_WIPEOUT_BUBBLE_WIDTH_CHARS));
161 layout->AddView(message); 222 layout->AddView(message);
162 223
163 const int extension_list_column_set_id = 2; 224 if (delegate_->ShouldShowExtensionList()) {
164 views::ColumnSet* middle_columns = 225 const int extension_list_column_set_id = 2;
165 layout->AddColumnSet(extension_list_column_set_id); 226 views::ColumnSet* middle_columns =
166 middle_columns->AddPaddingColumn(0, kExtensionListPadding); 227 layout->AddColumnSet(extension_list_column_set_id);
167 middle_columns->AddColumn( 228 middle_columns->AddPaddingColumn(0, kExtensionListPadding);
168 views::GridLayout::LEADING, views::GridLayout::CENTER, 229 middle_columns->AddColumn(
169 0, views::GridLayout::USE_PREF, 0, 0); 230 views::GridLayout::LEADING, views::GridLayout::CENTER,
231 0, views::GridLayout::USE_PREF, 0, 0);
170 232
171 layout->StartRowWithPadding(0, extension_list_column_set_id, 233 layout->StartRowWithPadding(0, extension_list_column_set_id,
172 0, kHeadlineMessagePadding); 234 0, kHeadlineMessagePadding);
173 views::Label* extensions = new views::Label(); 235 views::Label* extensions = new views::Label();
174 extensions->SetMultiLine(true); 236 extensions->SetMultiLine(true);
175 extensions->SetHorizontalAlignment(gfx::ALIGN_LEFT); 237 extensions->SetHorizontalAlignment(gfx::ALIGN_LEFT);
176 238
177 std::vector<string16> extension_list; 239 std::vector<string16> extension_list;
178 char16 bullet_point = 0x2022; 240 char16 bullet_point = 0x2022;
179 241
180 std::vector<string16> suspicious = controller_->GetSuspiciousExtensionNames(); 242 std::vector<string16> suspicious = delegate_->GetExtensions();
181 size_t i = 0; 243 size_t i = 0;
182 for (; i < suspicious.size() && i < kMaxExtensionsToShow; ++i) { 244 for (; i < suspicious.size() && i < kMaxExtensionsToShow; ++i) {
183 // Add each extension with bullet point. 245 // Add each extension with bullet point.
184 extension_list.push_back(bullet_point + ASCIIToUTF16(" ") + suspicious[i]); 246 extension_list.push_back(
247 bullet_point + ASCIIToUTF16(" ") + suspicious[i]);
248 }
249
250 if (i > kMaxExtensionsToShow) {
251 string16 difference = base::IntToString16(i - kMaxExtensionsToShow);
252 extension_list.push_back(bullet_point + ASCIIToUTF16(" ") +
253 delegate_->GetOverflowText(difference));
254 }
255
256 extensions->SetText(JoinString(extension_list, ASCIIToUTF16("\n")));
257 extensions->SizeToFit(views::Widget::GetLocalizedContentsWidth(
258 IDS_EXTENSION_WIPEOUT_BUBBLE_WIDTH_CHARS));
259 layout->AddView(extensions);
185 } 260 }
186 261
187 if (i > kMaxExtensionsToShow) { 262 string16 action_button = delegate_->GetActionButtonLabel();
188 base::string16 difference = base::IntToString16(i - kMaxExtensionsToShow);
189 extension_list.push_back(bullet_point + ASCIIToUTF16(" ") +
190 controller_->GetOverflowText(difference));
191 }
192
193 extensions->SetText(JoinString(extension_list, ASCIIToUTF16("\n")));
194 extensions->SizeToFit(views::Widget::GetLocalizedContentsWidth(
195 IDS_EXTENSION_WIPEOUT_BUBBLE_WIDTH_CHARS));
196 layout->AddView(extensions);
197 263
198 const int action_row_column_set_id = 3; 264 const int action_row_column_set_id = 3;
199 views::ColumnSet* bottom_columns = 265 views::ColumnSet* bottom_columns =
200 layout->AddColumnSet(action_row_column_set_id); 266 layout->AddColumnSet(action_row_column_set_id);
201 bottom_columns->AddColumn(views::GridLayout::LEADING, 267 bottom_columns->AddColumn(views::GridLayout::LEADING,
202 views::GridLayout::CENTER, 0, views::GridLayout::USE_PREF, 0, 0); 268 views::GridLayout::CENTER, 0, views::GridLayout::USE_PREF, 0, 0);
203 bottom_columns->AddPaddingColumn(1, 0); 269 bottom_columns->AddPaddingColumn(1, 0);
204 bottom_columns->AddColumn(views::GridLayout::TRAILING, 270 bottom_columns->AddColumn(views::GridLayout::TRAILING,
205 views::GridLayout::CENTER, 0, views::GridLayout::USE_PREF, 0, 0); 271 views::GridLayout::CENTER, 0, views::GridLayout::USE_PREF, 0, 0);
272 if (!action_button.empty()) {
273 bottom_columns->AddColumn(views::GridLayout::TRAILING,
274 views::GridLayout::CENTER, 0, views::GridLayout::USE_PREF, 0, 0);
275 }
206 layout->StartRowWithPadding(0, action_row_column_set_id, 276 layout->StartRowWithPadding(0, action_row_column_set_id,
207 0, kMessageBubblePadding); 277 0, kMessageBubblePadding);
208 278
209 learn_more_ = new views::Link(controller_->GetLearnMoreLabel()); 279 learn_more_ = new views::Link(delegate_->GetLearnMoreLabel());
210 learn_more_->set_listener(this); 280 learn_more_->set_listener(this);
211 layout->AddView(learn_more_); 281 layout->AddView(learn_more_);
212 282
283 if (!action_button.empty()) {
284 action_button_ = new views::LabelButton(this, action_button.c_str());
285 action_button_->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON);
286 layout->AddView(action_button_);
287 }
288
213 dismiss_button_ = new views::LabelButton(this, 289 dismiss_button_ = new views::LabelButton(this,
214 controller_->GetDismissButtonLabel()); 290 delegate_->GetDismissButtonLabel());
215 dismiss_button_->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON); 291 dismiss_button_->SetStyle(views::Button::STYLE_NATIVE_TEXTBUTTON);
216 layout->AddView(dismiss_button_); 292 layout->AddView(dismiss_button_);
217 } 293 }
218 294
219 void SuspiciousExtensionBubbleView::ButtonPressed(views::Button* sender, 295 void ExtensionMessageBubbleView::ButtonPressed(views::Button* sender,
220 const ui::Event& event) { 296 const ui::Event& event) {
221 DCHECK_EQ(dismiss_button_, sender); 297 if (sender == action_button_) {
298 action_taken_ = true;
299 action_callback_.Run();
300 } else {
301 DCHECK_EQ(dismiss_button_, sender);
302 }
222 GetWidget()->Close(); 303 GetWidget()->Close();
223 } 304 }
224 305
225 void SuspiciousExtensionBubbleView::LinkClicked(views::Link* source, 306 void ExtensionMessageBubbleView::LinkClicked(views::Link* source,
226 int event_flags) { 307 int event_flags) {
227 DCHECK_EQ(learn_more_, source); 308 DCHECK_EQ(learn_more_, source);
228 link_clicked_ = true; 309 link_clicked_ = true;
229 link_callback_.Run(); 310 link_callback_.Run();
230 GetWidget()->Close(); 311 GetWidget()->Close();
231 } 312 }
232 313
233 void SuspiciousExtensionBubbleView::GetAccessibleState( 314 void ExtensionMessageBubbleView::GetAccessibleState(
234 ui::AccessibleViewState* state) { 315 ui::AccessibleViewState* state) {
235 state->role = ui::AccessibilityTypes::ROLE_ALERT; 316 state->role = ui::AccessibilityTypes::ROLE_ALERT;
236 } 317 }
237 318
238 void SuspiciousExtensionBubbleView::ViewHierarchyChanged( 319 void ExtensionMessageBubbleView::ViewHierarchyChanged(
239 const ViewHierarchyChangedDetails& details) { 320 const ViewHierarchyChangedDetails& details) {
240 if (details.is_add && details.child == this) 321 if (details.is_add && details.child == this)
241 NotifyAccessibilityEvent(ui::AccessibilityTypes::EVENT_ALERT, true); 322 NotifyAccessibilityEvent(ui::AccessibilityTypes::EVENT_ALERT, true);
242 } 323 }
243 324
244 } // namespace extensions 325 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698