blob: 492237cc3e1f4e41d386127238652fae12375603 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
// Copyright (c) 2010 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 CHROME_RENDERER_PAGE_CLICK_TRACKER_H_
#define CHROME_RENDERER_PAGE_CLICK_TRACKER_H_
#include <vector>
#include "base/basictypes.h"
#include "base/observer_list.h"
#include "third_party/WebKit/WebKit/chromium/public/WebDOMEventListener.h"
#include "third_party/WebKit/WebKit/chromium/public/WebNode.h"
class PageClickListener;
class RenderView;
namespace WebKit {
class WebFrame;
class WebDOMEvent;
class WebMouseEvent;
}
// This class is responsible for tracking clicks on elements in web pages and
// notifiying the associated listener when a node is clicked.
// Compared to a simple WebDOMEventListener, it offers the added capability of
// notifying the listeners of whether the clicked node was already focused
// before it was clicked.
//
// This is useful for password/form autofill where we want to trigger a
// suggestion popup when a text input is clicked.
// It only notifies of WebInputElement that are text inputs being clicked, but
// could easily be changed to report click on any type of WebNode.
//
// There is one PageClickTracker per RenderView.
class PageClickTracker : public WebKit::WebDOMEventListener {
public:
explicit PageClickTracker(RenderView* render_view);
virtual ~PageClickTracker();
// Starts reporting node clicks for |frame| on the listener previously
// specified with SetListener().
void StartTrackingFrame(WebKit::WebFrame* frame);
// Stops reporting node clicks for |frame|. |frame_detached| should be true
// if the frame has already been detached.
void StopTrackingFrame(WebKit::WebFrame* frame, bool frame_detached);
// Called after the mouse event |event| has been processed by WebKit.
void DidHandleMouseEvent(const WebKit::WebMouseEvent& event);
// Adds/removes a listener for getting notification when an element is
// clicked. Note that the order of insertion is important as a listener when
// notified can decide to stop the propagation of the event (so that listeners
// inserted after don't get the notification).
void AddListener(PageClickListener* listener);
void RemoveListener(PageClickListener* listener);
private:
// WebKit::WebDOMEventListener implementation.
virtual void handleEvent(const WebKit::WebDOMEvent& event);
// Returns the currently focused node in the associated render view.
// That node may be null.
WebKit::WebNode GetFocusedNode();
// The last node that was clicked and had focus.
WebKit::WebNode last_node_clicked_;
// The render view we are associated with.
RenderView* render_view_;
// Whether the last clicked node had focused before it was clicked.
bool was_focused_;
// The frames we are listening to for mouse events.
typedef std::vector<WebKit::WebFrame*> FrameList;
FrameList tracked_frames_;
// The listener getting the actual notifications.
ObserverList<PageClickListener> listeners_;
DISALLOW_COPY_AND_ASSIGN(PageClickTracker);
};
#endif // CHROME_RENDERER_PAGE_CLICK_TRACKER_H_
|