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

Side by Side Diff: mandoline/ui/browser/browser.h

Issue 1133893003: Omnibox app (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 5 years, 7 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
OLDNEW
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_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698