Upstream version 10.38.220.0
[platform/framework/web/crosswalk.git] / src / components / plugins / renderer / webview_plugin.h
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef COMPONENTS_PLUGINS_RENDERER_WEBVIEW_PLUGIN_H_
6 #define COMPONENTS_PLUGINS_RENDERER_WEBVIEW_PLUGIN_H_
7
8 #include <list>
9
10 #include "base/memory/scoped_ptr.h"
11 #include "base/sequenced_task_runner_helpers.h"
12 #include "third_party/WebKit/public/platform/WebCursorInfo.h"
13 #include "third_party/WebKit/public/platform/WebString.h"
14 #include "third_party/WebKit/public/platform/WebURLResponse.h"
15 #include "third_party/WebKit/public/web/WebFrameClient.h"
16 #include "third_party/WebKit/public/web/WebPlugin.h"
17 #include "third_party/WebKit/public/web/WebViewClient.h"
18
19 namespace blink {
20 class WebMouseEvent;
21 }
22
23 namespace content {
24 class RenderView;
25 struct WebPreferences;
26 }
27
28 // This class implements the WebPlugin interface by forwarding drawing and
29 // handling input events to a WebView.
30 // It can be used as a placeholder for an actual plugin, using HTML for the UI.
31 // To show HTML data inside the WebViewPlugin,
32 // call web_view->mainFrame()->loadHTMLString() with the HTML data and a fake
33 // chrome:// URL as origin.
34
35 class WebViewPlugin : public blink::WebPlugin,
36                       public blink::WebViewClient,
37                       public blink::WebFrameClient {
38  public:
39   class Delegate {
40    public:
41     // Bind |frame| to a Javascript object, enabling the delegate to receive
42     // callback methods from Javascript inside the WebFrame.
43     // This method is called from WebFrameClient::didClearWindowObject.
44     virtual void BindWebFrame(blink::WebFrame* frame) = 0;
45
46     // Called upon a context menu event.
47     virtual void ShowContextMenu(const blink::WebMouseEvent&) = 0;
48
49     // Called when the WebViewPlugin is destroyed.
50     virtual void PluginDestroyed() = 0;
51   };
52
53   // Convenience method to set up a new WebViewPlugin using |preferences|
54   // and displaying |html_data|. |url| should be a (fake) chrome:// URL; it is
55   // only used for navigation and never actually resolved.
56   static WebViewPlugin* Create(Delegate* delegate,
57                                const content::WebPreferences& preferences,
58                                const std::string& html_data,
59                                const GURL& url);
60
61   blink::WebView* web_view() { return web_view_; }
62
63   // When loading a plug-in document (i.e. a full page plug-in not embedded in
64   // another page), we save all data that has been received, and replay it with
65   // this method on the actual plug-in.
66   void ReplayReceivedData(blink::WebPlugin* plugin);
67
68   void RestoreTitleText();
69
70   // WebPlugin methods:
71   virtual blink::WebPluginContainer* container() const;
72   virtual bool initialize(blink::WebPluginContainer*);
73   virtual void destroy();
74
75   virtual NPObject* scriptableObject();
76   virtual struct _NPP* pluginNPP();
77
78   virtual bool getFormValue(blink::WebString& value);
79
80   virtual void paint(blink::WebCanvas* canvas, const blink::WebRect& rect);
81
82   // Coordinates are relative to the containing window.
83   virtual void updateGeometry(
84       const blink::WebRect& frame_rect,
85       const blink::WebRect& clip_rect,
86       const blink::WebVector<blink::WebRect>& cut_out_rects,
87       bool is_visible);
88
89   virtual void updateFocus(bool);
90   virtual void updateVisibility(bool) {}
91
92   virtual bool acceptsInputEvents();
93   virtual bool handleInputEvent(const blink::WebInputEvent& event,
94                                 blink::WebCursorInfo& cursor_info);
95
96   virtual void didReceiveResponse(const blink::WebURLResponse& response);
97   virtual void didReceiveData(const char* data, int data_length);
98   virtual void didFinishLoading();
99   virtual void didFailLoading(const blink::WebURLError& error);
100
101   // Called in response to WebPluginContainer::loadFrameRequest
102   virtual void didFinishLoadingFrameRequest(const blink::WebURL& url,
103                                             void* notifyData) {}
104   virtual void didFailLoadingFrameRequest(const blink::WebURL& url,
105                                           void* notify_data,
106                                           const blink::WebURLError& error) {}
107
108   // WebViewClient methods:
109   virtual bool acceptsLoadDrops();
110
111   virtual void setToolTipText(const blink::WebString&,
112                               blink::WebTextDirection);
113
114   virtual void startDragging(blink::WebLocalFrame* frame,
115                              const blink::WebDragData& drag_data,
116                              blink::WebDragOperationsMask mask,
117                              const blink::WebImage& image,
118                              const blink::WebPoint& point);
119
120   // TODO(ojan): Remove this override and have this class use a non-null
121   // layerTreeView.
122   virtual bool allowsBrokenNullLayerTreeView() const;
123
124   // WebWidgetClient methods:
125   virtual void didInvalidateRect(const blink::WebRect&);
126   virtual void didChangeCursor(const blink::WebCursorInfo& cursor);
127   virtual void scheduleAnimation();
128
129   // WebFrameClient methods:
130   virtual void didClearWindowObject(blink::WebLocalFrame* frame);
131
132   // This method is defined in WebPlugin as well as in WebFrameClient, but with
133   // different parameters. We only care about implementing the WebPlugin
134   // version, so we implement this method and call the default in WebFrameClient
135   // (which does nothing) to correctly overload it.
136   virtual void didReceiveResponse(blink::WebLocalFrame* frame,
137                                   unsigned identifier,
138                                   const blink::WebURLResponse& response);
139
140  private:
141   friend class base::DeleteHelper<WebViewPlugin>;
142   WebViewPlugin(Delegate* delegate, const content::WebPreferences& preferences);
143   virtual ~WebViewPlugin();
144
145   // Manages its own lifetime.
146   Delegate* delegate_;
147
148   blink::WebCursorInfo current_cursor_;
149
150   // Owns us.
151   blink::WebPluginContainer* container_;
152
153   // Owned by us, deleted via |close()|.
154   blink::WebView* web_view_;
155
156   // Owned by us, deleted via |close()|.
157   blink::WebFrame* web_frame_;
158   gfx::Rect rect_;
159
160   blink::WebURLResponse response_;
161   std::list<std::string> data_;
162   bool finished_loading_;
163   scoped_ptr<blink::WebURLError> error_;
164   blink::WebString old_title_;
165   bool focused_;
166 };
167
168 #endif  // COMPONENTS_PLUGINS_RENDERER_WEBVIEW_PLUGIN_H_