| <script lang="ts"> | |
| import { PUBLIC_VERSION } from "$env/static/public"; | |
| import Logo from "$lib/components/icons/Logo.svelte"; | |
| import Modal from "$lib/components/Modal.svelte"; | |
| import { onMount } from "svelte"; | |
| let ethicsModal = false; | |
| const LOCAL_STORAGE_KEY = "has-seen-ethics-modal"; | |
| onMount(() => { | |
| ethicsModal = localStorage.getItem(LOCAL_STORAGE_KEY) === null; | |
| }); | |
| const handleClick = () => { | |
| ethicsModal = false; | |
| localStorage.setItem(LOCAL_STORAGE_KEY, "true"); | |
| }; | |
| </script> | |
| {#if ethicsModal} | |
| <Modal> | |
| <div | |
| class="flex w-full flex-col items-center gap-6 bg-gradient-to-t from-yellow-500/40 via-yellow-500/10 to-yellow-500/0 px-4 pb-10 pt-9 text-center" | |
| > | |
| <h2 class="flex items-center text-2xl font-semibold text-gray-800"> | |
| <Logo classNames="text-3xl mr-1.5" />HuggingChat | |
| {#if typeof PUBLIC_VERSION !== "undefined"} | |
| <div | |
| class="ml-3 flex h-6 items-center rounded-lg border border-gray-100 bg-gray-50 px-2 text-base text-gray-400" | |
| > | |
| v{PUBLIC_VERSION} | |
| </div> | |
| {/if} | |
| </h2> | |
| <p class="px-4 text-lg font-semibold leading-snug text-gray-800 sm:px-12"> | |
| This application is for demonstration purposes only. | |
| </p> | |
| <p class="text-gray-800"> | |
| AI is an area of active research with known problems such as biased generation and | |
| misinformation. Do not use this application for high-stakes decisions or advice. | |
| </p> | |
| <button | |
| type="button" | |
| on:click={handleClick} | |
| class="mt-2 rounded-full bg-black px-5 py-2 text-lg font-semibold text-gray-100 transition-colors hover:bg-yellow-500" | |
| > | |
| Start chatting | |
| </button> | |
| </div> | |
| </Modal> | |
| {/if} | |