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

Unified Diff: mojo/ui/content_viewer_app.h

Issue 1556803002: Add helpers for creating UI components. (Closed) Base URL: git@github.com:domokit/mojo.git@moz-13
Patch Set: Created 4 years, 12 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 side-by-side diff with in-line comments
Download patch
Index: mojo/ui/content_viewer_app.h
diff --git a/mojo/ui/content_viewer_app.h b/mojo/ui/content_viewer_app.h
new file mode 100644
index 0000000000000000000000000000000000000000..a45ebf9f2805ac22c75736db4da92adc8229939d
--- /dev/null
+++ b/mojo/ui/content_viewer_app.h
@@ -0,0 +1,72 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef MOJO_UI_CONTENT_VIEWER_APP_H_
+#define MOJO_UI_CONTENT_VIEWER_APP_H_
+
+#include "mojo/common/strong_binding_set.h"
+#include "mojo/services/content_handler/interfaces/content_handler.mojom.h"
+#include "mojo/ui/view_provider_app.h"
+
+namespace mojo {
+namespace ui {
+
+// A simple ContentHandler application implementation for rendering
+// content as Views. Subclasses must provide a function to create
+// the view provider application on demand.
+//
+// TODO(jeffbrown): Support creating the view provider application in a
+// separate thread if desired (often not the case). This is one reason
+// we are not using the ContentHandlerFactory here.
+class ContentViewerApp : public mojo::ApplicationDelegate,
+ public mojo::InterfaceFactory<mojo::ContentHandler> {
+ public:
+ ContentViewerApp();
+ ~ContentViewerApp() override;
+
+ mojo::ApplicationImpl* app_impl() { return app_impl_; }
+
+ // |ApplicationDelegate|:
+ void Initialize(mojo::ApplicationImpl* app) override;
+ bool ConfigureIncomingConnection(
+ mojo::ApplicationConnection* connection) override;
+
+ // Called to create the view provider application to view the content.
+ //
+ // This method may be called multiple times to load different content
+ // into separate view providers. The view provider implementation should
+ // cache the loaded content in case it is asked to create multiple instances
+ // of the view since the response can only be consumed once.
+ //
+ // The |content_handler_url| is the connection URL of the content handler
+ // request.
+ // The |response| carries the data retrieved by the content handler.
+ //
+ // Returns the view provider application delegate to view the content,
+ // or nullptr if the content could not be loaded.
+ virtual ViewProviderApp* LoadContent(const std::string& content_handler_url,
+ mojo::URLResponsePtr response) = 0;
+
+ private:
+ class DelegatingContentHandler;
+
+ // |InterfaceFactory<ContentHandler>|:
+ void Create(mojo::ApplicationConnection* connection,
+ mojo::InterfaceRequest<mojo::ContentHandler> request) override;
+
+ void StartViewer(
+ const std::string& content_handler_url,
+ mojo::InterfaceRequest<mojo::Application> application_request,
+ mojo::URLResponsePtr response);
+
+ mojo::ApplicationImpl* app_impl_ = nullptr;
+ mojo::StrongBindingSet<mojo::ContentHandler> bindings_;
+
+ MOJO_DISALLOW_COPY_AND_ASSIGN(ContentViewerApp);
+};
+
+} // namespace ui
+} // namespace mojo
+
+#endif // MOJO_UI_CONTENT_VIEWER_APP_H_

Powered by Google App Engine
This is Rietveld 408576698