Files
Modrinth-plus/apps/frontend/src/pages/settings.vue
Prospector cefa7b90ed Add noindex to pages that should be private (#5257)
* Add noindex to pages that should be private

* fix unused
2026-01-30 13:04:19 -08:00

109 lines
2.6 KiB
Vue

<template>
<div>
<div class="normal-page no-sidebar">
<h1>{{ formatMessage(commonMessages.settingsLabel) }}</h1>
</div>
<div class="normal-page">
<div class="normal-page__sidebar">
<NavStack
:items="
[
{ type: 'heading', label: 'Display' },
{
link: '/settings',
label: formatMessage(commonSettingsMessages.appearance),
icon: PaintbrushIcon,
},
{
link: '/settings/language',
label: formatMessage(commonSettingsMessages.language),
icon: LanguagesIcon,
badge: `${formatMessage(commonMessages.beta)}`,
},
auth.user ? { type: 'heading', label: 'Account' } : null,
auth.user
? {
link: '/settings/profile',
label: formatMessage(commonSettingsMessages.profile),
icon: UserIcon,
}
: null,
auth.user
? {
link: '/settings/account',
label: formatMessage(commonSettingsMessages.account),
icon: ShieldIcon,
}
: null,
auth.user
? {
link: '/settings/authorizations',
label: formatMessage(commonSettingsMessages.authorizedApps),
icon: GridIcon,
}
: null,
auth.user
? {
link: '/settings/sessions',
label: formatMessage(commonSettingsMessages.sessions),
icon: MonitorSmartphoneIcon,
}
: null,
auth.user
? {
link: '/settings/billing',
label: formatMessage(commonSettingsMessages.billing),
icon: CardIcon,
}
: null,
auth.user ? { type: 'heading', label: 'Developer' } : null,
auth.user
? {
link: '/settings/pats',
label: formatMessage(commonSettingsMessages.pats),
icon: KeyIcon,
}
: null,
auth.user
? {
link: '/settings/applications',
label: formatMessage(commonSettingsMessages.applications),
icon: ServerIcon,
}
: null,
].filter(Boolean)
"
/>
</div>
<div class="normal-page__content mt-3 lg:mt-0">
<NuxtPage :route="route" />
</div>
</div>
</div>
</template>
<script setup>
import {
CardIcon,
GridIcon,
KeyIcon,
LanguagesIcon,
MonitorSmartphoneIcon,
PaintbrushIcon,
ServerIcon,
ShieldIcon,
UserIcon,
} from '@modrinth/assets'
import { commonMessages, commonSettingsMessages, useVIntl } from '@modrinth/ui'
import NavStack from '~/components/ui/NavStack.vue'
const { formatMessage } = useVIntl()
const route = useNativeRoute()
const auth = await useAuth()
useSeoMeta({
robots: 'noindex',
})
</script>