Merge pull request #1121 from DEVTomatoCake/fix-deleting-non-empty-categories-1117
Allow deletion of non-empty categories
This commit is contained in:
commit
6be688d261
@ -90,6 +90,24 @@ router.delete(
|
|||||||
} else if (channel.type === ChannelType.GROUP_DM) {
|
} else if (channel.type === ChannelType.GROUP_DM) {
|
||||||
await Channel.removeRecipientFromChannel(channel, req.user_id);
|
await Channel.removeRecipientFromChannel(channel, req.user_id);
|
||||||
} else {
|
} else {
|
||||||
|
if (channel.type == ChannelType.GUILD_CATEGORY) {
|
||||||
|
const channels = await Channel.find({
|
||||||
|
where: { parent_id: channel_id },
|
||||||
|
});
|
||||||
|
for await (const c of channels) {
|
||||||
|
c.parent_id = null;
|
||||||
|
|
||||||
|
await Promise.all([
|
||||||
|
c.save(),
|
||||||
|
emitEvent({
|
||||||
|
event: "CHANNEL_UPDATE",
|
||||||
|
data: c,
|
||||||
|
channel_id: c.id,
|
||||||
|
} as ChannelUpdateEvent),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
Channel.delete({ id: channel_id }),
|
Channel.delete({ id: channel_id }),
|
||||||
emitEvent({
|
emitEvent({
|
||||||
|
@ -105,7 +105,7 @@ export class Channel extends BaseClass {
|
|||||||
|
|
||||||
@Column({ nullable: true })
|
@Column({ nullable: true })
|
||||||
@RelationId((channel: Channel) => channel.parent)
|
@RelationId((channel: Channel) => channel.parent)
|
||||||
parent_id: string;
|
parent_id: string | null;
|
||||||
|
|
||||||
@JoinColumn({ name: "parent_id" })
|
@JoinColumn({ name: "parent_id" })
|
||||||
@ManyToOne(() => Channel)
|
@ManyToOne(() => Channel)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user