Vencord/src/webpack/common.tsx

38 lines
1.4 KiB
TypeScript
Raw Normal View History

2022-08-31 14:47:07 -04:00
import { startAll } from "../plugins";
2022-09-27 10:57:46 -04:00
import { waitFor, filters, findByProps } from './webpack';
import type Components from "discord-types/components";
import type Stores from "discord-types/stores";
import type Other from "discord-types/other";
2022-08-31 14:47:07 -04:00
export let FluxDispatcher: Other.FluxDispatcher;
2022-08-31 14:47:07 -04:00
export let React: typeof import("react");
export let UserStore: Stores.UserStore;
2022-09-27 10:57:46 -04:00
export let Forms: any = {};
2022-08-31 14:47:07 -04:00
export let Button: any;
export let Switch: any;
export let Tooltip: Components.Tooltip;
2022-08-31 14:47:07 -04:00
waitFor("useState", m => React = m);
waitFor(["dispatch", "subscribe"], m => {
FluxDispatcher = m;
const cb = () => {
m.unsubscribe("CONNECTION_OPEN", cb);
startAll();
};
m.subscribe("CONNECTION_OPEN", cb);
});
waitFor(["getCurrentUser", "initialize"], m => UserStore = m);
2022-09-27 10:57:46 -04:00
waitFor(["Hovers", "Looks", "Sizes"], m => Button = m);
waitFor(filters.byCode("helpdeskArticleId"), m => Switch = m);
waitFor(["Positions", "Colors"], m => Tooltip = m);
waitFor(m => m.Tags && filters.byCode("errorSeparator")(m), m => Forms.FormTitle = m);
waitFor(m => m.Tags && filters.byCode("titleClassName", "sectionTitle")(m), m => Forms.FormSection = m);
waitFor(m => m.Types?.INPUT_PLACEHOLDER, m => Forms.FormText = m);
waitFor(m => {
if (typeof m !== "function") return false;
const s = m.toString();
return s.length < 200 && s.includes("divider");
}, m => Forms.FormDivider = m);