From dc7c79b8cabb5128dacc361dcc3940b0ed9df659 Mon Sep 17 00:00:00 2001 From: Pheuw1 Date: Sat, 18 Mar 2023 12:15:22 +0100 Subject: [PATCH] Alert component use with await show_popup and read from store content --- front/volume/src/components/Alert/content.ts | 29 ++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/front/volume/src/components/Alert/content.ts b/front/volume/src/components/Alert/content.ts index 04f6c84..7af8866 100644 --- a/front/volume/src/components/Alert/content.ts +++ b/front/volume/src/components/Alert/content.ts @@ -1,4 +1,29 @@ import { writable } from 'svelte/store'; +import Alert__SvelteComponent_ from './Alert.svelte'; +export const content = writable("") +export const popup = writable(null) +import { bind } from 'svelte-simple-modal'; +let val; +export async function show_popup(message, form = true) { + popup.set(bind(Alert__SvelteComponent_, { + message, + form + })) + await waitForCondition() +} -export const content = writable("init") -export const popup = writable(null) \ No newline at end of file +export async function waitForCondition() { + const unsub = popup.subscribe((value) => {val = value}) + async function checkFlag() { + if (val == null) { + console.log("finished",val) + unsub() + return new Promise(resolve => setTimeout(resolve, 0)); + } else { + console.log("waiting") + await new Promise(resolve => setTimeout(resolve, 1000)); + return await checkFlag(); + } + } + return await checkFlag() +} \ No newline at end of file