elk/components/main/MainContent.vue

42 lines
1.1 KiB
Vue
Raw Normal View History

2022-11-26 13:58:10 +01:00
<script setup lang="ts">
defineProps<{
2022-12-29 13:21:00 +01:00
/** Show the back button on small screens */
backOnSmallScreen?: boolean
2022-12-29 13:21:00 +01:00
/** Show the back button on both small and big screens */
back?: boolean
2022-11-26 13:58:10 +01:00
}>()
</script>
<template>
2022-12-30 23:45:34 +01:00
<div>
2022-11-23 09:08:49 +01:00
<div
2022-12-30 23:45:34 +01:00
sticky top-0 z10 backdrop-blur
pt="[env(safe-area-inset-top,0)]"
border="b base" bg="[rgba(var(--c-bg-base-rgb),0.7)]"
2022-11-23 09:08:49 +01:00
>
<div flex justify-between px5 py4>
2022-12-04 15:26:42 +01:00
<div flex gap-3 items-center overflow-hidden>
<NuxtLink
2022-12-29 13:21:00 +01:00
v-if="backOnSmallScreen || back" flex="~ gap1" items-center btn-text p-0
:class="{ 'lg:hidden': backOnSmallScreen }"
@click="$router.go(-1)"
>
2022-11-29 13:06:08 +01:00
<div i-ri:arrow-left-line />
2022-11-26 13:58:10 +01:00
</NuxtLink>
2022-12-04 15:26:42 +01:00
<div truncate>
<slot name="title" />
</div>
2022-12-04 15:26:42 +01:00
<div h-7 w-1px />
</div>
<div flex items-center flex-shrink-0 gap-x-2>
2022-12-04 15:26:42 +01:00
<slot name="actions" />
2022-12-23 19:26:28 +01:00
<PwaBadge lg:hidden />
2022-12-26 15:17:23 +01:00
<NavUser v-if="isMastoInitialised" />
</div>
</div>
2022-11-23 09:08:49 +01:00
<slot name="header" />
</div>
2022-11-27 01:35:19 +01:00
<slot />
</div>
</template>