forked from didirus/AstralRinth
* Begin Work * More work * Fix lint error * More work on label * Fix mistake * Finish adding delete pat modal keys * More label and button * More label keys * Fix lint error * Description key * Finish page * Forgot this * Fix lint error * Add to navstack * Apply suggestions from brawaru * Normalization * Re-organize PATs page messages (#10) - Group messages by their usage - Fix spelling mistakes in some of the property names and keys - Change some of the keys to conform to keying conventions - Change variable name in token.expires-in message to inTime * Regenrate index.json --------- Co-authored-by: Sasha Sorokin <10401817+brawaru@users.noreply.github.com>
70 lines
2.3 KiB
Vue
70 lines
2.3 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/authorizations" label="Authorizations">
|
|
<UsersIcon />
|
|
</NavStackItem>
|
|
<NavStackItem link="/settings/sessions" :label="formatMessage(messages.sessionsTitle)">
|
|
<ShieldIcon />
|
|
</NavStackItem>
|
|
</template>
|
|
<template v-if="auth.user">
|
|
<h3>Developer Settings</h3>
|
|
<NavStackItem link="/settings/pats" :label="formatMessage(messages.patsTitle)">
|
|
<KeyIcon />
|
|
</NavStackItem>
|
|
<NavStackItem link="/settings/applications" label="Applications">
|
|
<ServerIcon />
|
|
</NavStackItem>
|
|
</template>
|
|
</NavStack>
|
|
</aside>
|
|
</div>
|
|
<div class="normal-page__content">
|
|
<NuxtPage :route="route" />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<script setup>
|
|
import { UsersIcon, ServerIcon } from 'omorphia'
|
|
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 ShieldIcon from '~/assets/images/utils/shield.svg'
|
|
import KeyIcon from '~/assets/images/utils/key.svg'
|
|
import LanguagesIcon from '~/assets/images/utils/languages.svg'
|
|
|
|
const { formatMessage } = useVIntl()
|
|
|
|
const messages = defineMessages({
|
|
sessionsTitle: {
|
|
id: 'settings.sessions.title',
|
|
defaultMessage: 'Sessions',
|
|
},
|
|
patsTitle: {
|
|
id: 'settings.pats.title',
|
|
defaultMessage: 'PATs',
|
|
},
|
|
})
|
|
|
|
const route = useRoute()
|
|
const auth = await useAuth()
|
|
const isStaging = useRuntimeConfig().public.siteUrl !== 'https://modrinth.com'
|
|
</script>
|