blob: d05cccbe70a2d2df34e9e498d5bae1ace3d79d6c [file] [log] [blame]
// Copyright 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_TOOLBAR_TOOLBAR_MODEL_H_
#define CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_MODEL_H_
#include <string>
#include "base/basictypes.h"
#include "base/strings/string16.h"
#include "url/gurl.h"
namespace net {
class X509Certificate;
}
// This class is the model used by the toolbar, location bar and autocomplete
// edit. It populates its states from the current navigation entry retrieved
// from the navigation controller returned by GetNavigationController().
class ToolbarModel {
public:
// TODO(wtc): unify ToolbarModel::SecurityLevel with SecurityStyle. We
// don't need two sets of security UI levels. SECURITY_STYLE_AUTHENTICATED
// needs to be refined into three levels: warning, standard, and EV.
enum SecurityLevel {
#define DEFINE_TOOLBAR_MODEL_SECURITY_LEVEL(name,value) name = value,
#include "chrome/browser/ui/toolbar/toolbar_model_security_level_list.h"
#undef DEFINE_TOOLBAR_MODEL_SECURITY_LEVEL
};
virtual ~ToolbarModel();
// Returns the text to be displayed in the toolbar for the current page.
// The text is formatted in various ways:
// - If the current page's URL is a search URL for the user's default search
// engine, the query will be extracted and returned for display instead
// of the URL.
// - If the origin chip is enabled and visible, the text will be empty.
// - Otherwise, the text will contain the URL returned by GetFormattedURL().
virtual base::string16 GetText() const = 0;
// Returns a formatted URL for display in the toolbar. The formatting
// includes:
// - Some characters may be unescaped.
// - The scheme and/or trailing slash may be dropped.
// If |prefix_end| is non-NULL, it is set to the length of the pre-hostname
// portion of the resulting URL.
virtual base::string16 GetFormattedURL(size_t* prefix_end) const = 0;
// Some search URLs bundle a special "corpus" param that we can extract and
// display next to users' search terms in cases where we'd show the search
// terms instead of the URL anyway. For example, a Google image search might
// show the corpus "Images:" plus a search string. This is only used on
// mobile.
virtual base::string16 GetCorpusNameForMobile() const = 0;
// Returns the URL of the current navigation entry.
virtual GURL GetURL() const = 0;
// Returns true if a call to GetText() would successfully replace the URL
// with search terms. If |ignore_editing| is true, the result reflects the
// underlying state of the page without regard to any user edits that may be
// in progress in the omnibox.
virtual bool WouldPerformSearchTermReplacement(bool ignore_editing) const = 0;
// Returns true if a call to GetText() would return something other than the
// URL because of either search term replacement or URL omission in favor of
// the origin chip.
bool WouldReplaceURL() const;
// Returns the security level that the toolbar should display. If
// |ignore_editing| is true, the result reflects the underlying state of the
// page without regard to any user edits that may be in progress in the
// omnibox.
virtual SecurityLevel GetSecurityLevel(bool ignore_editing) const = 0;
// Returns the resource_id of the icon to show to the left of the address,
// based on the current URL. When search term replacement is active, this
// returns a search icon. This doesn't cover specialized icons while the
// user is editing; see OmniboxView::GetIcon().
virtual int GetIcon() const = 0;
// As |GetIcon()|, but returns the icon only taking into account the security
// |level| given, ignoring search term replacement state.
virtual int GetIconForSecurityLevel(SecurityLevel level) const = 0;
// Returns the name of the EV cert holder. This returns an empty string if
// the security level is not EV_SECURE.
virtual base::string16 GetEVCertName() const = 0;
// Returns whether the URL for the current navigation entry should be
// in the location bar.
virtual bool ShouldDisplayURL() const = 0;
// Returns true if a call to GetText() would return an empty string instead of
// the URL that would have otherwise been displayed because the host/origin is
// instead being displayed in the origin chip. This returns false when we
// wouldn't have displayed a URL to begin with (e.g. for the NTP).
virtual bool WouldOmitURLDueToOriginChip() const = 0;
// Returns true if the origin should be shown based on the current state of
// the ToolbarModel.
bool ShouldShowOriginChip() const;
// Whether the text in the omnibox is currently being edited.
void set_input_in_progress(bool input_in_progress) {
input_in_progress_ = input_in_progress;
}
bool input_in_progress() const { return input_in_progress_; }
// Whether the origin chip should be enabled.
void set_origin_chip_enabled(bool enabled) {
origin_chip_enabled_ = enabled;
}
bool origin_chip_enabled() const {
return origin_chip_enabled_;
}
// Whether URL replacement should be enabled.
void set_url_replacement_enabled(bool enabled) {
url_replacement_enabled_ = enabled;
}
bool url_replacement_enabled() const {
return url_replacement_enabled_;
}
protected:
ToolbarModel();
private:
bool input_in_progress_;
bool origin_chip_enabled_;
bool url_replacement_enabled_;
DISALLOW_COPY_AND_ASSIGN(ToolbarModel);
};
#endif // CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_MODEL_H_