pronounss/frontend/src/routes/@[username]/+page.svelte

106 lines
3.1 KiB
Svelte
Raw Normal View History

2023-03-11 01:36:30 +01:00
<script lang="ts">
import { marked } from "marked";
import sanitizeHtml from "sanitize-html";
import type { PageData } from "./$types";
import { Alert, Icon } from "sveltestrap";
import FieldCard from "$lib/components/FieldCard.svelte";
2023-03-11 01:36:30 +01:00
import StatusIcon from "$lib/components/StatusIcon.svelte";
2023-03-11 16:52:48 +01:00
import PronounLink from "$lib/components/PronounLink.svelte";
import PartialMemberCard from "$lib/components/PartialMemberCard.svelte";
import FallbackImage from "$lib/components/FallbackImage.svelte";
import { userStore } from "$lib/store";
2023-03-11 01:36:30 +01:00
export let data: PageData;
let bio: string | null;
$: bio = data.bio ? sanitizeHtml(marked.parse(data.bio)) : null;
</script>
<svelte:head>
<title>@{data.name} - pronouns.cc</title>
</svelte:head>
<div class="container">
{#if $userStore && $userStore.id === data.id}
<Alert color="secondary" fade={false}>
You are currently viewing your <strong>public</strong> profile.
<br /><a href="/edit/profile">Edit your profile</a>
</Alert>
{/if}
<div class="grid row-gap-3">
2023-03-11 01:36:30 +01:00
<div class="row">
2023-03-11 16:52:48 +01:00
<div class="col-md text-center">
<FallbackImage width={200} urls={data.avatar_urls} alt="Avatar for @{data.name}" />
2023-03-11 16:52:48 +01:00
</div>
<div class="col-md">
2023-03-11 01:36:30 +01:00
{#if data.display_name}
<div>
<h2>{data.display_name}</h2>
<h5 class="text-body-secondary">@{data.name}</h5>
</div>
2023-03-11 01:36:30 +01:00
{:else}
<h2>@{data.name}</h2>
{/if}
{#if bio}
<hr />
2023-03-11 01:36:30 +01:00
<p>{@html bio}</p>
{/if}
</div>
{#if data.links.length > 0}
<div class="col-md d-flex align-items-center">
<ul class="list-unstyled">
2023-03-11 01:36:30 +01:00
{#each data.links as link}
<li><Icon name="globe" /> <a href={link}>{link}</a></li>
2023-03-11 01:36:30 +01:00
{/each}
</ul>
</div>
{/if}
2023-03-11 01:36:30 +01:00
</div>
<div class="row row-cols-1 row-cols-sm-2 row-cols-md-3">
{#if data.names.length > 0}
<div class="col-md">
<h4>Names</h4>
<ul class="list-unstyled">
{#each data.names as name}
<li><StatusIcon status={name.status} /> {name.value}</li>
{/each}
</ul>
</div>
{/if}
{#if data.pronouns.length > 0}
<div class="col-md">
<h4>Pronouns</h4>
<ul class="list-unstyled">
{#each data.pronouns as pronouns}
<li>
<StatusIcon status={pronouns.status} />
<PronounLink {pronouns} />
</li>
{/each}
</ul>
</div>
{/if}
{#each data.fields as field}
<div class="col">
<FieldCard {field} />
</div>
{/each}
</div>
{#if data.members.length > 0}
<div class="row">
<div class="col">
<hr />
<h2>Members</h2>
</div>
</div>
<div class="row row-cols-1 row-cols-sm-2 row-cols-md-4 text-center">
{#each data.members as member}
<PartialMemberCard user={data} {member} />
{/each}
</div>
{/if}
</div>
2023-03-11 01:36:30 +01:00
</div>