[Global] Code cleanup pass

This commit is contained in:
Beef 2023-02-26 22:56:36 +00:00
parent 69c2544b99
commit 7d36903b2c
19 changed files with 47 additions and 73 deletions

8
src/def.d.ts vendored
View file

@ -46,7 +46,7 @@ interface Asset {
id: number;
}
declare enum ButtonColors {
export enum ButtonColors {
BRAND = "brand",
RED = "red",
GREEN = "green",
@ -121,7 +121,7 @@ interface ApplicationCommand {
type: ApplicationCommandType;
}
declare enum ApplicationCommandInputType {
export enum ApplicationCommandInputType {
BUILT_IN,
BUILT_IN_TEXT,
BUILT_IN_INTEGRATION,
@ -138,7 +138,7 @@ interface ApplicationCommandOption {
displayDescription: string;
}
declare enum ApplicationCommandOptionType {
export enum ApplicationCommandOptionType {
SUB_COMMAND = 1,
SUB_COMMAND_GROUP,
STRING,
@ -152,7 +152,7 @@ declare enum ApplicationCommandOptionType {
ATTACHMENT,
}
declare enum ApplicationCommandType {
export enum ApplicationCommandType {
CHAT = 1,
USER,
MESSAGE,

View file

@ -7,19 +7,16 @@ import logger from "@lib/logger";
export let socket: WebSocket;
export function connectToDebugger(url: string) {
if (socket !== undefined && socket.readyState !== WebSocket.CLOSED) {
socket.close();
}
if (socket !== undefined && socket.readyState !== WebSocket.CLOSED) socket.close();
if (url === "") {
if (!url) {
showToast("Invalid debugger URL!", getAssetIDByName("Small"));
return;
}
socket = new WebSocket(`ws://${url}`);
socket.addEventListener("open", () => showToast("Connected to debugger.", getAssetIDByName("Check")));
socket.addEventListener("message", (message: any) => {
try {
(0, eval)(message.data);

View file

@ -1,10 +1,10 @@
import { Emitter, EmitterEvent, EmitterListener, EmitterListenerData, EmitterListeners } from "@types";
export const Events = Object.freeze({
GET: "GET",
SET: "SET",
DEL: "DEL",
});
export enum Events {
GET = "GET",
SET = "SET",
DEL = "DEL",
};
export default function createEmitter(): Emitter {
return {

View file

@ -5,10 +5,10 @@
const basicFind = (prop: string) => Object.values(window.modules).find(m => m?.publicModule.exports?.[prop])?.publicModule?.exports;
// Hoist React on window
window.React = basicFind("createElement") as typeof import("react");;
window.React = basicFind("createElement") as typeof import("react");
// Export ReactNative
export const ReactNative = basicFind("Text") as typeof import("react-native");
export const ReactNative = basicFind("AppRegistry") as typeof import("react-native");
// Export Discord's constants
export const constants = basicFind("AbortCodes");

View file

@ -1,5 +1,5 @@
import { createFileBackend, createMMKVBackend, createStorage, wrapSync } from "@lib/storage";
import { LoaderConfig, Settings } from "@types";
import { createFileBackend, createMMKVBackend, createStorage, wrapSync } from "@lib/storage";
export default wrapSync(createStorage<Settings>(createMMKVBackend("VENDETTA_SETTINGS")));
export const loaderConfig = wrapSync(createStorage<LoaderConfig>(createFileBackend("vendetta_loader.json")));

View file

@ -1,5 +1,7 @@
import { clipboard } from "@metro/common";
// TODO: Remove/deprecate this, the clipboard module works the same way.
export default function copyText(content: string) {
try {
clipboard.setString(content);

View file

@ -1,8 +1,6 @@
// https://stackoverflow.com/a/68339174
export default function unfreeze(obj: object) {
if (Object.isFrozen(obj)) {
return Object.assign({}, obj);
}
if (Object.isFrozen(obj)) return Object.assign({}, obj);
return obj;
}

View file

@ -4,7 +4,7 @@ import InputAlert from "@ui/components/InputAlert";
const Alerts = findByProps("openLazy", "close");
interface InternalConfirmationAlertOptions extends Omit<ConfirmationAlertOptions, 'content'> {
interface InternalConfirmationAlertOptions extends Omit<ConfirmationAlertOptions, "content"> {
content: string | JSX.Element | JSX.Element[] | undefined;
body: string | undefined;
children: JSX.Element | JSX.Element[];
@ -20,18 +20,11 @@ export function showConfirmationAlert(options: ConfirmationAlertOptions) {
};
delete internalOptions.content;
return Alerts.show(internalOptions);
};
export function showCustomAlert(component: React.ComponentType, props: any) {
Alerts.openLazy({
importer: async function () {
return () => React.createElement(component, props);
}
});
};
export const showCustomAlert = (component: React.ComponentType, props: any) => Alerts.openLazy({
importer: async () => () => React.createElement(component, props),
});
export function showInputAlert(options: InputAlertProps) {
showCustomAlert(InputAlert as React.ComponentType, options);
};
export const showInputAlert = (options: InputAlertProps) => showCustomAlert(InputAlert as React.ComponentType, options);

View file

@ -1,6 +1,6 @@
import { Asset, Indexable } from "@types";
import { after } from "@lib/patcher";
import { assets } from "@metro/common";
import { after } from "@lib/patcher";
export const all: Indexable<Asset> = {};

View file

@ -5,13 +5,13 @@ import { constants } from "@metro/hoist";
//* In 167.1, most if not all traces of the old color modules were removed.
//* In 168.6, Discord restructured EVERYTHING again. SemanticColor on this module no longer works when passed to a stylesheet. We must now use what you see below.
//? However, this is not all bad. The changes made in 168.6 do allow for better native-less theming.
const colorModule = findByProps("SemanticColor");
const colorModule = findByProps("colors", "meta");
//* For both below, SemanticColor and RawColor are seemingly not used. Once again, what are Discord doing?
//? SemanticColor and default.colors are effectively ThemeColorMap
export const semanticColors = (constants.ThemeColorMap ?? colorModule?.default?.colors ?? colorModule?.SemanticColor);
export const semanticColors = (constants.ThemeColorMap ?? colorModule?.colors);
//? RawColor and default.unsafe_rawColors are effectively Colors
//* Note that constants.Colors does still appear to exist on newer versions despite Discord not internally using it - what the fuck?
export const rawColors = (constants.Colors ?? colorModule?.default?.unsafe_rawColors ?? colorModule?.RawColor);
export const rawColors = (constants.Colors ?? colorModule?.unsafe_rawColors);

View file

@ -3,7 +3,6 @@ import { Forms, Alert } from "@ui/components";
import { InputAlertProps } from "@types";
const { FormInput } = Forms;
const Alerts = findByProps("openLazy", "close");
export default function InputAlert({ title, confirmText, confirmColor, onConfirm, cancelText, placeholder, initialValue = "" }: InputAlertProps) {

View file

@ -1,8 +1,8 @@
// Based on https://github.com/Aliucord/AliucordRN/blob/main/src/ui/patchTheme.ts
// Literally could not figure this out, many thanks
import { findByProps, findByStoreName } from "@metro/filters";
import { FluxDispatcher } from "@metro/common";
import { findByProps, findByStoreName } from "@metro/filters";
import logger from "@lib/logger";
// TODO: Move these to common modules?

View file

@ -1,9 +1,9 @@
import { HTTP_REGEX } from "@/lib/constants";
import { semanticColors } from "@ui/color";
import { installPlugin } from "@lib/plugins";
import { clipboard, stylesheet } from "@metro/common";
import { HTTP_REGEX } from "@lib/constants";
import { installPlugin } from "@lib/plugins";
import { showInputAlert } from "@ui/alerts";
import { getAssetIDByName } from "@ui/assets";
import { semanticColors } from "@ui/color";
import { General } from "@ui/components";
const { TouchableOpacity, Image } = General;

View file

@ -1,16 +1,13 @@
import { ButtonColors, Plugin } from "@types";
import { ReactNative as RN, stylesheet, NavigationNative } from "@metro/common";
import { findByProps } from "@metro/filters";
import { Forms, General } from "@ui/components";
import { Plugin } from "@types";
import { getAssetIDByName } from "@ui/assets";
import { showToast } from "@ui/toasts";
import { showConfirmationAlert } from "@ui/alerts";
import { semanticColors } from "@ui/color";
import { removePlugin, startPlugin, stopPlugin, getSettings } from "@lib/plugins";
import copyText from "@utils/copyText";
// TODO: Replace with our eventual dialog API
const Dialog = findByProps("show", "openLazy", "close");
const { FormRow, FormSwitch } = Forms;
const { TouchableOpacity, Image } = General;
@ -79,12 +76,12 @@ export default function PluginCard({ plugin, index }: PluginCardProps) {
trailing={
<RN.View style={styles.actions}>
<TouchableOpacity
onPress={() => Dialog.show({
onPress={() => showConfirmationAlert({
title: "Wait!",
body: `Are you sure you wish to delete ${plugin.manifest.name}?`,
content: `Are you sure you wish to delete ${plugin.manifest.name}?`,
confirmText: "Delete",
cancelText: "Cancel",
confirmColor: "red",
confirmColor: ButtonColors.RED,
onConfirm: () => {
try {
removePlugin(plugin.id);

View file

@ -4,11 +4,11 @@ import { after } from "@lib/patcher";
import findInReactTree from "@utils/findInReactTree";
import ErrorBoundary from "@ui/components/ErrorBoundary";
import SettingsSection from "@ui/settings/components/SettingsSection";
import InstallPluginButton from "@ui/settings/components/InstallPluginButton";
import General from "@ui/settings/pages/General";
import Plugins from "@ui/settings/pages/Plugins";
import Developer from "@ui/settings/pages/Developer";
import AssetBrowser from "@ui/settings/pages/AssetBrowser";
import InstallPluginButton from "@ui/settings/components/InstallPluginButton";
const screensModule = findByDisplayName("getScreens", false);
const settingsModule = findByDisplayName("UserSettingsOverviewWrapper", false);

View file

@ -1,6 +1,6 @@
import { ReactNative as RN, stylesheet } from "@metro/common";
import { Forms, Search } from "@ui/components";
import { all } from "@ui/assets";
import { Forms, Search } from "@ui/components";
import ErrorBoundary from "@ui/components/ErrorBoundary";
import AssetDisplay from "@ui/settings/components/AssetDisplay";

View file

@ -1,11 +1,9 @@
import { ReactNative as RN, NavigationNative } from "@metro/common";
import { Forms } from "@ui/components";
import { getAssetIDByName } from "@ui/assets";
import { showToast } from "@ui/toasts";
import { connectToDebugger } from "@lib/debug";
import { useProxy } from "@lib/storage";
import settings, { loaderConfig } from "@lib/settings";
import logger from "@lib/logger";
import ErrorBoundary from "@ui/components/ErrorBoundary";
const { FormSection, FormRow, FormSwitchRow, FormInput, FormDivider } = Forms;
@ -37,18 +35,10 @@ export default function Developer() {
<FormRow
label="Connect to React DevTools"
leading={<FormRow.Icon source={getAssetIDByName("ic_badge_staff")} />}
onPress={() => {
try {
window.__vendetta_rdc?.connectToDevTools({
host: settings.debuggerUrl.split(":")?.[0],
resolveRNStyle: RN.StyleSheet.flatten,
});
} catch (e) {
// TODO: Check if this ever actually catches anything
logger.error("Failed to connect to React DevTools!", e);
showToast("Failed to connect to React DevTools!", getAssetIDByName("Small"));
}
}}
onPress={() => window.__vendetta_rdc?.connectToDevTools({
host: settings.debuggerUrl.split(":")?.[0],
resolveRNStyle: RN.StyleSheet.flatten,
})}
/>
</>}
</FormSection>

View file

@ -1,7 +1,7 @@
import { ReactNative as RN, url, invites } from "@metro/common";
import { DISCORD_SERVER, GITHUB } from "@lib/constants";
import { getAssetIDByName } from "@ui/assets";
import { Forms, Summary } from "@ui/components";
import { DISCORD_SERVER, GITHUB } from "@lib/constants";
import { getDebugInfo } from "@lib/debug";
import { useProxy } from "@lib/storage";
import settings from "@lib/settings";

View file

@ -1,8 +1,6 @@
import { toasts } from "@metro/common";
export function showToast(content: string, asset: number) {
return toasts.open({
content: content,
source: asset,
});
}
export const showToast = (content: string, asset: number) => toasts.open({
content: content,
source: asset,
});