2023-07-12 08:23:44 +02:00
|
|
|
<template>
|
2023-07-12 09:23:54 +02:00
|
|
|
<transition name="slide-fade">
|
2023-07-12 09:36:24 +02:00
|
|
|
<div v-if="show" class="_panel _shadow _acrylic" :class="$style.root">
|
2023-07-12 09:23:54 +02:00
|
|
|
<div :class="$style.icon">
|
2023-10-17 03:57:20 +02:00
|
|
|
<i :class="icon('ph-hand-heart ph-5x', false)" />
|
2023-07-12 08:23:44 +02:00
|
|
|
</div>
|
2023-07-12 09:23:54 +02:00
|
|
|
<div :class="$style.main">
|
|
|
|
<div :class="$style.title">
|
2023-07-15 23:21:17 +02:00
|
|
|
{{ i18n.ts._aboutFirefish.donateTitle }}
|
2023-07-12 09:23:54 +02:00
|
|
|
</div>
|
|
|
|
<div :class="$style.text">
|
2023-07-15 23:21:17 +02:00
|
|
|
{{ i18n.ts._aboutFirefish.pleaseDonateToFirefish }}
|
2024-03-07 02:52:32 +01:00
|
|
|
<p v-if="instance.donationLink">
|
2023-07-12 09:23:54 +02:00
|
|
|
{{
|
2023-07-15 23:21:17 +02:00
|
|
|
i18n.t("_aboutFirefish.pleaseDonateToHost", {
|
2023-07-12 09:23:54 +02:00
|
|
|
host: hostname,
|
|
|
|
})
|
|
|
|
}}
|
|
|
|
</p>
|
|
|
|
</div>
|
2023-07-13 08:22:58 +02:00
|
|
|
<div class="_flexList" style="gap: 0.6rem">
|
2023-07-12 09:23:54 +02:00
|
|
|
<MkButton
|
|
|
|
primary
|
|
|
|
@click="
|
2023-07-15 23:21:17 +02:00
|
|
|
openExternal('https://opencollective.com/firefish')
|
2023-07-12 09:23:54 +02:00
|
|
|
"
|
2023-07-15 23:21:17 +02:00
|
|
|
>{{ i18n.ts._aboutFirefish.donate }}</MkButton
|
2023-07-12 09:23:54 +02:00
|
|
|
>
|
|
|
|
<MkButton
|
2024-03-07 02:52:32 +01:00
|
|
|
v-if="instance.donationLink"
|
2023-07-12 10:05:16 +02:00
|
|
|
gradate
|
2024-04-10 18:48:35 +02:00
|
|
|
@click="openExternal(instance.donationLink!)"
|
2023-07-12 09:23:54 +02:00
|
|
|
>{{
|
2023-07-15 23:21:17 +02:00
|
|
|
i18n.t("_aboutFirefish.donateHost", {
|
2023-07-12 09:23:54 +02:00
|
|
|
host: hostname,
|
|
|
|
})
|
|
|
|
}}</MkButton
|
|
|
|
>
|
|
|
|
</div>
|
|
|
|
<div class="_flexList" style="margin-top: 0.6rem">
|
|
|
|
<MkButton @click="close">{{
|
|
|
|
i18n.ts.remindMeLater
|
|
|
|
}}</MkButton>
|
|
|
|
<MkButton @click="neverShow">{{
|
|
|
|
i18n.ts.neverShow
|
|
|
|
}}</MkButton>
|
|
|
|
</div>
|
2023-07-12 08:23:44 +02:00
|
|
|
</div>
|
2023-07-14 01:53:53 +02:00
|
|
|
<button
|
|
|
|
class="_button"
|
|
|
|
:class="$style.close"
|
2024-04-03 06:36:09 +02:00
|
|
|
:aria-label="i18n.ts.close"
|
2023-07-17 00:32:32 +02:00
|
|
|
@click="close"
|
2023-07-14 01:53:53 +02:00
|
|
|
>
|
2023-10-17 03:57:20 +02:00
|
|
|
<i :class="icon('ph-x')"></i>
|
2023-07-12 09:23:54 +02:00
|
|
|
</button>
|
2023-07-12 08:23:44 +02:00
|
|
|
</div>
|
2023-07-12 09:23:54 +02:00
|
|
|
</transition>
|
2023-07-12 08:23:44 +02:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
2023-07-17 00:32:32 +02:00
|
|
|
import { nextTick, ref } from "vue";
|
2023-07-12 08:23:44 +02:00
|
|
|
import MkButton from "@/components/MkButton.vue";
|
|
|
|
import { host } from "@/config";
|
|
|
|
import { i18n } from "@/i18n";
|
|
|
|
import * as os from "@/os";
|
|
|
|
import { instance } from "@/instance";
|
2023-10-17 03:57:20 +02:00
|
|
|
import icon from "@/scripts/icon";
|
2023-07-12 08:23:44 +02:00
|
|
|
|
2023-07-17 00:32:32 +02:00
|
|
|
const show = ref(false);
|
2023-07-12 09:23:54 +02:00
|
|
|
|
2023-07-12 08:23:44 +02:00
|
|
|
const emit = defineEmits<{
|
|
|
|
(ev: "closed"): void;
|
|
|
|
}>();
|
|
|
|
|
2024-04-10 18:48:35 +02:00
|
|
|
const hostname =
|
|
|
|
instance.name?.length && instance.name?.length < 38 ? instance.name : host;
|
2023-07-12 08:23:44 +02:00
|
|
|
|
|
|
|
const zIndex = os.claimZIndex("low");
|
|
|
|
|
2023-07-12 09:56:40 +02:00
|
|
|
function slideIn() {
|
2023-07-13 08:22:58 +02:00
|
|
|
show.value = false;
|
|
|
|
nextTick(() => {
|
|
|
|
show.value = true;
|
|
|
|
});
|
2023-07-12 09:56:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
slideIn();
|
|
|
|
|
2023-07-12 08:23:44 +02:00
|
|
|
function close() {
|
|
|
|
localStorage.setItem("latestDonationInfoShownAt", Date.now().toString());
|
|
|
|
emit("closed");
|
2023-07-12 09:23:54 +02:00
|
|
|
show.value = false;
|
2023-07-12 08:23:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function neverShow() {
|
|
|
|
localStorage.setItem("neverShowDonationInfo", "true");
|
|
|
|
close();
|
|
|
|
}
|
|
|
|
|
2024-04-10 18:48:35 +02:00
|
|
|
function openExternal(link: string) {
|
2023-07-12 08:23:44 +02:00
|
|
|
window.open(link, "_blank");
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
2023-07-12 09:36:24 +02:00
|
|
|
<style lang="scss" scoped>
|
2023-07-12 09:45:53 +02:00
|
|
|
.slide-fade-enter-from {
|
2023-07-13 08:22:58 +02:00
|
|
|
opacity: 0;
|
|
|
|
transform: translateY(100%);
|
2023-07-12 09:45:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
.slide-fade-enter-active {
|
2023-07-13 08:22:58 +02:00
|
|
|
transition:
|
|
|
|
opacity 0.5s,
|
|
|
|
transform 0.5s ease-out;
|
2023-07-12 09:45:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
.slide-fade-enter-to {
|
2023-07-13 08:22:58 +02:00
|
|
|
opacity: 1;
|
|
|
|
transform: translateY(0);
|
2023-07-12 09:36:24 +02:00
|
|
|
}
|
2023-07-12 09:45:53 +02:00
|
|
|
|
|
|
|
.slide-fade-leave-from {
|
2023-07-13 08:22:58 +02:00
|
|
|
opacity: 1;
|
|
|
|
transform: translateY(0);
|
2023-07-12 09:45:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
.slide-fade-leave-active {
|
2023-07-13 08:22:58 +02:00
|
|
|
transition:
|
|
|
|
opacity 0.5s,
|
|
|
|
transform 0.5s ease-out;
|
2023-07-12 09:36:24 +02:00
|
|
|
}
|
2023-07-12 09:45:53 +02:00
|
|
|
|
2023-07-12 09:36:24 +02:00
|
|
|
.slide-fade-leave-to {
|
2023-07-13 08:22:58 +02:00
|
|
|
opacity: 0;
|
|
|
|
transform: translateY(100%);
|
2023-07-12 09:36:24 +02:00
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
2023-07-12 08:23:44 +02:00
|
|
|
<style lang="scss" module>
|
|
|
|
.root {
|
2023-07-14 02:38:44 +02:00
|
|
|
background-color: var(--windowHeader);
|
2023-07-12 08:23:44 +02:00
|
|
|
position: fixed;
|
|
|
|
z-index: v-bind(zIndex);
|
|
|
|
bottom: var(--margin);
|
2023-07-12 09:36:24 +02:00
|
|
|
left: 2%;
|
|
|
|
bottom: 2%;
|
2023-07-12 08:23:44 +02:00
|
|
|
margin: auto;
|
|
|
|
box-sizing: border-box;
|
|
|
|
width: calc(100% - (var(--margin) * 2));
|
|
|
|
max-width: 500px;
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
|
|
|
|
.icon {
|
|
|
|
text-align: center;
|
|
|
|
padding-top: 25px;
|
|
|
|
width: 100px;
|
|
|
|
color: var(--accent);
|
|
|
|
}
|
|
|
|
|
|
|
|
@media (max-width: 500px) {
|
|
|
|
.icon {
|
|
|
|
width: 80px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@media (max-width: 450px) {
|
|
|
|
.icon {
|
|
|
|
width: 70px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.main {
|
|
|
|
padding: 25px 25px 25px 0;
|
|
|
|
flex: 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
.close {
|
|
|
|
position: absolute;
|
|
|
|
top: 8px;
|
|
|
|
right: 8px;
|
|
|
|
padding: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.title {
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
.text {
|
|
|
|
margin: 0.7em 0 1em 0;
|
|
|
|
}
|
|
|
|
</style>
|