// Copyright 2016 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 COMPONENTS_NTP_SNIPPETS_FEATURES_H_ #define COMPONENTS_NTP_SNIPPETS_FEATURES_H_ #include #include #include "base/feature_list.h" #include "components/ntp_snippets/category_rankers/category_ranker.h" #include "components/prefs/pref_service.h" namespace base { class Clock; } namespace ntp_snippets { // // Null-terminated list of all features related to content suggestions. // // If you add a base::Feature below, you must add it to this list. It is used in // internal pages to list relevant parameters and settings. // extern const base::Feature* const kAllFeatures[]; //////////////////////////////////////////////////////////////////////////////// // Dependent features. // DO NOT check directly whether these features are enabled (i.e. do // not use base::FeatureList::IsEnabled()). They are enabled conditionally. Use // helpers in chrome/browser/ntp_snippets/dependent_features.h instead. extern const base::Feature kBookmarkSuggestionsFeature; extern const base::Feature kRecentOfflineTabSuggestionsFeature; extern const base::Feature kPhysicalWebPageSuggestionsFeature; extern const base::Feature kForeignSessionsSuggestionsFeature; //////////////////////////////////////////////////////////////////////////////// // Independent features. Treat as normal // Feature to allow show/hide article suggestions by clicking the header. extern const base::Feature kArticleSuggestionsExpandableHeader; // TODO(jkrcal): Rename to kRemoteSuggestionsFeature. extern const base::Feature kArticleSuggestionsFeature; // Feature to allow UI as specified here: https://crbug.com/660837. extern const base::Feature kIncreasedVisibility; // Feature to listen for GCM push updates from the server. extern const base::Feature kBreakingNewsPushFeature; // Feature to choose a category ranker. extern const base::Feature kCategoryRanker; // Feature to allow the new Google favicon server for fetching publisher icons. extern const base::Feature kPublisherFaviconsFromNewServerFeature; // Feature for simple experimental comparison and validation of changes since // M58: enabling this brings back the M58 Stable fetching schedule (which is // suitable for Holdback groups). // TODO(jkrcal): Remove when the comparison is done (probably after M62). extern const base::Feature kRemoteSuggestionsEmulateM58FetchingSchedule; // Parameter and its values for the kCategoryRanker feature flag. extern const char kCategoryRankerParameter[]; extern const char kCategoryRankerConstantRanker[]; extern const char kCategoryRankerClickBasedRanker[]; enum class CategoryRankerChoice { CONSTANT, CLICK_BASED, }; // Returns which CategoryRanker to use according to kCategoryRanker feature and // Chrome Home. CategoryRankerChoice GetSelectedCategoryRanker(bool is_chrome_home_enabled); // Builds a CategoryRanker according to kCategoryRanker feature and Chrome Home. std::unique_ptr BuildSelectedCategoryRanker( PrefService* pref_service, base::Clock* clock, bool is_chrome_home_enabled); // Feature to choose a default category order. extern const base::Feature kCategoryOrder; // Parameter and its values for the kCategoryOrder feature flag. extern const char kCategoryOrderParameter[]; extern const char kCategoryOrderGeneral[]; extern const char kCategoryOrderEmergingMarketsOriented[]; enum class CategoryOrderChoice { GENERAL, EMERGING_MARKETS_ORIENTED, }; // Returns which category order to use according to kCategoryOrder feature. CategoryOrderChoice GetSelectedCategoryOrder(); // Enables and configures notifications for content suggestions on Android. extern const base::Feature kNotificationsFeature; // An integer. The priority of the notification, ranging from -2 (PRIORITY_MIN) // to 2 (PRIORITY_MAX). Vibrates and makes sound if >= 0. extern const char kNotificationsPriorityParam[]; constexpr int kNotificationsDefaultPriority = -1; // "publisher": use article's publisher as notification's text (default). // "snippet": use article's snippet as notification's text. // "and_more": use "From $1. Read this article and $2 more." as text. extern const char kNotificationsTextParam[]; extern const char kNotificationsTextValuePublisher[]; extern const char kNotificationsTextValueSnippet[]; extern const char kNotificationsTextValueAndMore[]; // "true": when Chrome becomes frontmost, leave notifications open. // "false": automatically dismiss notification when Chrome becomes frontmost. extern const char kNotificationsKeepWhenFrontmostParam[]; // "true": notifications link to chrome://newtab, with appropriate text. // "false": notifications link to URL of notifying article. extern const char kNotificationsOpenToNTPParam[]; // An integer. The maximum number of notifications that will be shown in 1 day. extern const char kNotificationsDailyLimit[]; constexpr int kNotificationsDefaultDailyLimit = 1; // An integer. The number of notifications that can be ignored. If the user // ignores this many notifications or more, we stop sending them. extern const char kNotificationsIgnoredLimitParam[]; constexpr int kNotificationsIgnoredDefaultLimit = 3; // Whether to keep some prefetched content suggestions even when new suggestions // have been fetched. extern const base::Feature kKeepPrefetchedContentSuggestions; // Enables debug logging accessible through snippets-internals. extern const base::Feature kContentSuggestionsDebugLog; } // namespace ntp_snippets #endif // COMPONENTS_NTP_SNIPPETS_FEATURES_H_