1
0
Fork 1
mirror of https://github.com/TeamOctolings/Octobot.git synced 2025-04-20 00:43:36 +03:00

mixed changes

Signed-off-by: mctaylors <cantsendmails@mctaylors.ru>
This commit is contained in:
Macintxsh 2023-12-18 16:04:06 +03:00
parent ffb4039ab1
commit 6a512b13fd
Signed by: mctaylors
GPG key ID: 7181BEBE676903C1
5 changed files with 31 additions and 53 deletions

View file

@ -588,7 +588,4 @@
<data name="ReminderInvalidTimeSpan" xml:space="preserve"> <data name="ReminderInvalidTimeSpan" xml:space="preserve">
<value>Incorrect reminder send time specified.</value> <value>Incorrect reminder send time specified.</value>
</data> </data>
<data name="ReminderNegativeTimeSpan" xml:space="preserve">
<value>Negative reminder send time specified.</value>
</data>
</root> </root>

View file

@ -588,7 +588,4 @@
<data name="ReminderInvalidTimeSpan" xml:space="preserve"> <data name="ReminderInvalidTimeSpan" xml:space="preserve">
<value>Указано некорректное время отправки напоминания.</value> <value>Указано некорректное время отправки напоминания.</value>
</data> </data>
<data name="ReminderNegativeTimeSpan" xml:space="preserve">
<value>Указано отрицательное время отправки напоминания.</value>
</data>
</root> </root>

View file

@ -588,7 +588,4 @@
<data name="ReminderInvalidTimeSpan" xml:space="preserve"> <data name="ReminderInvalidTimeSpan" xml:space="preserve">
<value>ты там правильно напиши когда мне тебя пинать</value> <value>ты там правильно напиши когда мне тебя пинать</value>
</data> </data>
<data name="ReminderNegativeTimeSpan" xml:space="preserve">
<value>ты там минусы не пиши когда мне тебя пинать</value>
</data>
</root> </root>

View file

