2023-01-25 02:25:29 +00:00
|
|
|
/*
|
|
|
|
* Vencord, a modification for Discord's desktop app
|
|
|
|
* Copyright (c) 2023 Vendicated and contributors
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2023-10-24 22:17:11 +00:00
|
|
|
import { proxyLazy } from "@utils/lazy";
|
2023-01-25 02:25:29 +00:00
|
|
|
import type { User } from "discord-types/general";
|
|
|
|
|
|
|
|
// eslint-disable-next-line path-alias/no-relative
|
2023-10-24 22:17:11 +00:00
|
|
|
import { _resolveReady, filters, find, findByCodeLazy, findByPropsLazy, findLazy, mapMangledModuleLazy, waitFor } from "../webpack";
|
2023-01-25 02:25:29 +00:00
|
|
|
import type * as t from "./types/utils";
|
|
|
|
|
|
|
|
export let FluxDispatcher: t.FluxDispatcher;
|
2023-10-25 12:39:57 +00:00
|
|
|
export let ComponentDispatch;
|
|
|
|
waitFor(["ComponentDispatch", "ComponentDispatcher"], m => ComponentDispatch = m.ComponentDispatch);
|
|
|
|
|
2023-01-25 02:25:29 +00:00
|
|
|
|
|
|
|
export const RestAPI: t.RestAPI = findByPropsLazy("getAPIBaseURL", "get");
|
|
|
|
export const moment: typeof import("moment") = findByPropsLazy("parseTwoDigitYear");
|
|
|
|
|
|
|
|
export const hljs: typeof import("highlight.js") = findByPropsLazy("highlight");
|
|
|
|
|
2023-03-25 02:37:29 +00:00
|
|
|
export const i18n: t.i18n = findLazy(m => m.Messages?.["en-US"]);
|
|
|
|
|
2023-01-25 02:25:29 +00:00
|
|
|
export let SnowflakeUtils: t.SnowflakeUtils;
|
|
|
|
waitFor(["fromTimestamp", "extractTimestamp"], m => SnowflakeUtils = m);
|
|
|
|
|
|
|
|
export let Parser: t.Parser;
|
|
|
|
export let Alerts: t.Alerts;
|
|
|
|
|
|
|
|
const ToastType = {
|
|
|
|
MESSAGE: 0,
|
|
|
|
SUCCESS: 1,
|
|
|
|
FAILURE: 2,
|
|
|
|
CUSTOM: 3
|
|
|
|
};
|
|
|
|
const ToastPosition = {
|
|
|
|
TOP: 0,
|
|
|
|
BOTTOM: 1
|
|
|
|
};
|
|
|
|
|
|
|
|
export const Toasts = {
|
|
|
|
Type: ToastType,
|
|
|
|
Position: ToastPosition,
|
|
|
|
// what's less likely than getting 0 from Math.random()? Getting it twice in a row
|
|
|
|
genId: () => (Math.random() || Math.random()).toString(36).slice(2),
|
|
|
|
|
|
|
|
// hack to merge with the following interface, dunno if there's a better way
|
|
|
|
...{} as {
|
|
|
|
show(data: {
|
|
|
|
message: string,
|
|
|
|
id: string,
|
|
|
|
/**
|
|
|
|
* Toasts.Type
|
|
|
|
*/
|
|
|
|
type: number,
|
|
|
|
options?: {
|
|
|
|
/**
|
|
|
|
* Toasts.Position
|
|
|
|
*/
|
|
|
|
position?: number;
|
|
|
|
component?: React.ReactNode,
|
|
|
|
duration?: number;
|
|
|
|
};
|
|
|
|
}): void;
|
|
|
|
pop(): void;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-06-29 14:06:21 +00:00
|
|
|
/**
|
|
|
|
* Show a simple toast. If you need more options, use Toasts.show manually
|
|
|
|
*/
|
|
|
|
export function showToast(message: string, type = ToastType.MESSAGE) {
|
|
|
|
Toasts.show({
|
|
|
|
id: Toasts.genId(),
|
|
|
|
message,
|
|
|
|
type
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-01-25 02:25:29 +00:00
|
|
|
export const UserUtils = {
|
|
|
|
fetchUser: findByCodeLazy(".USER(", "getUser") as (id: string) => Promise<User>,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const Clipboard = mapMangledModuleLazy('document.queryCommandEnabled("copy")||document.queryCommandSupported("copy")', {
|
2023-08-12 03:27:59 +00:00
|
|
|
copy: filters.byCode(".copy("),
|
2023-01-25 02:25:29 +00:00
|
|
|
SUPPORTS_COPY: x => typeof x === "boolean",
|
|
|
|
});
|
|
|
|
|
|
|
|
export const NavigationRouter = mapMangledModuleLazy("transitionToGuild - ", {
|
|
|
|
transitionTo: filters.byCode("transitionTo -"),
|
|
|
|
transitionToGuild: filters.byCode("transitionToGuild -"),
|
|
|
|
goBack: filters.byCode("goBack()"),
|
|
|
|
goForward: filters.byCode("goForward()"),
|
|
|
|
});
|
|
|
|
|
|
|
|
waitFor(["dispatch", "subscribe"], m => {
|
|
|
|
FluxDispatcher = m;
|
|
|
|
const cb = () => {
|
|
|
|
m.unsubscribe("CONNECTION_OPEN", cb);
|
|
|
|
_resolveReady();
|
|
|
|
};
|
|
|
|
m.subscribe("CONNECTION_OPEN", cb);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
// This is the same module but this is easier
|
2023-04-04 19:51:03 +00:00
|
|
|
waitFor("showToast", m => {
|
|
|
|
Toasts.show = m.showToast;
|
|
|
|
Toasts.pop = m.popToast;
|
|
|
|
});
|
2023-01-25 02:25:29 +00:00
|
|
|
|
|
|
|
waitFor(["show", "close"], m => Alerts = m);
|
|
|
|
waitFor("parseTopic", m => Parser = m);
|
|
|
|
|
|
|
|
export let SettingsRouter: any;
|
|
|
|
waitFor(["open", "saveAccountChanges"], m => SettingsRouter = m);
|
2023-05-15 00:33:04 +00:00
|
|
|
|
2023-10-24 22:17:11 +00:00
|
|
|
// FIXME: hack to support old stable and new canary
|
|
|
|
export const PermissionsBits: t.PermissionsBits = proxyLazy(() => {
|
|
|
|
try {
|
|
|
|
return find(m => m.Permissions?.ADMINISTRATOR).Permissions;
|
|
|
|
} catch {
|
|
|
|
return find(m => typeof m.ADMINISTRATOR === "bigint");
|
|
|
|
}
|
|
|
|
});
|