| <script lang="ts"> |
| import { env as envPublic } from "$env/dynamic/public"; |
| import Logo from "$lib/components/icons/Logo.svelte"; |
| import { createEventDispatcher } from "svelte"; |
| import IconGear from "~icons/bi/gear-fill"; |
| import AnnouncementBanner from "../AnnouncementBanner.svelte"; |
| import type { Model } from "$lib/types/Model"; |
| import ModelCardMetadata from "../ModelCardMetadata.svelte"; |
| import { findCurrentModel } from "$lib/utils/models"; |
| import { base } from "$app/paths"; |
| import { useSettingsStore } from "$lib/stores/settings"; |
| import JSON5 from "json5"; |
| |
| export let currentModel: Model; |
| export let models: Model[]; |
| |
| const settings = useSettingsStore(); |
| |
| $: currentModelMetadata = findCurrentModel(models, $settings.activeModel); |
| |
| const announcementBanners = envPublic.PUBLIC_ANNOUNCEMENT_BANNERS |
| ? JSON5.parse(envPublic.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 flex-none" /> |
| {envPublic.PUBLIC_APP_NAME} |
| <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{envPublic.PUBLIC_VERSION} |
| </div> |
| </div> |
| <p class="text-base text-gray-600 dark:text-gray-400"> |
| {envPublic.PUBLIC_APP_DESCRIPTION || |
| "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">{banner.linkTitle}</a |
| > |
| </AnnouncementBanner> |
| {/each} |
| <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="flex items-center gap-1.5 font-semibold max-sm:text-smd"> |
| {#if currentModel.logoUrl} |
| <img |
| class=" overflown aspect-square size-4 rounded border dark:border-gray-700" |
| src={currentModel.logoUrl} |
| alt="" |
| /> |
| {:else} |
| <div class="size-4 rounded border border-transparent bg-gray-300 dark:bg-gray-800" /> |
| {/if} |
| {currentModel.displayName} |
| </div> |
| </div> |
| <a |
| href="{base}/settings/{currentModel.id}" |
| 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" |
| ><IconGear /></a |
| > |
| </div> |
| <ModelCardMetadata variant="dark" model={currentModel} /> |
| </div> |
| </div> |
| {#if currentModelMetadata.promptExamples} |
| <div class="lg:col-span-3 lg:mt-6"> |
| <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-3 text-gray-600 hover:bg-gray-100 max-xl:text-sm xl:p-3.5 dark:border-gray-800 dark:bg-gray-800 dark:text-gray-300 dark:hover:bg-gray-700" |
| on:click={() => dispatch("message", example.prompt)} |
| > |
| {example.title} |
| </button> |
| {/each} |
| </div> |
| </div>{/if} |
| <div class="h-40 sm:h-24" /> |
| </div> |
| |