// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_PICKER_VIEWS_PICKER_EMOJI_BAR_VIEW_H_
#define ASH_PICKER_VIEWS_PICKER_EMOJI_BAR_VIEW_H_
#include <memory>
#include "ash/ash_export.h"
#include "ash/picker/views/picker_traversable_item_container.h"
#include "ash/public/cpp/picker/picker_search_result.h"
#include "base/memory/raw_ptr.h"
#include "ui/base/metadata/metadata_header_macros.h"
#include "ui/views/view.h"
namespace views {
class Button;
}
namespace ash {
class IconButton;
class PickerEmojiBarViewDelegate;
class SystemShadow;
// View for the Picker emoji bar, which is a small bar above the main Picker
// container that shows expression search results (i.e. emojis, symbols and
// emoticons).
class ASH_EXPORT PickerEmojiBarView : public views::View,
public PickerTraversableItemContainer {
METADATA_HEADER(PickerEmojiBarView, views::View)
public:
// `delegate` must remain valid for the lifetime of this class.
PickerEmojiBarView(PickerEmojiBarViewDelegate* delegate,
int picker_view_width,
bool is_gifs_enabled = false);
PickerEmojiBarView(const PickerEmojiBarView&) = delete;
PickerEmojiBarView& operator=(const PickerEmojiBarView&) = delete;
~PickerEmojiBarView() override;
// views::View:
gfx::Size CalculatePreferredSize(
const views::SizeBounds& available_size) const override;
// PickerTraversableItemContainer:
views::View* GetTopItem() override;
views::View* GetBottomItem() override;
views::View* GetItemAbove(views::View* item) override;
views::View* GetItemBelow(views::View* item) override;
views::View* GetItemLeftOf(views::View* item) override;
views::View* GetItemRightOf(views::View* item) override;
bool ContainsItem(views::View* item) override;
// Clears the emoji bar's search results.
void ClearSearchResults();
// Sets the results from `section` as the emoji bar's search results.
void SetSearchResults(std::vector<PickerEmojiResult> results);
// Returns the number of items displayed in the emoji bar.
size_t GetNumItems() const;
views::View::Views GetItemsForTesting() const;
views::Button* gifs_button_for_testing() { return gifs_button_; }
IconButton* more_emojis_button_for_testing() { return more_emojis_button_; }
private:
void SelectSearchResult(const PickerSearchResult& result);
void OpenMoreEmojis();
void OpenGifs();
int CalculateAvailableWidthForItemRow();
// Returns the leftmost child view in the emoji bar, or nullptr if there is no
// such view.
views::View* GetLeftmostItem();
std::unique_ptr<SystemShadow> shadow_;
// `delegate_` outlives `this`.
raw_ptr<PickerEmojiBarViewDelegate> delegate_;
// The width of the PickerView that contains this emoji bar.
int picker_view_width_ = 0;
// Contains the item views corresponding to each search result.
raw_ptr<views::View> item_row_ = nullptr;
// The button for opening the gif picker.
raw_ptr<views::Button> gifs_button_ = nullptr;
// The button for opening more emojis.
raw_ptr<IconButton> more_emojis_button_ = nullptr;
};
} // namespace ash
#endif // ASH_PICKER_VIEWS_PICKER_EMOJI_BAR_VIEW_H_