frontend/src/components/home/navigation.vue

194 lines
3.8 KiB
Vue
Raw Normal View History

<template>
2024-02-07 11:18:19 +00:00
<aside
:class="{'is-active': baseStore.menuActive}"
class="menu-container"
>
<nav class="menu top-menu">
2024-02-07 11:18:19 +00:00
<router-link
:to="{name: 'home'}"
class="logo"
>
<Logo
width="164"
height="48"
/>
</router-link>
2023-04-03 10:09:58 +00:00
<menu class="menu-list other-menu-items">
<li>
2024-02-07 11:18:19 +00:00
<router-link
v-shortcut="'g o'"
:to="{ name: 'home'}"
>
2022-11-18 12:59:38 +00:00
<span class="menu-item-icon icon">
2024-02-07 11:18:19 +00:00
<icon icon="calendar" />
</span>
{{ $t('navigation.overview') }}
</router-link>
</li>
<li>
2024-02-07 11:18:19 +00:00
<router-link
v-shortcut="'g u'"
:to="{ name: 'tasks.range'}"
>
2022-11-18 12:59:38 +00:00
<span class="menu-item-icon icon">
2024-02-07 11:18:19 +00:00
<icon :icon="['far', 'calendar-alt']" />
</span>
{{ $t('navigation.upcoming') }}
</router-link>
</li>
<li>
2024-02-07 11:18:19 +00:00
<router-link
v-shortcut="'g p'"
:to="{ name: 'projects.index'}"
>
2022-11-18 12:59:38 +00:00
<span class="menu-item-icon icon">
2024-02-07 11:18:19 +00:00
<icon icon="layer-group" />
</span>
{{ $t('project.projects') }}
</router-link>
</li>
<li>
2024-02-07 11:18:19 +00:00
<router-link
v-shortcut="'g a'"
:to="{ name: 'labels.index'}"
>
2022-11-18 12:59:38 +00:00
<span class="menu-item-icon icon">
2024-02-07 11:18:19 +00:00
<icon icon="tags" />
</span>
{{ $t('label.title') }}
</router-link>
</li>
<li>
2024-02-07 11:18:19 +00:00
<router-link
v-shortcut="'g m'"
:to="{ name: 'teams.index'}"
>
2022-11-18 12:59:38 +00:00
<span class="menu-item-icon icon">
2024-02-07 11:18:19 +00:00
<icon icon="users" />
</span>
{{ $t('team.title') }}
</router-link>
</li>
2023-04-03 10:09:58 +00:00
</menu>
</nav>
2023-04-10 18:57:39 +00:00
<Loading
2023-04-10 18:58:30 +00:00
v-if="projectStore.isLoading"
2023-04-10 18:57:39 +00:00
variant="small"
/>
<template v-else>
2024-02-07 11:18:19 +00:00
<nav
v-if="favoriteProjects"
class="menu"
>
<ProjectsNavigation
:model-value="favoriteProjects"
:can-edit-order="false"
:can-collapse="false"
/>
</nav>
2024-02-07 11:18:19 +00:00
<nav
v-if="savedFilterProjects"
class="menu"
>
<ProjectsNavigation
:model-value="savedFilterProjects"
:can-edit-order="false"
:can-collapse="false"
/>
</nav>
<nav class="menu">
2023-04-03 11:53:28 +00:00
<ProjectsNavigation
:model-value="projects"
:can-edit-order="true"
:can-collapse="true"
:level="1"
/>
</nav>
</template>
2024-02-07 11:18:19 +00:00
<PoweredByLink />
</aside>
</template>
<script setup lang="ts">
import {computed} from 'vue'
import PoweredByLink from '@/components/home/PoweredByLink.vue'
import Logo from '@/components/home/Logo.vue'
import Loading from '@/components/misc/loading.vue'
2022-09-24 13:20:40 +00:00
import {useBaseStore} from '@/stores/base'
import {useProjectStore} from '@/stores/projects'
import ProjectsNavigation from '@/components/home/ProjectsNavigation.vue'
2022-09-24 13:20:40 +00:00
const baseStore = useBaseStore()
const projectStore = useProjectStore()
2023-04-14 15:21:28 +00:00
const projects = computed(() => projectStore.notArchivedRootProjects)
const favoriteProjects = computed(() => projectStore.favoriteProjects)
const savedFilterProjects = computed(() => projectStore.savedFilterProjects)
</script>
2021-05-19 15:26:05 +00:00
<style lang="scss" scoped>
2022-11-13 21:34:37 +00:00
.logo {
display: block;
padding-left: 1rem;
margin-right: 1rem;
margin-bottom: 1rem;
@media screen and (min-width: $tablet) {
display: none;
}
}
2023-03-27 11:34:32 +00:00
.menu-container {
background: var(--site-background);
color: $vikunja-nav-color;
2023-06-06 15:27:05 +00:00
padding: 1rem 0;
transition: transform $transition-duration ease-in;
position: fixed;
top: $navbar-height;
bottom: 0;
left: 0;
transform: translateX(-100%);
overflow-x: auto;
width: $navbar-width;
@media screen and (max-width: $tablet) {
top: 0;
width: 70vw;
2022-04-02 21:09:28 +00:00
z-index: 20;
}
&.is-active {
transform: translateX(0);
transition: transform $transition-duration ease-out;
}
2022-11-13 21:11:51 +00:00
}
2023-04-01 19:52:52 +00:00
.top-menu .menu-list {
li {
font-weight: 600;
font-family: $vikunja-font;
}
2023-04-01 19:52:52 +00:00
.list-menu-link,
li > a {
padding-left: 2rem;
display: inline-block;
2022-11-13 21:11:51 +00:00
2023-04-01 19:52:52 +00:00
.icon {
padding-bottom: .25rem;
}
}
2022-11-13 21:11:51 +00:00
}
2023-04-03 11:53:28 +00:00
.menu + .menu {
padding-top: math.div($navbar-padding, 2);
}
2021-05-19 15:26:05 +00:00
</style>