blob: 63f4cb86233ed70cfa551e3108157339599615d5 [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 COMPONENTS_OMNIBOX_BROWSER_LOCATION_BAR_MODEL_H_
#define COMPONENTS_OMNIBOX_BROWSER_LOCATION_BAR_MODEL_H_
#include <stddef.h>
#include <string>
#include "base/macros.h"
#include "base/strings/string16.h"
#include "components/omnibox/common/omnibox_focus_state.h"
#include "components/security_state/core/security_state.h"
#include "third_party/metrics_proto/omnibox_event.pb.h"
#include "url/gurl.h"
namespace gfx {
struct VectorIcon;
}
// This class provides information about the current navigation entry.
// Its methods always return data related to the current page, and does not
// account for the state of the omnibox, which is tracked by OmniboxEditModel.
class LocationBarModel {
public:
virtual ~LocationBarModel() = default;
// Returns the formatted full URL for the toolbar. The formatting includes:
// - Some characters may be unescaped.
// - The scheme and/or trailing slash may be dropped.
// This method specifically keeps the URL suitable for editing by not
// applying any elisions that change the meaning of the URL.
virtual base::string16 GetFormattedFullURL() const = 0;
// Returns a simplified URL for display (but not editing) on the toolbar.
// This formatting is generally a superset of GetFormattedFullURL, and may
// include some destructive elisions that change the meaning of the URL.
// The returned string is not suitable for editing, and is for display only.
virtual base::string16 GetURLForDisplay() const = 0;
// Returns the URL of the current navigation entry.
virtual GURL GetURL() const = 0;
// Returns the security level that the toolbar should display.
virtual security_state::SecurityLevel GetSecurityLevel() const = 0;
// Returns true if the toolbar should display the search terms. When this
// method returns true, the extracted search terms will be filled into
// |search_terms| if it's not nullptr.
//
// This method can be called with nullptr |search_terms| if the caller wants
// to check the display status only. Virtual for testing purposes.
virtual bool GetDisplaySearchTerms(base::string16* search_terms) = 0;
// Classify the current page being viewed as, for example, the new tab
// page or a normal web page. Used for logging omnibox events for
// UMA opted-in users. Examines the user's profile to determine if the
// current page is the user's home page.
virtual metrics::OmniboxEventProto::PageClassification GetPageClassification(
OmniboxFocusSource focus_source) = 0;
// Returns the 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.
virtual const gfx::VectorIcon& GetVectorIcon() const = 0;
// Returns text for the omnibox secure verbose chip, displayed next to the
// security icon on certain platforms.
virtual base::string16 GetSecureDisplayText() const = 0;
// Returns text describing the security state for accessibility.
virtual base::string16 GetSecureAccessibilityText() const = 0;
// Returns whether the URL for the current navigation entry should be
// in the location bar.
virtual bool ShouldDisplayURL() const = 0;
// Returns whether the page is an offline page, sourced from a cache of
// previously-downloaded content.
virtual bool IsOfflinePage() const = 0;
protected:
LocationBarModel() = default;
private:
DISALLOW_COPY_AND_ASSIGN(LocationBarModel);
};
#endif // COMPONENTS_OMNIBOX_BROWSER_LOCATION_BAR_MODEL_H_