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:
parent
ffb4039ab1
commit
6a512b13fd
5 changed files with 31 additions and 53 deletions
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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();
|
||||||
|
|
8
src/Messages.Designer.cs
generated
8
src/Messages.Designer.cs
generated
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue