| 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/ui/webui/media_router/media_router_dialog_controller_im
pl.h" | 5 #include "chrome/browser/ui/webui/media_router/media_router_dialog_controller_im
pl.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <utility> | 8 #include <utility> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 70 | 70 |
| 71 GURL GetDialogContentURL() const override { | 71 GURL GetDialogContentURL() const override { |
| 72 return GURL(chrome::kChromeUIMediaRouterURL); | 72 return GURL(chrome::kChromeUIMediaRouterURL); |
| 73 } | 73 } |
| 74 | 74 |
| 75 void GetWebUIMessageHandlers( | 75 void GetWebUIMessageHandlers( |
| 76 std::vector<WebUIMessageHandler*>* handlers) const override { | 76 std::vector<WebUIMessageHandler*>* handlers) const override { |
| 77 // MediaRouterUI adds its own message handlers. | 77 // MediaRouterUI adds its own message handlers. |
| 78 } | 78 } |
| 79 | 79 |
| 80 void GetDialogSize(gfx::Size* size) const override; | 80 void GetDialogSize(gfx::Size* size) const override { |
| 81 DCHECK(size); |
| 82 #if defined(OS_MACOSX) |
| 83 // When WebDialogConstrainedWindowSheet::updateSheetPosition() calls |
| 84 // GetDialogSize() in OSX, we need to set |size| to be non-empty. Otherwise |
| 85 // the dialog may fail to show. |
| 86 if (size->IsEmpty()) |
| 87 *size = gfx::Size(kWidth, kMinHeight); |
| 88 #endif |
| 89 // GetDialogSize() is called when the dialog is created or the browser |
| 90 // window resizes. We may want to update the maximum height of the dialog |
| 91 // and scale the WebUI to the new height. |size| is not set (except for in |
| 92 // OSX) because the dialog is auto-resizeable. |
| 93 controller_->UpdateMaxDialogSize(); |
| 94 } |
| 81 | 95 |
| 82 std::string GetDialogArgs() const override { | 96 std::string GetDialogArgs() const override { |
| 83 return std::string(); | 97 return std::string(); |
| 84 } | 98 } |
| 85 | 99 |
| 86 void OnDialogClosed(const std::string& json_retval) override { | 100 void OnDialogClosed(const std::string& json_retval) override { |
| 87 // We don't delete |this| here because this class is owned | 101 // We don't delete |this| here because this class is owned |
| 88 // by ConstrainedWebDialogDelegate. | 102 // by ConstrainedWebDialogDelegate. |
| 89 if (action_) | 103 if (action_) |
| 90 action_->OnPopupHidden(); | 104 action_->OnPopupHidden(); |
| 91 } | 105 } |
| 92 | 106 |
| 93 void OnCloseContents(WebContents* source, bool* out_close_dialog) override { | 107 void OnCloseContents(WebContents* source, bool* out_close_dialog) override { |
| 94 if (out_close_dialog) | 108 if (out_close_dialog) |
| 95 *out_close_dialog = true; | 109 *out_close_dialog = true; |
| 96 } | 110 } |
| 97 | 111 |
| 98 bool ShouldShowDialogTitle() const override { | 112 bool ShouldShowDialogTitle() const override { |
| 99 return false; | 113 return false; |
| 100 } | 114 } |
| 101 | 115 |
| 102 private: | 116 private: |
| 103 base::WeakPtr<MediaRouterAction> action_; | 117 base::WeakPtr<MediaRouterAction> action_; |
| 104 base::WeakPtr<MediaRouterDialogControllerImpl> controller_; | 118 base::WeakPtr<MediaRouterDialogControllerImpl> controller_; |
| 105 | 119 |
| 106 DISALLOW_COPY_AND_ASSIGN(MediaRouterDialogDelegate); | 120 DISALLOW_COPY_AND_ASSIGN(MediaRouterDialogDelegate); |
| 107 }; | 121 }; |
| 108 | 122 |
| 109 void MediaRouterDialogDelegate::GetDialogSize(gfx::Size* size) const { | |
| 110 DCHECK(size); | |
| 111 // GetDialogSize() is called when the browser window resizes. We may want to | |
| 112 // update the maximum height of the dialog and scale the WebUI to the new | |
| 113 // height. |size| is not set because the dialog is auto-resizeable. | |
| 114 controller_->UpdateMaxDialogSize(); | |
| 115 } | |
| 116 | |
| 117 } // namespace | 123 } // namespace |
| 118 | 124 |
| 119 // static | 125 // static |
| 120 MediaRouterDialogControllerImpl* | 126 MediaRouterDialogControllerImpl* |
| 121 MediaRouterDialogControllerImpl::GetOrCreateForWebContents( | 127 MediaRouterDialogControllerImpl::GetOrCreateForWebContents( |
| 122 WebContents* web_contents) { | 128 WebContents* web_contents) { |
| 123 DCHECK(web_contents); | 129 DCHECK(web_contents); |
| 124 // This call does nothing if the controller already exists. | 130 // This call does nothing if the controller already exists. |
| 125 MediaRouterDialogControllerImpl::CreateForWebContents(web_contents); | 131 MediaRouterDialogControllerImpl::CreateForWebContents(web_contents); |
| 126 return MediaRouterDialogControllerImpl::FromWebContents(web_contents); | 132 return MediaRouterDialogControllerImpl::FromWebContents(web_contents); |
| (...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 319 ->GetWeakPtr(); | 325 ->GetWeakPtr(); |
| 320 if (!create_connection_request.get()) { | 326 if (!create_connection_request.get()) { |
| 321 media_router_ui->InitWithDefaultMediaSource(delegate); | 327 media_router_ui->InitWithDefaultMediaSource(delegate); |
| 322 } else { | 328 } else { |
| 323 media_router_ui->InitWithPresentationSessionRequest( | 329 media_router_ui->InitWithPresentationSessionRequest( |
| 324 initiator(), delegate, std::move(create_connection_request)); | 330 initiator(), delegate, std::move(create_connection_request)); |
| 325 } | 331 } |
| 326 } | 332 } |
| 327 | 333 |
| 328 } // namespace media_router | 334 } // namespace media_router |
| OLD | NEW |