mirror of
https://github.com/PluralKit/PluralKit.git
synced 2026-02-17 03:00:13 +00:00
refactor: movedb call for switch flag editing into switchedit
This commit is contained in:
parent
b3a80f9180
commit
9e8c60cd9a
1 changed files with 17 additions and 21 deletions
|
|
@ -110,60 +110,56 @@ public class Switch
|
|||
|
||||
var newMembers = await ctx.ParseMemberList(ctx.System.Id);
|
||||
|
||||
await using var conn = await ctx.Database.Obtain();
|
||||
var currentSwitch = await ctx.Repository.GetLatestSwitch(ctx.System.Id);
|
||||
var currentSwitchMembers = await ctx.Repository.GetSwitchMembers(conn, currentSwitch.Id).ToListAsync().AsTask();
|
||||
|
||||
if (ctx.MatchFlag("first", "f"))
|
||||
newMembers = await FirstInSwitch(ctx, newMembers[0]);
|
||||
newMembers = FirstInSwitch(newMembers[0], currentSwitchMembers);
|
||||
else if (ctx.MatchFlag("remove", "r"))
|
||||
newMembers = await RemoveFromSwitch(ctx, newMembers);
|
||||
newMembers = RemoveFromSwitch(newMembers, currentSwitchMembers);
|
||||
else if (ctx.MatchFlag("append", "a"))
|
||||
newMembers = await AppendToSwitch(ctx, newMembers);
|
||||
newMembers = AppendToSwitch(newMembers, currentSwitchMembers);
|
||||
else if (ctx.MatchFlag("prepend", "p"))
|
||||
newMembers = await PrependToSwitch(ctx, newMembers);
|
||||
newMembers = PrependToSwitch(newMembers, currentSwitchMembers);
|
||||
|
||||
if (newSwitch)
|
||||
{
|
||||
// if there's no edit flag, assume we're appending
|
||||
if (!ctx.MatchFlag("first", "f", "remove", "r", "append", "a", "prepend", "p"))
|
||||
newMembers = await AppendToSwitch(ctx, newMembers);
|
||||
newMembers = AppendToSwitch(newMembers, currentSwitchMembers);
|
||||
await DoSwitchCommand(ctx, newMembers);
|
||||
}
|
||||
else
|
||||
await DoEditCommand(ctx, newMembers);
|
||||
}
|
||||
public async Task<List<PKMember>> PrependToSwitch(Context ctx, List<PKMember> members)
|
||||
|
||||
public List<PKMember> PrependToSwitch(List<PKMember> members, List<PKMember> currentSwitchMembers)
|
||||
{
|
||||
await using var conn = await ctx.Database.Obtain();
|
||||
var currentSwitch = await ctx.Repository.GetLatestSwitch(ctx.System.Id);
|
||||
var currentSwitchMembers = await ctx.Repository.GetSwitchMembers(conn, currentSwitch.Id).ToListAsync().AsTask();
|
||||
members.AddRange(currentSwitchMembers);
|
||||
|
||||
return members;
|
||||
}
|
||||
public async Task<List<PKMember>> AppendToSwitch(Context ctx, List<PKMember> members)
|
||||
|
||||
public List<PKMember> AppendToSwitch(List<PKMember> members, List<PKMember> currentSwitchMembers)
|
||||
{
|
||||
await using var conn = await ctx.Database.Obtain();
|
||||
var currentSwitch = await ctx.Repository.GetLatestSwitch(ctx.System.Id);
|
||||
var currentSwitchMembers = await ctx.Repository.GetSwitchMembers(conn, currentSwitch.Id).ToListAsync().AsTask();
|
||||
currentSwitchMembers.AddRange(members);
|
||||
members = currentSwitchMembers;
|
||||
|
||||
return members;
|
||||
}
|
||||
public async Task<List<PKMember>> RemoveFromSwitch(Context ctx, List<PKMember> members)
|
||||
|
||||
public List<PKMember> RemoveFromSwitch(List<PKMember> members, List<PKMember> currentSwitchMembers)
|
||||
{
|
||||
await using var conn = await ctx.Database.Obtain();
|
||||
var currentSwitch = await ctx.Repository.GetLatestSwitch(ctx.System.Id);
|
||||
var currentSwitchMembers = await ctx.Repository.GetSwitchMembers(conn, currentSwitch.Id).ToListAsync().AsTask();
|
||||
var memberIds = members.Select(m => m.Id.Value);
|
||||
currentSwitchMembers = currentSwitchMembers.Where(m => !memberIds.Contains(m.Id.Value)).ToList();
|
||||
members = currentSwitchMembers;
|
||||
|
||||
return members;
|
||||
}
|
||||
public async Task<List<PKMember>> FirstInSwitch(Context ctx, PKMember member)
|
||||
|
||||
public List<PKMember> FirstInSwitch(PKMember member, List<PKMember> currentSwitchMembers)
|
||||
{
|
||||
await using var conn = await ctx.Database.Obtain();
|
||||
var currentSwitch = await ctx.Repository.GetLatestSwitch(ctx.System.Id);
|
||||
var currentSwitchMembers = await ctx.Repository.GetSwitchMembers(conn, currentSwitch.Id).ToListAsync().AsTask();
|
||||
currentSwitchMembers = currentSwitchMembers.Where(m => m.Id != member.Id).ToList();
|
||||
var members = new List<PKMember> { member };
|
||||
members.AddRange(currentSwitchMembers);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue