blob: e566553392098be3006142e39fa5948c6a12a3e8 [file] [log] [blame]
// Copyright 2017 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.
#include "chrome/browser/ui/blocked_content/popup_opener_tab_helper.h"
#include <utility>
#include "base/logging.h"
#include "base/memory/ptr_util.h"
#include "base/metrics/histogram_macros.h"
#include "base/time/tick_clock.h"
#include "chrome/browser/ui/blocked_content/scoped_visibility_tracker.h"
#include "chrome/browser/ui/blocked_content/tab_under_navigation_throttle.h"
#include "content/public/browser/navigation_handle.h"
#include "content/public/browser/web_contents.h"
#include "services/metrics/public/cpp/ukm_source_id.h"
DEFINE_WEB_CONTENTS_USER_DATA_KEY(PopupOpenerTabHelper);
// static
void PopupOpenerTabHelper::CreateForWebContents(
content::WebContents* contents,
std::unique_ptr<base::TickClock> tick_clock) {
DCHECK(contents);
if (!FromWebContents(contents)) {
contents->SetUserData(UserDataKey(),
base::WrapUnique(new PopupOpenerTabHelper(
contents, std::move(tick_clock))));
}
}
PopupOpenerTabHelper::~PopupOpenerTabHelper() {
DCHECK(visibility_tracker_);
base::TimeDelta total_visible_time =
visibility_tracker_->GetForegroundDuration();
if (did_tab_under()) {
UMA_HISTOGRAM_LONG_TIMES(
"Tab.TabUnder.VisibleTime",
total_visible_time - visible_time_before_tab_under_.value());
UMA_HISTOGRAM_LONG_TIMES("Tab.TabUnder.VisibleTimeBefore",
visible_time_before_tab_under_.value());
}
UMA_HISTOGRAM_LONG_TIMES("Tab.VisibleTime", total_visible_time);
}
void PopupOpenerTabHelper::OnOpenedPopup(PopupTracker* popup_tracker) {
has_opened_popup_since_last_user_gesture_ = true;
last_popup_open_time_ = tick_clock_->NowTicks();
}
void PopupOpenerTabHelper::OnDidTabUnder() {
// The tab already did a tab-under.
if (did_tab_under())
return;
// Tab-under requires a popup, so this better not be null.
DCHECK(!last_popup_open_time_.is_null());
UMA_HISTOGRAM_LONG_TIMES("Tab.TabUnder.PopupToTabUnderTime",
tick_clock_->NowTicks() - last_popup_open_time_);
visible_time_before_tab_under_ = visibility_tracker_->GetForegroundDuration();
}
PopupOpenerTabHelper::PopupOpenerTabHelper(
content::WebContents* web_contents,
std::unique_ptr<base::TickClock> tick_clock)
: content::WebContentsObserver(web_contents),
tick_clock_(std::move(tick_clock)) {
visibility_tracker_ = base::MakeUnique<ScopedVisibilityTracker>(
tick_clock_.get(), web_contents->IsVisible());
}
void PopupOpenerTabHelper::DidFinishNavigation(
content::NavigationHandle* navigation_handle) {
if (!navigation_handle->HasCommitted() ||
!navigation_handle->IsInMainFrame() ||
navigation_handle->IsSameDocument()) {
return;
}
last_committed_source_id_ = ukm::ConvertToSourceId(
navigation_handle->GetNavigationId(), ukm::SourceIdType::NAVIGATION_ID);
}
void PopupOpenerTabHelper::WasShown() {
visibility_tracker_->OnShown();
}
void PopupOpenerTabHelper::WasHidden() {
visibility_tracker_->OnHidden();
}
void PopupOpenerTabHelper::DidGetUserInteraction(
const blink::WebInputEvent::Type type) {
has_opened_popup_since_last_user_gesture_ = false;
}