diff --git a/src/lib/components/utils/TagList.svelte b/src/lib/components/utils/TagList.svelte index ac88464da..00af1eeb6 100644 --- a/src/lib/components/utils/TagList.svelte +++ b/src/lib/components/utils/TagList.svelte @@ -3,7 +3,7 @@ import type { Tag } from '$lib/generated/graphql'; import { queryStore, getContextClient } from '@urql/svelte'; import { Autocomplete, type AutocompleteOption, InputChip, type PopupSettings, popup } from '@skeletonlabs/skeleton'; - import { onMount } from 'svelte'; + import { afterUpdate, onMount } from 'svelte'; import TagDisplay from './TagDisplay.svelte'; const client = getContextClient(); @@ -32,11 +32,11 @@ target: 'popupAutocomplete', placement: 'bottom-start' }; - let tagList = []; - const loadTagList = () => (tagList = tags.map((t: Tag) => t.name)); + const loadTagList = tags ? () => (tagList = tags.map((t: Tag) => t.name)) : () => {}; onMount(loadTagList); + afterUpdate(loadTagList); const addTag = (tag: AutocompleteOption) => { const realTag = $getAllTags.data?.getTags?.find((t) => t.id == tag.value); @@ -55,7 +55,9 @@ const removeTag = (label: string) => { const idx = tags.findIndex((t) => t.name === label); tags = [...tags.slice(0, idx), ...tags.slice(idx + 1)]; - + if (tags.length == null) { + tags = []; + } loadTagList(); }; @@ -64,7 +66,7 @@
{#if !editable} - {#if tags.length > 0} + {#if tags && tags.length > 0}
{#each tags as tag} diff --git a/src/routes/mod/[modId]/+page.svelte b/src/routes/mod/[modId]/+page.svelte index 14b42f9c6..53869231f 100644 --- a/src/routes/mod/[modId]/+page.svelte +++ b/src/routes/mod/[modId]/+page.svelte @@ -101,7 +101,9 @@

{$mod.data.mod.name}

{#if canUserEdit} -