extractify.zip/components/tree-view.vue

37 lines
1.5 KiB
Vue
Raw Normal View History

2023-05-15 03:32:16 +03:00
<script setup lang="ts">
import { CompressedFile } from 'libarchive.js/src/compressed-file';
import type { iFile } from '~/composables/worker/7zip-manager';
2023-05-15 03:32:16 +03:00
interface Props {
filesList: iFile[],
2023-05-15 03:32:16 +03:00
nav: boolean
}
2023-06-03 06:59:17 +03:00
let { filesList, nav } = defineProps<Props>()
let selectedPath = useSelectedPath();
2023-05-15 03:32:16 +03:00
</script>
<template>
<v-list :selected="[selectedPath]" density="compact" :nav="nav">
2023-05-15 03:32:16 +03:00
<template v-for="file in filesList" :key="file.path">
<v-list-item active-color="light-blue-darken-4" :active="selectedPath == file.path" :title="file.name" :subtitle="file.path"
2023-06-03 06:59:17 +03:00
:value="file.path" @click="() => {
selectedPath = file.path;
2023-05-15 03:32:16 +03:00
file.toggle = !file.toggle;
}">
2023-06-03 06:59:17 +03:00
<template v-slot:prepend>
<v-avatar :color="file.isFolder ? 'light-blue-accent-4' : 'blue-grey-darken-1'">
<v-icon color="white">{{ file.isFolder ? 'mdi-folder' : 'mdi-file' }}</v-icon>
</v-avatar>
</template>
<template v-if="file.isFolder" v-slot:append>
<v-icon>{{ `mdi-chevron-${file.toggle ? 'up' : 'down'}` }}</v-icon>
2023-05-15 03:32:16 +03:00
</template>
2023-06-03 06:59:17 +03:00
</v-list-item>
<div v-if="file.isFolder && file.toggle && file.content"
2023-06-03 06:59:17 +03:00
:style="`background-color: rgba(0,0,0,0.05);${nav ? `border-radius: 4px;` : ''}`">
<TreeView :files-list="file.content" :nav="false"></TreeView>
2023-05-15 03:32:16 +03:00
</div>
</template>
</v-list>
</template>