mirror of
https://activitypub.software/TransFem-org/Sharkey
synced 2024-12-02 10:47:28 +00:00
ae5d052274
to keep things manageable i merged a lot of one off values into just a handful of common sizes, so some parts of the ui will look different than upstream even with the "Misskey" rounding mode
74 lines
1.6 KiB
Vue
74 lines
1.6 KiB
Vue
<!--
|
|
SPDX-FileCopyrightText: syuilo and other misskey contributors
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
-->
|
|
|
|
<template>
|
|
<div>
|
|
<Transition
|
|
:enterActiveClass="defaultStore.state.animation ? $style.transition_toast_enterActive : ''"
|
|
:leaveActiveClass="defaultStore.state.animation ? $style.transition_toast_leaveActive : ''"
|
|
:enterFromClass="defaultStore.state.animation ? $style.transition_toast_enterFrom : ''"
|
|
:leaveToClass="defaultStore.state.animation ? $style.transition_toast_leaveTo : ''"
|
|
appear @afterLeave="emit('closed')"
|
|
>
|
|
<div v-if="showing" class="_acrylic" :class="$style.root" :style="{ zIndex }">
|
|
<div style="padding: 16px 24px;">
|
|
{{ message }}
|
|
</div>
|
|
</div>
|
|
</Transition>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { onMounted } from 'vue';
|
|
import * as os from '@/os.js';
|
|
import { defaultStore } from '@/store.js';
|
|
|
|
defineProps<{
|
|
message: string;
|
|
}>();
|
|
|
|
const emit = defineEmits<{
|
|
(ev: 'closed'): void;
|
|
}>();
|
|
|
|
const zIndex = os.claimZIndex('high');
|
|
let showing = $ref(true);
|
|
|
|
onMounted(() => {
|
|
window.setTimeout(() => {
|
|
showing = false;
|
|
}, 4000);
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss" module>
|
|
.transition_toast_enterActive,
|
|
.transition_toast_leaveActive {
|
|
transition: opacity 0.3s, transform 0.3s !important;
|
|
}
|
|
.transition_toast_enterFrom,
|
|
.transition_toast_leaveTo {
|
|
opacity: 0;
|
|
transform: translateY(-100%);
|
|
}
|
|
|
|
.root {
|
|
position: fixed;
|
|
left: 0;
|
|
right: 0;
|
|
top: 50px;
|
|
margin: 0 auto;
|
|
margin-top: 16px;
|
|
min-width: 300px;
|
|
max-width: calc(100% - 32px);
|
|
width: min-content;
|
|
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
|
|
border-radius: var(--radius-sm);
|
|
overflow: clip;
|
|
text-align: center;
|
|
pointer-events: none;
|
|
}
|
|
</style>
|