Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
ppy
GitHub Repository: ppy/osu
Path: blob/master/osu.Game/Graphics/Carousel/CarouselItem.cs
4423 views
// Copyright (c) ppy Pty Ltd <[email protected]>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.

using System;

namespace osu.Game.Graphics.Carousel
{
    /// <summary>
    /// Represents a single display item for display in a <see cref="Carousel{T}"/>.
    /// This is used to house information related to the attached model that helps with display and tracking.
    /// </summary>
    public sealed class CarouselItem : IComparable<CarouselItem>
    {
        public const float DEFAULT_HEIGHT = 45;

        /// <summary>
        /// The model this item is representing.
        /// </summary>
        public readonly object Model;

        /// <summary>
        /// The current Y position in the carousel.
        ///
        /// This is managed by <see cref="Carousel{T}"/> and should not be set manually.
        /// </summary>
        public double CarouselYPosition { get; set; }

        /// <summary>
        /// The amount of input padding/lenience to be added to the area above this panel.
        /// Calculated as half of the calculated spacing between this panel and the panel above it.
        ///
        /// This is managed by <see cref="Carousel{T}"/> and should not be set manually.
        /// </summary>
        public float CarouselInputLenienceAbove { get; set; }

        /// <summary>
        /// The amount of input padding/lenience to be added to the area below this panel.
        /// Calculated as half of the calculated spacing between this panel and the panel below it.
        ///
        /// This is managed by <see cref="Carousel{T}"/> and should not be set manually.
        /// </summary>
        public float CarouselInputLenienceBelow { get; set; }

        /// <summary>
        /// The height this item will take when displayed. Defaults to <see cref="DEFAULT_HEIGHT"/>.
        /// </summary>
        public float DrawHeight { get; set; } = DEFAULT_HEIGHT;

        /// <summary>
        /// Defines the display depth relative to other <see cref="CarouselItem"/>s.
        /// </summary>
        public int DepthLayer { get; set; }

        /// <summary>
        /// Whether this item is visible or hidden.
        /// </summary>
        public bool IsVisible { get; set; } = true;

        /// <summary>
        /// Whether this item is expanded or not. Should only be used for headers of groups.
        /// </summary>
        public bool IsExpanded { get; set; }

        /// <summary>
        /// The number of nested items underneath this header. Should only be used for headers of groups.
        /// </summary>
        public int NestedItemCount { get; set; }

        public CarouselItem(object model)
        {
            Model = model;
        }

        public int CompareTo(CarouselItem? other)
        {
            if (other == null) return 1;

            return CarouselYPosition.CompareTo(other.CarouselYPosition);
        }
    }
}