OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "base/memory/ptr_util.h" | 5 #include "base/memory/ptr_util.h" |
6 #include "chrome/browser/ui/browser.h" | 6 #include "chrome/browser/ui/browser.h" |
7 #include "chrome/browser/ui/browser_dialogs.h" | 7 #include "chrome/browser/ui/browser_dialogs.h" |
| 8 #include "chrome/browser/ui/browser_finder.h" |
8 #include "chrome/browser/ui/browser_window.h" | 9 #include "chrome/browser/ui/browser_window.h" |
9 #import "chrome/browser/ui/cocoa/browser_window_controller.h" | 10 #import "chrome/browser/ui/cocoa/browser_window_controller.h" |
10 #import "chrome/browser/ui/cocoa/location_bar/location_bar_view_mac.h" | 11 #import "chrome/browser/ui/cocoa/location_bar/location_bar_view_mac.h" |
11 #import "chrome/browser/ui/cocoa/website_settings/permission_bubble_cocoa.h" | 12 #import "chrome/browser/ui/cocoa/website_settings/permission_bubble_cocoa.h" |
12 #import "chrome/browser/ui/cocoa/website_settings/permission_bubble_controller.h
" | 13 #import "chrome/browser/ui/cocoa/website_settings/permission_bubble_controller.h
" |
13 #include "chrome/browser/ui/views/website_settings/permission_prompt_impl.h" | 14 #include "chrome/browser/ui/views/website_settings/permission_prompt_impl.h" |
14 #import "ui/base/cocoa/cocoa_base_utils.h" | 15 #import "ui/base/cocoa/cocoa_base_utils.h" |
15 #import "ui/gfx/mac/coordinate_conversion.h" | 16 #import "ui/gfx/mac/coordinate_conversion.h" |
16 | 17 |
17 // Implementation of PermissionPromptImpl's anchor methods for Cocoa | 18 // Implementation of PermissionPromptImpl's anchor methods for Cocoa |
18 // browsers. In Cocoa browsers there is no parent views::View for the permission | 19 // browsers. In Cocoa browsers there is no parent views::View for the permission |
19 // bubble, so these methods supply an anchor point instead. | 20 // bubble, so these methods supply an anchor point instead. |
20 | 21 |
21 views::View* PermissionPromptImpl::GetAnchorView() { | 22 views::View* PermissionPromptImpl::GetAnchorView() { |
22 return nullptr; | 23 return nullptr; |
23 } | 24 } |
24 | 25 |
25 gfx::Point PermissionPromptImpl::GetAnchorPoint() { | 26 gfx::Point PermissionPromptImpl::GetAnchorPoint() { |
26 return gfx::ScreenPointFromNSPoint( | 27 return gfx::ScreenPointFromNSPoint( |
27 [PermissionBubbleController getAnchorPointForBrowser:browser_]); | 28 [PermissionBubbleController getAnchorPointForBrowser:browser_]); |
28 } | 29 } |
29 | 30 |
30 views::BubbleBorder::Arrow PermissionPromptImpl::GetAnchorArrow() { | 31 views::BubbleBorder::Arrow PermissionPromptImpl::GetAnchorArrow() { |
31 return views::BubbleBorder::TOP_LEFT; | 32 return views::BubbleBorder::TOP_LEFT; |
32 } | 33 } |
33 | 34 |
34 // static | 35 // static |
35 std::unique_ptr<PermissionPrompt> PermissionPrompt::Create(Browser* browser) { | 36 std::unique_ptr<PermissionPrompt> PermissionPrompt::Create( |
| 37 content::WebContents* web_contents) { |
36 if (chrome::ToolkitViewsWebUIDialogsEnabled()) | 38 if (chrome::ToolkitViewsWebUIDialogsEnabled()) |
37 return base::WrapUnique(new PermissionPromptImpl(browser)); | 39 return base::WrapUnique(new PermissionPromptImpl( |
38 return base::MakeUnique<PermissionBubbleCocoa>(browser); | 40 chrome::FindBrowserWithWebContents(web_contents))); |
| 41 return base::MakeUnique<PermissionBubbleCocoa>( |
| 42 chrome::FindBrowserWithWebContents(web_contents)); |
39 } | 43 } |
OLD | NEW |