1
0

feat(navigation): add hiding child projects

This commit is contained in:
kolaente
2023-03-27 11:33:24 +02:00
parent f2ca2d850d
commit 06c4c0d921
2 changed files with 56 additions and 34 deletions

View File

@ -31,6 +31,14 @@
:class="{'is-loading': projectUpdating[p.id]}"
>
<section>
<BaseButton
v-if="p.childProjects.length > 0"
@click="collapsedProjects[p.id] = !collapsedProjects[p.id]"
class="collapse-project-button"
>
<icon icon="chevron-down" :class="{ 'project-is-collapsed': collapsedProjects[p.id] }"/>
</BaseButton>
<span class="collapse-project-button-placeholder" v-else></span>
<BaseButton
:to="{ name: 'project.index', params: { projectId: p.id} }"
class="list-menu-link"
@ -64,7 +72,7 @@
<span class="list-setting-spacer" v-else></span>
</section>
<ProjectsNavigation
v-if="p.childProjects.length > 0"
v-if="p.childProjects.length > 0 && !collapsedProjects[p.id]"
:projects="p.childProjects"
/>
</li>
@ -106,11 +114,13 @@ const currentProject = computed(() => baseStore.currentProject)
// Hence, we'll clone the prop and work on the clone.
// FIXME: cloning does not work when loading the page initially
// TODO: child projects
const collapsedProjects = ref<{ [id: IProject['id']]: boolean }>({})
const availableProjects = ref<IProject[]>([])
watch(
() => props.projects,
projects => {
availableProjects.value = projects
projects.forEach(p => collapsedProjects.value[p.id] = false)
},
{immediate: true},
)
@ -161,4 +171,8 @@ async function saveProjectPosition(e: SortableEvent) {
width: 2.5rem;
flex-shrink: 0;
}
.project-is-collapsed {
transform: rotate(-90deg);
}
</style>