hippofish/packages/client/src/components/MkDriveFileThumbnail.vue

110 lines
2.7 KiB
Vue
Raw Normal View History

<template>
<button ref="thumbnail" class="zdjebgpv">
2023-04-08 02:01:42 +02:00
<ImgWithBlurhash
v-if="isThumbnailAvailable"
:hash="file.blurhash"
:src="file.thumbnailUrl"
:alt="file.comment"
2023-04-08 02:01:42 +02:00
:title="file.name"
:cover="fit !== 'contain'"
2024-03-25 15:32:20 +01:00
:show-alt-indicator="showAltIndicator"
2023-04-08 02:01:42 +02:00
/>
<i v-else-if="is === 'image'" :class="icon('ph-file-image icon')"></i>
<i v-else-if="is === 'video'" :class="icon('ph-file-video icon')"></i>
2023-04-08 02:01:42 +02:00
<i
v-else-if="is === 'audio' || is === 'midi'"
:class="icon('ph-file-audio icon')"
2023-04-08 02:01:42 +02:00
></i>
<i v-else-if="is === 'csv'" :class="icon('ph-file-csv icon')"></i>
<i v-else-if="is === 'pdf'" :class="icon('ph-file-pdf icon')"></i>
<i v-else-if="is === 'textfile'" :class="icon('ph-file-text icon')"></i>
<i v-else-if="is === 'archive'" :class="icon('ph-file-zip icon')"></i>
<i v-else :class="icon('ph-file icon')"></i>
2023-04-08 02:01:42 +02:00
<i
v-if="isThumbnailAvailable && is === 'video'"
:class="icon('ph-file-video icon-sub')"
2023-04-08 02:01:42 +02:00
></i>
</button>
</template>
<script lang="ts" setup>
2023-04-08 02:01:42 +02:00
import { computed } from "vue";
import type { entities } from "firefish-js";
2023-04-08 02:01:42 +02:00
import ImgWithBlurhash from "@/components/MkImgWithBlurhash.vue";
import icon from "@/scripts/icon";
const props = withDefaults(
defineProps<{
file: entities.DriveFile;
fit: string;
2024-03-28 06:26:09 +01:00
showAltIndicator?: boolean;
}>(),
{
2024-03-25 15:32:20 +01:00
showAltIndicator: false,
2024-03-28 06:26:09 +01:00
},
);
const is = computed(() => {
2023-04-08 02:01:42 +02:00
if (props.file.type.startsWith("image/")) return "image";
if (props.file.type.startsWith("video/")) return "video";
if (props.file.type === "audio/midi") return "midi";
if (props.file.type.startsWith("audio/")) return "audio";
if (props.file.type.endsWith("/csv")) return "csv";
if (props.file.type.endsWith("/pdf")) return "pdf";
if (props.file.type.startsWith("text/")) return "textfile";
if (
[
"application/zip",
"application/x-cpio",
"application/x-bzip",
"application/x-bzip2",
"application/java-archive",
"application/x-rar-compressed",
"application/x-tar",
"application/gzip",
"application/x-7z-compressed",
2023-09-02 01:27:33 +02:00
].includes(props.file.type)
2023-04-08 02:01:42 +02:00
)
return "archive";
return "unknown";
});
const isThumbnailAvailable = computed(() => {
return props.file.thumbnailUrl
2023-04-08 02:01:42 +02:00
? is.value === ("image" as const) || is.value === "video"
: false;
});
</script>
<style lang="scss" scoped>
.zdjebgpv {
2020-02-07 12:25:49 +01:00
position: relative;
2021-12-10 02:46:29 +01:00
display: flex;
background: var(--panel);
2021-12-10 02:46:29 +01:00
border-radius: 8px;
2022-07-13 14:41:06 +02:00
overflow: clip;
border: 0;
padding: 0;
cursor: pointer;
align-items: center;
justify-content: center;
> .icon-sub {
position: absolute;
width: 30%;
height: auto;
margin: 0;
right: 4%;
bottom: 4%;
}
> .icon {
pointer-events: none;
2021-12-10 02:46:29 +01:00
margin: auto;
font-size: 32px;
color: #777;
}
}
</style>