// 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
{
///
/// A collection of s and the properties and methods for using and manipulating them.
///
/// Instances of this class may contain data merged from one or more sources.
public interface IArtistCollection : IArtistCollectionBase, IArtistCollectionItem, IUrlCollection, IImageCollection, IPlayable, IAppModel, IMerged
{
///
/// Attempts to play a specific item in the artistItem 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 PlayArtistCollectionAsync(IArtistCollectionItem artistItem, CancellationToken cancellationToken = default);
///
/// Gets a requested number of s starting at the given offset.
///
/// 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 GetArtistItemsAsync(int limit, int offset, CancellationToken cancellationToken = default);
///
/// Adds an or to this artist collection.
///
/// The artistItem to add.
/// the position to insert the artistItem at.
/// A cancellation token that may be used to cancel the ongoing task.
/// A representing the asynchronous operation.
Task AddArtistItemAsync(IArtistCollectionItem artistItem, int index, CancellationToken cancellationToken = default);
///
/// Fires when the items in the backend are changed by something external.
///
event CollectionChangedEventHandler? ArtistItemsChanged;
}
}