OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/usb/web_usb_permission_bubble.h" | 5 #include "chrome/browser/usb/web_usb_permission_bubble.h" |
6 | 6 |
| 7 #include <utility> |
| 8 |
7 #include "chrome/browser/ui/browser_finder.h" | 9 #include "chrome/browser/ui/browser_finder.h" |
8 #include "chrome/browser/ui/chrome_bubble_manager.h" | 10 #include "chrome/browser/ui/chrome_bubble_manager.h" |
9 #include "chrome/browser/usb/usb_chooser_bubble_delegate.h" | 11 #include "chrome/browser/usb/usb_chooser_bubble_delegate.h" |
10 #include "components/bubble/bubble_controller.h" | 12 #include "components/bubble/bubble_controller.h" |
11 #include "content/public/browser/browser_thread.h" | 13 #include "content/public/browser/browser_thread.h" |
12 #include "content/public/browser/render_frame_host.h" | 14 #include "content/public/browser/render_frame_host.h" |
13 | 15 |
14 ChromeWebUsbPermissionBubble::ChromeWebUsbPermissionBubble( | 16 ChromeWebUsbPermissionBubble::ChromeWebUsbPermissionBubble( |
15 content::RenderFrameHost* render_frame_host) | 17 content::RenderFrameHost* render_frame_host) |
16 : render_frame_host_(render_frame_host) { | 18 : render_frame_host_(render_frame_host) { |
17 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 19 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
18 DCHECK(render_frame_host); | 20 DCHECK(render_frame_host); |
19 } | 21 } |
20 | 22 |
21 ChromeWebUsbPermissionBubble::~ChromeWebUsbPermissionBubble() { | 23 ChromeWebUsbPermissionBubble::~ChromeWebUsbPermissionBubble() { |
22 for (const auto& bubble : bubbles_) { | 24 for (const auto& bubble : bubbles_) { |
23 if (bubble) | 25 if (bubble) |
24 bubble->CloseBubble(BUBBLE_CLOSE_FORCED); | 26 bubble->CloseBubble(BUBBLE_CLOSE_FORCED); |
25 } | 27 } |
26 } | 28 } |
27 | 29 |
28 void ChromeWebUsbPermissionBubble::GetPermission( | 30 void ChromeWebUsbPermissionBubble::GetPermission( |
29 mojo::Array<device::usb::DeviceFilterPtr> device_filters, | 31 mojo::Array<device::usb::DeviceFilterPtr> device_filters, |
30 const GetPermissionCallback& callback) { | 32 const GetPermissionCallback& callback) { |
31 content::WebContents* web_contents = | 33 content::WebContents* web_contents = |
32 content::WebContents::FromRenderFrameHost(render_frame_host_); | 34 content::WebContents::FromRenderFrameHost(render_frame_host_); |
33 Browser* browser = chrome::FindBrowserWithWebContents(web_contents); | 35 Browser* browser = chrome::FindBrowserWithWebContents(web_contents); |
34 scoped_ptr<BubbleDelegate> bubble_delegate(new UsbChooserBubbleDelegate( | 36 scoped_ptr<UsbChooserBubbleDelegate> bubble_delegate( |
35 browser, device_filters.Pass(), render_frame_host_, callback)); | 37 new UsbChooserBubbleDelegate(browser, std::move(device_filters), |
36 BubbleReference bubble_reference = | 38 render_frame_host_, callback)); |
37 browser->GetBubbleManager()->ShowBubble(bubble_delegate.Pass()); | 39 UsbChooserBubbleDelegate* bubble_delegate_ptr = bubble_delegate.get(); |
38 bubbles_.push_back(bubble_reference); | 40 BubbleReference bubble_controller = |
| 41 browser->GetBubbleManager()->ShowBubble(std::move(bubble_delegate)); |
| 42 bubble_delegate_ptr->set_bubble_controller(bubble_controller); |
| 43 bubbles_.push_back(bubble_controller); |
39 } | 44 } |
40 | 45 |
41 void ChromeWebUsbPermissionBubble::Bind( | 46 void ChromeWebUsbPermissionBubble::Bind( |
42 mojo::InterfaceRequest<webusb::WebUsbPermissionBubble> request) { | 47 mojo::InterfaceRequest<webusb::WebUsbPermissionBubble> request) { |
43 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 48 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
44 bindings_.AddBinding(this, request.Pass()); | 49 bindings_.AddBinding(this, request.Pass()); |
45 } | 50 } |
OLD | NEW |