| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/html_dialog_ui.h" | 5 #include "chrome/browser/ui/webui/html_dialog_ui.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
| 10 #include "base/property_bag.h" | 10 #include "base/property_bag.h" |
| 11 #include "base/values.h" | 11 #include "base/values.h" |
| 12 #include "chrome/common/chrome_notification_types.h" | 12 #include "chrome/common/chrome_notification_types.h" |
| 13 #include "content/browser/renderer_host/render_view_host.h" | 13 #include "content/browser/renderer_host/render_view_host.h" |
| 14 #include "content/public/browser/notification_service.h" | 14 #include "content/public/browser/notification_service.h" |
| 15 #include "content/public/browser/web_contents.h" | 15 #include "content/public/browser/web_contents.h" |
| 16 #include "content/public/browser/web_ui_message_handler.h" | 16 #include "content/public/browser/web_ui_message_handler.h" |
| 17 #include "content/public/common/bindings_policy.h" | 17 #include "content/public/common/bindings_policy.h" |
| 18 | 18 |
| 19 using content::WebContents; | 19 using content::WebContents; |
| 20 using content::WebUIMessageHandler; | 20 using content::WebUIMessageHandler; |
| 21 | 21 |
| 22 static base::LazyInstance<base::PropertyAccessor<HtmlDialogUIDelegate*> > | 22 static base::LazyInstance<base::PropertyAccessor<HtmlDialogUIDelegate*> > |
| 23 g_html_dialog_ui_property_accessor = LAZY_INSTANCE_INITIALIZER; | 23 g_html_dialog_ui_property_accessor = LAZY_INSTANCE_INITIALIZER; |
| 24 | 24 |
| 25 HtmlDialogUI::HtmlDialogUI(WebContents* web_contents) | 25 HtmlDialogUI::HtmlDialogUI(WebContents* web_contents) |
| 26 : WebUI(web_contents) { | 26 : WebUI(web_contents, this) { |
| 27 } | 27 } |
| 28 | 28 |
| 29 HtmlDialogUI::~HtmlDialogUI() { | 29 HtmlDialogUI::~HtmlDialogUI() { |
| 30 // Don't unregister our property. During the teardown of the WebContents, | 30 // Don't unregister our property. During the teardown of the WebContents, |
| 31 // this will be deleted, but the WebContents will already be destroyed. | 31 // this will be deleted, but the WebContents will already be destroyed. |
| 32 // | 32 // |
| 33 // This object is owned indirectly by the WebContents. WebUIs can change, so | 33 // This object is owned indirectly by the WebContents. WebUIs can change, so |
| 34 // it's scary if this WebUI is changed out and replaced with something else, | 34 // it's scary if this WebUI is changed out and replaced with something else, |
| 35 // since the property will still point to the old delegate. But the delegate | 35 // since the property will still point to the old delegate. But the delegate |
| 36 // is itself the owner of the WebContents for a dialog so will be in scope, | 36 // is itself the owner of the WebContents for a dialog so will be in scope, |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 70 render_view_host->SetWebUIProperty("dialogArguments", dialog_args); | 70 render_view_host->SetWebUIProperty("dialogArguments", dialog_args); |
| 71 for (std::vector<WebUIMessageHandler*>::iterator it = handlers.begin(); | 71 for (std::vector<WebUIMessageHandler*>::iterator it = handlers.begin(); |
| 72 it != handlers.end(); ++it) { | 72 it != handlers.end(); ++it) { |
| 73 AddMessageHandler(*it); | 73 AddMessageHandler(*it); |
| 74 } | 74 } |
| 75 | 75 |
| 76 content::NotificationService::current()->Notify( | 76 content::NotificationService::current()->Notify( |
| 77 chrome::NOTIFICATION_HTML_DIALOG_SHOWN, | 77 chrome::NOTIFICATION_HTML_DIALOG_SHOWN, |
| 78 content::Source<WebUI>(this), | 78 content::Source<WebUI>(this), |
| 79 content::Details<RenderViewHost>(render_view_host)); | 79 content::Details<RenderViewHost>(render_view_host)); |
| 80 | |
| 81 WebUI::RenderViewCreated(render_view_host); | |
| 82 } | 80 } |
| 83 | 81 |
| 84 void HtmlDialogUI::OnDialogClosed(const ListValue* args) { | 82 void HtmlDialogUI::OnDialogClosed(const ListValue* args) { |
| 85 HtmlDialogUIDelegate** delegate = GetPropertyAccessor().GetProperty( | 83 HtmlDialogUIDelegate** delegate = GetPropertyAccessor().GetProperty( |
| 86 web_contents()->GetPropertyBag()); | 84 web_contents()->GetPropertyBag()); |
| 87 if (delegate) { | 85 if (delegate) { |
| 88 std::string json_retval; | 86 std::string json_retval; |
| 89 if (args && !args->empty() && !args->GetString(0, &json_retval)) | 87 if (args && !args->empty() && !args->GetString(0, &json_retval)) |
| 90 NOTREACHED() << "Could not read JSON argument"; | 88 NOTREACHED() << "Could not read JSON argument"; |
| 91 | 89 |
| 92 (*delegate)->OnDialogClosed(json_retval); | 90 (*delegate)->OnDialogClosed(json_retval); |
| 93 } | 91 } |
| 94 } | 92 } |
| 95 | 93 |
| 96 ExternalHtmlDialogUI::ExternalHtmlDialogUI(WebContents* web_contents) | 94 ExternalHtmlDialogUI::ExternalHtmlDialogUI(WebContents* web_contents) |
| 97 : HtmlDialogUI(web_contents) { | 95 : HtmlDialogUI(web_contents) { |
| 98 // Non-file based UI needs to not have access to the Web UI bindings | 96 // Non-file based UI needs to not have access to the Web UI bindings |
| 99 // for security reasons. The code hosting the dialog should provide | 97 // for security reasons. The code hosting the dialog should provide |
| 100 // dialog specific functionality through other bindings and methods | 98 // dialog specific functionality through other bindings and methods |
| 101 // that are scoped in duration to the dialogs existence. | 99 // that are scoped in duration to the dialogs existence. |
| 102 bindings_ &= ~content::BINDINGS_POLICY_WEB_UI; | 100 bindings_ &= ~content::BINDINGS_POLICY_WEB_UI; |
| 103 } | 101 } |
| 104 | 102 |
| 105 ExternalHtmlDialogUI::~ExternalHtmlDialogUI() { | 103 ExternalHtmlDialogUI::~ExternalHtmlDialogUI() { |
| 106 } | 104 } |
| 107 | 105 |
| 108 bool HtmlDialogUIDelegate::HandleContextMenu(const ContextMenuParams& params) { | 106 bool HtmlDialogUIDelegate::HandleContextMenu(const ContextMenuParams& params) { |
| 109 return false; | 107 return false; |
| 110 } | 108 } |
| OLD | NEW |