forked from Cutlery/immich
bce916e4c8
* wrapper * no more callback * refactor: wip * refactor: wip * refactor: wip * pr feedback * fix * pr feedback
49 lines
952 B
TypeScript
49 lines
952 B
TypeScript
import { writable } from 'svelte/store';
|
|
|
|
type DialogActions = {
|
|
onConfirm: () => void;
|
|
onCancel: () => void;
|
|
};
|
|
|
|
type DialogOptions = {
|
|
id?: string;
|
|
title?: string;
|
|
prompt?: string;
|
|
confirmText?: string;
|
|
cancelText?: string;
|
|
hideCancelButton?: boolean;
|
|
disable?: boolean;
|
|
width?: 'wide' | 'narrow' | undefined;
|
|
};
|
|
|
|
export type Dialog = DialogOptions & DialogActions;
|
|
|
|
function createDialogWrapper() {
|
|
const dialog = writable<Dialog | undefined>();
|
|
|
|
async function show(options: DialogOptions) {
|
|
return new Promise((resolve) => {
|
|
const newDialog: Dialog = {
|
|
...options,
|
|
onConfirm: () => {
|
|
dialog.set(undefined);
|
|
resolve(true);
|
|
},
|
|
onCancel: () => {
|
|
dialog.set(undefined);
|
|
resolve(false);
|
|
},
|
|
};
|
|
|
|
dialog.set(newDialog);
|
|
});
|
|
}
|
|
|
|
return {
|
|
dialog,
|
|
show,
|
|
};
|
|
}
|
|
|
|
export const dialogController = createDialogWrapper();
|