Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(831)

Unified Diff: chrome/browser/engagement/site_engagement_helper.h

Issue 1373363005: Add a delay to Site Engagement tracking after navigation. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address comments, refactor Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/engagement/site_engagement_helper.h
diff --git a/chrome/browser/engagement/site_engagement_helper.h b/chrome/browser/engagement/site_engagement_helper.h
index af059d431b24d98915c81add6e339156697d6519..1be83ad0360a0caeecd4d1d75084da60206e0c8b 100644
--- a/chrome/browser/engagement/site_engagement_helper.h
+++ b/chrome/browser/engagement/site_engagement_helper.h
@@ -25,7 +25,9 @@ class SiteEngagementHelper
public:
~SiteEngagementHelper() override;
- static void SetSecondsBetweenUserInputCheck(double seconds);
+ static void SetSecondsBetweenUserInputCheck(int seconds);
+ static void SetSecondsTrackingDelayAfterNavigation(int seconds);
+ static void SetSecondsTrackingDelayAfterShow(int seconds);
private:
// Class to encapsulate the user input listening.
@@ -51,28 +53,38 @@ class SiteEngagementHelper
bool HandleMouseEvent(const blink::WebMouseEvent& event);
// Register callbacks to listen for user input.
- void StartTracking(content::RenderViewHost* host);
+ void StartTracking(content::RenderViewHost* host, int initial_delay);
- // Pause listening for user input, restarting listening after
- // g_seconds_between_user_input_check seconds.
- void PauseTracking(content::RenderViewHost* host);
-
- // Restart listening for user input.
- void ResumeTracking();
+ // Pause listening for user input, restarting listening after a delay.
+ void PauseTracking();
// Stop listening for user input.
- void StopTracking(content::RenderViewHost* host);
+ void StopTracking();
- // Set the timer object for testing purposes.
- void SetTimerForTesting(scoped_ptr<base::Timer> timer);
+ // Returns whether the InputTracker has been started for a RenderViewHost.
+ bool is_tracking() { return is_tracking_; }
+ // Returns whether input tracking callbacks have been added to
+ // RenderViewHost.
bool callbacks_added() { return callbacks_added_; }
+ // Set the timer object for testing purposes.
+ void SetPauseTimerForTesting(scoped_ptr<base::Timer> timer);
+
private:
+ // Starts the timer for adding callbacks to the RenderViewHost.
+ void StartTimer(int delay);
+
+ // Adds/removes tracking callbacks to the RenderViewHost.
+ void AddCallbacks();
+ void RemoveCallbacks();
+
SiteEngagementHelper* helper_;
scoped_ptr<base::Timer> pause_timer_;
+ content::RenderViewHost* host_;
content::RenderWidgetHost::KeyPressEventCallback key_press_event_callback_;
content::RenderWidgetHost::MouseEventCallback mouse_event_callback_;
+ bool is_tracking_;
bool callbacks_added_;
dominickn 2015/10/06 04:11:46 I don't think both of these bools are necessary. C
};
@@ -84,16 +96,12 @@ class SiteEngagementHelper
// current contents location.
void RecordUserInput();
- bool ShouldRecordEngagement();
-
// content::WebContentsObserver overrides.
void DidNavigateMainFrame(
const content::LoadCommittedDetails& details,
const content::FrameNavigateParams& params) override;
-
void RenderViewHostChanged(content::RenderViewHost* old_host,
content::RenderViewHost* new_host) override;
-
void WasShown() override;
void WasHidden() override;

Powered by Google App Engine
This is Rietveld 408576698