mirror of
				https://gitlab.com/Kwoth/nadekobot.git
				synced 2025-11-03 16:24:27 -05:00 
			
		
		
		
	Merge branch 'v5' of https://gitlab.com/kwoth/nadekobot into v5
This commit is contained in:
		@@ -149,10 +149,24 @@ public partial class Gambling : GamblingModule<GamblingService>
 | 
			
		||||
            ctx.Guild?.Id,
 | 
			
		||||
            true,
 | 
			
		||||
            when,
 | 
			
		||||
            GetText(strs.timely_time));
 | 
			
		||||
            GetText(strs.timely_time),
 | 
			
		||||
            ReminderType.Timely);
 | 
			
		||||
 | 
			
		||||
        await smc.RespondConfirmAsync(_eb, GetText(strs.remind_timely(tt)), ephemeral: true);
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    private NadekoInteraction CreateRemindMeInteraction(int period)
 | 
			
		||||
    {
 | 
			
		||||
        return _inter
 | 
			
		||||
            .Create(ctx.User.Id,
 | 
			
		||||
                new SimpleInteraction<DateTime>(
 | 
			
		||||
                    new ButtonBuilder(
 | 
			
		||||
                        label: "Remind me",
 | 
			
		||||
                        emote: Emoji.Parse("⏰"),
 | 
			
		||||
                        customId: "timely:remind_me"),
 | 
			
		||||
                    RemindTimelyAction,
 | 
			
		||||
                    DateTime.UtcNow.Add(TimeSpan.FromHours(period))));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    [Cmd]
 | 
			
		||||
    public async Task Timely()
 | 
			
		||||
@@ -164,12 +178,20 @@ public partial class Gambling : GamblingModule<GamblingService>
 | 
			
		||||
            await ReplyErrorLocalizedAsync(strs.timely_none);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        var inter = CreateRemindMeInteraction(period);
 | 
			
		||||
 | 
			
		||||
        if (await _service.ClaimTimelyAsync(ctx.User.Id, period) is { } rem)
 | 
			
		||||
        {
 | 
			
		||||
            // Removes timely button if there is a timely reminder in DB
 | 
			
		||||
            if (_service.UserHasTimelyReminder(ctx.User.Id))
 | 
			
		||||
            {
 | 
			
		||||
                inter = null;
 | 
			
		||||
            }
 | 
			
		||||
            
 | 
			
		||||
            var now = DateTime.UtcNow;
 | 
			
		||||
            var relativeTag = TimestampTag.FromDateTime(now.Add(rem), TimestampTagStyles.Relative);
 | 
			
		||||
            await ReplyPendingLocalizedAsync(strs.timely_already_claimed(relativeTag));
 | 
			
		||||
            await ReplyPendingLocalizedAsync(strs.timely_already_claimed(relativeTag), inter);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@@ -179,19 +201,9 @@ public partial class Gambling : GamblingModule<GamblingService>
 | 
			
		||||
 | 
			
		||||
        await _cs.AddAsync(ctx.User.Id, val, new("timely", "claim"));
 | 
			
		||||
 | 
			
		||||
        var inter = _inter
 | 
			
		||||
            .Create(ctx.User.Id,
 | 
			
		||||
                new SimpleInteraction<DateTime>(
 | 
			
		||||
                    new ButtonBuilder(
 | 
			
		||||
                        label: "Remind me",
 | 
			
		||||
                        emote: Emoji.Parse("⏰"),
 | 
			
		||||
                        customId: "timely:remind_me"),
 | 
			
		||||
                    RemindTimelyAction,
 | 
			
		||||
                    DateTime.UtcNow.Add(TimeSpan.FromHours(period))));
 | 
			
		||||
 | 
			
		||||
        await ReplyConfirmLocalizedAsync(strs.timely(N(val), period), inter);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    
 | 
			
		||||
    [Cmd]
 | 
			
		||||
    [OwnerOnly]
 | 
			
		||||
    public async Task TimelyReset()
 | 
			
		||||
 
 | 
			
		||||
@@ -209,6 +209,13 @@ public class GamblingService : INService, IReadyExecutor
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public bool UserHasTimelyReminder(ulong userId)
 | 
			
		||||
    {
 | 
			
		||||
        var db = _db.GetDbContext();
 | 
			
		||||
        return db.GetTable<Reminder>().Any(x => x.UserId == userId
 | 
			
		||||
                                         && x.Type == ReminderType.Timely);
 | 
			
		||||
    }   
 | 
			
		||||
 | 
			
		||||
    public async Task RemoveAllTimelyClaimsAsync()
 | 
			
		||||
        => await _cache.RemoveAsync(_timelyKey);
 | 
			
		||||
}
 | 
			
		||||
@@ -269,8 +269,9 @@ public partial class Gambling
 | 
			
		||||
                ? "-"
 | 
			
		||||
                : string.Join("\n",
 | 
			
		||||
                    itemList.Where(x => waifuItems.TryGetValue(x.ItemEmoji, out _))
 | 
			
		||||
                            .OrderBy(x => waifuItems[x.ItemEmoji].Price)
 | 
			
		||||
                            .OrderByDescending(x => waifuItems[x.ItemEmoji].Price)
 | 
			
		||||
                            .GroupBy(x => x.ItemEmoji)
 | 
			
		||||
                            .Take(60)
 | 
			
		||||
                            .Select(x => $"{x.Key} x{x.Count(),-3}")
 | 
			
		||||
                            .Chunk(2)
 | 
			
		||||
                            .Select(x => string.Join(" ", x)));
 | 
			
		||||
@@ -283,8 +284,10 @@ public partial class Gambling
 | 
			
		||||
 | 
			
		||||
            var fansList = await _service.GetFansNames(wi.WaifuId);
 | 
			
		||||
            var fansStr = fansList
 | 
			
		||||
                          .Select((x) => claimsNames.Contains(x) ? $"{x} 💞" : x)
 | 
			
		||||
                          .Join('\n');
 | 
			
		||||
                            .Shuffle()
 | 
			
		||||
                            .Take(30)
 | 
			
		||||
                            .Select((x) => claimsNames.Contains(x) ? $"{x} 💞" : x)
 | 
			
		||||
                            .Join('\n');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            if (string.IsNullOrWhiteSpace(fansStr))
 | 
			
		||||
@@ -370,4 +373,4 @@ public partial class Gambling
 | 
			
		||||
                await ReplyErrorLocalizedAsync(strs.not_enough(CurrencySign));
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user