feat(plugin): add quickreply (#61)
This commit is contained in:
parent
8842ad7652
commit
0109381a4f
61
src/plugins/quickreply.ts
Normal file
61
src/plugins/quickreply.ts
Normal 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,
|
||||||
|
});
|
||||||
|
};
|
Loading…
Reference in a new issue