pluralchat / src /routes /models /[...model] /+page.svelte
Andrew
Add rotating INIT_PROMPTS placeholder in chat input
5510827
<script lang="ts">
import { page } from "$app/state";
import { base } from "$app/paths";
import { goto } from "$app/navigation";
import { onMount } from "svelte";
import { usePublicConfig } from "$lib/utils/PublicConfig.svelte";
import ChatWindow from "$lib/components/chat/ChatWindow.svelte";
import { findCurrentModel } from "$lib/utils/models";
import { useSettingsStore } from "$lib/stores/settings";
import { ERROR_MESSAGES, error } from "$lib/stores/errors";
import { pendingMessage } from "$lib/stores/pendingMessage";
import { resetActivePersonasToDefaults } from "$lib/utils/personaDefaults";
let { data } = $props();
let loading = $state(false);
let files: File[] = $state([]);
const settings = useSettingsStore();
const modelId = page.params.model;
const publicConfig = usePublicConfig();
async function createConversation(message: string) {
try {
loading = true;
await resetActivePersonasToDefaults(
settings,
$settings.personas,
$settings.activePersonas
);
const res = await fetch(`${base}/conversation`, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
model: modelId,
}),
});
if (!res.ok) {
error.set("Error while creating conversation, try again.");
console.error("Error while creating conversation: " + (await res.text()));
return;
}
const { conversationId } = await res.json();
// Ugly hack to use a store as temp storage, feel free to improve ^^
pendingMessage.set({
content: message,
files,
});
// invalidateAll to update list of conversations
await goto(`${base}/conversation/${conversationId}`, { invalidateAll: true });
} catch (err) {
error.set(ERROR_MESSAGES.default);
console.error(err);
} finally {
loading = false;
}
}
onMount(async () => {
const query = page.url.searchParams.get("q");
if (query) createConversation(query);
settings.instantSet({ activeModel: modelId });
});
</script>
<svelte:head>
<meta property="og:title" content={modelId + " - " + publicConfig.PUBLIC_APP_NAME} />
<meta property="og:type" content="link" />
<meta property="og:description" content={`Use ${modelId} with ${publicConfig.PUBLIC_APP_NAME}`} />
<meta
property="og:image"
content="{publicConfig.PUBLIC_ORIGIN || page.url.origin}{base}/models/{modelId}/thumbnail.png"
/>
<meta property="og:url" content={page.url.href} />
<meta name="twitter:card" content="summary_large_image" />
</svelte:head>
<ChatWindow
onmessage={(message) => createConversation(message)}
{loading}
currentModel={findCurrentModel(data.models, data.oldModels, modelId)}
models={data.models}
initPrompts={data.initPrompts}
bind:files
/>