// 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_TRAVERSABLE_ITEM_CONTAINER_H_
#define ASH_PICKER_VIEWS_PICKER_TRAVERSABLE_ITEM_CONTAINER_H_
#include "ash/ash_export.h"
namespace views {
class View;
}
namespace ash {
// Interface implemented by Picker item containers that support item traversal.
class ASH_EXPORT PickerTraversableItemContainer {
public:
virtual ~PickerTraversableItemContainer() = default;
// Returns the item to highlight to when navigating to this container from the
// top, or nullptr if the container is empty.
virtual views::View* GetTopItem() = 0;
// Returns the item to highlight to when navigating to this container from the
// bottom, or nullptr if the container is empty.
virtual views::View* GetBottomItem() = 0;
// Returns the item directly above `item`, or nullptr if there is no such item
// in the container.
virtual views::View* GetItemAbove(views::View* item) = 0;
// Returns the item directly below `item`, or nullptr if there is no such item
// in the container.
virtual views::View* GetItemBelow(views::View* item) = 0;
// Returns the item directly to the left of `item`, or nullptr if there is no
// such item in the container.
virtual views::View* GetItemLeftOf(views::View* item) = 0;
// Returns the item directly to the right of `item`, or nullptr if there is no
// such item in the container.
virtual views::View* GetItemRightOf(views::View* item) = 0;
virtual bool ContainsItem(views::View* item) = 0;
};
} // namespace ash
#endif // ASH_PICKER_VIEWS_PICKER_TRAVERSABLE_ITEM_CONTAINER_H_