@ -75,12 +75,10 @@ public class RemindCommandGroup : CommandGroup
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
return await ListRemindersAsync(data.GetOrCreateMemberData(executorId), guildId, executor, bot, return await ListRemindersAsync(data.GetOrCreateMemberData(executorId), guildId, executor, bot, CancellationToken);
CancellationToken);
} }
private Task<Result> ListRemindersAsync(MemberData data, Snowflake guildId, IUser executor, IUser bot, private Task<Result> ListRemindersAsync(MemberData data, Snowflake guildId, IUser executor, IUser bot, CancellationToken ct)
CancellationToken ct)
{ {
if (data.Reminders.Count == 0) if (data.Reminders.Count == 0)
{ {
@ -95,12 +93,10 @@ public class RemindCommandGroup : CommandGroup
for (var i = 0; i < data.Reminders.Count; i++) for (var i = 0; i < data.Reminders.Count; i++)
{ {
var reminder = data.Reminders[i]; var reminder = data.Reminders[i];
builder.AppendBulletPointLine(string.Format(Messages.ReminderPosition, builder.AppendBulletPointLine(string.Format(Messages.ReminderPosition, Markdown.InlineCode((i + 1).ToString())))
Markdown.InlineCode((i + 1).ToString())))
.AppendSubBulletPointLine(string.Format(Messages.ReminderText, Markdown.InlineCode(reminder.Text))) .AppendSubBulletPointLine(string.Format(Messages.ReminderText, Markdown.InlineCode(reminder.Text)))
.AppendSubBulletPointLine(string.Format(Messages.ReminderTime, Markdown.Timestamp(reminder.At))) .AppendSubBulletPointLine(string.Format(Messages.ReminderTime, Markdown.Timestamp(reminder.At)))
.AppendSubBulletPointLine(string.Format(Messages.DescriptionActionJumpToMessage, .AppendSubBulletPointLine(string.Format(Messages.DescriptionActionJumpToMessage, $"https://discord.com/channels/{guildId.Value}/{reminder.ChannelId}/{reminder.MessageId}"));
$"https://discord.com/channels/{guildId.Value}/{reminder.ChannelId}/{reminder.MessageId}"));
} }
var embed = new EmbedBuilder().WithSmallTitle( var embed = new EmbedBuilder().WithSmallTitle(
@ -115,7 +111,7 @@ public class RemindCommandGroup : CommandGroup
/// <summary> /// <summary>
/// A slash command that schedules a reminder with the specified text. /// A slash command that schedules a reminder with the specified text.
/// </summary> /// </summary>
/// <param name="in">The period of time which must pass before the reminder will be sent.</param> /// <param name="timeSpanString">The period of time which must pass before the reminder will be sent.</param>
/// <param name="text">The text of the reminder.</param> /// <param name="text">The text of the reminder.</param>
/// <returns>A feedback sending result which may or may not have succeeded.</returns> /// <returns>A feedback sending result which may or may not have succeeded.</returns>
[Command("remind")] [Command("remind")]
@ -125,7 +121,8 @@ public class RemindCommandGroup : CommandGroup
[UsedImplicitly] [UsedImplicitly]
public async Task<Result> ExecuteReminderAsync( public async Task<Result> ExecuteReminderAsync(
[Description("After what period of time mention the reminder")] [Description("After what period of time mention the reminder")]
string @in, [Option("in")]
string timeSpanString,
[Description("Reminder text")] [MaxLength(512)] [Description("Reminder text")] [MaxLength(512)]
string text) string text)
{ {
@ -149,25 +146,14 @@ public class RemindCommandGroup : CommandGroup
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
return await AddReminderAsync(@in, text, data, channelId, bot, executor, CancellationToken); return await AddReminderAsync(timeSpanString, text, data, channelId, bot, executor, CancellationToken);
} }
private async Task<Result> AddReminderAsync(string strIn, string text, GuildData data, private async Task<Result> AddReminderAsync(string timeSpanString, string text, GuildData data,
Snowflake channelId, IUser bot, IUser executor, CancellationToken ct = default) Snowflake channelId, IUser bot, IUser executor, CancellationToken ct = default)
{ {
if (strIn.StartsWith('-')) var timeSpan = await ParseReminderAsync(timeSpanString, ct);
{ if (timeSpan == TimeSpan.Zero)
var failedEmbed = new EmbedBuilder()
.WithSmallTitle(Messages.ReminderNegativeTimeSpan, bot)
.WithColour(ColorsList.Red)
.Build();
return await _feedback.SendContextualEmbedResultAsync(failedEmbed, ct: ct);
}
var parser = new TimeSpanParser();
var parseResult = await parser.TryParseAsync(strIn, ct);
if (!parseResult.IsDefined(out var @in))
{ {
var failedEmbed = new EmbedBuilder() var failedEmbed = new EmbedBuilder()
.WithSmallTitle(Messages.ReminderInvalidTimeSpan, bot) .WithSmallTitle(Messages.ReminderInvalidTimeSpan, bot)
@ -178,9 +164,8 @@ public class RemindCommandGroup : CommandGroup
} }
var memberData = data.GetOrCreateMemberData(executor.ID); var memberData = data.GetOrCreateMemberData(executor.ID);
var remindAt = DateTimeOffset.UtcNow.Add(@in); var remindAt = DateTimeOffset.UtcNow.Add(timeSpan);
var responseResult = await _interactionApi.GetOriginalInteractionResponseAsync( var responseResult = await _interactionApi.GetOriginalInteractionResponseAsync(_context.Interaction.ApplicationID, _context.Interaction.Token, ct);
_context.Interaction.ApplicationID, _context.Interaction.Token, ct);
if (!responseResult.IsDefined(out var response)) if (!responseResult.IsDefined(out var response))
{ {
return (Result)responseResult; return (Result)responseResult;
@ -198,8 +183,8 @@ public class RemindCommandGroup : CommandGroup
var builder = new StringBuilder() var builder = new StringBuilder()
.AppendBulletPointLine(string.Format(Messages.ReminderText, Markdown.InlineCode(text))) .AppendBulletPointLine(string.Format(Messages.ReminderText, Markdown.InlineCode(text)))
.AppendBulletPoint(string.Format(Messages.ReminderTime, Markdown.Timestamp(remindAt))); .AppendBulletPoint(string.Format(Messages.ReminderTime, Markdown.Timestamp(remindAt)));
var embed = new EmbedBuilder() var embed = new EmbedBuilder().WithSmallTitle(
.WithSmallTitle(string.Format(Messages.ReminderCreated, executor.GetTag()), executor) string.Format(Messages.ReminderCreated, executor.GetTag()), executor)
.WithDescription(builder.ToString()) .WithDescription(builder.ToString())
.WithColour(ColorsList.Green) .WithColour(ColorsList.Green)
.WithFooter(string.Format(Messages.ReminderPosition, memberData.Reminders.Count)) .WithFooter(string.Format(Messages.ReminderPosition, memberData.Reminders.Count))
@ -208,6 +193,19 @@ public class RemindCommandGroup : CommandGroup
return await _feedback.SendContextualEmbedResultAsync(embed, ct: ct); return await _feedback.SendContextualEmbedResultAsync(embed, ct: ct);
} }
private static async Task<TimeSpan> ParseReminderAsync(string timeSpanString, CancellationToken ct)
{
if (timeSpanString.StartsWith('-'))
{
return TimeSpan.Zero;
}
var parseResult = await new TimeSpanParser().TryParseAsync(timeSpanString, ct);
return !parseResult.IsDefined(out var @in)
? TimeSpan.Zero
: @in;
}
/// <summary> /// <summary>
/// A slash command that deletes a reminder using its list position. /// A slash command that deletes a reminder using its list position.
/// </summary> /// </summary>
@ -236,8 +234,7 @@ public class RemindCommandGroup : CommandGroup
var data = await _guildData.GetData(guildId, CancellationToken); var data = await _guildData.GetData(guildId, CancellationToken);
Messages.Culture = GuildSettings.Language.Get(data.Settings); Messages.Culture = GuildSettings.Language.Get(data.Settings);
return await DeleteReminderAsync( return await DeleteReminderAsync(data.GetOrCreateMemberData(executorId), position - 1, bot, CancellationToken);
data.GetOrCreateMemberData(executorId), position - 1, bot, CancellationToken);
} }
private Task<Result> DeleteReminderAsync(MemberData data, int index, IUser bot, private Task<Result> DeleteReminderAsync(MemberData data, int index, IUser bot,
@ -245,8 +242,7 @@ public class RemindCommandGroup : CommandGroup
{ {
if (index >= data.Reminders.Count) if (index >= data.Reminders.Count)
{ {
var failedEmbed = new EmbedBuilder() var failedEmbed = new EmbedBuilder().WithSmallTitle(Messages.InvalidReminderPosition, bot)
.WithSmallTitle(Messages.InvalidReminderPosition, bot)
.WithColour(ColorsList.Red) .WithColour(ColorsList.Red)
.Build(); .Build();
@ -261,8 +257,7 @@ public class RemindCommandGroup : CommandGroup
data.Reminders.RemoveAt(index); data.Reminders.RemoveAt(index);
var embed = new EmbedBuilder() var embed = new EmbedBuilder().WithSmallTitle(Messages.ReminderDeleted, bot)
.WithSmallTitle(Messages.ReminderDeleted, bot)
.WithDescription(description.ToString()) .WithDescription(description.ToString())
.WithColour(ColorsList.Green) .WithColour(ColorsList.Green)
.Build(); .Build();

View file

@ -1044,13 +1044,5 @@ namespace Octobot {
return ResourceManager.GetString("ReminderInvalidTimeSpan", resourceCulture); return ResourceManager.GetString("ReminderInvalidTimeSpan", resourceCulture);
} }
} }
internal static string ReminderNegativeTimeSpan
{
get
{
return ResourceManager.GetString("ReminderNegativeTimeSpan", resourceCulture);
}
}
} }
} }