53 lines
1.8 KiB
Vue
53 lines
1.8 KiB
Vue
<template>
|
|
<div class="normal-page">
|
|
<div class="normal-page__sidebar">
|
|
<aside class="universal-card">
|
|
<h1>Settings</h1>
|
|
<NavStack>
|
|
<NavStackItem link="/settings" label="Appearance">
|
|
<PaintbrushIcon />
|
|
</NavStackItem>
|
|
<NavStackItem v-if="isStaging" link="/settings/language" label="Language">
|
|
<LanguagesIcon />
|
|
</NavStackItem>
|
|
<template v-if="auth.user">
|
|
<h3>User settings</h3>
|
|
<NavStackItem link="/settings/account" label="Account">
|
|
<UserIcon />
|
|
</NavStackItem>
|
|
<NavStackItem link="/settings/pats" label="PATs">
|
|
<KeyIcon />
|
|
</NavStackItem>
|
|
<NavStackItem link="/settings/sessions" label="Sessions">
|
|
<ShieldIcon />
|
|
</NavStackItem>
|
|
<NavStackItem link="/settings/monetization" label="Monetization">
|
|
<CurrencyIcon />
|
|
</NavStackItem>
|
|
</template>
|
|
</NavStack>
|
|
</aside>
|
|
</div>
|
|
<div class="normal-page__content">
|
|
<NuxtPage :route="route" />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<script setup>
|
|
import NavStack from '~/components/ui/NavStack.vue'
|
|
import NavStackItem from '~/components/ui/NavStackItem.vue'
|
|
|
|
import PaintbrushIcon from '~/assets/images/utils/paintbrush.svg'
|
|
import UserIcon from '~/assets/images/utils/user.svg'
|
|
import CurrencyIcon from '~/assets/images/utils/currency.svg'
|
|
import ShieldIcon from '~/assets/images/utils/shield.svg'
|
|
import KeyIcon from '~/assets/images/utils/key.svg'
|
|
import LanguagesIcon from '~/assets/images/utils/languages.svg'
|
|
|
|
const route = useRoute()
|
|
const auth = await useAuth()
|
|
const isStaging = useRuntimeConfig().public.siteUrl !== 'https://modrinth.com'
|
|
</script>
|
|
|
|
<style lang="scss" scoped></style>
|