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 #ifndef MANDOLINE_UI_BROWSER_BROWSER_H_ | 5 #ifndef MANDOLINE_UI_BROWSER_BROWSER_H_ |
6 #define MANDOLINE_UI_BROWSER_BROWSER_H_ | 6 #define MANDOLINE_UI_BROWSER_BROWSER_H_ |
7 | 7 |
8 #include "base/memory/weak_ptr.h" | 8 #include "base/memory/weak_ptr.h" |
9 #include "components/view_manager/public/cpp/view_manager.h" | 9 #include "components/view_manager/public/cpp/view_manager.h" |
10 #include "components/view_manager/public/cpp/view_manager_delegate.h" | 10 #include "components/view_manager/public/cpp/view_manager_delegate.h" |
11 #include "components/window_manager/window_manager_app.h" | 11 #include "components/window_manager/window_manager_app.h" |
12 #include "components/window_manager/window_manager_delegate.h" | 12 #include "components/window_manager/window_manager_delegate.h" |
13 #include "mandoline/services/navigation/public/interfaces/navigation.mojom.h" | 13 #include "mandoline/services/navigation/public/interfaces/navigation.mojom.h" |
14 #include "mandoline/ui/browser/navigator_host_impl.h" | 14 #include "mandoline/ui/browser/navigator_host_impl.h" |
15 #include "mandoline/ui/browser/omnibox.mojom.h" | |
15 #include "third_party/mojo/src/mojo/public/cpp/application/application_delegate. h" | 16 #include "third_party/mojo/src/mojo/public/cpp/application/application_delegate. h" |
16 #include "third_party/mojo/src/mojo/public/cpp/application/application_impl.h" | 17 #include "third_party/mojo/src/mojo/public/cpp/application/application_impl.h" |
17 #include "third_party/mojo/src/mojo/public/cpp/application/connect.h" | 18 #include "third_party/mojo/src/mojo/public/cpp/application/connect.h" |
18 #include "third_party/mojo/src/mojo/public/cpp/application/service_provider_impl .h" | 19 #include "third_party/mojo/src/mojo/public/cpp/application/service_provider_impl .h" |
19 #include "ui/mojo/events/input_events.mojom.h" | 20 #include "ui/mojo/events/input_events.mojom.h" |
20 | 21 |
21 namespace mandoline { | 22 namespace mandoline { |
22 | 23 |
23 class BrowserUI; | 24 class BrowserUI; |
24 class MergedServiceProvider; | 25 class MergedServiceProvider; |
25 | 26 |
26 class Browser : public mojo::ApplicationDelegate, | 27 class Browser : public mojo::ApplicationDelegate, |
27 public mojo::ViewManagerDelegate, | 28 public mojo::ViewManagerDelegate, |
28 public window_manager::WindowManagerDelegate, | 29 public window_manager::WindowManagerDelegate, |
30 public OmniboxClient, | |
29 public mojo::InterfaceFactory<mojo::NavigatorHost> { | 31 public mojo::InterfaceFactory<mojo::NavigatorHost> { |
30 public: | 32 public: |
31 Browser(); | 33 Browser(); |
32 ~Browser() override; | 34 ~Browser() override; |
33 | 35 |
34 base::WeakPtr<Browser> GetWeakPtr(); | 36 base::WeakPtr<Browser> GetWeakPtr(); |
35 | 37 |
36 void ReplaceContentWithURL(const mojo::String& url); | 38 void ReplaceContentWithURL(const mojo::String& url); |
37 | 39 |
40 mojo::View* content() { return content_; } | |
41 mojo::View* omnibox() { return omnibox_; } | |
42 | |
43 const mojo::String& current_url() const { return current_url_; } | |
sky
2015/05/12 21:49:54
Can we keep usage of mojo types only to interfaces
| |
44 | |
38 private: | 45 private: |
39 // Overridden from mojo::ApplicationDelegate: | 46 // Overridden from mojo::ApplicationDelegate: |
40 void Initialize(mojo::ApplicationImpl* app) override; | 47 void Initialize(mojo::ApplicationImpl* app) override; |
41 bool ConfigureIncomingConnection( | 48 bool ConfigureIncomingConnection( |
42 mojo::ApplicationConnection* connection) override; | 49 mojo::ApplicationConnection* connection) override; |
43 bool ConfigureOutgoingConnection( | 50 bool ConfigureOutgoingConnection( |
44 mojo::ApplicationConnection* connection) override; | 51 mojo::ApplicationConnection* connection) override; |
45 | 52 |
46 // Overridden from mojo::ViewManagerDelegate: | 53 // Overridden from mojo::ViewManagerDelegate: |
47 void OnEmbed(mojo::View* root, | 54 void OnEmbed(mojo::View* root, |
48 mojo::InterfaceRequest<mojo::ServiceProvider> services, | 55 mojo::InterfaceRequest<mojo::ServiceProvider> services, |
49 mojo::ServiceProviderPtr exposed_services) override; | 56 mojo::ServiceProviderPtr exposed_services) override; |
50 void OnViewManagerDisconnected(mojo::ViewManager* view_manager) override; | 57 void OnViewManagerDisconnected(mojo::ViewManager* view_manager) override; |
51 | 58 |
52 // Overridden from WindowManagerDelegate: | 59 // Overridden from WindowManagerDelegate: |
53 void Embed(const mojo::String& url, | 60 void Embed(const mojo::String& url, |
54 mojo::InterfaceRequest<mojo::ServiceProvider> services, | 61 mojo::InterfaceRequest<mojo::ServiceProvider> services, |
55 mojo::ServiceProviderPtr exposed_services) override; | 62 mojo::ServiceProviderPtr exposed_services) override; |
56 void OnAcceleratorPressed(mojo::View* view, | 63 void OnAcceleratorPressed(mojo::View* view, |
57 mojo::KeyboardCode keyboard_code, | 64 mojo::KeyboardCode keyboard_code, |
58 mojo::EventFlags flags) override; | 65 mojo::EventFlags flags) override; |
59 | 66 |
67 // Overridden from OmniboxClient: | |
68 void OpenURL(const mojo::String& url) override; | |
69 | |
60 // Overridden from mojo::InterfaceFactory<mojo::NavigatorHost>: | 70 // Overridden from mojo::InterfaceFactory<mojo::NavigatorHost>: |
61 void Create(mojo::ApplicationConnection* connection, | 71 void Create(mojo::ApplicationConnection* connection, |
62 mojo::InterfaceRequest<mojo::NavigatorHost> request) override; | 72 mojo::InterfaceRequest<mojo::NavigatorHost> request) override; |
63 | 73 |
74 void ShowOmnibox(const mojo::String& url, | |
75 mojo::InterfaceRequest<mojo::ServiceProvider> services, | |
76 mojo::ServiceProviderPtr exposed_services); | |
77 | |
78 mojo::ApplicationImpl* app_impl_; | |
sky
2015/05/12 21:49:54
You don't seem to set or use this.
| |
79 | |
64 scoped_ptr<window_manager::WindowManagerApp> window_manager_app_; | 80 scoped_ptr<window_manager::WindowManagerApp> window_manager_app_; |
65 | 81 |
66 // Only support being embedded once, so both application-level | 82 // Only support being embedded once, so both application-level |
67 // and embedding-level state are shared on the same object. | 83 // and embedding-level state are shared on the same object. |
68 mojo::View* root_; | 84 mojo::View* root_; |
69 mojo::View* content_; | 85 mojo::View* content_; |
86 mojo::View* omnibox_; | |
70 std::string default_url_; | 87 std::string default_url_; |
71 std::string pending_url_; | 88 std::string pending_url_; |
72 | 89 |
73 mojo::ServiceProviderImpl exposed_services_impl_; | 90 mojo::ServiceProviderImpl exposed_services_impl_; |
74 scoped_ptr<MergedServiceProvider> merged_service_provider_; | 91 scoped_ptr<MergedServiceProvider> merged_service_provider_; |
75 | 92 |
76 NavigatorHostImpl navigator_host_; | 93 NavigatorHostImpl navigator_host_; |
77 | 94 |
95 mojo::String current_url_; | |
96 | |
78 scoped_ptr<BrowserUI> ui_; | 97 scoped_ptr<BrowserUI> ui_; |
79 | 98 |
80 base::WeakPtrFactory<Browser> weak_factory_; | 99 base::WeakPtrFactory<Browser> weak_factory_; |
81 | 100 |
82 DISALLOW_COPY_AND_ASSIGN(Browser); | 101 DISALLOW_COPY_AND_ASSIGN(Browser); |
83 }; | 102 }; |
84 | 103 |
85 } // namespace mandoline | 104 } // namespace mandoline |
86 | 105 |
87 #endif // MANDOLINE_UI_BROWSER_BROWSER_H_ | 106 #endif // MANDOLINE_UI_BROWSER_BROWSER_H_ |
OLD | NEW |