| OLD | NEW |
| 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/webui/constrained_web_dialog_delegate_base.h" | 5 #include "chrome/browser/ui/webui/constrained_web_dialog_delegate_base.h" |
| 6 | 6 |
| 7 #import <Cocoa/Cocoa.h> | 7 #import <Cocoa/Cocoa.h> |
| 8 | 8 |
| 9 #include "base/mac/scoped_nsobject.h" | 9 #include "base/mac/scoped_nsobject.h" |
| 10 #import "chrome/browser/ui/cocoa/constrained_window/constrained_window_custom_sh
eet.h" | 10 #import "chrome/browser/ui/cocoa/constrained_window/constrained_window_custom_sh
eet.h" |
| (...skipping 10 matching lines...) Expand all Loading... |
| 21 using ui::WebDialogWebContentsDelegate; | 21 using ui::WebDialogWebContentsDelegate; |
| 22 using web_modal::NativeWebContentsModalDialog; | 22 using web_modal::NativeWebContentsModalDialog; |
| 23 | 23 |
| 24 namespace { | 24 namespace { |
| 25 | 25 |
| 26 class ConstrainedWebDialogDelegateMac | 26 class ConstrainedWebDialogDelegateMac |
| 27 : public ConstrainedWebDialogDelegateBase { | 27 : public ConstrainedWebDialogDelegateBase { |
| 28 public: | 28 public: |
| 29 ConstrainedWebDialogDelegateMac( | 29 ConstrainedWebDialogDelegateMac( |
| 30 content::BrowserContext* browser_context, | 30 content::BrowserContext* browser_context, |
| 31 WebDialogDelegate* delegate, | 31 WebDialogDelegate* delegate) |
| 32 WebDialogWebContentsDelegate* tab_delegate) | 32 : ConstrainedWebDialogDelegateBase(browser_context, delegate, NULL) {} |
| 33 : ConstrainedWebDialogDelegateBase( | |
| 34 browser_context, delegate, tab_delegate) {} | |
| 35 | 33 |
| 36 // WebDialogWebContentsDelegate interface. | 34 // WebDialogWebContentsDelegate interface. |
| 37 virtual void CloseContents(WebContents* source) OVERRIDE { | 35 virtual void CloseContents(WebContents* source) OVERRIDE { |
| 38 window_->CloseWebContentsModalDialog(); | 36 window_->CloseWebContentsModalDialog(); |
| 39 } | 37 } |
| 40 | 38 |
| 41 void set_window(ConstrainedWindowMac* window) { window_ = window; } | 39 void set_window(ConstrainedWindowMac* window) { window_ = window; } |
| 42 ConstrainedWindowMac* window() const { return window_; } | 40 ConstrainedWindowMac* window() const { return window_; } |
| 43 | 41 |
| 44 private: | 42 private: |
| 45 // Weak, owned by ConstrainedWebDialogDelegateViewMac. | 43 // Weak, owned by ConstrainedWebDialogDelegateViewMac. |
| 46 ConstrainedWindowMac* window_; | 44 ConstrainedWindowMac* window_; |
| 47 | 45 |
| 48 DISALLOW_COPY_AND_ASSIGN(ConstrainedWebDialogDelegateMac); | 46 DISALLOW_COPY_AND_ASSIGN(ConstrainedWebDialogDelegateMac); |
| 49 }; | 47 }; |
| 50 | 48 |
| 51 } // namespace | 49 } // namespace |
| 52 | 50 |
| 53 class ConstrainedWebDialogDelegateViewMac : | 51 class ConstrainedWebDialogDelegateViewMac : |
| 54 public ConstrainedWindowMacDelegate, | 52 public ConstrainedWindowMacDelegate, |
| 55 public ConstrainedWebDialogDelegate { | 53 public ConstrainedWebDialogDelegate { |
| 56 | 54 |
| 57 public: | 55 public: |
| 58 ConstrainedWebDialogDelegateViewMac( | 56 ConstrainedWebDialogDelegateViewMac( |
| 59 content::BrowserContext* browser_context, | 57 content::BrowserContext* browser_context, |
| 60 WebDialogDelegate* delegate, | 58 WebDialogDelegate* delegate, |
| 61 WebDialogWebContentsDelegate* tab_delegate, | |
| 62 content::WebContents* web_contents); | 59 content::WebContents* web_contents); |
| 63 virtual ~ConstrainedWebDialogDelegateViewMac() {} | 60 virtual ~ConstrainedWebDialogDelegateViewMac() {} |
| 64 | 61 |
| 65 // ConstrainedWebDialogDelegate interface | 62 // ConstrainedWebDialogDelegate interface |
| 66 virtual const WebDialogDelegate* | 63 virtual const WebDialogDelegate* |
| 67 GetWebDialogDelegate() const OVERRIDE { | 64 GetWebDialogDelegate() const OVERRIDE { |
| 68 return impl_->GetWebDialogDelegate(); | 65 return impl_->GetWebDialogDelegate(); |
| 69 } | 66 } |
| 70 virtual WebDialogDelegate* GetWebDialogDelegate() OVERRIDE { | 67 virtual WebDialogDelegate* GetWebDialogDelegate() OVERRIDE { |
| 71 return impl_->GetWebDialogDelegate(); | 68 return impl_->GetWebDialogDelegate(); |
| (...skipping 23 matching lines...) Expand all Loading... |
| 95 scoped_ptr<ConstrainedWebDialogDelegateMac> impl_; | 92 scoped_ptr<ConstrainedWebDialogDelegateMac> impl_; |
| 96 scoped_ptr<ConstrainedWindowMac> constrained_window_; | 93 scoped_ptr<ConstrainedWindowMac> constrained_window_; |
| 97 base::scoped_nsobject<NSWindow> window_; | 94 base::scoped_nsobject<NSWindow> window_; |
| 98 | 95 |
| 99 DISALLOW_COPY_AND_ASSIGN(ConstrainedWebDialogDelegateViewMac); | 96 DISALLOW_COPY_AND_ASSIGN(ConstrainedWebDialogDelegateViewMac); |
| 100 }; | 97 }; |
| 101 | 98 |
| 102 ConstrainedWebDialogDelegateViewMac::ConstrainedWebDialogDelegateViewMac( | 99 ConstrainedWebDialogDelegateViewMac::ConstrainedWebDialogDelegateViewMac( |
| 103 content::BrowserContext* browser_context, | 100 content::BrowserContext* browser_context, |
| 104 WebDialogDelegate* delegate, | 101 WebDialogDelegate* delegate, |
| 105 WebDialogWebContentsDelegate* tab_delegate, | |
| 106 content::WebContents* web_contents) | 102 content::WebContents* web_contents) |
| 107 : impl_(new ConstrainedWebDialogDelegateMac(browser_context, | 103 : impl_(new ConstrainedWebDialogDelegateMac(browser_context, delegate)) { |
| 108 delegate, | |
| 109 tab_delegate)) { | |
| 110 // Create a window to hold web_contents in the constrained sheet: | 104 // Create a window to hold web_contents in the constrained sheet: |
| 111 gfx::Size size; | 105 gfx::Size size; |
| 112 delegate->GetDialogSize(&size); | 106 delegate->GetDialogSize(&size); |
| 113 NSRect frame = NSMakeRect(0, 0, size.width(), size.height()); | 107 NSRect frame = NSMakeRect(0, 0, size.width(), size.height()); |
| 114 | 108 |
| 115 window_.reset( | 109 window_.reset( |
| 116 [[ConstrainedWindowCustomWindow alloc] initWithContentRect:frame]); | 110 [[ConstrainedWindowCustomWindow alloc] initWithContentRect:frame]); |
| 117 [GetWebContents()->GetNativeView() setFrame:frame]; | 111 [GetWebContents()->GetNativeView() setFrame:frame]; |
| 118 [[window_ contentView] addSubview:GetWebContents()->GetNativeView()]; | 112 [[window_ contentView] addSubview:GetWebContents()->GetNativeView()]; |
| 119 | 113 |
| 120 base::scoped_nsobject<CustomConstrainedWindowSheet> sheet( | 114 base::scoped_nsobject<CustomConstrainedWindowSheet> sheet( |
| 121 [[CustomConstrainedWindowSheet alloc] initWithCustomWindow:window_]); | 115 [[CustomConstrainedWindowSheet alloc] initWithCustomWindow:window_]); |
| 122 constrained_window_.reset(new ConstrainedWindowMac( | 116 constrained_window_.reset(new ConstrainedWindowMac( |
| 123 this, web_contents, sheet)); | 117 this, web_contents, sheet)); |
| 124 | 118 |
| 125 impl_->set_window(constrained_window_.get()); | 119 impl_->set_window(constrained_window_.get()); |
| 126 } | 120 } |
| 127 | 121 |
| 128 ConstrainedWebDialogDelegate* CreateConstrainedWebDialog( | 122 ConstrainedWebDialogDelegate* CreateConstrainedWebDialog( |
| 129 content::BrowserContext* browser_context, | 123 content::BrowserContext* browser_context, |
| 130 WebDialogDelegate* delegate, | 124 WebDialogDelegate* delegate, |
| 131 WebDialogWebContentsDelegate* tab_delegate, | |
| 132 content::WebContents* web_contents) { | 125 content::WebContents* web_contents) { |
| 133 // Deleted when the dialog closes. | 126 // Deleted when the dialog closes. |
| 134 ConstrainedWebDialogDelegateViewMac* constrained_delegate = | 127 ConstrainedWebDialogDelegateViewMac* constrained_delegate = |
| 135 new ConstrainedWebDialogDelegateViewMac( | 128 new ConstrainedWebDialogDelegateViewMac( |
| 136 browser_context, delegate, tab_delegate, web_contents); | 129 browser_context, delegate, web_contents); |
| 137 return constrained_delegate; | 130 return constrained_delegate; |
| 138 } | 131 } |
| OLD | NEW |