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

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: comments 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 // This is the constructor that should be used by providers.
27 const ContentSuggestionsProviderType provider, 27 // Note that the |original_id| provided here is different from the ID that is
28 // returned from |id()| because it will be combined with the |provider_type|
29 // to obtain an ID that is unique application-wide.
30 ContentSuggestion(const std::string& original_id,
31 const ContentSuggestionsProviderType provider_type,
tschumann 2016/07/01 09:37:10 IMO the suggestion constructor should only get a s
Philipp Keck 2016/07/01 13:00:04 I can't think of any good solution in which this c
Marc Treib 2016/07/01 13:29:17 For "Articles for you", the mixing will happen on
Philipp Keck 2016/07/01 13:45:11 Acknowledged.
28 const ContentSuggestionCategory category, 32 const ContentSuggestionCategory category,
29 const GURL& url); 33 const GURL& url);
34 ContentSuggestion(ContentSuggestion&&);
35 ContentSuggestion& operator=(ContentSuggestion&&);
30 36
31 ~ContentSuggestion(); 37 ~ContentSuggestion();
32 38
33 // An ID for identifying the suggestion. The ID is unique among all 39 // An ID for identifying the suggestion. The ID is unique among all
34 // suggestions from the same provider, so to determine a globally unique 40 // suggestions of all providers.
35 // identifier, combine this ID with the provider type.
36 const std::string& id() const { return id_; } 41 const std::string& id() const { return id_; }
37 42
38 // The provider that created this suggestion.
39 ContentSuggestionsProviderType provider() const { return provider_; }
40
41 // The category that this suggestion belongs to. 43 // The category that this suggestion belongs to.
42 ContentSuggestionCategory category() const { return category_; } 44 ContentSuggestionCategory category() const { return category_; }
43 45
44 // The normal content URL where the content referenced by the suggestion can 46 // The normal content URL where the content referenced by the suggestion can
45 // be accessed. 47 // be accessed.
46 const GURL& url() const { return url_; } 48 const GURL& url() const { return url_; }
47 49
48 // If available, this contains an URL to an AMP version of the same content. 50 // If available, this contains an URL to an AMP version of the same content.
49 // Otherwise, this is an empty GURL(). 51 // Otherwise, this is an empty GURL().
50 const GURL& amp_url() const { return amp_url_; } 52 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 77 // TODO(pke) Remove the score from the ContentSuggestion class. The UI only
76 // uses it to track user clicks (histogram data). Instead, the providers 78 // uses it to track user clicks (histogram data). Instead, the providers
77 // should be informed about clicks and do appropriate logging themselves. 79 // should be informed about clicks and do appropriate logging themselves.
78 // IMPORTANT: The score may simply be 0 for suggestions from providers which 80 // IMPORTANT: The score may simply be 0 for suggestions from providers which
79 // cannot provide score values. 81 // cannot provide score values.
80 float score() const { return score_; } 82 float score() const { return score_; }
81 void set_score(float score) { score_ = score; } 83 void set_score(float score) { score_ = score; }
82 84
83 private: 85 private:
84 std::string id_; 86 std::string id_;
85 ContentSuggestionsProviderType provider_;
86 ContentSuggestionCategory category_; 87 ContentSuggestionCategory category_;
87 GURL url_; 88 GURL url_;
88 GURL amp_url_; 89 GURL amp_url_;
89 std::string title_; 90 std::string title_;
90 std::string snippet_text_; 91 std::string snippet_text_;
91 GURL salient_image_url_; 92 GURL salient_image_url_;
92 base::Time publish_date_; 93 base::Time publish_date_;
93 std::string publisher_name_; 94 std::string publisher_name_;
94 float score_; 95 float score_;
95 96
96 DISALLOW_COPY_AND_ASSIGN(ContentSuggestion); 97 DISALLOW_COPY_AND_ASSIGN(ContentSuggestion);
97 }; 98 };
98 99
99 } // namespace ntp_snippets 100 } // namespace ntp_snippets
100 101
101 #endif // COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_ 102 #endif // COMPONENTS_NTP_SNIPPETS_CONTENT_SUGGESTION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698