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

Unified Diff: chrome/browser/ui/webui/browsing_history_handler.cc

Issue 1462813003: Split BrowsingHistoryHandler out of history_ui.cc (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 1 month 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/ui/webui/browsing_history_handler.cc
diff --git a/chrome/browser/ui/webui/history_ui.cc b/chrome/browser/ui/webui/browsing_history_handler.cc
similarity index 78%
copy from chrome/browser/ui/webui/history_ui.cc
copy to chrome/browser/ui/webui/browsing_history_handler.cc
index 36cc8c2f9166ee8484140debedcdfa40450bd682..21e9d5426e256a0f6e5c5f89ec7ddd6a7c892af3 100644
--- a/chrome/browser/ui/webui/history_ui.cc
+++ b/chrome/browser/ui/webui/browsing_history_handler.cc
@@ -1,18 +1,15 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Copyright 2015 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/webui/history_ui.h"
+#include "chrome/browser/ui/webui/browsing_history_handler.h"
#include <set>
#include "base/bind.h"
#include "base/bind_helpers.h"
-#include "base/command_line.h"
#include "base/i18n/rtl.h"
#include "base/i18n/time_formatting.h"
-#include "base/memory/singleton.h"
-#include "base/message_loop/message_loop.h"
#include "base/metrics/histogram.h"
#include "base/prefs/pref_service.h"
#include "base/strings/string16.h"
@@ -22,22 +19,16 @@
#include "base/values.h"
#include "chrome/browser/banners/app_banner_settings_helper.h"
#include "chrome/browser/bookmarks/bookmark_model_factory.h"
-#include "chrome/browser/chrome_notification_types.h"
#include "chrome/browser/engagement/site_engagement_service.h"
#include "chrome/browser/history/history_service_factory.h"
#include "chrome/browser/history/history_utils.h"
#include "chrome/browser/history/web_history_service_factory.h"
-#include "chrome/browser/prefs/incognito_mode_prefs.h"
#include "chrome/browser/profiles/profile.h"
-#include "chrome/browser/signin/signin_manager_factory.h"
#include "chrome/browser/sync/profile_sync_service_factory.h"
#include "chrome/browser/ui/browser_finder.h"
#include "chrome/browser/ui/chrome_pages.h"
#include "chrome/browser/ui/webui/favicon_source.h"
-#include "chrome/browser/ui/webui/metrics_handler.h"
-#include "chrome/common/chrome_switches.h"
#include "chrome/common/pref_names.h"
-#include "chrome/common/url_constants.h"
#include "chrome/grit/generated_resources.h"
#include "components/bookmarks/browser/bookmark_model.h"
#include "components/bookmarks/browser/bookmark_utils.h"
@@ -45,21 +36,17 @@
#include "components/history/core/browser/history_service.h"
#include "components/history/core/browser/history_types.h"
#include "components/history/core/browser/web_history_service.h"
-#include "components/search/search.h"
-#include "components/signin/core/browser/signin_manager.h"
+#include "components/keyed_service/core/service_access_type.h"
+#include "components/query_parser/snippet.h"
#include "components/sync_driver/device_info.h"
+#include "components/sync_driver/device_info_tracker.h"
#include "components/url_formatter/url_formatter.h"
#include "content/public/browser/url_data_source.h"
#include "content/public/browser/web_ui.h"
-#include "content/public/browser/web_ui_data_source.h"
-#include "grit/browser_resources.h"
-#include "grit/theme_resources.h"
-#include "net/base/escape.h"
#include "sync/protocol/history_delete_directive_specifics.pb.h"
+#include "sync/protocol/sync_enums.pb.h"
#include "ui/base/l10n/l10n_util.h"
#include "ui/base/l10n/time_format.h"
-#include "ui/base/resource/resource_bundle.h"
-#include "ui/base/webui/web_ui_util.h"
#if defined(ENABLE_EXTENSIONS)
#include "chrome/browser/extensions/activity_log/activity_log.h"
@@ -76,20 +63,11 @@
#include "chrome/browser/android/chrome_application.h"
#endif
-#if !defined(OS_ANDROID) && !defined(OS_IOS)
-#include "chrome/browser/ui/webui/foreign_session_handler.h"
-#include "chrome/browser/ui/webui/history_login_handler.h"
-#endif
-
-using bookmarks::BookmarkModel;
-
-static const char kStringsJsFile[] = "strings.js";
-static const char kHistoryJsFile[] = "history.js";
-static const char kOtherDevicesJsFile[] = "other_devices.js";
-
// The amount of time to wait for a response from the WebHistoryService.
static const int kWebHistoryTimeoutSeconds = 3;
+using bookmarks::BookmarkModel;
+
namespace {
// Buckets for UMA histograms.
@@ -100,129 +78,11 @@ enum WebHistoryQueryBuckets {
NUM_WEB_HISTORY_QUERY_BUCKETS
};
-#if defined(OS_MACOSX)
-const char kIncognitoModeShortcut[] = "("
- "\xE2\x87\xA7" // Shift symbol (U+21E7 'UPWARDS WHITE ARROW').
- "\xE2\x8C\x98" // Command symbol (U+2318 'PLACE OF INTEREST SIGN').
- "N)";
-#elif defined(OS_WIN)
-const char kIncognitoModeShortcut[] = "(Ctrl+Shift+N)";
-#else
-const char kIncognitoModeShortcut[] = "(Shift+Ctrl+N)";
-#endif
-
// Identifiers for the type of device from which a history entry originated.
static const char kDeviceTypeLaptop[] = "laptop";
static const char kDeviceTypePhone[] = "phone";
static const char kDeviceTypeTablet[] = "tablet";
-content::WebUIDataSource* CreateHistoryUIHTMLSource(Profile* profile) {
- PrefService* prefs = profile->GetPrefs();
-
- // Check if the profile is authenticated. Guest profiles or incognito
- // windows may not have a sign in manager, and are considered not
- // authenticated.
- SigninManagerBase* signin_manager =
- SigninManagerFactory::GetForProfile(profile);
- bool is_authenticated = signin_manager != nullptr &&
- signin_manager->IsAuthenticated();
-
- content::WebUIDataSource* source =
- content::WebUIDataSource::Create(chrome::kChromeUIHistoryFrameHost);
- source->AddBoolean("isUserSignedIn", is_authenticated);
- source->AddLocalizedString("collapseSessionMenuItemText",
- IDS_HISTORY_OTHER_SESSIONS_COLLAPSE_SESSION);
- source->AddLocalizedString("expandSessionMenuItemText",
- IDS_HISTORY_OTHER_SESSIONS_EXPAND_SESSION);
- source->AddLocalizedString("restoreSessionMenuItemText",
- IDS_HISTORY_OTHER_SESSIONS_OPEN_ALL);
- source->AddLocalizedString("xMore", IDS_HISTORY_OTHER_DEVICES_X_MORE);
- source->AddLocalizedString("loading", IDS_HISTORY_LOADING);
- source->AddLocalizedString("title", IDS_HISTORY_TITLE);
- source->AddLocalizedString("newest", IDS_HISTORY_NEWEST);
- source->AddLocalizedString("newer", IDS_HISTORY_NEWER);
- source->AddLocalizedString("older", IDS_HISTORY_OLDER);
- source->AddLocalizedString("searchResultsFor", IDS_HISTORY_SEARCHRESULTSFOR);
- source->AddLocalizedString("searchResult", IDS_HISTORY_SEARCH_RESULT);
- source->AddLocalizedString("searchResults", IDS_HISTORY_SEARCH_RESULTS);
- source->AddLocalizedString("foundSearchResults",
- IDS_HISTORY_FOUND_SEARCH_RESULTS);
- source->AddLocalizedString("history", IDS_HISTORY_BROWSERESULTS);
- source->AddLocalizedString("cont", IDS_HISTORY_CONTINUED);
- source->AddLocalizedString("searchButton", IDS_HISTORY_SEARCH_BUTTON);
- source->AddLocalizedString("noSearchResults", IDS_HISTORY_NO_SEARCH_RESULTS);
- source->AddLocalizedString("noResults", IDS_HISTORY_NO_RESULTS);
- source->AddLocalizedString("historyInterval", IDS_HISTORY_INTERVAL);
- source->AddLocalizedString("removeSelected",
- IDS_HISTORY_REMOVE_SELECTED_ITEMS);
- source->AddLocalizedString("clearAllHistory",
- IDS_HISTORY_OPEN_CLEAR_BROWSING_DATA_DIALOG);
-
- auto availability = IncognitoModePrefs::GetAvailability(profile->GetPrefs());
- base::string16 delete_warning = availability == IncognitoModePrefs::ENABLED ?
- l10n_util::GetStringFUTF16(IDS_HISTORY_DELETE_PRIOR_VISITS_WARNING,
- base::UTF8ToUTF16(kIncognitoModeShortcut)) :
- l10n_util::GetStringUTF16(
- IDS_HISTORY_DELETE_PRIOR_VISITS_WARNING_NO_INCOGNITO);
- source->AddString("deleteWarning", delete_warning);
-
- source->AddLocalizedString("removeBookmark", IDS_HISTORY_REMOVE_BOOKMARK);
- source->AddLocalizedString("actionMenuDescription",
- IDS_HISTORY_ACTION_MENU_DESCRIPTION);
- source->AddLocalizedString("removeFromHistory", IDS_HISTORY_REMOVE_PAGE);
- source->AddLocalizedString("moreFromSite", IDS_HISTORY_MORE_FROM_SITE);
- source->AddLocalizedString("groupByDomainLabel", IDS_GROUP_BY_DOMAIN_LABEL);
- source->AddLocalizedString("rangeLabel", IDS_HISTORY_RANGE_LABEL);
- source->AddLocalizedString("rangeAllTime", IDS_HISTORY_RANGE_ALL_TIME);
- source->AddLocalizedString("rangeWeek", IDS_HISTORY_RANGE_WEEK);
- source->AddLocalizedString("rangeMonth", IDS_HISTORY_RANGE_MONTH);
- source->AddLocalizedString("rangeToday", IDS_HISTORY_RANGE_TODAY);
- source->AddLocalizedString("rangeNext", IDS_HISTORY_RANGE_NEXT);
- source->AddLocalizedString("rangePrevious", IDS_HISTORY_RANGE_PREVIOUS);
- source->AddLocalizedString("numberVisits", IDS_HISTORY_NUMBER_VISITS);
- source->AddLocalizedString("filterAllowed", IDS_HISTORY_FILTER_ALLOWED);
- source->AddLocalizedString("filterBlocked", IDS_HISTORY_FILTER_BLOCKED);
- source->AddLocalizedString("inContentPack", IDS_HISTORY_IN_CONTENT_PACK);
- source->AddLocalizedString("allowItems", IDS_HISTORY_FILTER_ALLOW_ITEMS);
- source->AddLocalizedString("blockItems", IDS_HISTORY_FILTER_BLOCK_ITEMS);
- source->AddLocalizedString("blockedVisitText",
- IDS_HISTORY_BLOCKED_VISIT_TEXT);
- source->AddLocalizedString("hasSyncedResults",
- IDS_HISTORY_HAS_SYNCED_RESULTS);
- source->AddLocalizedString("noSyncedResults", IDS_HISTORY_NO_SYNCED_RESULTS);
- source->AddLocalizedString("cancel", IDS_CANCEL);
- source->AddLocalizedString("deleteConfirm",
- IDS_HISTORY_DELETE_PRIOR_VISITS_CONFIRM_BUTTON);
- source->AddLocalizedString("bookmarked", IDS_HISTORY_ENTRY_BOOKMARKED);
- source->AddLocalizedString("entrySummary", IDS_HISTORY_ENTRY_SUMMARY);
- source->AddBoolean("isFullHistorySyncEnabled",
- WebHistoryServiceFactory::GetForProfile(profile) != NULL);
- bool group_by_domain = base::CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kHistoryEnableGroupByDomain);
- // Supervised users get the "group by domain" version, but not on mobile,
- // because that version isn't adjusted for small screens yet. crbug.com/452859
-#if !defined(OS_ANDROID) && !defined(OS_IOS)
- group_by_domain = group_by_domain || profile->IsSupervised();
-#endif
- source->AddBoolean("groupByDomain", group_by_domain);
- bool allow_deleting_history =
- prefs->GetBoolean(prefs::kAllowDeletingBrowserHistory);
- source->AddBoolean("allowDeletingHistory", allow_deleting_history);
- source->AddBoolean("isInstantExtendedApiEnabled",
- search::IsInstantExtendedAPIEnabled());
- source->AddBoolean("isSupervisedProfile", profile->IsSupervised());
- source->AddBoolean("hideDeleteVisitUI",
- profile->IsSupervised() && !allow_deleting_history);
-
- source->SetJsonPath(kStringsJsFile);
- source->AddResourcePath(kHistoryJsFile, IDR_HISTORY_JS);
- source->AddResourcePath(kOtherDevicesJsFile, IDR_OTHER_DEVICES_JS);
- source->SetDefaultResource(IDR_HISTORY_HTML);
- source->DisableDenyXFrameOptions();
-
- return source;
-}
-
// Returns a localized version of |visit_time| including a relative
// indicator (e.g. today, yesterday).
base::string16 getRelativeDateLocalized(const base::Time& visit_time) {
Dan Beam 2015/11/20 20:13:00 GetRelativeDateLocalized
tsergeant 2015/11/22 23:45:18 Done.
@@ -239,7 +99,6 @@ base::string16 getRelativeDateLocalized(const base::Time& visit_time) {
return date_str;
}
-
// Sets the correct year when substracting months from a date.
void normalizeMonths(base::Time::Exploded* exploded) {
Dan Beam 2015/11/20 20:13:00 NormalizeMonths
tsergeant 2015/11/22 23:45:18 Done.
// Decrease a year at a time until we have a proper date.
@@ -290,12 +149,6 @@ void GetDeviceNameAndType(const ProfileSyncService* sync_service,
} // namespace
-////////////////////////////////////////////////////////////////////////////////
-//
-// BrowsingHistoryHandler
-//
-////////////////////////////////////////////////////////////////////////////////
-
BrowsingHistoryHandler::HistoryEntry::HistoryEntry(
BrowsingHistoryHandler::HistoryEntry::EntryType entry_type,
const GURL& url, const base::string16& title, base::Time time,
@@ -1030,35 +883,3 @@ void BrowsingHistoryHandler::OnURLsDeleted(
if (all_history || DeletionsDiffer(deleted_rows, urls_to_be_deleted_))
web_ui()->CallJavascriptFunction("historyDeleted");
}
-
-////////////////////////////////////////////////////////////////////////////////
-//
-// HistoryUI
-//
-////////////////////////////////////////////////////////////////////////////////
-
-HistoryUI::HistoryUI(content::WebUI* web_ui) : WebUIController(web_ui) {
- web_ui->AddMessageHandler(new BrowsingHistoryHandler());
- web_ui->AddMessageHandler(new MetricsHandler());
-
- // On mobile we deal with foreign sessions differently.
-#if !defined(OS_ANDROID) && !defined(OS_IOS)
- if (search::IsInstantExtendedAPIEnabled()) {
- web_ui->AddMessageHandler(new browser_sync::ForeignSessionHandler());
- web_ui->AddMessageHandler(new HistoryLoginHandler());
- }
-#endif
-
- // Set up the chrome://history-frame/ source.
- Profile* profile = Profile::FromWebUI(web_ui);
- content::WebUIDataSource::Add(profile, CreateHistoryUIHTMLSource(profile));
-}
-
-HistoryUI::~HistoryUI() {}
-
-// static
-base::RefCountedMemory* HistoryUI::GetFaviconResourceBytes(
- ui::ScaleFactor scale_factor) {
- return ResourceBundle::GetSharedInstance().
- LoadDataResourceBytesForScale(IDR_HISTORY_FAVICON, scale_factor);
-}

Powered by Google App Engine
This is Rietveld 408576698