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 "mandoline/ui/browser/browser.h" | 5 #include "mandoline/ui/browser/browser.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
9 #include "components/view_manager/public/cpp/view.h" | 9 #include "components/view_manager/public/cpp/view.h" |
10 #include "components/view_manager/public/cpp/view_manager_init.h" | 10 #include "components/view_manager/public/cpp/view_manager_init.h" |
(...skipping 18 matching lines...) Expand all Loading... |
29 } | 29 } |
30 | 30 |
31 } // namespace | 31 } // namespace |
32 | 32 |
33 Browser::Browser() | 33 Browser::Browser() |
34 : root_(nullptr), | 34 : root_(nullptr), |
35 content_(nullptr), | 35 content_(nullptr), |
36 omnibox_(nullptr), | 36 omnibox_(nullptr), |
37 navigator_host_(this), | 37 navigator_host_(this), |
38 ui_(nullptr) { | 38 ui_(nullptr) { |
39 exposed_services_impl_.AddService(this); | 39 exposed_services_impl_.AddService<mojo::NavigatorHost>(this); |
40 } | 40 } |
41 | 41 |
42 Browser::~Browser() { | 42 Browser::~Browser() { |
43 } | 43 } |
44 | 44 |
45 void Browser::ReplaceContentWithURL(const mojo::String& url) { | 45 void Browser::ReplaceContentWithURL(const mojo::String& url) { |
46 Embed(url, nullptr, nullptr); | 46 Embed(url, nullptr, nullptr); |
47 } | 47 } |
48 | 48 |
49 void Browser::Initialize(mojo::ApplicationImpl* app) { | 49 void Browser::Initialize(mojo::ApplicationImpl* app) { |
(...skipping 15 matching lines...) Expand all Loading... |
65 } | 65 } |
66 | 66 |
67 bool Browser::ConfigureIncomingConnection( | 67 bool Browser::ConfigureIncomingConnection( |
68 mojo::ApplicationConnection* connection) { | 68 mojo::ApplicationConnection* connection) { |
69 // TODO: register embed interface here. | 69 // TODO: register embed interface here. |
70 return true; | 70 return true; |
71 } | 71 } |
72 | 72 |
73 bool Browser::ConfigureOutgoingConnection( | 73 bool Browser::ConfigureOutgoingConnection( |
74 mojo::ApplicationConnection* connection) { | 74 mojo::ApplicationConnection* connection) { |
| 75 connection->AddService<ViewEmbedder>(this); |
75 return true; | 76 return true; |
76 } | 77 } |
77 | 78 |
78 void Browser::OnEmbed( | 79 void Browser::OnEmbed( |
79 mojo::View* root, | 80 mojo::View* root, |
80 mojo::InterfaceRequest<mojo::ServiceProvider> services, | 81 mojo::InterfaceRequest<mojo::ServiceProvider> services, |
81 mojo::ServiceProviderPtr exposed_services) { | 82 mojo::ServiceProviderPtr exposed_services) { |
82 // Browser does not support being embedded more than once. | 83 // Browser does not support being embedded more than once. |
83 CHECK(!root_); | 84 CHECK(!root_); |
84 | 85 |
(...skipping 30 matching lines...) Expand all Loading... |
115 DCHECK_EQ(mojo::KEYBOARD_CODE_BROWSER_BACK, | 116 DCHECK_EQ(mojo::KEYBOARD_CODE_BROWSER_BACK, |
116 event->key_data->windows_key_code); | 117 event->key_data->windows_key_code); |
117 navigator_host_.RequestNavigateHistory(-1); | 118 navigator_host_.RequestNavigateHistory(-1); |
118 } | 119 } |
119 | 120 |
120 void Browser::OpenURL(const mojo::String& url) { | 121 void Browser::OpenURL(const mojo::String& url) { |
121 omnibox_->SetVisible(false); | 122 omnibox_->SetVisible(false); |
122 ReplaceContentWithURL(url); | 123 ReplaceContentWithURL(url); |
123 } | 124 } |
124 | 125 |
125 void Browser::Create(mojo::ApplicationConnection* connection, | |
126 mojo::InterfaceRequest<mojo::NavigatorHost> request) { | |
127 navigator_host_.Bind(request.Pass()); | |
128 } | |
129 | |
130 void Browser::ShowOmnibox( | |
131 const mojo::String& url, | |
132 mojo::InterfaceRequest<mojo::ServiceProvider> services, | |
133 mojo::ServiceProviderPtr exposed_services) { | |
134 if (!omnibox_) { | |
135 omnibox_ = root_->view_manager()->CreateView(); | |
136 root_->AddChild(omnibox_); | |
137 omnibox_->SetVisible(true); | |
138 omnibox_->SetBounds(root_->bounds()); | |
139 } | |
140 omnibox_->Embed(url, services.Pass(), exposed_services.Pass()); | |
141 } | |
142 | |
143 void Browser::Embed(const mojo::String& url, | 126 void Browser::Embed(const mojo::String& url, |
144 mojo::InterfaceRequest<mojo::ServiceProvider> services, | 127 mojo::InterfaceRequest<mojo::ServiceProvider> services, |
145 mojo::ServiceProviderPtr exposed_services) { | 128 mojo::ServiceProviderPtr exposed_services) { |
146 if (url == "mojo:omnibox") { | 129 if (url == "mojo:omnibox") { |
147 ShowOmnibox(url, services.Pass(), exposed_services.Pass()); | 130 ShowOmnibox(url, services.Pass(), exposed_services.Pass()); |
148 return; | 131 return; |
149 } | 132 } |
150 | 133 |
151 // We can get Embed calls before we've actually been | 134 // We can get Embed calls before we've actually been |
152 // embedded into the root view and content_ is created. | 135 // embedded into the root view and content_ is created. |
(...skipping 10 matching lines...) Expand all Loading... |
163 ui_->OnURLChanged(); | 146 ui_->OnURLChanged(); |
164 | 147 |
165 merged_service_provider_.reset( | 148 merged_service_provider_.reset( |
166 new MergedServiceProvider(exposed_services.Pass(), this)); | 149 new MergedServiceProvider(exposed_services.Pass(), this)); |
167 content_->Embed(url, services.Pass(), | 150 content_->Embed(url, services.Pass(), |
168 merged_service_provider_->GetServiceProviderPtr().Pass()); | 151 merged_service_provider_->GetServiceProviderPtr().Pass()); |
169 | 152 |
170 navigator_host_.RecordNavigation(url); | 153 navigator_host_.RecordNavigation(url); |
171 } | 154 } |
172 | 155 |
| 156 void Browser::Create(mojo::ApplicationConnection* connection, |
| 157 mojo::InterfaceRequest<mojo::NavigatorHost> request) { |
| 158 navigator_host_.Bind(request.Pass()); |
| 159 } |
| 160 |
| 161 void Browser::Create(mojo::ApplicationConnection* connection, |
| 162 mojo::InterfaceRequest<ViewEmbedder> request) { |
| 163 view_embedder_bindings_.AddBinding(this, request.Pass()); |
| 164 } |
| 165 |
| 166 void Browser::ShowOmnibox( |
| 167 const mojo::String& url, |
| 168 mojo::InterfaceRequest<mojo::ServiceProvider> services, |
| 169 mojo::ServiceProviderPtr exposed_services) { |
| 170 if (!omnibox_) { |
| 171 omnibox_ = root_->view_manager()->CreateView(); |
| 172 root_->AddChild(omnibox_); |
| 173 omnibox_->SetVisible(true); |
| 174 omnibox_->SetBounds(root_->bounds()); |
| 175 } |
| 176 omnibox_->Embed(url, services.Pass(), exposed_services.Pass()); |
| 177 } |
| 178 |
173 } // namespace mandoline | 179 } // namespace mandoline |
OLD | NEW |