Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(175)

Side by Side Diff: ui/keyboard/webui/vk_webui_controller.cc

Issue 328303008: athena: Use mojo to provide the bindings for the virtual keyboard. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/system/core.h"
14 #include "ui/keyboard/keyboard_constants.h" 17 #include "ui/keyboard/keyboard_constants.h"
15 #include "ui/keyboard/keyboard_util.h" 18 #include "ui/keyboard/keyboard_util.h"
19 #include "ui/keyboard/webui/vk_mojo_handler.h"
16 20
17 namespace athena { 21 namespace keyboard {
18 22
19 namespace { 23 namespace {
20 24
21 content::WebUIDataSource* CreateKeyboardUIDataSource() { 25 content::WebUIDataSource* CreateKeyboardUIDataSource() {
22 content::WebUIDataSource* source = 26 content::WebUIDataSource* source =
23 content::WebUIDataSource::Create(keyboard::kKeyboardHost); 27 content::WebUIDataSource::Create(kKeyboardHost);
24 28
25 size_t count = 0; 29 size_t count = 0;
26 const GritResourceMap* resources = 30 const GritResourceMap* resources = GetKeyboardExtensionResources(&count);
27 keyboard::GetKeyboardExtensionResources(&count);
28 source->SetDefaultResource(IDR_KEYBOARD_INDEX); 31 source->SetDefaultResource(IDR_KEYBOARD_INDEX);
29 32
30 const std::string keyboard_host = 33 const std::string keyboard_host = base::StringPrintf("%s/", kKeyboardHost);
31 base::StringPrintf("%s/", keyboard::kKeyboardHost);
32 for (size_t i = 0; i < count; ++i) { 34 for (size_t i = 0; i < count; ++i) {
33 size_t offset = 0; 35 size_t offset = 0;
36 // The webui URL needs to skip the 'keyboard/' at the front of the resource
37 // names, since it is part of the data-source name.
34 if (StartsWithASCII(std::string(resources[i].name), keyboard_host, false)) 38 if (StartsWithASCII(std::string(resources[i].name), keyboard_host, false))
35 offset = keyboard_host.length(); 39 offset = keyboard_host.length();
36 source->AddResourcePath(resources[i].name + offset, resources[i].value); 40 source->AddResourcePath(resources[i].name + offset, resources[i].value);
37 } 41 }
38 return source; 42 return source;
39 } 43 }
40 44
41 } // namespace 45 } // namespace
42 46
43 //////////////////////////////////////////////////////////////////////////////// 47 ////////////////////////////////////////////////////////////////////////////////
44 // VKWebUIController: 48 // VKWebUIController:
45 49
46 VKWebUIController::VKWebUIController(content::WebUI* web_ui) 50 VKWebUIController::VKWebUIController(content::WebUI* web_ui)
47 : WebUIController(web_ui) { 51 : WebUIController(web_ui),
52 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)
57 ->AddResourcePath("ui/keyboard/webui/keyboard.mojom",
58 IDR_KEYBOARD_MOJO_GEN_JS);
52 } 59 }
53 60
54 VKWebUIController::~VKWebUIController() { 61 VKWebUIController::~VKWebUIController() {
55 } 62 }
56 63
64 void VKWebUIController::RenderViewCreated(content::RenderViewHost* host) {
65 host->GetMainFrame()->GetServiceRegistry()->AddService(
Sam McNally 2014/06/26 11:04:40 You'll want to use AddService<KeyboardUIHandlerMoj
sadrul 2014/08/01 22:41:47 Done.
66 "webui_controller",
67 base::Bind(&VKWebUIController::CreateAndStoreUIHandler,
68 weak_factory_.GetWeakPtr()));
69 }
70
71 void VKWebUIController::CreateAndStoreUIHandler(
72 mojo::ScopedMessagePipeHandle handle_to_api) {
Sam McNally 2014/06/26 11:04:40 With the above change, this can turn into mojo::In
sadrul 2014/08/01 22:41:47 Done.
73 ui_handler_ = scoped_ptr<VKMojoHandler>(
74 mojo::BindToPipe(new VKMojoHandler(), handle_to_api.Pass()));
75 }
76
57 //////////////////////////////////////////////////////////////////////////////// 77 ////////////////////////////////////////////////////////////////////////////////
58 // VKWebUIControllerFactory: 78 // VKWebUIControllerFactory:
59 79
60 content::WebUI::TypeID VKWebUIControllerFactory::GetWebUIType( 80 content::WebUI::TypeID VKWebUIControllerFactory::GetWebUIType(
61 content::BrowserContext* browser_context, 81 content::BrowserContext* browser_context,
62 const GURL& url) const { 82 const GURL& url) const {
63 if (url == GURL(keyboard::kKeyboardURL)) 83 if (url == GURL(kKeyboardURL))
64 return const_cast<VKWebUIControllerFactory*>(this); 84 return const_cast<VKWebUIControllerFactory*>(this);
65 85
66 return content::WebUI::kNoWebUI; 86 return content::WebUI::kNoWebUI;
67 } 87 }
68 88
69 bool VKWebUIControllerFactory::UseWebUIForURL( 89 bool VKWebUIControllerFactory::UseWebUIForURL(
70 content::BrowserContext* browser_context, 90 content::BrowserContext* browser_context,
71 const GURL& url) const { 91 const GURL& url) const {
72 return GetWebUIType(browser_context, url) != content::WebUI::kNoWebUI; 92 return GetWebUIType(browser_context, url) != content::WebUI::kNoWebUI;
73 } 93 }
74 94
75 bool VKWebUIControllerFactory::UseWebUIBindingsForURL( 95 bool VKWebUIControllerFactory::UseWebUIBindingsForURL(
76 content::BrowserContext* browser_context, 96 content::BrowserContext* browser_context,
77 const GURL& url) const { 97 const GURL& url) const {
78 return UseWebUIForURL(browser_context, url); 98 return UseWebUIForURL(browser_context, url);
79 } 99 }
80 100
81 content::WebUIController* VKWebUIControllerFactory::CreateWebUIControllerForURL( 101 content::WebUIController* VKWebUIControllerFactory::CreateWebUIControllerForURL(
82 content::WebUI* web_ui, 102 content::WebUI* web_ui,
83 const GURL& url) const { 103 const GURL& url) const {
84 if (url == GURL(keyboard::kKeyboardURL)) 104 if (url == GURL(kKeyboardURL))
85 return new VKWebUIController(web_ui); 105 return new VKWebUIController(web_ui);
86 return NULL; 106 return NULL;
87 } 107 }
88 108
89 // static 109 // static
90 VKWebUIControllerFactory* VKWebUIControllerFactory::GetInstance() { 110 VKWebUIControllerFactory* VKWebUIControllerFactory::GetInstance() {
91 return Singleton<VKWebUIControllerFactory>::get(); 111 return Singleton<VKWebUIControllerFactory>::get();
92 } 112 }
93 113
94 // protected 114 // protected
95 VKWebUIControllerFactory::VKWebUIControllerFactory() { 115 VKWebUIControllerFactory::VKWebUIControllerFactory() {
96 } 116 }
97 117
98 VKWebUIControllerFactory::~VKWebUIControllerFactory() { 118 VKWebUIControllerFactory::~VKWebUIControllerFactory() {
99 } 119 }
100 120
101 } // namespace athena 121 } // namespace keyboard
OLDNEW
« ui/keyboard/resources/keyboard_mojo.js ('K') | « ui/keyboard/webui/vk_webui_controller.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698