<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} <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>