mirror of
https://github.com/barelyprofessional/KfChatDotNet.git
synced 2026-05-02 04:22:04 -04:00
Added recent bets command and now casting the magic number to a float so the bot can show bets <$1
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
|
using Humanizer;
|
||||||
using KfChatDotNetKickBot.Models.DbModels;
|
using KfChatDotNetKickBot.Models.DbModels;
|
||||||
using KfChatDotNetKickBot.Settings;
|
using KfChatDotNetKickBot.Settings;
|
||||||
using KfChatDotNetWsClient.Models.Events;
|
using KfChatDotNetWsClient.Models.Events;
|
||||||
@@ -18,7 +19,7 @@ public class HowlggStatsCommand : ICommand
|
|||||||
{
|
{
|
||||||
var window = Convert.ToInt32(arguments["window"].Value);
|
var window = Convert.ToInt32(arguments["window"].Value);
|
||||||
var start = DateTimeOffset.UtcNow.AddHours(-window);
|
var start = DateTimeOffset.UtcNow.AddHours(-window);
|
||||||
var division = (await Helpers.GetValue(BuiltIn.Keys.HowlggDivisionAmount)).ToType<int>();
|
var division = (await Helpers.GetValue(BuiltIn.Keys.HowlggDivisionAmount)).ToType<float>();
|
||||||
await using var db = new ApplicationDbContext();
|
await using var db = new ApplicationDbContext();
|
||||||
// EF SQLite doesn't support filtering on dates :(
|
// EF SQLite doesn't support filtering on dates :(
|
||||||
var bets = (await db.HowlggBets.ToListAsync(ctx)).Where(b => b.Date.UtcDateTime > start).ToList();
|
var bets = (await db.HowlggBets.ToListAsync(ctx)).Where(b => b.Date.UtcDateTime > start).ToList();
|
||||||
@@ -31,4 +32,29 @@ public class HowlggStatsCommand : ICommand
|
|||||||
$"Bets: {bets.Count:N0}; Profit: {bets.Sum(b => b.Profit) / division:C}; Wagered: {bets.Sum(b => b.Bet) / division:C}";
|
$"Bets: {bets.Count:N0}; Profit: {bets.Sum(b => b.Profit) / division:C}; Wagered: {bets.Sum(b => b.Bet) / division:C}";
|
||||||
botInstance.SendChatMessage(output, true);
|
botInstance.SendChatMessage(output, true);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class HowlggRecentBetCommand : ICommand
|
||||||
|
{
|
||||||
|
public List<Regex> Patterns => [
|
||||||
|
new Regex(@"^howl recent$")
|
||||||
|
];
|
||||||
|
public string HelpText => "Get the most recent 3 bets";
|
||||||
|
public bool HideFromHelp => false;
|
||||||
|
public UserRight RequiredRight => UserRight.Guest;
|
||||||
|
public async Task RunCommand(KickBot botInstance, MessageModel message, GroupCollection arguments, CancellationToken ctx)
|
||||||
|
{
|
||||||
|
var division = (await Helpers.GetValue(BuiltIn.Keys.HowlggDivisionAmount)).ToType<float>();
|
||||||
|
await using var db = new ApplicationDbContext();
|
||||||
|
// EF SQLite doesn't support filtering on dates :(
|
||||||
|
var bets = (await db.HowlggBets.ToListAsync(ctx)).OrderByDescending(j => j.Date).Take(3).ToList();
|
||||||
|
var output = "Most recent 3 bets on Howl.gg:";
|
||||||
|
foreach (var bet in bets)
|
||||||
|
{
|
||||||
|
var color = "#3dd179";
|
||||||
|
if (bet.Profit < 0) color = "#f1323e";
|
||||||
|
output += $"[br]Bet: {bet.Bet / division:C}; Profit: [color={color}]{bet.Profit / division:C}[/color]; Game: {bet.Game.Humanize()}; {(DateTimeOffset.UtcNow - bet.Date).Humanize(precision: 1)} ago";
|
||||||
|
}
|
||||||
|
botInstance.SendChatMessage(output, true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user