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

Side by Side Diff: components/ntp_snippets/content_suggestion.h

Issue 2102023002: Add ContentSuggestionsService (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Minor corrections Created 4 years, 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_ 5 #ifndef COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_
6 #define COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_ 6 #define COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_
7 7
8 #include <memory> 8 #include <memory>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
11 11
12 #include "base/macros.h" 12 #include "base/macros.h"
13 #include "base/time/time.h" 13 #include "base/time/time.h"
14 #include "components/ntp_snippets/content_suggestion_category.h" 14 #include "components/ntp_snippets/content_suggestion_category.h"
15 #include "components/ntp_snippets/content_suggestions_provider_type.h" 15 #include "components/ntp_snippets/content_suggestions_provider_type.h"
16 #include "url/gurl.h" 16 #include "url/gurl.h"
17 17
18 namespace ntp_snippets { 18 namespace ntp_snippets {
19 19
20 // A content suggestion for the new tab page, which can be an article or an 20 // A content suggestion for the new tab page, which can be an article or an
21 // offline page, for example. 21 // offline page, for example.
22 // NOTE: This class is not yet in use, please use NTPSnippet for now 22 // NOTE: This class is not yet in use, please use NTPSnippet for now
23 // (see ntp_snippet.h). 23 // (see ntp_snippet.h).
24 class ContentSuggestion { 24 class ContentSuggestion {
25 public: 25 public:
26 ContentSuggestion(const std::string& id, 26 ContentSuggestion(const std::string& id,
Marc Treib 2016/06/30 10:36:53 Rename this to "provider_id" or something like tha
Philipp Keck 2016/06/30 17:14:07 Should avoid "provider_id" because it would be an
Marc Treib 2016/07/01 09:15:32 Acknowledged.
27 const ContentSuggestionsProviderType provider, 27 const ContentSuggestionsProviderType provider_type,
28 const ContentSuggestionCategory category, 28 const ContentSuggestionCategory category,
29 const GURL& url); 29 const GURL& url);
30 ContentSuggestion(ContentSuggestion&&);
31 ContentSuggestion& operator=(ContentSuggestion&&);
30 32
31 ~ContentSuggestion(); 33 ~ContentSuggestion();
32 34
33 // An ID for identifying the suggestion. The ID is unique among all 35 // An ID for identifying the suggestion. The ID is unique among all
34 // suggestions from the same provider, so to determine a globally unique 36 // suggestions of all providers.
35 // identifier, combine this ID with the provider type.
36 const std::string& id() const { return id_; } 37 const std::string& id() const { return id_; }
37 38
38 // The provider that created this suggestion.
39 ContentSuggestionsProviderType provider() const { return provider_; }
40
41 // The category that this suggestion belongs to. 39 // The category that this suggestion belongs to.
42 ContentSuggestionCategory category() const { return category_; } 40 ContentSuggestionCategory category() const { return category_; }
43 41
44 // The normal content URL where the content referenced by the suggestion can 42 // The normal content URL where the content referenced by the suggestion can
45 // be accessed. 43 // be accessed.
46 const GURL& url() const { return url_; } 44 const GURL& url() const { return url_; }
47 45
48 // If available, this contains an URL to an AMP version of the same content. 46 // If available, this contains an URL to an AMP version of the same content.
49 // Otherwise, this is an empty GURL(). 47 // Otherwise, this is an empty GURL().
50 const GURL& amp_url() const { return amp_url_; } 48 const GURL& amp_url() const { return amp_url_; }
(...skipping 24 matching lines...) Expand all
75 // TODO(pke) Remove the score from the ContentSuggestion class. The UI only 73 // TODO(pke) Remove the score from the ContentSuggestion class. The UI only
76 // uses it to track user clicks (histogram data). Instead, the providers 74 // uses it to track user clicks (histogram data). Instead, the providers
77 // should be informed about clicks and do appropriate logging themselves. 75 // should be informed about clicks and do appropriate logging themselves.
78 // IMPORTANT: The score may simply be 0 for suggestions from providers which 76 // IMPORTANT: The score may simply be 0 for suggestions from providers which
79 // cannot provide score values. 77 // cannot provide score values.
80 float score() const { return score_; } 78 float score() const { return score_; }
81 void set_score(float score) { score_ = score; } 79 void set_score(float score) { score_ = score; }
82 80
83 private: 81 private:
84 std::string id_; 82 std::string id_;
85 ContentSuggestionsProviderType provider_;
86 ContentSuggestionCategory category_; 83 ContentSuggestionCategory category_;
87 GURL url_; 84 GURL url_;
88 GURL amp_url_; 85 GURL amp_url_;
89 std::string title_; 86 std::string title_;
90 std::string snippet_text_; 87 std::string snippet_text_;
91 GURL salient_image_url_; 88 GURL salient_image_url_;
92 base::Time publish_date_; 89 base::Time publish_date_;
93 std::string publisher_name_; 90 std::string publisher_name_;
94 float score_; 91 float score_;
95 92
96 DISALLOW_COPY_AND_ASSIGN(ContentSuggestion); 93 DISALLOW_COPY_AND_ASSIGN(ContentSuggestion);
97 }; 94 };
98 95
99 } // namespace ntp_snippets 96 } // namespace ntp_snippets
100 97
101 #endif // COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_ 98 #endif // COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698