123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- <!--
- - @copyright 2023 Christopher Ng <chrng8@gmail.com>
- -
- - @author Christopher Ng <chrng8@gmail.com>
- -
- - @license AGPL-3.0-or-later
- -
- - This program is free software: you can redistribute it and/or modify
- - it under the terms of the GNU Affero General Public License as
- - published by the Free Software Foundation, either version 3 of the
- - License, or (at your option) any later version.
- -
- - This program is distributed in the hope that it will be useful,
- - but WITHOUT ANY WARRANTY; without even the implied warranty of
- - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- - GNU Affero General Public License for more details.
- -
- - You should have received a copy of the GNU Affero General Public License
- - along with this program. If not, see <http://www.gnu.org/licenses/>.
- -
- -->
-
- <template>
- <NcHeaderMenu id="user-menu"
- class="user-menu"
- :aria-label="t('core', 'Open settings menu')">
- <template #trigger>
- <NcAvatar class="user-menu__avatar"
- :disable-menu="true"
- :disable-tooltip="true"
- :user="userId" />
- </template>
- <nav class="user-menu__nav"
- :aria-label="t('core', 'Settings menu')">
- <ul>
- <UserMenuEntry v-for="entry in settingsNavEntries"
- v-bind="entry"
- :key="entry.id" />
- </ul>
- </nav>
- </NcHeaderMenu>
- </template>
-
- <script>
- import { emit } from '@nextcloud/event-bus'
- import { getCurrentUser } from '@nextcloud/auth'
- import { loadState } from '@nextcloud/initial-state'
-
- import NcAvatar from '@nextcloud/vue/dist/Components/NcAvatar.js'
- import NcHeaderMenu from '@nextcloud/vue/dist/Components/NcHeaderMenu.js'
-
- import UserMenuEntry from '../components/UserMenu/UserMenuEntry.vue'
-
- const settingsNavEntries = loadState('core', 'settingsNavEntries', [])
-
- export default {
- name: 'UserMenu',
-
- components: {
- NcAvatar,
- NcHeaderMenu,
- UserMenuEntry,
- },
-
- data() {
- return {
- settingsNavEntries,
- userId: getCurrentUser()?.uid,
- }
- },
-
- mounted() {
- emit('core:user-menu:mounted')
- },
- }
- </script>
-
- <style lang="scss" scoped>
- .user-menu {
- margin-right: 12px;
-
- &:deep {
- .header-menu {
- &__trigger {
- opacity: 1 !important;
- &:focus-visible {
- .user-menu__avatar {
- border: 2px solid var(--color-primary-element);
- }
- }
- }
-
- &__carret {
- display: none !important;
- }
-
- &__content {
- width: fit-content !important;
- }
- }
- }
-
- &__avatar {
- &:active,
- &:focus,
- &:hover {
- border: 2px solid var(--color-primary-element-text);
- }
- }
-
- &__nav {
- display: flex;
- width: 100%;
-
- ul {
- display: flex;
- flex-direction: column;
- gap: 2px;
-
- &:deep {
- li {
- a,
- button {
- border-radius: 6px;
- display: inline-flex;
- align-items: center;
- height: var(--header-menu-item-height);
- color: var(--color-main-text);
- padding: 10px 8px;
- box-sizing: border-box;
- white-space: nowrap;
- position: relative;
- width: 100%;
-
- &:hover {
- background-color: var(--color-background-hover);
- }
-
- &:focus-visible {
- background-color: var(--color-background-hover) !important;
- box-shadow: inset 0 0 0 2px var(--color-primary-element) !important;
- outline: none !important;
- }
-
- &:active,
- &.active {
- background-color: var(--color-primary-element-light);
- }
-
- span {
- padding-bottom: 0;
- color: var(--color-main-text);
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- max-width: 110px;
- }
-
- img {
- width: 16px;
- height: 16px;
- margin-right: 10px;
- }
-
- img,
- svg {
- opacity: .7;
- filter: var(--background-invert-if-dark);
- }
- }
-
- // Override global button styles
- button {
- background-color: transparent;
- border: none;
- font-weight: normal;
- margin: 0;
- }
- }
- }
- }
- }
- }
- </style>
|