hippofish/packages/client/src/pages/announcements.vue

118 lines
2.6 KiB
Vue
Raw Normal View History

<template>
2023-04-08 02:01:42 +02:00
<MkStickyContainer>
<template #header
><MkPageHeader :actions="headerActions" :tabs="headerTabs"
/></template>
<MkSpacer :content-max="800">
<MkPagination
ref="paginationEl"
2023-04-08 02:01:42 +02:00
v-slot="{ items }"
:pagination="pagination"
class="ruryvtyk _gaps_m"
2023-04-08 02:01:42 +02:00
>
<section
v-for="announcement in items"
2023-04-08 02:01:42 +02:00
:key="announcement.id"
class="announcement _panel"
2023-04-08 02:01:42 +02:00
>
<div class="_title">
<h3>
<span v-if="isSignedIn && !announcement.isRead">
🆕&nbsp;
</span>
{{ announcement.title }}
</h3>
<MkTime :time="announcement.createdAt" />
<div v-if="announcement.updatedAt">
{{ i18n.ts.updatedAt }}:
<MkTime :time="announcement.createdAt" />
</div>
2023-04-08 02:01:42 +02:00
</div>
2023-08-09 03:03:21 +02:00
<hr class="_seperator" />
2023-04-08 02:01:42 +02:00
<div class="_content">
<Mfm :text="announcement.text" />
<img
v-if="announcement.imageUrl"
:src="announcement.imageUrl"
/>
</div>
<div
v-if="isSignedIn && !announcement.isRead"
class="_footer"
>
<MkButton primary @click="read(announcement.id)"
><i :class="icon('ph-check')"></i>
2023-04-08 02:01:42 +02:00
{{ i18n.ts.gotIt }}</MkButton
>
</div>
</section>
</MkPagination>
</MkSpacer>
</MkStickyContainer>
</template>
<script lang="ts" setup>
2023-09-02 01:27:33 +02:00
import { computed, ref } from "vue";
2023-04-08 02:01:42 +02:00
import MkPagination from "@/components/MkPagination.vue";
import MkButton from "@/components/MkButton.vue";
import * as os from "@/os";
import { i18n } from "@/i18n";
import { definePageMetadata } from "@/scripts/page-metadata";
import icon from "@/scripts/icon";
2024-03-07 03:06:45 +01:00
import { isSignedIn } from "@/me";
const pagination = {
2023-04-08 02:01:42 +02:00
endpoint: "announcements" as const,
limit: 10,
};
const paginationEl = ref<InstanceType<typeof MkPagination>>();
function read(id: string) {
if (!paginationEl.value) return;
paginationEl.value.updateItem(id, (announcement) => {
announcement.isRead = true;
return announcement;
});
os.api("i/read-announcement", { announcementId: id });
}
const headerActions = computed(() => []);
const headerTabs = computed(() => []);
definePageMetadata({
title: i18n.ts.announcements,
icon: `${icon("ph-megaphone-simple")}`,
});
</script>
<style lang="scss" scoped>
.ruryvtyk {
> .announcement {
2021-10-24 17:13:54 +02:00
&:not(:last-child) {
margin-bottom: var(--margin);
}
> ._title {
padding: 0.5rem 2rem !important;
}
> ._seperator {
margin: 1rem;
}
> ._content {
padding: 0 2rem !important;
> img {
display: block;
max-height: 300px;
max-width: 100%;
2023-04-17 04:04:28 +02:00
border-radius: 10px;
margin-top: 1rem;
}
}
}
}
</style>