| <script lang="ts"> | |
| import { PUBLIC_VERSION } from "$env/static/public"; | |
| import { PUBLIC_ANNOUNCEMENT_BANNERS } from "$env/static/public"; | |
| import Logo from "$lib/components/icons/Logo.svelte"; | |
| import { createEventDispatcher } from "svelte"; | |
| import IconChevron from "$lib/components/icons/IconChevron.svelte"; | |
| import CarbonArrowUpRight from "~icons/carbon/arrow-up-right"; | |
| import AnnouncementBanner from "../AnnouncementBanner.svelte"; | |
| import ModelsModal from "../ModelsModal.svelte"; | |
| import type { Model } from "$lib/types/Model"; | |
| import ModelCardMetadata from "../ModelCardMetadata.svelte"; | |
| import type { LayoutData } from "../../../routes/$types"; | |
| import { findCurrentModel } from "$lib/utils/models"; | |
| export let currentModel: Model; | |
| export let settings: LayoutData["settings"]; | |
| export let models: Model[]; | |
| let isModelsModalOpen = false; | |
| $: currentModelMetadata = findCurrentModel(models, settings.activeModel); | |
| const announcementBanners = PUBLIC_ANNOUNCEMENT_BANNERS | |
| ? JSON.parse(PUBLIC_ANNOUNCEMENT_BANNERS) | |
| : []; | |
| const dispatch = createEventDispatcher<{ message: string }>(); | |
| </script> | |
| <div class="my-auto grid gap-8 lg:grid-cols-3"> | |
| <div class="lg:col-span-1"> | |
| <div> | |
| <div class="mb-3 flex items-center text-2xl font-semibold"> | |
| <Logo classNames="mr-1 text-yellow-400 text-4xl flex-none" /> | |
| HuggingChat | |
| <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 dark:border-gray-700/60 dark:bg-gray-800" | |
| > | |
| v{PUBLIC_VERSION} | |
| </div> | |
| </div> | |
| <p class="text-base text-gray-600 dark:text-gray-400"> | |
| Making the community's best AI chat models available to everyone. | |
| </p> | |
| </div> | |
| </div> | |
| <div class="lg:col-span-2 lg:pl-24"> | |
| {#each announcementBanners as banner} | |
| <AnnouncementBanner classNames="mb-4" title={banner.title}> | |
| <a | |
| target="_blank" | |
| href={banner.linkHref} | |
| class="mr-2 flex items-center underline hover:no-underline" | |
| ><CarbonArrowUpRight class="mr-1.5 text-xs" /> {banner.linkTitle}</a | |
| > | |
| </AnnouncementBanner> | |
| {/each} | |
| {#if isModelsModalOpen} | |
| <ModelsModal {settings} {models} on:close={() => (isModelsModalOpen = false)} /> | |
| {/if} | |
| <div class="overflow-hidden rounded-xl border dark:border-gray-800"> | |
| <div class="flex p-3"> | |
| <div> | |
| <div class="text-sm text-gray-600 dark:text-gray-400">Current Model</div> | |
| <div class="font-semibold">{currentModel.displayName}</div> | |
| </div> | |
| {#if models.length > 1} | |
| <button | |
| type="button" | |
| on:click={() => (isModelsModalOpen = true)} | |
| class="btn ml-auto flex h-7 w-7 self-start rounded-full bg-gray-100 p-1 text-xs hover:bg-gray-100 dark:border-gray-600 dark:bg-gray-800 dark:hover:bg-gray-600" | |
| ><IconChevron /></button | |
| > | |
| {/if} | |
| </div> | |
| <ModelCardMetadata variant="dark" model={currentModel} /> | |
| </div> | |
| </div> | |
| {#if currentModelMetadata.promptExamples} | |
| <div class="lg:col-span-3 lg:mt-12"> | |
| <p class="mb-3 text-gray-600 dark:text-gray-300">Examples</p> | |
| <div class="grid gap-3 lg:grid-cols-3 lg:gap-5"> | |
| {#each currentModelMetadata.promptExamples as example} | |
| <button | |
| type="button" | |
| class="rounded-xl border bg-gray-50 p-2.5 text-gray-600 hover:bg-gray-100 dark:border-gray-800 dark:bg-gray-800 dark:text-gray-300 dark:hover:bg-gray-700 sm:p-4" | |
| on:click={() => dispatch("message", example.prompt)} | |
| > | |
| {example.title} | |
| </button> | |
| {/each} | |
| </div> | |
| </div>{/if} | |
| </div> | |