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

Unified Diff: ios/chrome/browser/content_suggestions/mediator_util.mm

Issue 2798563002: Add MostVistedSites to ContentSuggestionsMediator (Closed)
Patch Set: Rebase (different HEAD) Created 3 years, 8 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: ios/chrome/browser/content_suggestions/mediator_util.mm
diff --git a/ios/chrome/browser/content_suggestions/mediator_util.mm b/ios/chrome/browser/content_suggestions/mediator_util.mm
index 26f7335fe2a9858e7b7fb7b31c532eafbf11165d..d4ea2f9dd6876ac1e4cfac70ddad913c1ba73e00 100644
--- a/ios/chrome/browser/content_suggestions/mediator_util.mm
+++ b/ios/chrome/browser/content_suggestions/mediator_util.mm
@@ -6,6 +6,9 @@
#include "base/strings/sys_string_conversions.h"
#include "components/ntp_snippets/category.h"
+#include "components/ntp_tiles/metrics.h"
+#include "components/rappor/rappor_service_impl.h"
+#include "ios/chrome/browser/application_context.h"
#import "ios/chrome/browser/content_suggestions/content_suggestions_category_wrapper.h"
#import "ios/chrome/browser/ui/content_suggestions/identifier/content_suggestion_identifier.h"
#include "ios/chrome/grit/ios_strings.h"
@@ -96,3 +99,46 @@ ntp_snippets::ContentSuggestion::ID SuggestionIDForSectionID(
const std::string& id_in_category) {
return ntp_snippets::ContentSuggestion::ID(category.category, id_in_category);
}
+
+ContentSuggestion* EmptySuggestion() {
+ ContentSuggestion* suggestion = [[ContentSuggestion alloc] init];
+ suggestion.type = ContentSuggestionTypeEmpty;
+ suggestion.suggestionIdentifier = [[ContentSuggestionIdentifier alloc] init];
+
+ return suggestion;
+}
+
+ContentSuggestionsSectionInformation* MostVisitedSectionInformation() {
+ ContentSuggestionsSectionInformation* sectionInfo =
+ [[ContentSuggestionsSectionInformation alloc]
+ initWithSectionID:ContentSuggestionsSectionMostVisited];
+ sectionInfo.title = nil;
+ sectionInfo.footerTitle = nil;
+ sectionInfo.showIfEmpty = NO;
+ sectionInfo.layout = ContentSuggestionsSectionLayoutCustom;
+
+ return sectionInfo;
+}
+
+void RecordPageImpression(const ntp_tiles::NTPTilesVector& mostVisited) {
+ std::vector<ntp_tiles::metrics::TileImpression> tiles;
+ for (const ntp_tiles::NTPTile& ntpTile : mostVisited) {
+ tiles.emplace_back(ntpTile.source, ntp_tiles::UNKNOWN_TILE_TYPE,
+ ntpTile.url);
+ }
+ ntp_tiles::metrics::RecordPageImpression(
+ tiles, GetApplicationContext()->GetRapporServiceImpl());
+}
+
+ContentSuggestion* ConvertNTPTile(const ntp_tiles::NTPTile& tile) {
+ ContentSuggestion* suggestion = [[ContentSuggestion alloc] init];
+
+ suggestion.title = base::SysUTF16ToNSString(tile.title);
+ suggestion.url = tile.url;
+ suggestion.type = ContentSuggestionTypeMostVisited;
+
+ suggestion.suggestionIdentifier = [[ContentSuggestionIdentifier alloc] init];
+ suggestion.suggestionIdentifier.IDInSection = tile.url.spec();
+
+ return suggestion;
+}
« no previous file with comments | « ios/chrome/browser/content_suggestions/mediator_util.h ('k') | ios/chrome/browser/ui/content_suggestions/content_suggestion.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698