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

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

Issue 1105713002: [Extension Toolbar] Slide out overflowed actions for popups (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Latest master Created 5 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 unified diff | Download patch
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/extensions/extension_popup.h" 5 #include "chrome/browser/ui/views/extensions/extension_popup.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "chrome/browser/chrome_notification_types.h" 8 #include "chrome/browser/chrome_notification_types.h"
9 #include "chrome/browser/devtools/devtools_window.h" 9 #include "chrome/browser/devtools/devtools_window.h"
10 #include "chrome/browser/extensions/extension_view_host.h" 10 #include "chrome/browser/extensions/extension_view_host.h"
11 #include "chrome/browser/extensions/extension_view_host_factory.h"
12 #include "chrome/browser/ui/browser.h" 11 #include "chrome/browser/ui/browser.h"
13 #include "chrome/browser/ui/tabs/tab_strip_model.h" 12 #include "chrome/browser/ui/tabs/tab_strip_model.h"
14 #include "content/public/browser/devtools_agent_host.h" 13 #include "content/public/browser/devtools_agent_host.h"
15 #include "content/public/browser/notification_details.h" 14 #include "content/public/browser/notification_details.h"
16 #include "content/public/browser/notification_source.h" 15 #include "content/public/browser/notification_source.h"
17 #include "content/public/browser/render_view_host.h" 16 #include "content/public/browser/render_view_host.h"
18 #include "content/public/browser/web_contents.h" 17 #include "content/public/browser/web_contents.h"
19 #include "ui/gfx/geometry/insets.h" 18 #include "ui/gfx/geometry/insets.h"
20 #include "ui/views/layout/fill_layout.h" 19 #include "ui/views/layout/fill_layout.h"
21 #include "ui/views/widget/widget.h" 20 #include "ui/views/widget/widget.h"
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 inspect_with_devtools_ = show_action == SHOW_AND_INSPECT; 59 inspect_with_devtools_ = show_action == SHOW_AND_INSPECT;
61 // Adjust the margin so that contents fit better. 60 // Adjust the margin so that contents fit better.
62 const int margin = views::BubbleBorder::GetCornerRadius() / 2; 61 const int margin = views::BubbleBorder::GetCornerRadius() / 2;
63 set_margins(gfx::Insets(margin, margin, margin, margin)); 62 set_margins(gfx::Insets(margin, margin, margin, margin));
64 SetLayoutManager(new views::FillLayout()); 63 SetLayoutManager(new views::FillLayout());
65 AddChildView(GetExtensionView(host)); 64 AddChildView(GetExtensionView(host));
66 GetExtensionView(host)->set_container(this); 65 GetExtensionView(host)->set_container(this);
67 // ExtensionPopup closes itself on very specific de-activation conditions. 66 // ExtensionPopup closes itself on very specific de-activation conditions.
68 set_close_on_deactivate(false); 67 set_close_on_deactivate(false);
69 68
70 // Wait to show the popup until the contained host finishes loading.
71 registrar_.Add(this, content::NOTIFICATION_LOAD_COMPLETED_MAIN_FRAME,
72 content::Source<content::WebContents>(host->host_contents()));
73 69
74 // Listen for the containing view calling window.close(); 70 // Listen for the containing view calling window.close();
75 registrar_.Add( 71 registrar_.Add(
76 this, 72 this,
77 extensions::NOTIFICATION_EXTENSION_HOST_VIEW_SHOULD_CLOSE, 73 extensions::NOTIFICATION_EXTENSION_HOST_VIEW_SHOULD_CLOSE,
78 content::Source<content::BrowserContext>(host->browser_context())); 74 content::Source<content::BrowserContext>(host->browser_context()));
79 content::DevToolsAgentHost::AddAgentStateCallback(devtools_callback_); 75 content::DevToolsAgentHost::AddAgentStateCallback(devtools_callback_);
80 76
81 GetExtensionView(host)->GetBrowser()->tab_strip_model()->AddObserver(this); 77 GetExtensionView(host)->GetBrowser()->tab_strip_model()->AddObserver(this);
78
79 // If the host had somehow finished loading, then we'd miss the notification
80 // and not show. This seems to happen in single-process mode.
81 if (host_->has_loaded_once()) {
82 ShowBubble();
83 } else {
84 // Wait to show the popup until the contained host finishes loading.
85 registrar_.Add(this,
86 content::NOTIFICATION_LOAD_COMPLETED_MAIN_FRAME,
87 content::Source<content::WebContents>(
88 host_->host_contents()));
89 }
82 } 90 }
83 91
84 ExtensionPopup::~ExtensionPopup() { 92 ExtensionPopup::~ExtensionPopup() {
85 content::DevToolsAgentHost::RemoveAgentStateCallback(devtools_callback_); 93 content::DevToolsAgentHost::RemoveAgentStateCallback(devtools_callback_);
86 94
87 GetExtensionView( 95 GetExtensionView(
88 host_.get())->GetBrowser()->tab_strip_model()->RemoveObserver(this); 96 host_.get())->GetBrowser()->tab_strip_model()->RemoveObserver(this);
89 } 97 }
90 98
91 void ExtensionPopup::Observe(int type, 99 void ExtensionPopup::Observe(int type,
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after
163 // TODO(msw): Find any remaining crashes related to http://crbug.com/327776 171 // TODO(msw): Find any remaining crashes related to http://crbug.com/327776
164 // No calls are expected if the widget isn't initialized or no longer exists. 172 // No calls are expected if the widget isn't initialized or no longer exists.
165 CHECK(widget_initialized_); 173 CHECK(widget_initialized_);
166 CHECK(GetWidget()); 174 CHECK(GetWidget());
167 175
168 if (!inspect_with_devtools_) 176 if (!inspect_with_devtools_)
169 GetWidget()->Close(); 177 GetWidget()->Close();
170 } 178 }
171 179
172 // static 180 // static
173 ExtensionPopup* ExtensionPopup::ShowPopup(const GURL& url, 181 ExtensionPopup* ExtensionPopup::ShowPopup(
174 Browser* browser, 182 scoped_ptr<extensions::ExtensionViewHost> host,
175 views::View* anchor_view, 183 views::View* anchor_view,
176 views::BubbleBorder::Arrow arrow, 184 views::BubbleBorder::Arrow arrow,
177 ShowAction show_action) { 185 ShowAction show_action) {
178 extensions::ExtensionViewHost* host = 186 return ExtensionPopup::Create(
179 extensions::ExtensionViewHostFactory::CreatePopupHost(url, browser); 187 host.release(), anchor_view, arrow, show_action);
180 auto popup = ExtensionPopup::Create(host, anchor_view, arrow, show_action);
181
182 // If the host had somehow finished loading, then we'd miss the notification
183 // and not show. This seems to happen in single-process mode.
184 if (host->has_loaded_once())
185 popup->ShowBubble();
186
187 return popup;
188 } 188 }
189 189
190 void ExtensionPopup::ShowBubble() { 190 void ExtensionPopup::ShowBubble() {
191 GetWidget()->Show(); 191 GetWidget()->Show();
192 192
193 // Focus on the host contents when the bubble is first shown. 193 // Focus on the host contents when the bubble is first shown.
194 host()->host_contents()->Focus(); 194 host()->host_contents()->Focus();
195 195
196 if (inspect_with_devtools_) { 196 if (inspect_with_devtools_) {
197 DevToolsWindow::OpenDevToolsWindow(host()->host_contents(), 197 DevToolsWindow::OpenDevToolsWindow(host()->host_contents(),
198 DevToolsToggleAction::ShowConsole()); 198 DevToolsToggleAction::ShowConsole());
199 } 199 }
200 } 200 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/extensions/extension_popup.h ('k') | chrome/browser/ui/views/toolbar/browser_actions_container.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698