49 lines
1.4 KiB
Vue
49 lines
1.4 KiB
Vue
<script setup>
|
|
import { computed } from 'vue';
|
|
import { useI18n } from 'vue-i18n';
|
|
import SettingsHeader from './SettingsHeader.vue';
|
|
|
|
const props = defineProps({
|
|
headerTitle: { type: String, default: '' },
|
|
headerButtonText: { type: String, default: '' },
|
|
icon: { type: String, default: '' },
|
|
keepAlive: { type: Boolean, default: true },
|
|
newButtonRoutes: { type: Array, default: () => [] },
|
|
showBackButton: { type: Boolean, default: false },
|
|
backUrl: { type: [String, Object], default: '' },
|
|
showSidemenuIcon: { type: Boolean, default: true },
|
|
});
|
|
|
|
const { t } = useI18n();
|
|
|
|
const showNewButton = computed(
|
|
() => props.newButtonRoutes.length && !props.showBackButton
|
|
);
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
class="flex flex-1 h-full justify-between flex-col m-0 bg-n-background overflow-auto"
|
|
>
|
|
<div class="max-w-6xl mx-auto w-full h-full">
|
|
<SettingsHeader
|
|
button-route="new"
|
|
:icon="icon"
|
|
:header-title="t(headerTitle)"
|
|
:button-text="t(headerButtonText)"
|
|
:show-back-button="showBackButton"
|
|
:back-url="backUrl"
|
|
:show-new-button="showNewButton"
|
|
:show-sidemenu-icon="showSidemenuIcon"
|
|
/>
|
|
|
|
<router-view v-slot="{ Component }" class="px-5">
|
|
<component :is="Component" v-if="!keepAlive" :key="$route.fullPath" />
|
|
<keep-alive v-else>
|
|
<component :is="Component" :key="$route.fullPath" />
|
|
</keep-alive>
|
|
</router-view>
|
|
</div>
|
|
</div>
|
|
</template>
|