2025-05-03 00:41:42 +02:00
|
|
|
import ConfirmDialog from '$lib/components/shared-components/dialog/confirm-dialog.svelte';
|
|
|
|
|
import { mount, unmount, type Component, type ComponentProps } from 'svelte';
|
|
|
|
|
|
2025-05-07 16:01:51 +02:00
|
|
|
type OnCloseData<T> = T extends { onClose: (data: infer R) => void | Promise<void> } ? R : never;
|
2025-05-03 00:41:42 +02:00
|
|
|
|
|
|
|
|
class ModalManager {
|
2025-05-07 16:01:51 +02:00
|
|
|
open<T = { onClose: (data: unknown) => void }, K = OnCloseData<T>>(
|
|
|
|
|
Component: Component<{ onClose: T }>,
|
|
|
|
|
props?: Record<string, never>,
|
2025-05-06 14:44:44 +02:00
|
|
|
): Promise<K>;
|
2025-05-07 16:01:51 +02:00
|
|
|
open<T extends object, K = OnCloseData<T>>(Component: Component<T>, props: Omit<T, 'onClose'>): Promise<K>;
|
|
|
|
|
open<T extends object, K = OnCloseData<T>>(Component: Component<T>, props?: Omit<T, 'onClose'>) {
|
2025-05-03 00:41:42 +02:00
|
|
|
return new Promise<K>((resolve) => {
|
|
|
|
|
let modal: object = {};
|
|
|
|
|
|
|
|
|
|
const onClose = async (data: K) => {
|
|
|
|
|
await unmount(modal);
|
|
|
|
|
resolve(data);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
modal = mount(Component, {
|
|
|
|
|
target: document.body,
|
|
|
|
|
props: {
|
2025-05-06 14:44:44 +02:00
|
|
|
...((props ?? {}) as T),
|
2025-05-03 00:41:42 +02:00
|
|
|
onClose,
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
openDialog(options: Omit<ComponentProps<typeof ConfirmDialog>, 'onClose'>) {
|
|
|
|
|
return this.open(ConfirmDialog, options);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export const modalManager = new ModalManager();
|