Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / mojo / examples / embedded_app / embedded_app.cc
index 840df07..fd58773 100644 (file)
@@ -5,13 +5,15 @@
 #include "base/basictypes.h"
 #include "base/bind.h"
 #include "base/logging.h"
+#include "base/message_loop/message_loop.h"
 #include "base/strings/string_number_conversions.h"
-#include "mojo/examples/window_manager/window_manager.mojom.h"
-#include "mojo/public/cpp/application/application.h"
-#include "mojo/services/public/cpp/view_manager/node.h"
-#include "mojo/services/public/cpp/view_manager/node_observer.h"
+#include "mojo/public/cpp/application/application_connection.h"
+#include "mojo/public/cpp/application/application_delegate.h"
+#include "mojo/public/cpp/application/application_impl.h"
+#include "mojo/public/cpp/application/interface_factory_impl.h"
 #include "mojo/services/public/cpp/view_manager/view.h"
 #include "mojo/services/public/cpp/view_manager/view_manager.h"
+#include "mojo/services/public/cpp/view_manager/view_manager_client_factory.h"
 #include "mojo/services/public/cpp/view_manager/view_manager_delegate.h"
 #include "mojo/services/public/cpp/view_manager/view_observer.h"
 #include "mojo/services/public/interfaces/navigation/navigation.mojom.h"
 #include "url/gurl.h"
 #include "url/url_util.h"
 
