Discord.Net.Labs 2.4.8

Suggested Alternatives

Discord.Net

There is a newer version of this package available.
See the version list below for details.
dotnet add package Discord.Net.Labs --version 2.4.8                
NuGet\Install-Package Discord.Net.Labs -Version 2.4.8                
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="Discord.Net.Labs" Version="2.4.8" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Discord.Net.Labs --version 2.4.8                
#r "nuget: Discord.Net.Labs, 2.4.8"                
#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 Discord.Net.Labs as a Cake Addin
#addin nuget:?package=Discord.Net.Labs&version=2.4.8

// Install Discord.Net.Labs as a Cake Tool
#tool nuget:?package=Discord.Net.Labs&version=2.4.8                

Discord.Net Labs

NuGet

Join our Discord server for support using labs

This repo is a custom fork of Discord.Net that introduces the newest features of discord for testing and experimenting. Nothing here is guaranteed to work but you are more than welcome to submit bugs in the issues tabs

Known issues

Labs will not work with normal package of Playwo's InteractivityAddon. The reason is that his package depends on the base discord.net lib. You can instead use the InteractivityAddon.Labs package which implements some of the features added in Discord.Net-Labs.

How to use

Setting up labs in your project is really simple, here's how to do it:

  1. Remove Discord.Net from your project
  2. Add Discord.Net Labs nuget to your project
  3. Enjoy!

Listening for interactions

// Subscribe to the InteractionCreated event
client.InteractionCreated += Client_InteractionCreated;

...
private async Task Client_InteractionCreated(SocketInteraction arg)
{
  switch (arg.Type) // We want to check the type of this interaction
  {
    //Slash commands
    case InteractionType.ApplicationCommand:
      await MySlashCommandHandler(arg);
      break;
    //Button clicks/selection dropdowns
    case InteractionType.MessageComponent:
      await MyMessageComponentHandler(arg);
      break;
    //Unused
    case InteractionType.Ping:
      break;
    //Unknown/Unsupported
    default:
      Console.WriteLine("Unsupported interaction type: " + arg.Type);
      break;
  }
}

Handling button clicks and selection dropdowns

private async Task MyMessageComponentHandler(SocketInteraction arg)
{
    // Parse the arg
    var parsedArg = (SocketMessageComponent) arg;
    // Get the custom ID 
    var customId = parsedArg.Data.CustomId;
    // Get the user
    var user = (SocketGuildUser) arg.User;
    // Get the guild
    var guild = user.Guild;
    
    // Respond with the update message response type. This edits the original message if you have set AlwaysAcknowledgeInteractions to false.
    // You can also use "ephemeral" so that only the original user of the interaction sees the message
    await parsedArg.RespondAsync($"Clicked {parsedArg.Data.CustomId}!", type: InteractionResponseType.UpdateMessage, ephemeral: true);
    
    // You can also followup with a second message
    await parsedArg.FollowupAsync($"Clicked {parsedArg.Data.CustomId}!", type: InteractionResponseType.ChannelMessageWithSource, ephemeral: true);
    
    //If you are using selection dropdowns, you can get the selected label and values using these:
    var selectedLabel = ((SelectMenu) parsedArg.Message.Components.First().Components.First()).Options.FirstOrDefault(x => x.Value == parsedArg.Data.Values.FirstOrDefault())?.Label;
    var selectedValue = parsedArg.Data.Values.First();
}

Note: The example above assumes that the selection dropdown is expecting only 1 returned value, if you configured your dropdown for multiple values, you'll need to modify the code slightly.

Sending messages with buttons

Theres a new field in all SendMessageAsync functions that takes in a MessageComponent, you can use it like so:

var builder = new ComponentBuilder().WithButton("Hello!", customId: "id_1", ButtonStyle.Primary, row: 0);
await Context.Channel.SendMessageAsync("Test buttons!", component: builder.Build());

Sending messages with selection dropdowns

Theres a new field in all SendMessageAsync functions that takes in a MessageComponent, you can use it like so:

var builder = new ComponentBuilder()
  .WithSelectMenu(new SelectMenuBuilder()
  .WithCustomId("id_2")
  .WithLabel("Select menu!")
  .WithPlaceholder("This is a placeholder")
  .WithOptions(new List<SelectMenuOptionBuilder>()
  {
    new SelectMenuOptionBuilder()
      .WithLabel("Option A")
      .WithEmote(Emote.Parse("<:evanpog:810017136814194698>"))
      .WithDescription("Evan pog champ")
      .WithValue("value1"),
    new SelectMenuOptionBuilder()
      .WithLabel("Option B")
      .WithDescription("Option B is poggers")
      .WithValue("value2")
  }));
await Context.Channel.SendMessageAsync("Test selection!", component: builder.Build());

Note: You can only have 5 buttons per row and 5 rows per message. If a row contains a selection dropdown it cannot contain any buttons.

Slash commands

Slash command example how to's can be found here. If you want to read some code using slash commands, you can do that here

There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages (4)

Showing the top 4 NuGet packages that depend on Discord.Net.Labs:

Package Downloads
Discord.KillersLibrary.Labs

This package is an Addon for Discord.Net It provides embedding pages and multi buttons for your Discord Bot. Moreover it includes support for any command framework and slash commands.

