webcompile/src/routes/instances/+page.svelte

65 lines
1.8 KiB
Svelte
Raw Normal View History

2022-11-10 00:12:34 +05:30
<script lang="ts">
2022-11-20 23:42:38 +05:30
import { CardInner, CardOuter, LinksOuter } from "$lib/Card";
import InstanceLink from "./InstanceLink.svelte";
2022-11-10 00:12:34 +05:30
import dayjs from "dayjs";
2022-11-20 23:42:38 +05:30
import type { PageData } from "./$types";
2022-11-10 00:12:34 +05:30
export let data: PageData;
2022-08-07 19:05:50 +05:30
</script>
2022-08-24 21:37:30 +05:30
<svelte:head>
2022-09-10 21:28:19 +05:30
<title>Our instances | Project Segfault</title>
<meta name="description" content="Our collection of instances." />
2022-08-24 21:37:30 +05:30
</svelte:head>
2022-09-10 21:28:19 +05:30
<h1>Our instances</h1>
2022-11-10 00:12:34 +05:30
<div class="flex flex-col gap-4">
<CardOuter>
<div class="wrapper">
2022-11-11 19:02:29 +05:30
{#each data.status as group}
2022-11-10 00:12:34 +05:30
<h2>{group.name}</h2>
<div class="items">
{#each group.data as item}
<CardInner
title={item.name}
description={item.description}
icon={item.icon}
>
<LinksOuter>
2022-11-20 23:55:34 +05:30
<InstanceLink url={item.link} item={item.status} type="main" />
2022-11-20 23:42:38 +05:30
{#if item.us}
2022-11-20 23:55:34 +05:30
<InstanceLink url={item.us} item={item.statusUs} type="us" />
2022-11-20 23:42:38 +05:30
{/if}
2022-11-21 00:18:59 +05:30
{#if item.bp}
2022-11-20 23:55:34 +05:30
<InstanceLink url={item.backup} item={item.statusBp} type="backup" />
2022-11-20 23:42:38 +05:30
{/if}
2022-11-10 00:12:34 +05:30
</LinksOuter>
</CardInner>
{/each}
</div>
{/each}
</div>
</CardOuter>
<span>Last updated: {dayjs
.unix(data.updated)
.format("DD/MM/YYYY HH:mm:ss")}
</span>
</div>
2022-08-07 19:05:50 +05:30
<style>
2022-08-27 22:07:37 +05:30
.wrapper {
2022-08-08 10:50:03 +05:30
display: flex;
flex-direction: column;
}
2022-08-07 19:05:50 +05:30
2022-08-08 10:50:03 +05:30
.items {
display: flex;
flex-direction: row;
2022-08-27 22:07:37 +05:30
flex-wrap: wrap;
2022-08-08 10:50:03 +05:30
gap: 2rem;
}
</style>