-using mojo::view_manager::Node;
-using mojo::view_manager::NodeObserver;
-using mojo::view_manager::View;
-using mojo::view_manager::ViewManager;
-using mojo::view_manager::ViewManagerDelegate;
-using mojo::view_manager::ViewObserver;
-
 namespace mojo {
 namespace examples {
+class EmbeddedApp;
+
+class NavigatorImpl : public InterfaceImpl<Navigator> {
+ public:
+  explicit NavigatorImpl(EmbeddedApp* app) : app_(app) {}
+
+ private:
+  virtual void Navigate(
+      uint32 view_id,
+      NavigationDetailsPtr navigation_details,
+      ResponseDetailsPtr response_details) OVERRIDE;
+
+  EmbeddedApp* app_;
+  DISALLOW_COPY_AND_ASSIGN(NavigatorImpl);
+};
 
-class EmbeddedApp : public Application,
-                    public ViewManagerDelegate,
-                    public ViewObserver,
-                    public NodeObserver {
+class EmbeddedApp
+    : public ApplicationDelegate,
+      public ViewManagerDelegate,
+      public ViewObserver {
  public:
-  EmbeddedApp() : view_manager_(NULL) {
+  EmbeddedApp()
+      : navigator_factory_(this),
+        view_manager_(NULL),
+        view_manager_client_factory_(this) {
     url::AddStandardScheme("mojo");
   }
   virtual ~EmbeddedApp() {}
 
-  void SetNodeColor(uint32 node_id, SkColor color) {
-    pending_node_colors_[node_id] = color;
-    ProcessPendingNodeColor(node_id);
+  void SetViewColor(uint32 view_id, SkColor color) {
+    pending_view_colors_[view_id] = color;
+    ProcessPendingViewColor(view_id);
   }
 
  private:
-  class Navigator : public InterfaceImpl<navigation::Navigator> {
-   public:
-    explicit Navigator(EmbeddedApp* app) : app_(app) {}
-   private:
-    virtual void Navigate(
-        uint32 node_id,
-        navigation::NavigationDetailsPtr navigation_details,
-        navigation::ResponseDetailsPtr response_details) OVERRIDE {
-      GURL url(navigation_details->url.To<std::string>());
-      if (!url.is_valid()) {
-        LOG(ERROR) << "URL is invalid.";
-        return;
-      }
-      // TODO(aa): Verify new URL is same origin as current origin.
-      SkColor color = 0x00;
-      if (!base::HexStringToUInt(url.path().substr(1), &color)) {
-        LOG(ERROR) << "Invalid URL, path not convertible to integer";
-        return;
-      }
-      app_->SetNodeColor(node_id, color);
-    }
-    EmbeddedApp* app_;
-    DISALLOW_COPY_AND_ASSIGN(Navigator);
-  };
 
-  // Overridden from Application:
-  virtual void Initialize() MOJO_OVERRIDE {
-    ViewManager::Create(this, this);
+  // Overridden from ApplicationDelegate:
+  virtual void Initialize(ApplicationImpl* app) MOJO_OVERRIDE {
     // TODO(aa): Weird for embeddee to talk to embedder by URL. Seems like
     // embedder should be able to specify the SP embeddee receives, then
     // communication can be anonymous.
-    ConnectTo<IWindowManager>("mojo:mojo_window_manager", &window_manager_);
-    AddService<Navigator>(this);
+    app->ConnectToService("mojo:mojo_window_manager", &navigator_host_);
+  }
+
+  virtual bool ConfigureIncomingConnection(ApplicationConnection* connection)
+      MOJO_OVERRIDE {
+    connection->AddService(&view_manager_client_factory_);
+    connection->AddService(&navigator_factory_);
+    return true;
   }
 
   // Overridden from ViewManagerDelegate:
-  virtual void OnRootAdded(ViewManager* view_manager, Node* root) OVERRIDE {
-    View* view = View::Create(view_manager);
-    view->AddObserver(this);
-    root->SetActiveView(view);
+  virtual void OnEmbed(ViewManager* view_manager,
+                       View* root,
+                       ServiceProviderImpl* exported_services,
+                       scoped_ptr<ServiceProvider> imported_services) OVERRIDE {
     root->AddObserver(this);
-
     roots_[root->id()] = root;
-    ProcessPendingNodeColor(root->id());
+    ProcessPendingViewColor(root->id());
   }
-
-  // Overridden from ViewObserver:
-  virtual void OnViewInputEvent(View* view, const EventPtr& event) OVERRIDE {
-    if (event->action == ui::ET_MOUSE_RELEASED)
-      window_manager_->CloseWindow(view->node()->id());
+  virtual void OnViewManagerDisconnected(ViewManager* view_manager) OVERRIDE {
+    base::MessageLoop::current()->Quit();
   }
 
-  // Overridden from NodeObserver:
-  virtual void OnNodeActiveViewChange(
-      Node* node,
-      View* old_view,
-      View* new_view,
-      NodeObserver::DispositionChangePhase phase) OVERRIDE {
-    if (new_view == 0)
-      views_to_reap_[node] = old_view;
+  // Overridden from ViewObserver:
+  virtual void OnViewDestroyed(View* view) OVERRIDE {
+    DCHECK(roots_.find(view->id()) != roots_.end());
+    roots_.erase(view->id());
   }
-  virtual void OnNodeDestroy(
-      Node* node,
-      NodeObserver::DispositionChangePhase phase) OVERRIDE {
-    if (phase != NodeObserver::DISPOSITION_CHANGED)
-      return;
-    DCHECK(roots_.find(node->id()) != roots_.end());
-    roots_.erase(node->id());
-    std::map<Node*, View*>::const_iterator it = views_to_reap_.find(node);
-    if (it != views_to_reap_.end())
-      it->second->Destroy();
+  virtual void OnViewInputEvent(View* view, const EventPtr& event) OVERRIDE {
+    if (event->action == EVENT_TYPE_MOUSE_RELEASED) {
+      if (event->flags & EVENT_FLAGS_LEFT_MOUSE_BUTTON) {
+        NavigationDetailsPtr nav_details(NavigationDetails::New());
+        nav_details->request->url =
+            "http://www.aaronboodman.com/z_dropbox/test.html";
+        navigator_host_->RequestNavigate(view->id(), TARGET_SOURCE_NODE,
+                                         nav_details.Pass());
+      }
+    }
   }
 
-  void ProcessPendingNodeColor(uint32 node_id) {
-    RootMap::iterator root = roots_.find(node_id);
+  void ProcessPendingViewColor(uint32 view_id) {
+    RootMap::iterator root = roots_.find(view_id);
     if (root == roots_.end())
       return;
 
-    PendingNodeColors::iterator color = pending_node_colors_.find(node_id);
-    if (color == pending_node_colors_.end())
+    PendingViewColors::iterator color = pending_view_colors_.find(view_id);
+    if (color == pending_view_colors_.end())
       return;
 
-    root->second->active_view()->SetColor(color->second);
-    pending_node_colors_.erase(color);
+    root->second->SetColor(color->second);
+    pending_view_colors_.erase(color);
   }
 
-  view_manager::ViewManager* view_manager_;
-  IWindowManagerPtr window_manager_;
-  std::map<Node*, View*> views_to_reap_;
+  InterfaceFactoryImplWithContext<NavigatorImpl, EmbeddedApp>
+      navigator_factory_;
+
+  ViewManager* view_manager_;
+  NavigatorHostPtr navigator_host_;
+  ViewManagerClientFactory view_manager_client_factory_;
 
-  typedef std::map<view_manager::Id, Node*> RootMap;
+  typedef std::map<Id, View*> RootMap;
   RootMap roots_;
 
-  // We can receive navigations for nodes we don't have yet.
-  typedef std::map<uint32, SkColor> PendingNodeColors;
-  PendingNodeColors pending_node_colors_;
+  // We can receive navigations for views we don't have yet.
+  typedef std::map<uint32, SkColor> PendingViewColors;
+  PendingViewColors pending_view_colors_;
 
   DISALLOW_COPY_AND_ASSIGN(EmbeddedApp);
 };
 
+void NavigatorImpl::Navigate(uint32 view_id,
+                             NavigationDetailsPtr navigation_details,
+                             ResponseDetailsPtr response_details) {
+  GURL url(navigation_details->request->url.To<std::string>());
+  if (!url.is_valid()) {
+    LOG(ERROR) << "URL is invalid.";
+    return;
+  }
+  // TODO(aa): Verify new URL is same origin as current origin.
+  SkColor color = 0x00;
+  if (!base::HexStringToUInt(url.path().substr(1), &color)) {
+    LOG(ERROR) << "Invalid URL, path not convertible to integer";
+    return;
+  }
+  app_->SetViewColor(view_id, color);
+}
+
 }  // namespace examples
 
 // static
-Application* Application::Create() {
+ApplicationDelegate* ApplicationDelegate::Create() {
   return new examples::EmbeddedApp;
 }