OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_TILES_MOST_VISITED_SITES_H_ | 5 #ifndef COMPONENTS_NTP_TILES_MOST_VISITED_SITES_H_ |
6 #define COMPONENTS_NTP_TILES_MOST_VISITED_SITES_H_ | 6 #define COMPONENTS_NTP_TILES_MOST_VISITED_SITES_H_ |
7 | 7 |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 | 9 |
10 #include <memory> | 10 #include <memory> |
11 #include <vector> | 11 #include <vector> |
12 | 12 |
13 #include "base/compiler_specific.h" | 13 #include "base/compiler_specific.h" |
14 #include "base/files/file_path.h" | 14 #include "base/files/file_path.h" |
15 #include "base/macros.h" | 15 #include "base/macros.h" |
16 #include "base/memory/weak_ptr.h" | 16 #include "base/memory/weak_ptr.h" |
17 #include "base/optional.h" | 17 #include "base/optional.h" |
18 #include "base/scoped_observer.h" | 18 #include "base/scoped_observer.h" |
19 #include "base/strings/string16.h" | 19 #include "base/strings/string16.h" |
20 #include "components/history/core/browser/history_types.h" | 20 #include "components/history/core/browser/history_types.h" |
21 #include "components/history/core/browser/top_sites_observer.h" | 21 #include "components/history/core/browser/top_sites_observer.h" |
22 #include "components/ntp_tiles/ntp_tile.h" | 22 #include "components/ntp_tiles/ntp_tile.h" |
23 #include "components/ntp_tiles/popular_sites.h" | 23 #include "components/ntp_tiles/popular_sites.h" |
| 24 #include "components/ntp_tiles/tile_source.h" |
24 #include "components/suggestions/proto/suggestions.pb.h" | 25 #include "components/suggestions/proto/suggestions.pb.h" |
25 #include "components/suggestions/suggestions_service.h" | 26 #include "components/suggestions/suggestions_service.h" |
26 #include "url/gurl.h" | 27 #include "url/gurl.h" |
27 | 28 |
28 namespace history { | 29 namespace history { |
29 class TopSites; | 30 class TopSites; |
30 } | 31 } |
31 | 32 |
32 namespace user_prefs { | 33 namespace user_prefs { |
33 class PrefRegistrySyncable; | 34 class PrefRegistrySyncable; |
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
98 suggestions::SuggestionsService* suggestions, | 99 suggestions::SuggestionsService* suggestions, |
99 std::unique_ptr<PopularSites> popular_sites, | 100 std::unique_ptr<PopularSites> popular_sites, |
100 std::unique_ptr<IconCacher> icon_cacher, | 101 std::unique_ptr<IconCacher> icon_cacher, |
101 std::unique_ptr<MostVisitedSitesSupervisor> supervisor); | 102 std::unique_ptr<MostVisitedSitesSupervisor> supervisor); |
102 | 103 |
103 ~MostVisitedSites() override; | 104 ~MostVisitedSites() override; |
104 | 105 |
105 // Returns true if this object was created with a non-null provider for the | 106 // Returns true if this object was created with a non-null provider for the |
106 // given NTP tile source. That source may or may not actually provide tiles, | 107 // given NTP tile source. That source may or may not actually provide tiles, |
107 // depending on its configuration and the priority of different sources. | 108 // depending on its configuration and the priority of different sources. |
108 bool DoesSourceExist(NTPTileSource source) const; | 109 bool DoesSourceExist(TileSource source) const; |
109 | 110 |
110 // Returns the corresponding object passed at construction. | 111 // Returns the corresponding object passed at construction. |
111 history::TopSites* top_sites() { return top_sites_.get(); } | 112 history::TopSites* top_sites() { return top_sites_.get(); } |
112 suggestions::SuggestionsService* suggestions() { | 113 suggestions::SuggestionsService* suggestions() { |
113 return suggestions_service_; | 114 return suggestions_service_; |
114 } | 115 } |
115 PopularSites* popular_sites() { return popular_sites_.get(); } | 116 PopularSites* popular_sites() { return popular_sites_.get(); } |
116 MostVisitedSitesSupervisor* supervisor() { return supervisor_.get(); } | 117 MostVisitedSitesSupervisor* supervisor() { return supervisor_.get(); } |
117 | 118 |
118 // Sets the observer, and immediately fetches the current suggestions. | 119 // Sets the observer, and immediately fetches the current suggestions. |
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
199 int num_sites_; | 200 int num_sites_; |
200 | 201 |
201 std::unique_ptr< | 202 std::unique_ptr< |
202 suggestions::SuggestionsService::ResponseCallbackList::Subscription> | 203 suggestions::SuggestionsService::ResponseCallbackList::Subscription> |
203 suggestions_subscription_; | 204 suggestions_subscription_; |
204 | 205 |
205 ScopedObserver<history::TopSites, history::TopSitesObserver> | 206 ScopedObserver<history::TopSites, history::TopSitesObserver> |
206 top_sites_observer_; | 207 top_sites_observer_; |
207 | 208 |
208 // The main source of personal tiles - either TOP_SITES or SUGGESTIONS_SEVICE. | 209 // The main source of personal tiles - either TOP_SITES or SUGGESTIONS_SEVICE. |
209 NTPTileSource mv_source_; | 210 TileSource mv_source_; |
210 | 211 |
211 // Current set of tiles. Optional so that the observer can be notified | 212 // Current set of tiles. Optional so that the observer can be notified |
212 // whenever it changes, including possibily an initial change from | 213 // whenever it changes, including possibily an initial change from |
213 // !current_tiles_.has_value() to current_tiles_->empty(). | 214 // !current_tiles_.has_value() to current_tiles_->empty(). |
214 base::Optional<NTPTilesVector> current_tiles_; | 215 base::Optional<NTPTilesVector> current_tiles_; |
215 | 216 |
216 // For callbacks may be run after destruction, used exclusively for TopSites | 217 // For callbacks may be run after destruction, used exclusively for TopSites |
217 // (since it's used to detect whether there's a query in flight). | 218 // (since it's used to detect whether there's a query in flight). |
218 base::WeakPtrFactory<MostVisitedSites> top_sites_weak_ptr_factory_; | 219 base::WeakPtrFactory<MostVisitedSites> top_sites_weak_ptr_factory_; |
219 | 220 |
220 DISALLOW_COPY_AND_ASSIGN(MostVisitedSites); | 221 DISALLOW_COPY_AND_ASSIGN(MostVisitedSites); |
221 }; | 222 }; |
222 | 223 |
223 } // namespace ntp_tiles | 224 } // namespace ntp_tiles |
224 | 225 |
225 #endif // COMPONENTS_NTP_TILES_MOST_VISITED_SITES_H_ | 226 #endif // COMPONENTS_NTP_TILES_MOST_VISITED_SITES_H_ |
OLD | NEW |