2020-03-12 14:29:21 +01:00
|
|
|
<template>
|
2022-08-26 16:08:58 +02:00
|
|
|
<aside class="mb-6">
|
2020-06-19 19:27:10 +02:00
|
|
|
<ul>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuSection
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Account')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.ACCOUNT_SETTINGS }"
|
|
|
|
>
|
2020-06-25 11:36:35 +02:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('General')"
|
2020-06-25 11:36:35 +02:00
|
|
|
:to="{ name: RouteName.ACCOUNT_SETTINGS_GENERAL }"
|
|
|
|
/>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Preferences')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.PREFERENCES }"
|
|
|
|
/>
|
2020-06-25 11:36:35 +02:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Notifications')"
|
2020-06-25 11:36:35 +02:00
|
|
|
:to="{ name: RouteName.NOTIFICATIONS }"
|
|
|
|
/>
|
2023-02-15 19:31:23 +01:00
|
|
|
<SettingMenuItem
|
|
|
|
:title="t('Apps')"
|
|
|
|
:to="{ name: RouteName.AUTHORIZED_APPS }"
|
|
|
|
/>
|
2020-06-25 11:36:35 +02:00
|
|
|
</SettingMenuSection>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuSection
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Profiles')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.IDENTITIES }"
|
|
|
|
>
|
2020-06-25 11:36:35 +02:00
|
|
|
<SettingMenuItem
|
|
|
|
v-for="profile in identities"
|
|
|
|
:key="profile.preferredUsername"
|
|
|
|
:title="profile.preferredUsername"
|
|
|
|
:to="{
|
|
|
|
name: RouteName.UPDATE_IDENTITY,
|
|
|
|
params: { identityName: profile.preferredUsername },
|
|
|
|
}"
|
|
|
|
/>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('New profile')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.CREATE_IDENTITY }"
|
|
|
|
/>
|
2020-06-25 11:36:35 +02:00
|
|
|
</SettingMenuSection>
|
2020-06-19 19:27:10 +02:00
|
|
|
<SettingMenuSection
|
2020-06-25 11:36:35 +02:00
|
|
|
v-if="
|
2022-07-12 10:55:28 +02:00
|
|
|
currentUser?.role &&
|
2020-06-25 11:36:35 +02:00
|
|
|
[ICurrentUserRole.MODERATOR, ICurrentUserRole.ADMINISTRATOR].includes(
|
2022-07-12 10:55:28 +02:00
|
|
|
currentUser?.role
|
2020-06-25 11:36:35 +02:00
|
|
|
)
|
|
|
|
"
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Moderation')"
|
2020-06-25 11:36:35 +02:00
|
|
|
:to="{ name: RouteName.MODERATION }"
|
|
|
|
>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Reports')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.REPORTS }"
|
|
|
|
/>
|
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Moderation log')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.REPORT_LOGS }"
|
|
|
|
/>
|
2022-07-12 10:55:28 +02:00
|
|
|
<SettingMenuItem :title="t('Users')" :to="{ name: RouteName.USERS }" />
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Profiles')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.PROFILES }"
|
|
|
|
/>
|
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Groups')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.ADMIN_GROUPS }"
|
|
|
|
/>
|
2020-06-25 11:36:35 +02:00
|
|
|
</SettingMenuSection>
|
|
|
|
<SettingMenuSection
|
2022-07-12 10:55:28 +02:00
|
|
|
v-if="currentUser?.role == ICurrentUserRole.ADMINISTRATOR"
|
|
|
|
:title="t('Admin')"
|
2020-06-25 11:36:35 +02:00
|
|
|
:to="{ name: RouteName.ADMIN }"
|
|
|
|
>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Dashboard')"
|
2020-11-30 10:24:11 +01:00
|
|
|
:to="{ name: RouteName.ADMIN_DASHBOARD }"
|
|
|
|
/>
|
2020-06-25 11:36:35 +02:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Instance settings')"
|
2020-06-25 11:36:35 +02:00
|
|
|
:to="{ name: RouteName.ADMIN_SETTINGS }"
|
|
|
|
/>
|
2020-11-30 10:24:11 +01:00
|
|
|
<SettingMenuItem
|
2022-07-12 10:55:28 +02:00
|
|
|
:title="t('Federation')"
|
2021-12-28 11:42:08 +01:00
|
|
|
:to="{ name: RouteName.INSTANCES }"
|
2020-11-30 10:24:11 +01:00
|
|
|
/>
|
2020-06-25 11:36:35 +02:00
|
|
|
</SettingMenuSection>
|
2020-06-19 19:27:10 +02:00
|
|
|
</ul>
|
|
|
|
</aside>
|
2020-03-12 14:29:21 +01:00
|
|
|
</template>
|
2022-07-12 10:55:28 +02:00
|
|
|
<script lang="ts" setup>
|
2020-11-27 19:27:44 +01:00
|
|
|
import { ICurrentUserRole } from "@/types/enums";
|
2020-06-25 11:36:35 +02:00
|
|
|
import SettingMenuSection from "./SettingMenuSection.vue";
|
|
|
|
import SettingMenuItem from "./SettingMenuItem.vue";
|
|
|
|
|
|
|
|
import RouteName from "../../router/name";
|
2022-07-12 10:55:28 +02:00
|
|
|
import { useCurrentUserClient } from "@/composition/apollo/user";
|
|
|
|
import { useCurrentUserIdentities } from "@/composition/apollo/actor";
|
|
|
|
import { useI18n } from "vue-i18n";
|
2020-07-09 17:24:28 +02:00
|
|
|
|
2022-07-12 10:55:28 +02:00
|
|
|
const { currentUser } = useCurrentUserClient();
|
|
|
|
const { identities } = useCurrentUserIdentities();
|
2020-06-25 11:36:35 +02:00
|
|
|
|
2022-07-12 10:55:28 +02:00
|
|
|
const { t } = useI18n({ useScope: "global" });
|
2020-02-18 08:57:00 +01:00
|
|
|
</script>
|
2020-06-17 15:54:24 +02:00
|
|
|
<style lang="scss" scoped>
|
2022-07-12 10:55:28 +02:00
|
|
|
:deep(a) {
|
2020-06-17 15:54:24 +02:00
|
|
|
text-decoration: none;
|
|
|
|
}
|
|
|
|
</style>
|