// Copyright (c) 2010 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_PAGE_INFO_MODEL_H_
#define CHROME_BROWSER_PAGE_INFO_MODEL_H_
#pragma once
#include <vector>
#include "base/string16.h"
#include "chrome/browser/history/history.h"
#include "content/browser/cancelable_request.h"
#include "content/browser/tab_contents/navigation_entry.h"
#include "googleurl/src/gurl.h"
#include "ui/gfx/image.h"
class PrefService;
class Profile;
// The model that provides the information that should be displayed in the page
// info dialog/bubble.
class PageInfoModel {
public:
class PageInfoModelObserver {
public:
virtual ~PageInfoModelObserver() {}
virtual void ModelChanged() = 0;
};
enum SectionInfoType {
SECTION_INFO_IDENTITY = 0,
SECTION_INFO_CONNECTION,
SECTION_INFO_FIRST_VISIT,
};
// NOTE: ICON_STATE_OK ... ICON_STATE_ERROR must be listed in increasing
// order of severity. Code may depend on this order.
enum SectionStateIcon {
// No icon.
ICON_NONE = -1,
// State is OK.
ICON_STATE_OK,
// For example, if state is OK but contains mixed content.
ICON_STATE_WARNING_MINOR,
// For example, if content was served over HTTP.
ICON_STATE_WARNING_MAJOR,
// For example, unverified identity over HTTPS.
ICON_STATE_ERROR,
// An information icon.
ICON_STATE_INFO
};
struct SectionInfo {
SectionInfo(SectionStateIcon icon_id,
const string16& headline,
const string16& description,
SectionInfoType type)
: icon_id(icon_id),
headline(headline),
description(description),
type(type) {
}
// The overall state of the connection (error, warning, ok).
SectionStateIcon icon_id;
// A single line describing the section, optional.
string16 headline;
// The full description of what this section is.
string16 description;
// The type of SectionInfo we are dealing with, for example: Identity,
// Connection, First Visit.
SectionInfoType type;
};
PageInfoModel(Profile* profile,
const GURL& url,
const NavigationEntry::SSLStatus& ssl,
bool show_history,
PageInfoModelObserver* observer);
~PageInfoModel();
int GetSectionCount();
SectionInfo GetSectionInfo(int index);
// Returns the native image type for an icon with the given id.
gfx::Image* GetIconImage(SectionStateIcon icon_id);
// Callback from history service with number of visits to url.
void OnGotVisitCountToHost(HistoryService::Handle handle,
bool found_visits,
int count,
base::Time first_visit);
protected:
// Testing constructor. DO NOT USE.
PageInfoModel();
// Shared initialization for default and testing constructor.
void Init();
PageInfoModelObserver* observer_;
std::vector<SectionInfo> sections_;
// All possible icons that go next to the text descriptions to indicate state.
std::vector<gfx::Image*> icons_;
// Used to request number of visits.
CancelableRequestConsumer request_consumer_;
private:
DISALLOW_COPY_AND_ASSIGN(PageInfoModel);
};
#endif // CHROME_BROWSER_PAGE_INFO_MODEL_H_