// 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 #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 FrameList; FrameList tracked_frames_; // The listener getting the actual notifications. ObserverList listeners_; DISALLOW_COPY_AND_ASSIGN(PageClickTracker); }; #endif // CHROME_RENDERER_PAGE_CLICK_TRACKER_H_