<script lang="ts">
	import { PUBLIC_APP_NAME, 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";
	import { env } from "$env/dynamic/public";
	import { curr_model_writable } from "../../../routes/LayoutWritable";

	export let currentModel: Model;
	export let settings: LayoutData["settings"];
	export let models: Model[];

	let isModelsModalOpen = false;
	let selectedNum = 0;

	curr_model_writable.subscribe((val) => {
		selectedNum = val;
	});

	$: currentModelMetadata = findCurrentModel(models, models[selectedNum].name);

	const announcementBanners = PUBLIC_ANNOUNCEMENT_BANNERS
		? JSON.parse(PUBLIC_ANNOUNCEMENT_BANNERS)
		: [];

	const dispatch = createEventDispatcher<{ message: string }>();

	function getTitles(str: string) {
		const split = str.split(' ')
		const map_str = new Map();
		for (let i = 0; i < split.length; i++) {
			map_str.set(i, split[i])
		}
    	return map_str
	}

	$: title = env.PUBLIC_APP_NAME;
</script>

<div class="my-auto grid gap-8 lg:grid-cols-2">
	<div class="lg:col-span-1">
		<div>
			<div class="mb-3 flex items-center text-2xl font-semibold">
				<Logo classNames="mr-1flex-none" />
				<div class = "pl-2 text-white"> {PUBLIC_APP_NAME} </div>
			</div>
			<p class="text-base text-gray-600 dark:text-gray-400">
				Enjoying the best AI models, with privacy
			</p>
		</div>
	</div>
	<div class="lg:col-span-2 lg:pl-24 w-[50%] flex absolute right-[0%]">
		{#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)}
				on:closeAndSave={(id) => (
					(isModelsModalOpen = false), curr_model_writable.set(id.detail.id)
				)}
			/>
		{/if}
		{#if models.length > 1}
		<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>
		{/if}
	</div>
	{#if currentModelMetadata.promptExamples}
		<div class="lg:col-span-2 lg:mt-6">
			<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-prompts dark:text-gray-300 dark:hover:bg-gray-700 sm:p-4"
						on:click={() => {
							dataLayer.push({ event: "prompt", titre_prompt: [example.title] });
							dispatch("message", example.prompt)}
					}
					>
					{#each [...getTitles(example.title)] as [key, value]}
						{#if key < 3}
							<b>{value + " "} </b>
						{:else}
							{value + " "} 
						{/if}
					{/each}
					</button>
				{/each}
			</div>
		</div>{/if}
</div>