| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "athena/virtual_keyboard/vk_webui_controller.h" | 5 #include "ui/keyboard/webui/vk_webui_controller.h" |
| 6 | 6 |
| 7 #include "athena/virtual_keyboard/vk_message_handler.h" | |
| 8 #include "base/strings/string_util.h" | 7 #include "base/strings/string_util.h" |
| 9 #include "base/strings/stringprintf.h" | 8 #include "base/strings/stringprintf.h" |
| 9 #include "content/public/browser/render_frame_host.h" |
| 10 #include "content/public/browser/render_view_host.h" |
| 10 #include "content/public/browser/web_contents.h" | 11 #include "content/public/browser/web_contents.h" |
| 11 #include "content/public/browser/web_ui_data_source.h" | 12 #include "content/public/browser/web_ui_data_source.h" |
| 13 #include "content/public/common/service_registry.h" |
| 12 #include "grit/keyboard_resources.h" | 14 #include "grit/keyboard_resources.h" |
| 13 #include "grit/keyboard_resources_map.h" | 15 #include "grit/keyboard_resources_map.h" |
| 16 #include "mojo/public/cpp/bindings/interface_impl.h" |
| 17 #include "mojo/public/cpp/system/core.h" |
| 14 #include "ui/keyboard/keyboard_constants.h" | 18 #include "ui/keyboard/keyboard_constants.h" |
| 15 #include "ui/keyboard/keyboard_util.h" | 19 #include "ui/keyboard/keyboard_util.h" |
| 20 #include "ui/keyboard/webui/vk_mojo_handler.h" |
| 16 | 21 |
| 17 namespace athena { | 22 namespace keyboard { |
| 18 | 23 |
| 19 namespace { | 24 namespace { |
| 20 | 25 |
| 21 content::WebUIDataSource* CreateKeyboardUIDataSource() { | 26 content::WebUIDataSource* CreateKeyboardUIDataSource() { |
| 22 content::WebUIDataSource* source = | 27 content::WebUIDataSource* source = |
| 23 content::WebUIDataSource::Create(keyboard::kKeyboardHost); | 28 content::WebUIDataSource::Create(kKeyboardHost); |
| 24 | 29 |
| 25 size_t count = 0; | 30 size_t count = 0; |
| 26 const GritResourceMap* resources = | 31 const GritResourceMap* resources = GetKeyboardExtensionResources(&count); |
| 27 keyboard::GetKeyboardExtensionResources(&count); | |
| 28 source->SetDefaultResource(IDR_KEYBOARD_INDEX); | 32 source->SetDefaultResource(IDR_KEYBOARD_INDEX); |
| 29 | 33 |
| 30 const std::string keyboard_host = | 34 const std::string keyboard_host = base::StringPrintf("%s/", kKeyboardHost); |
| 31 base::StringPrintf("%s/", keyboard::kKeyboardHost); | |
| 32 for (size_t i = 0; i < count; ++i) { | 35 for (size_t i = 0; i < count; ++i) { |
| 33 size_t offset = 0; | 36 size_t offset = 0; |
| 37 // The webui URL needs to skip the 'keyboard/' at the front of the resource |
| 38 // names, since it is part of the data-source name. |
| 34 if (StartsWithASCII(std::string(resources[i].name), keyboard_host, false)) | 39 if (StartsWithASCII(std::string(resources[i].name), keyboard_host, false)) |
| 35 offset = keyboard_host.length(); | 40 offset = keyboard_host.length(); |
| 36 source->AddResourcePath(resources[i].name + offset, resources[i].value); | 41 source->AddResourcePath(resources[i].name + offset, resources[i].value); |
| 37 } | 42 } |
| 38 return source; | 43 return source; |
| 39 } | 44 } |
| 40 | 45 |
| 41 } // namespace | 46 } // namespace |
| 42 | 47 |
| 43 //////////////////////////////////////////////////////////////////////////////// | 48 //////////////////////////////////////////////////////////////////////////////// |
| 44 // VKWebUIController: | 49 // VKWebUIController: |
| 45 | 50 |
| 46 VKWebUIController::VKWebUIController(content::WebUI* web_ui) | 51 VKWebUIController::VKWebUIController(content::WebUI* web_ui) |
| 47 : WebUIController(web_ui) { | 52 : WebUIController(web_ui), weak_factory_(this) { |
| 48 content::BrowserContext* browser_context = | 53 content::BrowserContext* browser_context = |
| 49 web_ui->GetWebContents()->GetBrowserContext(); | 54 web_ui->GetWebContents()->GetBrowserContext(); |
| 50 web_ui->AddMessageHandler(new VKMessageHandler()); | |
| 51 content::WebUIDataSource::Add(browser_context, CreateKeyboardUIDataSource()); | 55 content::WebUIDataSource::Add(browser_context, CreateKeyboardUIDataSource()); |
| 56 content::WebUIDataSource::AddMojoDataSource(browser_context)->AddResourcePath( |
| 57 "ui/keyboard/webui/keyboard.mojom", IDR_KEYBOARD_MOJO_GEN_JS); |
| 52 } | 58 } |
| 53 | 59 |
| 54 VKWebUIController::~VKWebUIController() { | 60 VKWebUIController::~VKWebUIController() { |
| 55 } | 61 } |
| 56 | 62 |
| 63 void VKWebUIController::RenderViewCreated(content::RenderViewHost* host) { |
| 64 host->GetMainFrame()->GetServiceRegistry()->AddService<KeyboardUIHandlerMojo>( |
| 65 base::Bind(&VKWebUIController::CreateAndStoreUIHandler, |
| 66 weak_factory_.GetWeakPtr())); |
| 67 } |
| 68 |
| 69 void VKWebUIController::CreateAndStoreUIHandler( |
| 70 mojo::InterfaceRequest<KeyboardUIHandlerMojo> request) { |
| 71 ui_handler_ = scoped_ptr<VKMojoHandler>( |
| 72 mojo::WeakBindToRequest(new VKMojoHandler(), &request)); |
| 73 } |
| 74 |
| 57 //////////////////////////////////////////////////////////////////////////////// | 75 //////////////////////////////////////////////////////////////////////////////// |
| 58 // VKWebUIControllerFactory: | 76 // VKWebUIControllerFactory: |
| 59 | 77 |
| 60 content::WebUI::TypeID VKWebUIControllerFactory::GetWebUIType( | 78 content::WebUI::TypeID VKWebUIControllerFactory::GetWebUIType( |
| 61 content::BrowserContext* browser_context, | 79 content::BrowserContext* browser_context, |
| 62 const GURL& url) const { | 80 const GURL& url) const { |
| 63 if (url == GURL(keyboard::kKeyboardURL)) | 81 if (url == GURL(kKeyboardURL)) |
| 64 return const_cast<VKWebUIControllerFactory*>(this); | 82 return const_cast<VKWebUIControllerFactory*>(this); |
| 65 | 83 |
| 66 return content::WebUI::kNoWebUI; | 84 return content::WebUI::kNoWebUI; |
| 67 } | 85 } |
| 68 | 86 |
| 69 bool VKWebUIControllerFactory::UseWebUIForURL( | 87 bool VKWebUIControllerFactory::UseWebUIForURL( |
| 70 content::BrowserContext* browser_context, | 88 content::BrowserContext* browser_context, |
| 71 const GURL& url) const { | 89 const GURL& url) const { |
| 72 return GetWebUIType(browser_context, url) != content::WebUI::kNoWebUI; | 90 return GetWebUIType(browser_context, url) != content::WebUI::kNoWebUI; |
| 73 } | 91 } |
| 74 | 92 |
| 75 bool VKWebUIControllerFactory::UseWebUIBindingsForURL( | 93 bool VKWebUIControllerFactory::UseWebUIBindingsForURL( |
| 76 content::BrowserContext* browser_context, | 94 content::BrowserContext* browser_context, |
| 77 const GURL& url) const { | 95 const GURL& url) const { |
| 78 return UseWebUIForURL(browser_context, url); | 96 return UseWebUIForURL(browser_context, url); |
| 79 } | 97 } |
| 80 | 98 |
| 81 content::WebUIController* VKWebUIControllerFactory::CreateWebUIControllerForURL( | 99 content::WebUIController* VKWebUIControllerFactory::CreateWebUIControllerForURL( |
| 82 content::WebUI* web_ui, | 100 content::WebUI* web_ui, |
| 83 const GURL& url) const { | 101 const GURL& url) const { |
| 84 if (url == GURL(keyboard::kKeyboardURL)) | 102 if (url == GURL(kKeyboardURL)) |
| 85 return new VKWebUIController(web_ui); | 103 return new VKWebUIController(web_ui); |
| 86 return NULL; | 104 return NULL; |
| 87 } | 105 } |
| 88 | 106 |
| 89 // static | 107 // static |
| 90 VKWebUIControllerFactory* VKWebUIControllerFactory::GetInstance() { | 108 VKWebUIControllerFactory* VKWebUIControllerFactory::GetInstance() { |
| 91 return Singleton<VKWebUIControllerFactory>::get(); | 109 return Singleton<VKWebUIControllerFactory>::get(); |
| 92 } | 110 } |
| 93 | 111 |
| 94 // protected | 112 // protected |
| 95 VKWebUIControllerFactory::VKWebUIControllerFactory() { | 113 VKWebUIControllerFactory::VKWebUIControllerFactory() { |
| 96 } | 114 } |
| 97 | 115 |
| 98 VKWebUIControllerFactory::~VKWebUIControllerFactory() { | 116 VKWebUIControllerFactory::~VKWebUIControllerFactory() { |
| 99 } | 117 } |
| 100 | 118 |
| 101 } // namespace athena | 119 } // namespace keyboard |
| OLD | NEW |