aboutsummaryrefslogtreecommitdiff
path: root/src/plugins
diff options
context:
space:
mode:
authorVendicated <vendicated@riseup.net>2022-08-29 22:05:22 +0200
committerVendicated <vendicated@riseup.net>2022-08-29 22:05:22 +0200
commit483bc13a31ab2ba878ff8d9002b0a8671a640ec8 (patch)
tree9967493cf8d65dc90202bb76d604749c5c4ba5ca /src/plugins
parentc39ff8f6481463a1700014ebd204f2b6189759a1 (diff)
downloadVencord-483bc13a31ab2ba878ff8d9002b0a8671a640ec8.tar.gz
Vencord-483bc13a31ab2ba878ff8d9002b0a8671a640ec8.tar.bz2
Vencord-483bc13a31ab2ba878ff8d9002b0a8671a640ec8.zip
Finish rewrite
Diffstat (limited to 'src/plugins')
-rw-r--r--src/plugins/STFU.ts10
-rw-r--r--src/plugins/apiMessageClicks.ts16
-rw-r--r--src/plugins/bar.ts10
-rw-r--r--src/plugins/clientInfo.ts17
-rw-r--r--src/plugins/experiments.ts14
-rw-r--r--src/plugins/foo.ts10
-rw-r--r--src/plugins/messageActions.ts36
-rw-r--r--src/plugins/noTrack.ts31
8 files changed, 124 insertions, 20 deletions
diff --git a/src/plugins/STFU.ts b/src/plugins/STFU.ts
new file mode 100644
index 0000000..63dd7ef
--- /dev/null
+++ b/src/plugins/STFU.ts
@@ -0,0 +1,10 @@
+import definePlugin from "../utils/types";
+
+export default definePlugin({
+ name: "STFU",
+ description: "Disabled the fat warning in the DevTools console",
+ author: "Vendicated",
+ start() {
+ window.DiscordNative.window.setDevtoolsCallbacks(null, null);
+ }
+}); \ No newline at end of file
diff --git a/src/plugins/apiMessageClicks.ts b/src/plugins/apiMessageClicks.ts
new file mode 100644
index 0000000..7155b94
--- /dev/null
+++ b/src/plugins/apiMessageClicks.ts
@@ -0,0 +1,16 @@
+import definePlugin from "../utils/types";
+
+export default definePlugin({
+ name: "MessageClicksApi",
+ description: "Api required by anything using message click actions",
+ author: "Vendicated",
+ patches: [{
+ find: "if(e.altKey){",
+ replacement: {
+ match: /\.useClickMessage=function\((.{1,2}),(.{1,2})\).+?function\((.{1,2})\){/,
+ replace: (m, message, channel, event) =>
+ // the message param is shadowed by the event param, so need to alias them
+ `${m.replace("{", `{var _msg=${message};var _chan=${channel};`)}Vencord.Api.MessageClicks._handleClick(_msg, _chan, ${event});`
+ }
+ }]
+});
diff --git a/src/plugins/bar.ts b/src/plugins/bar.ts
deleted file mode 100644
index 76d1a8f..0000000
--- a/src/plugins/bar.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-import definePlugin from '../utils/types';
-
-export default definePlugin({
- name: "bar",
- description: "Just to test",
- author: ["Vendicated"],
- start() {
- console.log("bar");
- }
-}); \ No newline at end of file
diff --git a/src/plugins/clientInfo.ts b/src/plugins/clientInfo.ts
new file mode 100644
index 0000000..77cc70c
--- /dev/null
+++ b/src/plugins/clientInfo.ts
@@ -0,0 +1,17 @@
+import definePlugin from "../utils/types";
+
+export default definePlugin({
+ name: "ClientInfo",
+ description: "Adds extra info to Client Info in settings",
+ author: "Vendicated",
+ patches: [{
+ find: "default.versionHash",
+ replacement: {
+ match: /\w\.createElement.+?["']Host ["'].+?\):null/,
+ replace: m => {
+ const idx = m.indexOf("Host") - 1;
+ return `${m},${m.slice(0, idx)}"Vencord ".repeat(50),"1.0.0")," ")`;
+ }
+ }
+ }]
+}); \ No newline at end of file
diff --git a/src/plugins/experiments.ts b/src/plugins/experiments.ts
new file mode 100644
index 0000000..9db2e05
--- /dev/null
+++ b/src/plugins/experiments.ts
@@ -0,0 +1,14 @@
+import definePlugin from '../utils/types';
+
+export default definePlugin({
+ name: "Experiments",
+ author: "Vendicated",
+ description: "Enable Experiments",
+ patches: [{
+ find: "Object.defineProperties(this,{isDeveloper",
+ replacement: {
+ match: /(?<={isDeveloper:\{[^}]+,get:function\(\)\{return )\w/,
+ replace: "true"
+ }
+ }]
+});
diff --git a/src/plugins/foo.ts b/src/plugins/foo.ts
deleted file mode 100644
index f365b31..0000000
--- a/src/plugins/foo.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-import definePlugin from "../utils/types";
-
-export default definePlugin({
- name: "foo",
- description: "Just to test",
- author: ["Vendicated"],
- start() {
- console.log("foo");
- }
-}); \ No newline at end of file
diff --git a/src/plugins/messageActions.ts b/src/plugins/messageActions.ts
new file mode 100644
index 0000000..c2857cb
--- /dev/null
+++ b/src/plugins/messageActions.ts
@@ -0,0 +1,36 @@
+import { MessageClicks } from "../api";
+import definePlugin from "../utils/types";
+import { find, findByProps } from "../utils/webpack";
+
+export default definePlugin({
+ name: "MessageQuickActions",
+ description: "Quick Delete, Quick edit",
+ author: "Vendicated",
+ start() {
+ const { deleteMessage, startEditMessage } = findByProps("deleteMessage");
+ const { can } = findByProps("can", "initialize");
+ const { Permissions: { MANAGE_MESSAGES } } = find(m => m.Permissions?.MANAGE_MESSAGES);
+ const { getCurrentUser } = findByProps("getCurrentUser");
+
+ let isDeletePressed = false;
+ document.addEventListener("keydown", e => {
+ if (e.key === "Backspace") isDeletePressed = true;
+ });
+ document.addEventListener("keyup", e => {
+ if (e.key === "Backspace") isDeletePressed = false;
+ });
+
+ MessageClicks.addListener((msg, chan, event) => {
+ const isMe = msg.author.id === getCurrentUser().id;
+ if (!isDeletePressed) {
+ if (isMe && event.detail >= 2) {
+ startEditMessage(chan.id, msg.id, msg.content);
+ event.preventDefault();
+ }
+ } else if (isMe || can(MANAGE_MESSAGES, chan)) {
+ deleteMessage(chan.id, msg.id);
+ event.preventDefault();
+ }
+ });
+ }
+}); \ No newline at end of file
diff --git a/src/plugins/noTrack.ts b/src/plugins/noTrack.ts
new file mode 100644
index 0000000..6d3a0ba
--- /dev/null
+++ b/src/plugins/noTrack.ts
@@ -0,0 +1,31 @@
+import definePlugin from "../utils/types";
+import { findByProps } from "../utils/webpack";
+
+const DO_NOTHING = () => void 0;
+
+export default definePlugin({
+ name: "NoTrack",
+ description: "Disable Discord's tracking and crash reporting",
+ author: "Vendicated",
+ start() {
+ findByProps("getSuperPropertiesBase64", "track").track = DO_NOTHING;
+ findByProps("submitLiveCrashReport").submitLiveCrashReport = DO_NOTHING;
+ findByProps("AnalyticsActionHandlers").AnalyticsActionHandlers.handleTrack = DO_NOTHING;
+
+ const sentry = window.__SENTRY__;
+ sentry.logger.disable();
+
+ sentry.hub.addBreadcrumb = DO_NOTHING;
+ sentry.hub.getClient().close(0);
+ sentry.hub.getScope().clear();
+
+ const c = console;
+ for (const method in c) {
+ if (c[method].__sentry_original__)
+ c[method] = c[method].__sentry_original__;
+ if (c[method].__REACT_DEVTOOLS_ORIGINAL_METHOD__?.__sentry_original__)
+ c[method].__REACT_DEVTOOLS_ORIGINAL_METHOD__ = c[method].__REACT_DEVTOOLS_ORIGINAL_METHOD__.__sentry_original__;
+ }
+ }
+
+}); \ No newline at end of file