blob: dbff54a4fb446eebae617a0eb352a3ea749a9994 [file] [log] [blame]
// Copyright (c) 2018 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.
#include "ui/views/view.h"
namespace views {
class ImageView;
struct AutocompleteMatch;
class OmniboxResultView;
class OmniboxTextView;
class OmniboxMatchCellView : public views::View {
// The right-hand margin used for rows.
static constexpr int kMarginRight = 8;
explicit OmniboxMatchCellView(OmniboxResultView* result_view);
~OmniboxMatchCellView() override;
views::ImageView* icon() { return icon_view_; }
views::ImageView* answer_image() { return answer_image_view_; }
OmniboxTextView* content() { return content_view_; }
OmniboxTextView* description() { return description_view_; }
OmniboxTextView* separator() { return separator_view_; }
static int GetTextIndent();
void OnMatchUpdate(const OmniboxResultView* result_view,
const AutocompleteMatch& match);
// Sets the answer image and, if the image is not square, sets the answer size
// proportional to the image size to preserve its aspect ratio.
void SetImage(const gfx::ImageSkia& image);
// views::View:
gfx::Size CalculatePreferredSize() const override;
bool CanProcessEventsWithinSubtree() const override;
enum class LayoutStyle {
// views::View:
void Layout() override;
const char* GetClassName() const override;
void LayoutOldStyleAnswer(int icon_view_width, int text_indent);
void LayoutNewStyleTwoLineSuggestion();
void LayoutOneLineSuggestion(int icon_view_width, int text_indent);
bool is_rich_suggestion_ = false;
bool is_search_type_ = false;
LayoutStyle layout_style_ = LayoutStyle::ONE_LINE_SUGGESTION;
// Weak pointers for easy reference.
// An icon representing the type or content.
views::ImageView* icon_view_;
// The image for answers in suggest and rich entity suggestions.
views::ImageView* answer_image_view_;
OmniboxTextView* content_view_;
OmniboxTextView* description_view_;
OmniboxTextView* separator_view_;
void SetTailSuggestCommonPrefixWidth(const base::string16& common_prefix);
// This (permanently) holds the rendered width of
// AutocompleteMatch::kEllipsis so that we don't have to keep calculating
// it.
int ellipsis_width_ = 0;
// This holds the rendered width of the common prefix of a set of tail
// suggestions so that it doesn't have to be re-calculated if the prefix
// doesn't change.
int tail_suggest_common_prefix_width_ = 0;