Spaces:
Build error
Build error
<script lang="ts"> | |
import { createEventDispatcher } from "svelte"; | |
import Modal from "$lib/components/Modal.svelte"; | |
import CarbonClose from "~icons/carbon/close"; | |
import Switch from "$lib/components/Switch.svelte"; | |
import { enhance } from "$app/forms"; | |
import { base } from "$app/paths"; | |
import { PUBLIC_APP_DATA_SHARING } from "$env/static/public"; | |
import type { Model } from "$lib/types/Model"; | |
import type { LayoutData } from "../../routes/$types"; | |
export let settings: LayoutData["settings"]; | |
export let models: Array<Model>; | |
let shareConversationsWithModelAuthors = settings.shareConversationsWithModelAuthors; | |
let isConfirmingDeletion = false; | |
const dispatch = createEventDispatcher<{ close: void }>(); | |
</script> | |
<Modal on:close> | |
<div class="flex w-full flex-col gap-5 p-6"> | |
<div class="flex items-start justify-between text-xl font-semibold text-gray-800"> | |
<h2>Settings</h2> | |
<button type="button" class="group" on:click={() => dispatch("close")}> | |
<CarbonClose class="text-gray-900 group-hover:text-gray-500" /> | |
</button> | |
</div> | |
<form | |
class="flex flex-col gap-5" | |
use:enhance={() => { | |
dispatch("close"); | |
}} | |
method="post" | |
action="{base}/settings" | |
> | |
{#if PUBLIC_APP_DATA_SHARING} | |
<label class="flex cursor-pointer select-none items-center gap-2 text-gray-500"> | |
{#each Object.entries(settings).filter(([k]) => !(k === "shareConversationsWithModelAuthors" || k === "customPrompts")) as [key, val]} | |
<input type="hidden" name={key} value={val} /> | |
{/each} | |
<input | |
type="hidden" | |
name="customPrompts" | |
value={JSON.stringify(settings.customPrompts)} | |
/> | |
<Switch | |
name="shareConversationsWithModelAuthors" | |
bind:checked={shareConversationsWithModelAuthors} | |
/> | |
Share conversations with model authors | |
</label> | |
<p class="text-gray-800"> | |
Sharing your data will help improve the training data and make open models better over | |
time. | |
</p> | |
<p class="text-gray-800"> | |
You can change this setting at any time, it applies to all your conversations. | |
</p> | |
<div> | |
<p class="text-gray-800">Read more about model authors:</p> | |
<ul class="list-inside list-disc"> | |
{#each models as model} | |
<li class="list-item"> | |
<a | |
href={model["websiteUrl"]} | |
target="_blank" | |
rel="noreferrer" | |
class="underline decoration-gray-300 hover:decoration-gray-700">{model["name"]}</a | |
> | |
</li> | |
{/each} | |
</ul> | |
</div> | |
{/if} | |
<label class="flex cursor-pointer select-none items-center gap-2 text-sm text-gray-500"> | |
<input | |
type="checkbox" | |
name="hideEmojiOnSidebar" | |
bind:checked={settings.hideEmojiOnSidebar} | |
/> | |
Hide emoticons in conversation topics | |
</label> | |
<form | |
method="post" | |
action="{base}/conversations?/delete" | |
on:submit|preventDefault={() => (isConfirmingDeletion = true)} | |
> | |
<button type="submit" class="underline decoration-gray-300 hover:decoration-gray-700"> | |
Delete all conversations | |
</button> | |
</form> | |
<button | |
type="submit" | |
class="mt-2 rounded-full bg-black px-5 py-2 text-lg font-semibold text-gray-100 ring-gray-400 ring-offset-1 transition-all focus-visible:outline-none focus-visible:ring hover:ring" | |
> | |
Apply | |
</button> | |
</form> | |
{#if isConfirmingDeletion} | |
<Modal on:close={() => (isConfirmingDeletion = false)}> | |
<form | |
use:enhance={() => { | |
dispatch("close"); | |
}} | |
method="post" | |
action="{base}/conversations?/delete" | |
class="flex w-full flex-col gap-5 p-6" | |
> | |
<div class="flex items-start justify-between text-xl font-semibold text-gray-800"> | |
<h2>Are you sure?</h2> | |
<button type="button" class="group" on:click={() => (isConfirmingDeletion = false)}> | |
<CarbonClose class="text-gray-900 group-hover:text-gray-500" /> | |
</button> | |
</div> | |
<p class="text-gray-800"> | |
This action will delete all your conversations. This cannot be undone. | |
</p> | |
<button | |
type="submit" | |
class="mt-2 rounded-full bg-red-700 px-5 py-2 text-lg font-semibold text-gray-100 ring-gray-400 ring-offset-1 transition-all focus-visible:outline-none focus-visible:ring hover:ring" | |
> | |
Confirm deletion | |
</button> | |
</form> | |
</Modal> | |
{/if} | |
</div> | |
</Modal> | |