// 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 "content/renderer/render_view_observer.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebDOMEventListener.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebNode.h" class PageClickListener; // 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 RenderViewObserver, public WebKit::WebDOMEventListener { public: explicit PageClickTracker(RenderView* render_view); virtual ~PageClickTracker(); // 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: // RenderView::Observer implementation. virtual bool OnMessageReceived(const IPC::Message& message); virtual void DidFinishDocumentLoad(WebKit::WebFrame* frame); virtual void FrameDetached(WebKit::WebFrame* frame); // WebKit::WebDOMEventListener implementation. virtual void handleEvent(const WebKit::WebDOMEvent& event); // Called after the mouse event |event| has been processed by WebKit. virtual void DidHandleMouseEvent(const WebKit::WebMouseEvent& 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_; // 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_