mirror of
				https://gitlab.com/Kwoth/nadekobot.git
				synced 2025-11-03 16:24:27 -05:00 
			
		
		
		
	Add timely reminder button*
* Add a check in Timely command that removes the reminder button if there already is a timely reminder in DB. * Add ReminderType in db/models. As well as migrations. * Set Normal reminders to be of `ReminderType.User`, and Timely reminders to be of `ReminderType.Timely`
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);
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user