QuickReply & Up Key: Do not attempt to edit/reply to logged deleted message

This commit is contained in:
Vendicated 2023-04-02 22:14:58 +02:00
parent 8378638ee4
commit 8c47b7080d
No known key found for this signature in database
GPG key ID: A1DC0CFB5615D905
2 changed files with 15 additions and 3 deletions

View file

@ -209,6 +209,11 @@ export default definePlugin({
" m" +
")" +
".update($3"
},
{
// fix up key (edit last message) attempting to edit a deleted message
match: /(?<=getLastEditableMessage=.{0,200}\.find\(\(function\((\i)\)\{)return/,
replace: "return !$1.deleted &&"
}
]
},

View file

@ -111,7 +111,7 @@ function jumpIfOffScreen(channelId: string, messageId: string) {
}
function getNextMessage(isUp: boolean, isReply: boolean) {
let messages: Message[] = MessageStore.getMessages(SelectedChannelStore.getChannelId())._array;
let messages: Array<Message & { deleted?: boolean; }> = MessageStore.getMessages(SelectedChannelStore.getChannelId())._array;
if (!isReply) { // we are editing so only include own
const meId = UserStore.getCurrentUser().id;
messages = messages.filter(m => m.author.id === meId);
@ -121,11 +121,18 @@ function getNextMessage(isUp: boolean, isReply: boolean) {
? Math.min(messages.length - 1, i + 1)
: Math.max(-1, i - 1);
const findNextNonDeleted = (i: number) => {
do {
i = mutate(i);
} while (i !== -1 && messages[messages.length - i - 1]?.deleted === true);
return i;
};
let i: number;
if (isReply)
replyIdx = i = mutate(replyIdx);
replyIdx = i = findNextNonDeleted(replyIdx);
else
editIdx = i = mutate(editIdx);
editIdx = i = findNextNonDeleted(editIdx);
return i === - 1 ? undefined : messages[messages.length - i - 1];
}