diff --git a/.vscode/tasks.json b/.vscode/tasks.json index 5b160cb8..13297d62 100644 --- a/.vscode/tasks.json +++ b/.vscode/tasks.json @@ -12,6 +12,18 @@ "isDefault": true } }, + { + // for use with the vencord companion extension + "label": "BuildCompanionReporter", + "type": "shell", + "command": "pnpm build --dev --reporter --companion-test" + }, + { + "label": "BuildDev", + "type": "shell", + "command": "pnpm build --dev", + "group": "build" + }, { "label": "Watch", "type": "shell", @@ -22,4 +34,4 @@ } } ] -} \ No newline at end of file +} diff --git a/src/plugins/devCompanion.dev/index.tsx b/src/plugins/devCompanion.dev/index.tsx index 961c8dbf..715a3240 100644 --- a/src/plugins/devCompanion.dev/index.tsx +++ b/src/plugins/devCompanion.dev/index.tsx @@ -23,6 +23,7 @@ import { Logger } from "@utils/Logger"; import { canonicalizeMatch, canonicalizeReplace } from "@utils/patches"; import definePlugin, { OptionType, ReporterTestable } from "@utils/types"; import { filters, findAll, search, wreq } from "@webpack"; +import { reporterData } from "debug/runReporter"; import { extractModule, extractOrThrow, FindData, findModuleId, FindType, mkRegexFind, parseNode, PatchData, SendData } from "./util"; @@ -67,6 +68,12 @@ function initWs(isManual = false) { data: Object.keys(wreq.m), ok: true, }); + // if we are running the reporter with companion integration, send the list to vscode as soon as we can + replyData({ + type: "report", + data: reporterData, + ok: true + }); (settings.store.notifyOnAutoConnect || isManual) && showNotification({ title: "Dev Companion Connected", @@ -174,6 +181,10 @@ function initWs(isManual = false) { } break; } + case "reload": { + window.location.reload(); + break; + } case "extract": { try { const { extractType, idOrSearch } = data;