feat(plugin): add quickreply (#61)

This commit is contained in:
obscurity 2022-10-08 19:27:20 +02:00 committed by GitHub
parent 8842ad7652
commit 0109381a4f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

61
src/plugins/quickreply.ts Normal file
View file

@ -0,0 +1,61 @@
import definePlugin from "../utils/types";
import { Devs } from "../utils/constants";
import { FluxDispatcher as Dispatcher } from "../webpack/common";
import { filters } from "../webpack";
import { lazyWebpack } from "../utils/misc";
const channelIdModule = lazyWebpack(filters.byProps(["getChannelId"]));
const channelModule = lazyWebpack(filters.byProps(["getChannel"]));
const messagesModule = lazyWebpack(filters.byProps(["getRawMessages"]));
export default definePlugin({
name: "Quickreply",
authors: [Devs.obscurity],
description: "Reply to messages faster (ctrl + direction)",
start() {
Dispatcher.subscribe("DELETE_PENDING_REPLY", onDeletePendingReply);
document.addEventListener("keydown", keydown);
},
stop() {
Dispatcher.unsubscribe("DELETE_PENDING_REPLY", onDeletePendingReply);
document.removeEventListener("keydown", keydown);
},
});
let idx = -1;
const onDeletePendingReply = () => {
idx = -1;
};
const keydown = e => {
if (
(!e.ctrlKey && !e.metaKey) ||
(e.key !== "ArrowUp" && e.key !== "ArrowDown")
) {
return;
}
const channelId = channelIdModule.getChannelId();
const channel = channelModule.getChannel(channelId);
const messages = messagesModule.getMessages(channelId).toArray().reverse();
if (e.key === "ArrowUp") idx += 1;
else if (e.key === "ArrowDown") idx = Math.max(-1, idx - 1);
if (idx > messages.length) idx = messages.length;
if (idx < 0) {
return Dispatcher.dispatch({
type: "DELETE_PENDING_REPLY",
channelId,
});
}
Dispatcher.dispatch({
type: "CREATE_PENDING_REPLY",
channel: channel,
message: messages[idx],
showMentionToggle: channel.guild_id !== null,
});
};