Merge pull request #1184 from DEVTomatoCake/fix/widget.json-channel-ordering-deleted-channels
This commit is contained in:
commit
346641cf5b
@ -115,7 +115,7 @@ router.delete(
|
|||||||
}
|
}
|
||||||
|
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
Channel.delete({ id: channel_id }),
|
Channel.deleteChannel(channel),
|
||||||
emitEvent({
|
emitEvent({
|
||||||
event: "CHANNEL_DELETE",
|
event: "CHANNEL_DELETE",
|
||||||
data: channel,
|
data: channel,
|
||||||
|
@ -53,7 +53,12 @@ router.get(
|
|||||||
async (req: Request, res: Response) => {
|
async (req: Request, res: Response) => {
|
||||||
const { guild_id } = req.params;
|
const { guild_id } = req.params;
|
||||||
|
|
||||||
const guild = await Guild.findOneOrFail({ where: { id: guild_id } });
|
const guild = await Guild.findOneOrFail({
|
||||||
|
where: { id: guild_id },
|
||||||
|
select: {
|
||||||
|
channel_ordering: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
if (!guild.widget_enabled) throw DiscordApiErrors.EMBED_DISABLED;
|
if (!guild.widget_enabled) throw DiscordApiErrors.EMBED_DISABLED;
|
||||||
|
|
||||||
// Fetch existing widget invite for widget channel
|
// Fetch existing widget invite for widget channel
|
||||||
|
@ -459,9 +459,21 @@ export class Channel extends BaseClass {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static async deleteChannel(channel: Channel) {
|
static async deleteChannel(channel: Channel) {
|
||||||
await Message.delete({ channel_id: channel.id }); //TODO we should also delete the attachments from the cdn but to do that we need to move cdn.ts in util
|
// TODO Delete attachments from the CDN for messages in the channel
|
||||||
//TODO before deleting the channel we should check and delete other relations
|
|
||||||
await Channel.delete({ id: channel.id });
|
await Channel.delete({ id: channel.id });
|
||||||
|
|
||||||
|
const guild = await Guild.findOneOrFail({
|
||||||
|
where: { id: channel.guild_id },
|
||||||
|
select: { channel_ordering: true },
|
||||||
|
});
|
||||||
|
|
||||||
|
const updatedOrdering = guild.channel_ordering.filter(
|
||||||
|
(id) => id != channel.id,
|
||||||
|
);
|
||||||
|
await Guild.update(
|
||||||
|
{ id: channel.guild_id },
|
||||||
|
{ channel_ordering: updatedOrdering },
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
static async calculatePosition(
|
static async calculatePosition(
|
||||||
@ -487,15 +499,19 @@ export class Channel extends BaseClass {
|
|||||||
|
|
||||||
const channels = await Promise.all(
|
const channels = await Promise.all(
|
||||||
guild.channel_ordering.map((id) =>
|
guild.channel_ordering.map((id) =>
|
||||||
Channel.findOneOrFail({ where: { id } }),
|
Channel.findOne({ where: { id } }),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
return channels.reduce((r, v) => {
|
return channels
|
||||||
v.position = (guild as Guild).channel_ordering.indexOf(v.id);
|
.filter((channel) => channel !== null)
|
||||||
r[v.position] = v;
|
.reduce((r, v) => {
|
||||||
return r;
|
v = v as Channel;
|
||||||
}, [] as Array<Channel>);
|
|
||||||
|
v.position = (guild as Guild).channel_ordering.indexOf(v.id);
|
||||||
|
r[v.position] = v;
|
||||||
|
return r;
|
||||||
|
}, [] as Array<Channel>);
|
||||||
}
|
}
|
||||||
|
|
||||||
isDm() {
|
isDm() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user