feature/fetch-fonts #14

Merged
ilia merged 76 commits from feature/fetch-fonts into main 2026-01-14 11:01:44 +00:00
2 changed files with 38 additions and 12 deletions
Showing only changes of commit 76172aaa6b - Show all commits

View File

@@ -1,20 +1,46 @@
<script lang="ts">
import { fontshareStore } from '$entities/Font/model/store/fontshareStore.svelte';
import type { UnifiedFont } from '$entities/Font/model/types/normalize';
import {
Content as ItemContent,
Root as ItemRoot,
Title as ItemTitle,
} from '$shared/shadcn/ui/item';
import { VirtualList } from '$shared/ui';
import { fontCollection } from '../../model';
/**
* FontList
*
* Displays a virtualized list of fonts with loading, empty, and error states.
* Uses unifiedFontStore from context for data, but can accept explicit fonts via props.
*/
interface FontListProps {
/** Font items to display (defaults to filtered fonts from store) */
fonts?: UnifiedFont[];
/** Show loading state */
loading?: boolean;
/** Show empty state when no results */
showEmpty?: boolean;
/** Custom error message to display */
errorMessage?: string;
}
let {
fonts,
loading,
showEmpty = true,
errorMessage,
}: FontListProps = $props();
// const fontshareStore = getFontshareContext();
</script>
<VirtualList items={fontCollection.filteredFonts}>
{#snippet children({ item, index })}
<ItemRoot>
<ItemContent>
<ItemTitle>{item.name}</ItemTitle>
{item.name}
</ItemContent>
</ItemRoot>
{/snippet}
</VirtualList>
{#each fontshareStore.fonts as font (font.id)}
<ItemRoot>
<ItemContent>
<ItemTitle>{font.name}</ItemTitle>
<span class="text-xs text-muted-foreground">
{font.category}{font.provider}
</span>
</ItemContent>
</ItemRoot>
{/each}

View File

@@ -31,7 +31,7 @@ let {
}: Props = $props();
let open = $state(false);
let triggerRef = $state<HTMLInputElement>();
let triggerRef = $state<HTMLInputElement>(null!);
const contentId = useId(id);
function closeAndFocusTrigger() {