New Embeds module to avoid duplication between trainer and hacker battle
This commit is contained in:
parent
a4d9926cfa
commit
308409a1bc
@ -4,14 +4,16 @@
|
|||||||
<OutputType>Exe</OutputType>
|
<OutputType>Exe</OutputType>
|
||||||
<TargetFramework>net6.0</TargetFramework>
|
<TargetFramework>net6.0</TargetFramework>
|
||||||
<DockerDefaultTargetOS>Linux</DockerDefaultTargetOS>
|
<DockerDefaultTargetOS>Linux</DockerDefaultTargetOS>
|
||||||
<RootNamespace>PlayerRegistration</RootNamespace>
|
<RootNamespace>Degenz</RootNamespace>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Content Include="Items.json">
|
<Content Include="Items.json">
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Content Include="paket.references" />
|
<Content Include="paket.references" />
|
||||||
|
<Compile Include="GameConfig.fs" />
|
||||||
<Compile Include="GuildEnvironment.fs" />
|
<Compile Include="GuildEnvironment.fs" />
|
||||||
|
<Compile Include="Embeds.fs" />
|
||||||
<Compile Include="Store.fs" />
|
<Compile Include="Store.fs" />
|
||||||
<Compile Include="Trainer.fs" />
|
<Compile Include="Trainer.fs" />
|
||||||
<Compile Include="HackerBattle.fs" />
|
<Compile Include="HackerBattle.fs" />
|
||||||
|
85
Bot/Embeds.fs
Normal file
85
Bot/Embeds.fs
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
module Degenz.Embeds
|
||||||
|
|
||||||
|
open DSharpPlus.EventArgs
|
||||||
|
open Degenz.Shared
|
||||||
|
open DSharpPlus.Entities
|
||||||
|
open AsciiTableFormatter
|
||||||
|
|
||||||
|
let constructEmbed message =
|
||||||
|
let builder = DiscordEmbedBuilder()
|
||||||
|
builder.Color <- Optional(DiscordColor.PhthaloGreen)
|
||||||
|
builder.Description <- message
|
||||||
|
let author = DiscordEmbedBuilder.EmbedAuthor()
|
||||||
|
author.Name <- "Degenz Hacker Game"
|
||||||
|
author.Url <- "https://twitter.com/degenzgame"
|
||||||
|
author.IconUrl <- "https://pbs.twimg.com/profile_images/1473192843359309825/cqjm0VQ4_400x400.jpg"
|
||||||
|
builder.Author <- author
|
||||||
|
builder.Build()
|
||||||
|
|
||||||
|
let pickDefense actionId player =
|
||||||
|
let buttons =
|
||||||
|
constructButtons actionId (string player.DiscordId) player.Shields
|
||||||
|
|> Seq.cast<DiscordComponent>
|
||||||
|
|
||||||
|
let embed =
|
||||||
|
DiscordEmbedBuilder()
|
||||||
|
.WithColor(DiscordColor.PhthaloGreen)
|
||||||
|
.WithDescription("Pick a defense to mount for 10 hours")
|
||||||
|
.WithImageUrl("https://s10.gifyu.com/images/Defense-Degenz-V2.gif")
|
||||||
|
|
||||||
|
DiscordInteractionResponseBuilder()
|
||||||
|
.AddComponents(buttons)
|
||||||
|
.AddEmbed(embed)
|
||||||
|
.AsEphemeral true
|
||||||
|
|
||||||
|
let pickHack actionId attacker defender =
|
||||||
|
let buttons =
|
||||||
|
constructButtons actionId $"{defender.DiscordId}-{defender.Name}" attacker.Weapons
|
||||||
|
|> Seq.cast<DiscordComponent>
|
||||||
|
|
||||||
|
let embed =
|
||||||
|
DiscordEmbedBuilder()
|
||||||
|
.WithColor(DiscordColor.PhthaloGreen)
|
||||||
|
.WithDescription("Pick the hack that you want to use")
|
||||||
|
.WithImageUrl("https://s10.gifyu.com/images/Hacker-Degenz-V2.gif")
|
||||||
|
|
||||||
|
DiscordInteractionResponseBuilder()
|
||||||
|
.AddComponents(buttons)
|
||||||
|
.AddEmbed(embed.Build())
|
||||||
|
.AsEphemeral true
|
||||||
|
|
||||||
|
let eventSuccessfulHack (event : ComponentInteractionCreateEventArgs) targetId prize =
|
||||||
|
DiscordMessageBuilder()
|
||||||
|
.WithContent($"{event.User.Username} successfully hacked <@{targetId}> for a total of {prize} GoodBoyTokenz")
|
||||||
|
|
||||||
|
[<CLIMutable>]
|
||||||
|
type Table = {
|
||||||
|
Name : string
|
||||||
|
Cost : string
|
||||||
|
Class : string
|
||||||
|
}
|
||||||
|
|
||||||
|
let storeListing store =
|
||||||
|
let embeds =
|
||||||
|
store
|
||||||
|
|> Array.map (fun ( itemType , items ) ->
|
||||||
|
items
|
||||||
|
|> Array.map (fun (item : Item) ->
|
||||||
|
let itemClass =
|
||||||
|
if itemType = ItemType.Hack
|
||||||
|
then weaponInventory
|
||||||
|
|> Array.find (fun w -> item.Name = string w)
|
||||||
|
|> int
|
||||||
|
|> getClass
|
||||||
|
else shieldInventory
|
||||||
|
|> Array.find (fun w -> item.Name = string w)
|
||||||
|
|> int
|
||||||
|
|> getClass
|
||||||
|
{ Name = item.Name ; Cost = string item.Cost ; Class = string itemClass })
|
||||||
|
|> Formatter.Format
|
||||||
|
|> sprintf "**%A**\n``` %s ```" itemType
|
||||||
|
|> constructEmbed)
|
||||||
|
|
||||||
|
DiscordInteractionResponseBuilder()
|
||||||
|
.AddEmbeds(embeds)
|
||||||
|
.AsEphemeral(true)
|
1
Bot/GameConfig.fs
Normal file
1
Bot/GameConfig.fs
Normal file
@ -0,0 +1 @@
|
|||||||
|
module Degenz.GameConfig
|
@ -11,7 +11,6 @@ open Degenz.Shared
|
|||||||
|
|
||||||
let attack (ctx : InteractionContext) (target : DiscordUser) =
|
let attack (ctx : InteractionContext) (target : DiscordUser) =
|
||||||
async {
|
async {
|
||||||
// TODO: We need to check if the player has any active embed hacks going, if not they can cheat
|
|
||||||
let! attacker = DbService.tryFindPlayer ctx.Member.Id
|
let! attacker = DbService.tryFindPlayer ctx.Member.Id
|
||||||
let! defender = DbService.tryFindPlayer target.Id
|
let! defender = DbService.tryFindPlayer target.Id
|
||||||
match attacker , defender with
|
match attacker , defender with
|
||||||
@ -21,23 +20,9 @@ let attack (ctx : InteractionContext) (target : DiscordUser) =
|
|||||||
|> removeExpiredActions (TimeSpan.FromMinutes(15)) (fun (atk : Attack) -> atk.Timestamp)
|
|> removeExpiredActions (TimeSpan.FromMinutes(15)) (fun (atk : Attack) -> atk.Timestamp)
|
||||||
do! DbService.updatePlayer <| { attacker with Attacks = updatedAttacks }
|
do! DbService.updatePlayer <| { attacker with Attacks = updatedAttacks }
|
||||||
if updatedAttacks.Length < 2 then
|
if updatedAttacks.Length < 2 then
|
||||||
let embed = DiscordEmbedBuilder()
|
let embed = Embeds.pickHack "Attack" attacker defender
|
||||||
embed.Color <- Optional(DiscordColor.PhthaloGreen)
|
|
||||||
embed.Description <- "Pick the hack that you want to use"
|
|
||||||
embed.ImageUrl <- "https://s10.gifyu.com/images/Hacker-Degenz-V2.gif"
|
|
||||||
|
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, embed)
|
||||||
builder.AddEmbed (embed.Build()) |> ignore
|
|
||||||
|
|
||||||
let defenderInfo = $"{defender.DiscordId}-{target.Username}"
|
|
||||||
constructButtons "Attack" defenderInfo attacker.Weapons
|
|
||||||
|> Seq.cast<DiscordComponent>
|
|
||||||
|> builder.AddComponents
|
|
||||||
|> ignore
|
|
||||||
|
|
||||||
builder.AsEphemeral true |> ignore
|
|
||||||
|
|
||||||
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder)
|
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
|
|
||||||
else
|
else
|
||||||
@ -64,17 +49,9 @@ let defend (ctx : InteractionContext) =
|
|||||||
let updatedDefenses = removeExpiredActions (TimeSpan.FromHours(24)) (fun (pro : Defense) -> pro.Timestamp) player.Defenses
|
let updatedDefenses = removeExpiredActions (TimeSpan.FromHours(24)) (fun (pro : Defense) -> pro.Timestamp) player.Defenses
|
||||||
do! DbService.updatePlayer <| { player with Defenses = updatedDefenses }
|
do! DbService.updatePlayer <| { player with Defenses = updatedDefenses }
|
||||||
if updatedDefenses.Length < 3 then
|
if updatedDefenses.Length < 3 then
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let embed = Embeds.pickDefense "Defend" player
|
||||||
builder.AddEmbed (constructEmbed "Pick a defense to mount for 24 hours") |> ignore
|
|
||||||
|
|
||||||
constructButtons "Defend" (string player.DiscordId) player.Shields
|
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, embed)
|
||||||
|> Seq.cast<DiscordComponent>
|
|
||||||
|> builder.AddComponents
|
|
||||||
|> ignore
|
|
||||||
|
|
||||||
builder.AsEphemeral true |> ignore
|
|
||||||
|
|
||||||
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder)
|
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
else
|
else
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let builder = DiscordInteractionResponseBuilder()
|
||||||
@ -115,9 +92,11 @@ let handleAttack (event : ComponentInteractionCreateEventArgs) =
|
|||||||
// let prize = 1.337f // LEET
|
// let prize = 1.337f // LEET
|
||||||
let prize = 13
|
let prize = 13
|
||||||
let attack = { HackType = enum<Hack>(int weapon) ; Timestamp = DateTime.UtcNow ; Target = { Id = targetId ; Name = split.[3] } }
|
let attack = { HackType = enum<Hack>(int weapon) ; Timestamp = DateTime.UtcNow ; Target = { Id = targetId ; Name = split.[3] } }
|
||||||
// TODO: Make a single update instead of two
|
|
||||||
do! DbService.updatePlayer <| updatePlayer prize attack player
|
let! _ =
|
||||||
do! DbService.updatePlayer { target with Bank = Math.Max(target.Bank - prize, 0)}
|
[ DbService.updatePlayer <| updatePlayer prize attack player
|
||||||
|
DbService.updatePlayer { target with Bank = Math.Max(target.Bank - prize, 0)} ]
|
||||||
|
|> Async.Parallel
|
||||||
|
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let builder = DiscordInteractionResponseBuilder()
|
||||||
builder.IsEphemeral <- true
|
builder.IsEphemeral <- true
|
||||||
@ -125,9 +104,8 @@ let handleAttack (event : ComponentInteractionCreateEventArgs) =
|
|||||||
do! event.Interaction.CreateResponseAsync(InteractionResponseType.UpdateMessage, builder)
|
do! event.Interaction.CreateResponseAsync(InteractionResponseType.UpdateMessage, builder)
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
|
|
||||||
let builder = DiscordMessageBuilder()
|
let builder = Embeds.eventSuccessfulHack event targetId prize
|
||||||
builder.WithContent($"{event.User.Username} successfully hacked <@{targetId}> for a total of {prize} GoodBoyTokenz") |> ignore
|
let channel = event.Guild.GetChannel(GuildEnvironment.channelEventsHackerBattle)
|
||||||
let channel = (event.Guild.GetChannel(GuildEnvironment.channelEventsHackerBattle))
|
|
||||||
do! channel.SendMessageAsync(builder)
|
do! channel.SendMessageAsync(builder)
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
|> Async.Ignore
|
|> Async.Ignore
|
||||||
|
47
Bot/Store.fs
47
Bot/Store.fs
@ -6,9 +6,9 @@ open DSharpPlus
|
|||||||
open DSharpPlus.EventArgs
|
open DSharpPlus.EventArgs
|
||||||
open DSharpPlus.SlashCommands
|
open DSharpPlus.SlashCommands
|
||||||
open Degenz
|
open Degenz
|
||||||
|
open Degenz.Embeds
|
||||||
open Degenz.Shared
|
open Degenz.Shared
|
||||||
open Newtonsoft.Json
|
open Newtonsoft.Json
|
||||||
open AsciiTableFormatter
|
|
||||||
|
|
||||||
let store =
|
let store =
|
||||||
try
|
try
|
||||||
@ -17,52 +17,9 @@ let store =
|
|||||||
|> Array.groupBy (fun (i : Item) -> i.ItemType)
|
|> Array.groupBy (fun (i : Item) -> i.ItemType)
|
||||||
with _ -> [||]
|
with _ -> [||]
|
||||||
|
|
||||||
//[<Sealed>]
|
|
||||||
//type Table() =
|
|
||||||
// member val Name = "" with get , set
|
|
||||||
// member val Cost = "" with get , set
|
|
||||||
// member val Class = "" with get , set
|
|
||||||
//
|
|
||||||
|
|
||||||
[<CLIMutable>]
|
|
||||||
type Table = {
|
|
||||||
Name : string
|
|
||||||
Cost : string
|
|
||||||
Class : string
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
let storeListing =
|
|
||||||
store
|
|
||||||
|> Array.map (fun ( itemType , items ) ->
|
|
||||||
let itemsData =
|
|
||||||
items
|
|
||||||
|> Array.map (fun (item : Item) ->
|
|
||||||
let itemClass =
|
|
||||||
if itemType = ItemType.Hack
|
|
||||||
then weaponInventory
|
|
||||||
|> Array.find (fun w -> item.Name = string w)
|
|
||||||
|> int
|
|
||||||
|> getClass
|
|
||||||
else shieldInventory
|
|
||||||
|> Array.find (fun w -> item.Name = string w)
|
|
||||||
|> int
|
|
||||||
|> getClass
|
|
||||||
{ Name = item.Name ; Cost = string item.Cost ; Class = string itemClass })
|
|
||||||
|
|
||||||
let table = Formatter.Format(ResizeArray(itemsData))
|
|
||||||
|
|
||||||
(constructEmbed $"**{itemType}s**\n```{table}```"))
|
|
||||||
|
|
||||||
let viewStore (ctx : InteractionContext) =
|
let viewStore (ctx : InteractionContext) =
|
||||||
async {
|
async {
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, Embeds.storeListing store)
|
||||||
|
|
||||||
builder.AddEmbeds(storeListing)
|
|
||||||
.AsEphemeral(true)
|
|
||||||
|> ignore
|
|
||||||
|
|
||||||
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder)
|
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
} |> Async.StartAsTask
|
} |> Async.StartAsTask
|
||||||
:> Task
|
:> Task
|
||||||
|
@ -7,47 +7,6 @@ open DSharpPlus.EventArgs
|
|||||||
open DSharpPlus.SlashCommands
|
open DSharpPlus.SlashCommands
|
||||||
open Degenz.Shared
|
open Degenz.Shared
|
||||||
|
|
||||||
module Message =
|
|
||||||
let sendFollowUpMessage (event : ComponentInteractionCreateEventArgs) msg =
|
|
||||||
async {
|
|
||||||
let builder = DiscordFollowupMessageBuilder()
|
|
||||||
builder.IsEphemeral <- true
|
|
||||||
builder.Content <- msg
|
|
||||||
do! event.Interaction.CreateFollowupMessageAsync(builder)
|
|
||||||
|> Async.AwaitTask
|
|
||||||
|> Async.Ignore
|
|
||||||
}
|
|
||||||
|
|
||||||
let sendFollowUpMessageWithButton (event : ComponentInteractionCreateEventArgs) buttonId msg =
|
|
||||||
async {
|
|
||||||
let builder = DiscordFollowupMessageBuilder()
|
|
||||||
let button = DiscordButtonComponent(ButtonStyle.Primary, buttonId, "Got it") :> DiscordComponent
|
|
||||||
builder.AddComponents [| button |] |> ignore
|
|
||||||
builder.IsEphemeral <- true
|
|
||||||
builder.Content <- msg
|
|
||||||
do! event.Interaction.CreateFollowupMessageAsync(builder)
|
|
||||||
|> Async.AwaitTask
|
|
||||||
|> Async.Ignore
|
|
||||||
}
|
|
||||||
|
|
||||||
let sendInteractionEvent (event : ComponentInteractionCreateEventArgs) msg =
|
|
||||||
async {
|
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
|
||||||
builder.IsEphemeral <- true
|
|
||||||
builder.Content <- msg
|
|
||||||
do! event.Interaction.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder) |> Async.AwaitTask
|
|
||||||
}
|
|
||||||
|
|
||||||
let sendInteractionEventWithButton (event : ComponentInteractionCreateEventArgs) buttonId msg =
|
|
||||||
async {
|
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
|
||||||
let button = DiscordButtonComponent(ButtonStyle.Primary, buttonId, "Got it") :> DiscordComponent
|
|
||||||
builder.AddComponents [| button |] |> ignore
|
|
||||||
builder.IsEphemeral <- true
|
|
||||||
builder.Content <- msg
|
|
||||||
do! event.Interaction.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder) |> Async.AwaitTask
|
|
||||||
}
|
|
||||||
|
|
||||||
let sendInitialEmbed (client : DiscordClient) =
|
let sendInitialEmbed (client : DiscordClient) =
|
||||||
async {
|
async {
|
||||||
let! channel = client.GetChannelAsync(GuildEnvironment.channelTraining) |> Async.AwaitTask
|
let! channel = client.GetChannelAsync(GuildEnvironment.channelTraining) |> Async.AwaitTask
|
||||||
@ -92,17 +51,9 @@ let defend (ctx : InteractionContext) =
|
|||||||
let! playerResult = DbService.tryFindPlayer ctx.Member.Id
|
let! playerResult = DbService.tryFindPlayer ctx.Member.Id
|
||||||
match playerResult with
|
match playerResult with
|
||||||
| Some player ->
|
| Some player ->
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let embed = Embeds.pickDefense "Trainer-3" player
|
||||||
builder.AddEmbed (constructEmbed "Pick a defense to mount for 8 hours") |> ignore
|
|
||||||
|
|
||||||
constructButtons "Trainer-3" (string player.DiscordId) player.Shields
|
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, embed)
|
||||||
|> Seq.cast<DiscordComponent>
|
|
||||||
|> builder.AddComponents
|
|
||||||
|> ignore
|
|
||||||
|
|
||||||
builder.AsEphemeral true |> ignore
|
|
||||||
|
|
||||||
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder)
|
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
| None ->
|
| None ->
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let builder = DiscordInteractionResponseBuilder()
|
||||||
@ -158,17 +109,9 @@ let attack (ctx : InteractionContext) (target : DiscordUser) =
|
|||||||
let! playerResult = DbService.tryFindPlayer ctx.Member.Id
|
let! playerResult = DbService.tryFindPlayer ctx.Member.Id
|
||||||
match isRightTarget , playerResult with
|
match isRightTarget , playerResult with
|
||||||
| true , Some player ->
|
| true , Some player ->
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let embed = Embeds.pickHack "Trainer-5" player player
|
||||||
builder.AddEmbed (constructEmbed "Pick an attack to use on your target") |> ignore
|
|
||||||
|
|
||||||
constructButtons "Trainer-5" (string player.DiscordId) player.Weapons
|
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, embed)
|
||||||
|> Seq.cast<DiscordComponent>
|
|
||||||
|> builder.AddComponents
|
|
||||||
|> ignore
|
|
||||||
|
|
||||||
builder.AsEphemeral true |> ignore
|
|
||||||
|
|
||||||
do! ctx.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder)
|
|
||||||
|> Async.AwaitTask
|
|> Async.AwaitTask
|
||||||
| false , _ ->
|
| false , _ ->
|
||||||
let builder = DiscordInteractionResponseBuilder()
|
let builder = DiscordInteractionResponseBuilder()
|
||||||
|
@ -3,6 +3,7 @@ module Degenz.Shared
|
|||||||
open System
|
open System
|
||||||
open DSharpPlus
|
open DSharpPlus
|
||||||
open DSharpPlus.Entities
|
open DSharpPlus.Entities
|
||||||
|
open DSharpPlus.EventArgs
|
||||||
open DSharpPlus.SlashCommands
|
open DSharpPlus.SlashCommands
|
||||||
|
|
||||||
type ItemType =
|
type ItemType =
|
||||||
@ -105,17 +106,6 @@ let constructButtons (actionType: string) (playerInfo: string) (weapons: 'a arra
|
|||||||
let removeExpiredActions timespan (timestamp: 'a -> DateTime) actions =
|
let removeExpiredActions timespan (timestamp: 'a -> DateTime) actions =
|
||||||
actions |> Array.filter (fun act -> DateTime.UtcNow - (timestamp act) < timespan)
|
actions |> Array.filter (fun act -> DateTime.UtcNow - (timestamp act) < timespan)
|
||||||
|
|
||||||
let constructEmbed message =
|
|
||||||
let builder = DiscordEmbedBuilder()
|
|
||||||
builder.Color <- Optional(DiscordColor.PhthaloGreen)
|
|
||||||
builder.Description <- message
|
|
||||||
let author = DiscordEmbedBuilder.EmbedAuthor()
|
|
||||||
author.Name <- "Degenz Hacker Game"
|
|
||||||
author.Url <- "https://twitter.com/degenzgame"
|
|
||||||
author.IconUrl <- "https://pbs.twimg.com/profile_images/1473192843359309825/cqjm0VQ4_400x400.jpg"
|
|
||||||
builder.Author <- author
|
|
||||||
builder.Build()
|
|
||||||
|
|
||||||
let calculateDamage (hack: int) (shield: int) =
|
let calculateDamage (hack: int) (shield: int) =
|
||||||
let hackClass = getClass hack
|
let hackClass = getClass hack
|
||||||
let protectionClass = getClass shield
|
let protectionClass = getClass shield
|
||||||
@ -123,3 +113,45 @@ let calculateDamage (hack: int) (shield: int) =
|
|||||||
match hackClass, protectionClass with
|
match hackClass, protectionClass with
|
||||||
| h, p when h = p -> Weak
|
| h, p when h = p -> Weak
|
||||||
| _ -> Strong
|
| _ -> Strong
|
||||||
|
|
||||||
|
module Message =
|
||||||
|
let sendFollowUpMessage (event : ComponentInteractionCreateEventArgs) msg =
|
||||||
|
async {
|
||||||
|
let builder = DiscordFollowupMessageBuilder()
|
||||||
|
builder.IsEphemeral <- true
|
||||||
|
builder.Content <- msg
|
||||||
|
do! event.Interaction.CreateFollowupMessageAsync(builder)
|
||||||
|
|> Async.AwaitTask
|
||||||
|
|> Async.Ignore
|
||||||
|
}
|
||||||
|
|
||||||
|
let sendFollowUpMessageWithButton (event : ComponentInteractionCreateEventArgs) buttonId msg =
|
||||||
|
async {
|
||||||
|
let builder = DiscordFollowupMessageBuilder()
|
||||||
|
let button = DiscordButtonComponent(ButtonStyle.Primary, buttonId, "Got it") :> DiscordComponent
|
||||||
|
builder.AddComponents [| button |] |> ignore
|
||||||
|
builder.IsEphemeral <- true
|
||||||
|
builder.Content <- msg
|
||||||
|
do! event.Interaction.CreateFollowupMessageAsync(builder)
|
||||||
|
|> Async.AwaitTask
|
||||||
|
|> Async.Ignore
|
||||||
|
}
|
||||||
|
|
||||||
|
let sendInteractionEvent (event : ComponentInteractionCreateEventArgs) msg =
|
||||||
|
async {
|
||||||
|
let builder = DiscordInteractionResponseBuilder()
|
||||||
|
builder.IsEphemeral <- true
|
||||||
|
builder.Content <- msg
|
||||||
|
do! event.Interaction.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder) |> Async.AwaitTask
|
||||||
|
}
|
||||||
|
|
||||||
|
let sendInteractionEventWithButton (event : ComponentInteractionCreateEventArgs) buttonId msg =
|
||||||
|
async {
|
||||||
|
let builder = DiscordInteractionResponseBuilder()
|
||||||
|
let button = DiscordButtonComponent(ButtonStyle.Primary, buttonId, "Got it") :> DiscordComponent
|
||||||
|
builder.AddComponents [| button |] |> ignore
|
||||||
|
builder.IsEphemeral <- true
|
||||||
|
builder.Content <- msg
|
||||||
|
do! event.Interaction.CreateResponseAsync(InteractionResponseType.ChannelMessageWithSource, builder) |> Async.AwaitTask
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user