open-webui/src/routes/(app)/workspace/prompts/create/+page.svelte

80 lines
1.8 KiB
Svelte
Raw Normal View History

2024-11-17 04:53:05 +00:00
<script lang="ts">
2024-03-01 09:18:07 +00:00
import { toast } from 'svelte-sonner';
2024-01-03 05:35:47 +00:00
import { goto } from '$app/navigation';
import { prompts } from '$lib/stores';
import { onMount, tick, getContext } from 'svelte';
2024-01-03 05:35:47 +00:00
2024-11-17 04:53:05 +00:00
const i18n = getContext('i18n');
2024-01-03 05:35:47 +00:00
import { createNewPrompt, getPrompts } from '$lib/apis/prompts';
2024-11-11 02:20:46 +00:00
import PromptEditor from '$lib/components/workspace/Prompts/PromptEditor.svelte';
2024-01-03 05:35:47 +00:00
let prompt: {
title: string;
command: string;
content: string;
access_control: any | null;
} | null = null;
let clone = false;
2024-11-17 01:49:13 +00:00
const onSubmit = async (_prompt) => {
const res = await createNewPrompt(localStorage.token, _prompt).catch((error) => {
2025-01-21 06:41:32 +00:00
toast.error(`${error}`);
2024-11-17 01:49:13 +00:00
return null;
});
2024-01-03 04:41:37 +00:00
if (res) {
2024-11-17 04:53:05 +00:00
toast.success($i18n.t('Prompt created successfully'));
2024-11-11 02:20:46 +00:00
await prompts.set(await getPrompts(localStorage.token));
await goto('/workspace/prompts');
}
2024-01-03 04:41:37 +00:00
};
2024-02-18 23:53:54 +00:00
onMount(async () => {
2024-01-03 04:41:37 +00:00
window.addEventListener('message', async (event) => {
2025-12-07 23:06:06 +00:00
console.log(event);
2024-01-03 04:41:37 +00:00
if (
2025-12-07 23:06:06 +00:00
!['https://openwebui.com', 'https://www.openwebui.com', 'http://localhost:9999'].includes(
2024-06-02 04:16:32 +00:00
event.origin
)
2024-01-03 04:41:37 +00:00
)
return;
2024-11-11 02:20:46 +00:00
const _prompt = JSON.parse(event.data);
console.log('Received prompt via window message:', _prompt);
2024-11-11 02:20:46 +00:00
clone = true;
2024-11-11 02:20:46 +00:00
prompt = {
title: _prompt.title,
command: _prompt.command,
2024-11-17 01:49:13 +00:00
content: _prompt.content,
access_control: null
2024-11-11 02:20:46 +00:00
};
2024-01-03 04:41:37 +00:00
});
if (window.opener ?? false) {
window.opener.postMessage('loaded', '*');
}
2024-02-18 23:53:54 +00:00
if (sessionStorage.prompt) {
2024-11-11 02:20:46 +00:00
const _prompt = JSON.parse(sessionStorage.prompt);
sessionStorage.removeItem('prompt');
2024-02-18 23:53:54 +00:00
console.log('Received prompt via sessionStorage:', _prompt);
clone = true;
2024-11-11 02:20:46 +00:00
prompt = {
title: _prompt.title,
command: _prompt.command,
2024-11-17 01:49:13 +00:00
content: _prompt.content,
access_control: null
2024-11-11 02:20:46 +00:00
};
2024-02-18 23:53:54 +00:00
}
2024-01-03 04:41:37 +00:00
});
</script>
2024-11-11 02:42:52 +00:00
{#key prompt}
<PromptEditor {prompt} {onSubmit} {clone} />
2024-11-11 02:42:52 +00:00
{/key}