Xssp.Discord.Util

Provides various utilities to simplify the use of the Discord.NET API.

DNetLabRat

Button lib for Discord.Net-Labs

Discord.Killer

This package is an Addon for Discord.Net. It provides enbeding pages for your Discord Bot. Moreover it includes support for any command framework.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.6.1 23,755 12/24/2021 3.6.1 is deprecated because it is no longer maintained.
3.6.0 569 12/24/2021 3.6.0 is deprecated because it is no longer maintained.
3.5.0 1,488 12/15/2021 3.5.0 is deprecated because it is no longer maintained.
3.4.9 3,233 12/6/2021 3.4.9 is deprecated because it is no longer maintained.
3.4.8 5,201 12/4/2021 3.4.8 is deprecated because it is no longer maintained.
3.4.7 2,815 11/28/2021 3.4.7 is deprecated because it is no longer maintained.
3.4.6 690 11/27/2021 3.4.6 is deprecated because it is no longer maintained.
3.4.5 544 11/27/2021 3.4.5 is deprecated because it is no longer maintained.
3.4.4 586 11/27/2021 3.4.4 is deprecated because it is no longer maintained.
3.4.3 582 11/27/2021 3.4.3 is deprecated because it is no longer maintained.
3.4.2 2,350 11/26/2021 3.4.2 is deprecated because it is no longer maintained.
3.4.1 1,862 11/26/2021 3.4.1 is deprecated because it is no longer maintained.
3.4.0 1,929 11/26/2021 3.4.0 is deprecated because it is no longer maintained.
3.3.3 800 11/23/2021 3.3.3 is deprecated because it is no longer maintained.
3.3.2 1,088 11/21/2021 3.3.2 is deprecated because it is no longer maintained.
3.3.1 1,234 11/21/2021 3.3.1 is deprecated because it is no longer maintained.
3.3.0 1,479 11/19/2021 3.3.0 is deprecated because it is no longer maintained.
3.2.0 1,738 11/9/2021 3.2.0 is deprecated because it is no longer maintained.
3.1.7 3,449 10/20/2021 3.1.7 is deprecated because it is no longer maintained.
3.1.6 1,387 10/15/2021 3.1.6 is deprecated because it is no longer maintained.
3.1.5 685 10/15/2021 3.1.5 is deprecated because it is no longer maintained.
3.1.4 878 10/13/2021 3.1.4 is deprecated because it is no longer maintained.
3.1.3 1,080 10/12/2021 3.1.3 is deprecated because it is no longer maintained.
3.1.2 685 10/12/2021 3.1.2 is deprecated because it is no longer maintained.
3.1.1 3,233 9/23/2021 3.1.1 is deprecated because it is no longer maintained.
3.1.0 810 9/21/2021 3.1.0 is deprecated because it is no longer maintained.
3.0.4 1,191 9/15/2021 3.0.4 is deprecated because it is no longer maintained.
3.0.3 3,310 9/13/2021 3.0.3 is deprecated because it is no longer maintained.
3.0.2 3,562 8/25/2021 3.0.2 is deprecated because it is no longer maintained.
3.0.2-pre 763 8/8/2021 3.0.2-pre is deprecated because it is no longer maintained.
3.0.1 587 8/25/2021 3.0.1 is deprecated because it is no longer maintained.
3.0.1-pre 405 8/5/2021 3.0.1-pre is deprecated because it is no longer maintained.
3.0.0 701 8/24/2021 3.0.0 is deprecated because it is no longer maintained.
3.0.0-pre 270 8/5/2021 3.0.0-pre is deprecated because it is no longer maintained.
2.4.9 1,642 7/17/2021 2.4.9 is deprecated because it is no longer maintained.
2.4.8 689 7/15/2021 2.4.8 is deprecated because it is no longer maintained.
2.4.7 871 7/11/2021 2.4.7 is deprecated because it is no longer maintained.
2.4.6 764 7/11/2021 2.4.6 is deprecated because it is no longer maintained.
2.4.5 671 7/7/2021 2.4.5 is deprecated because it is no longer maintained.
2.4.4 688 7/6/2021 2.4.4 is deprecated because it is no longer maintained.
2.4.3 657 7/5/2021 2.4.3 is deprecated because it is no longer maintained.
2.4.2 670 7/4/2021 2.4.2 is deprecated because it is no longer maintained.
2.4.1 697 7/3/2021 2.4.1 is deprecated because it is no longer maintained.
2.4.0 681 7/3/2021 2.4.0 is deprecated because it is no longer maintained.
2.3.8-dev 367 7/2/2021 2.3.8-dev is deprecated because it is no longer maintained.
2.3.7 1,210 5/30/2021 2.3.7 is deprecated because it is no longer maintained.
2.3.6 750 5/30/2021 2.3.6 is deprecated because it is no longer maintained.
2.3.5 716 5/30/2021 2.3.5 is deprecated because it is no longer maintained.
2.3.4 678 5/29/2021 2.3.4 is deprecated because it is no longer maintained.
2.3.3 655 5/28/2021 2.3.3 is deprecated because it is no longer maintained.
2.3.2 609 5/28/2021 2.3.2 is deprecated because it is no longer maintained.
2.3.1 683 5/27/2021 2.3.1 is deprecated because it is no longer maintained.