blob: 20d1b66578346563d7101287f884ae92a8dc3cda [file] [log] [blame]
// 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_QUICK_INSERT_VIEWS_QUICK_INSERT_IMAGE_ITEM_VIEW_H_
#define ASH_QUICK_INSERT_VIEWS_QUICK_INSERT_IMAGE_ITEM_VIEW_H_
#include <memory>
#include "ash/ash_export.h"
#include "ash/quick_insert/model/quick_insert_action_type.h"
#include "ash/quick_insert/views/quick_insert_item_view.h"
#include "base/memory/raw_ptr.h"
#include "ui/base/metadata/metadata_header_macros.h"
namespace views {
class ImageView;
} // namespace views
namespace ash {
// Quick Insert item which contains just an image.
class ASH_EXPORT QuickInsertImageItemView : public QuickInsertItemView {
METADATA_HEADER(QuickInsertImageItemView, QuickInsertItemView)
public:
QuickInsertImageItemView(std::unique_ptr<views::ImageView> image,
std::u16string accessible_name,
SelectItemCallback select_item_callback);
QuickInsertImageItemView(const QuickInsertImageItemView&) = delete;
QuickInsertImageItemView& operator=(const QuickInsertImageItemView&) = delete;
~QuickInsertImageItemView() override;
void SetAction(QuickInsertActionType action);
// Resizes the contained image to `width`, with the height scaled to retain
// the same aspect ratio.
void FitToWidth(int width);
views::ImageView* image_view_for_testing() const { return image_view_; }
private:
raw_ptr<views::ImageView> image_view_ = nullptr;
std::u16string accessible_name_;
};
} // namespace ash
#endif // ASH_QUICK_INSERT_VIEWS_QUICK_INSERT_IMAGE_ITEM_VIEW_H_