J4asper.DSharpPlus.BetterPagination 1.0.4

dotnet add package J4asper.DSharpPlus.BetterPagination --version 1.0.4                
NuGet\Install-Package J4asper.DSharpPlus.BetterPagination -Version 1.0.4                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="J4asper.DSharpPlus.BetterPagination" Version="1.0.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add J4asper.DSharpPlus.BetterPagination --version 1.0.4                
#r "nuget: J4asper.DSharpPlus.BetterPagination, 1.0.4"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install J4asper.DSharpPlus.BetterPagination as a Cake Addin
#addin nuget:?package=J4asper.DSharpPlus.BetterPagination&version=1.0.4

// Install J4asper.DSharpPlus.BetterPagination as a Cake Tool
#tool nuget:?package=J4asper.DSharpPlus.BetterPagination&version=1.0.4                

BetterPagination

This NuGet package provides an enhanced pagination experience for DSharpPlus, offering a better visual interface for navigating between paginated content.

NuGet Version

Installation

NuGet

To install the package, open the terminal in your project and run the following command, replacing 1.0.0 with the latest version:

dotnet add package J4asper.DSharpPlus.BetterPagination --version 1.0.0

Alternatively, you can search for J4asper.DSharpPlus.BetterPagination in your IDE’s NuGet Package Manager.

From Source

To build the package from source, follow these steps:

  1. Clone the repository:

    git clone https://github.com/j4asper/DSharpPlus.BetterPagination.git
    
  2. In your project’s .csproj file, add the following reference:

    <ProjectReference Include="../DSharpPlus.BetterPagination/DSharpPlus.BetterPagination/DSharpPlus.BetterPagination.csproj" />
    

Documentation

This package adds an extension method, SendBetterPaginatedMessageAsync, to the SlashCommandContext class, enabling easy pagination in your bot commands.

SendBetterPaginatedMessageAsync Parameters

  • commandContext (SlashCommandContext):
    The context of the slash command invocation, containing user information and the interaction context. This is required to send the initial response and track the user interaction.
    More info on SlashCommandContext

  • pages (IReadOnlyList<Page>):
    A read-only list of Page objects. Each Page object contains the embed and optional components (buttons, select menus, etc.) to be displayed on a specific page of the paginated message. The content of each page is encapsulated in the Page object.

  • additionalComponents (IReadOnlyList<DiscordComponent>?, optional):
    Optional additional components (e.g., buttons, select menus) that can be added to the message. This can be used to add custom interactive elements like menus, or other buttons. Default is null.

  • asEphemeral (bool, optional):
    A flag indicating whether the paginated message should be sent as an ephemeral message. If set to true, the message will only be visible to the user who invoked the command. Default is false.

  • allowUsageByAnyone (bool, optional):
    A flag indicating whether any user can interact with the pagination buttons, or if the interaction should be restricted to the invoking user only. If set to false, only the user who invoked the command will be able to interact with the buttons. Default is false.

Example Usage

Here’s an example of how to use the package to send a paginated message within a command:

[Command("example")]
[Description("This is a paginated example command")]
public async ValueTask PaginatedExampleCommand(SlashCommandContext context)
{
    var embedPageOne = new DiscordEmbedBuilder()
        .WithDescription("This is page 1");

    var embedPageTwo = new DiscordEmbedBuilder()
        .WithDescription("This is page 2");

    List<Page> pages =
    [
        new() { Embed = embedPageOne },
        new() { Embed = embedPageTwo, Content = "Text content in message" }
    ];

    // Send the paginated message
    await context.SendBetterPaginatedMessageAsync(pages);
}

In this example:

  • Two pages are created using DiscordEmbedBuilder, each with different content.
  • These pages are added to a List<Page>, which is passed to the SendBetterPaginatedMessageAsync method to send a paginated message.
  • Users can navigate between pages using the forward and back buttons that are automatically added to the message.

Example of paginated message with 4 pages and an additional button.

Paginated Example

Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.4 53 11/27/2024
1.0.3 40 11/26/2024
1.0.2 43 11/26/2024
1.0.1 47 11/26/2024
1.0.0 44 11/26/2024