From e52225304e47d92bf1b84f5a2c8e97ab57bd85a4 Mon Sep 17 00:00:00 2001 From: Vendicated Date: Thu, 8 Sep 2022 21:47:53 +0200 Subject: Add modal api --- src/utils/modal.tsx | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 src/utils/modal.tsx (limited to 'src/utils') diff --git a/src/utils/modal.tsx b/src/utils/modal.tsx new file mode 100644 index 0000000..5628ebe --- /dev/null +++ b/src/utils/modal.tsx @@ -0,0 +1,34 @@ +import Components from "discord-types/components"; +import { waitFor } from "../webpack"; + +let Modal: Components.Modal; +let modals: any; + +waitFor("openModalLazy", m => modals = m); +waitFor("ModalRoot", m => Modal = m); + +let modalId = 1337; + +/** + * Open a modal + * @param Component The component to render in the modal + * @returns The key of this modal. This can be used to close the modal later with closeModal + */ +export function openModal(Component: React.ComponentType) { + let key = `Vencord${modalId++}`; + modals.openModal(props => + + + + , { modalKey: key }); + + return key; +}; + +/** + * Close a modal by key. The id you need for this is returned by openModal. + * @param key The key of the modal to close + */ +export function closeModal(key: string) { + modals.closeModal(key); +} \ No newline at end of file -- cgit