Discord.Net.Labs
2.4.9
See the version list below for details.
dotnet add package Discord.Net.Labs --version 2.4.9
NuGet\Install-Package Discord.Net.Labs -Version 2.4.9
<PackageReference Include="Discord.Net.Labs" Version="2.4.9" />
paket add Discord.Net.Labs --version 2.4.9
#r "nuget: Discord.Net.Labs, 2.4.9"
// Install Discord.Net.Labs as a Cake Addin #addin nuget:?package=Discord.Net.Labs&version=2.4.9 // Install Discord.Net.Labs as a Cake Tool #tool nuget:?package=Discord.Net.Labs&version=2.4.9
Discord.Net Labs
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:
- Remove Discord.Net from your project
- Add Discord.Net Labs nuget to your project
- Enjoy!
Listening for interactions
// Subscribe to the InteractionCreated event
client.InteractionCreated += Client_InteractionCreated;
...
private async Task Client_InteractionCreated(SocketInteraction interaction)
{
// Checking the type of this interaction
switch (interaction)
{
// Slash commands
case SocketSlashCommand commandInteraction:
await MySlashCommandHandler(commandInteraction);
break;
// Button clicks/selection dropdowns
case SocketMessageComponent componentInteraction:
await MyMessageComponentHandler(componentInteraction);
break;
// Unused or Unknown/Unsupported
default:
break;
}
}
Simple handling slash commands
private async Task MySlashCommandHandler(SocketSlashCommand interaction)
{
// Checking command name
if (interaction.Data.Name == "ping")
{
// Respond to interaction with message.
// You can also use "ephemeral" so that only the original user of the interaction sees the message
await interaction.RespondAsync($"Pong!", ephemeral: true);
// Also you can followup with a additional messages, which also can be "ephemeral"
await interaction.FollowupAsync($"PongPong!", ephemeral: true);
}
}
Simple handling button clicks and selection dropdowns
private async Task MyMessageComponentHandler(SocketMessageComponent interaction)
{
// Get the custom ID
var customId = interaction.Data.CustomId;
// Get the user
var user = (SocketGuildUser) interaction.User;
// Get the guild
var guild = user.Guild;
// Respond with the update message. This edits the message which this component resides.
await interaction.UpdateAsync(msgProps => msgProps.Content = $"Clicked {interaction.Data.CustomId}!");
// Also you can followup with a additional messages
await interaction.FollowupAsync($"Clicked {interaction.Data.CustomId}!", ephemeral: true);
// If you are using selection dropdowns, you can get the selected label and values using these
var selectedLabel = ((SelectMenu) interaction.Message.Components.First().Components.First()).Options.FirstOrDefault(x => x.Value == interaction.Data.Values.FirstOrDefault())?.Label;
var selectedValue = interaction.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")
.WithPlaceholder("This is a placeholder")
.AddOption(
label: "Option",
value: "value1",
description: "Evan pog champ",
emote: Emote.Parse("<:evanpog:810017136814194698>")
)
.AddOption("Option B", "value2", "Option B is poggers")
);
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.
Learn more about Target Frameworks and .NET Standard.
-
.NETFramework 4.6.1
- Discord.Net.Labs.Commands (>= 2.3.5)
- Discord.Net.Labs.Core (>= 2.4.6)
- Discord.Net.Labs.Rest (>= 2.4.6)
- Discord.Net.Labs.Webhook (>= 2.3.4)
- Discord.Net.Labs.WebSocket (>= 2.4.8)
-
.NETStandard 2.0
- Discord.Net.Labs.Commands (>= 2.3.5)
- Discord.Net.Labs.Core (>= 2.4.6)
- Discord.Net.Labs.Rest (>= 2.4.6)
- Discord.Net.Labs.Webhook (>= 2.3.4)
- Discord.Net.Labs.WebSocket (>= 2.4.8)
-
.NETStandard 2.1
- Discord.Net.Labs.Commands (>= 2.3.5)
- Discord.Net.Labs.Core (>= 2.4.6)
- Discord.Net.Labs.Rest (>= 2.4.6)
- Discord.Net.Labs.Webhook (>= 2.3.4)
- Discord.Net.Labs.WebSocket (>= 2.4.8)
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,600 | 12/24/2021 | |
3.6.0 | 561 | 12/24/2021 | |
3.5.0 | 1,480 | 12/15/2021 | |
3.4.9 | 3,192 | 12/6/2021 | |
3.4.8 | 5,193 | 12/4/2021 | |
3.4.7 | 2,807 | 11/28/2021 | |
3.4.6 | 682 | 11/27/2021 | |
3.4.5 | 536 | 11/27/2021 | |
3.4.4 | 578 | 11/27/2021 | |
3.4.3 | 574 | 11/27/2021 | |
3.4.2 | 2,342 | 11/26/2021 | |
3.4.1 | 1,854 | 11/26/2021 | |
3.4.0 | 1,921 | 11/26/2021 | |
3.3.3 | 792 | 11/23/2021 | |
3.3.2 | 1,080 | 11/21/2021 | |
3.3.1 | 1,226 | 11/21/2021 | |
3.3.0 | 1,471 | 11/19/2021 | |
3.2.0 | 1,730 | 11/9/2021 | |
3.1.7 | 3,426 | 10/20/2021 | |
3.1.6 | 1,376 | 10/15/2021 | |
3.1.5 | 677 | 10/15/2021 | |
3.1.4 | 870 | 10/13/2021 | |
3.1.3 | 1,072 | 10/12/2021 | |
3.1.2 | 677 | 10/12/2021 | |
3.1.1 | 3,223 | 9/23/2021 | |
3.1.0 | 802 | 9/21/2021 | |
3.0.4 | 1,183 | 9/15/2021 | |
3.0.3 | 3,302 | 9/13/2021 | |
3.0.2 | 3,554 | 8/25/2021 | |
3.0.2-pre | 759 | 8/8/2021 | |
3.0.1 | 579 | 8/25/2021 | |
3.0.1-pre | 401 | 8/5/2021 | |
3.0.0 | 693 | 8/24/2021 | |
3.0.0-pre | 266 | 8/5/2021 | |
2.4.9 | 1,634 | 7/17/2021 | |
2.4.8 | 681 | 7/15/2021 | |
2.4.7 | 863 | 7/11/2021 | |
2.4.6 | 756 | 7/11/2021 | |
2.4.5 | 663 | 7/7/2021 | |
2.4.4 | 678 | 7/6/2021 | |
2.4.3 | 649 | 7/5/2021 | |
2.4.2 | 661 | 7/4/2021 | |
2.4.1 | 689 | 7/3/2021 | |
2.4.0 | 673 | 7/3/2021 | |
2.3.8-dev | 363 | 7/2/2021 | |
2.3.7 | 1,202 | 5/30/2021 | |
2.3.6 | 742 | 5/30/2021 | |
2.3.5 | 708 | 5/30/2021 | |
2.3.4 | 670 | 5/29/2021 | |
2.3.3 | 647 | 5/28/2021 | |
2.3.2 | 601 | 5/28/2021 | |
2.3.1 | 675 | 5/27/2021 |