// Copyright (c) Arlo Godfrey. All Rights Reserved. // Licensed under the GNU Lesser General Public License, Version 3.0 with additional terms. // See the LICENSE, LICENSE.LESSER and LICENSE.ADDITIONAL files in the project root for more information. using System.Collections.Generic; using System.Threading; using System.Threading.Tasks; using OwlCore.Events; using StrixMusic.Sdk.AdapterModels; using StrixMusic.Sdk.BaseModels; using StrixMusic.Sdk.CoreModels; namespace StrixMusic.Sdk.AppModels { /// /// Represents a collection of albums that may contain one or more sources. /// /// Instances of this class may contain data merged from one or more sources. public interface IAlbumCollection : IAlbumCollectionBase, IAlbumCollectionItem, IImageCollection, IUrlCollection, IPlayable, IAppModel, IMerged { /// /// Attempts to play a specific item in the album collection. Restarts playback if already playing. /// /// An item from the collection where playback begins. /// A cancellation token that may be used to cancel the ongoing task. /// A representing the asynchronous operation. Task PlayAlbumCollectionAsync(IAlbumCollectionItem albumItem, CancellationToken cancellationToken = default); /// /// Gets a requested number of s starting at the given offset in the backend. /// /// The max number of items to return. /// Get items starting at this index. /// A cancellation token that may be used to cancel the ongoing task. /// The requested range of items. IAsyncEnumerable GetAlbumItemsAsync(int limit, int offset, CancellationToken cancellationToken = default); /// /// Adds an or to this album collection. /// /// The album to add. /// the position to insert the album at. /// A cancellation token that may be used to cancel the ongoing task. /// A representing the asynchronous operation. Task AddAlbumItemAsync(IAlbumCollectionItem albumItem, int index, CancellationToken cancellationToken = default); /// /// Fires when the items in the backend are changed by something external. /// event CollectionChangedEventHandler? AlbumItemsChanged; } }