blob: fd174d50c833be29ecccada200c19012232a4e90 [file] [log] [blame]
// Copyright (c) 2012 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 CHROME_BROWSER_UI_WEBUI_NTP_SUGGESTIONS_SOURCE_H_
#define CHROME_BROWSER_UI_WEBUI_NTP_SUGGESTIONS_SOURCE_H_
#include "base/basictypes.h"
class Profile;
class SuggestionsCombiner;
namespace base {
class DictionaryValue;
}
// Interface for a source of suggested pages. The various sources will be
// combined by the SuggestionsCombiner.
class SuggestionsSource {
public:
virtual ~SuggestionsSource() {}
protected:
SuggestionsSource() {}
friend class SuggestionsCombiner;
// Enables or disables debug mode for the current source. The source is
// expected to provide additional data when debug mode is enabled.
virtual void SetDebug(bool enable) = 0;
// The source's weight indicates how many items from this source will be
// selected by the combiner. If a source weight is x and the total weight of
// all the sources is y, then the combiner will select x/y items from it.
virtual int GetWeight() = 0;
// Returns the number of items this source can produce.
virtual int GetItemCount() = 0;
// Removes the most important item from this source and returns it. The
// returned item must be in the right format to be sent to the javascript,
// which you typically get by calling NewTabUI::SetUrlTitleAndDirection. If
// the source is empty this method returns null.
// The caller takes ownership of the returned item.
virtual base::DictionaryValue* PopItem() = 0;
// Requests that the source fetch its items. If the source is already fetching
// it does not have to reset and can continue fetching.
virtual void FetchItems(Profile* profile) = 0;
// Sets the combiner holding this suggestion source. This method can only
// be called once.
virtual void SetCombiner(SuggestionsCombiner* combiner) = 0;
private:
DISALLOW_COPY_AND_ASSIGN(SuggestionsSource);
};
#endif // CHROME_BROWSER_UI_WEBUI_NTP_SUGGESTIONS_SOURCE_H_