2019-03-19 09:26:07 +01:00
|
|
|
<template>
|
2023-04-30 00:30:14 +02:00
|
|
|
<button ref="thumbnail" class="zdjebgpv">
|
2023-04-08 02:01:42 +02:00
|
|
|
<ImgWithBlurhash
|
|
|
|
v-if="isThumbnailAvailable"
|
|
|
|
:hash="file.blurhash"
|
|
|
|
:src="file.thumbnailUrl"
|
2024-03-25 05:29:06 +01:00
|
|
|
: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
|
|
|
/>
|
2023-10-17 03:57:20 +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'"
|
2023-10-17 03:57:20 +02:00
|
|
|
:class="icon('ph-file-audio icon')"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
2023-10-17 03:57:20 +02:00
|
|
|
<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>
|
2021-04-20 16:22:59 +02:00
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
<i
|
|
|
|
v-if="isThumbnailAvailable && is === 'video'"
|
2023-10-17 03:57:20 +02:00
|
|
|
:class="icon('ph-file-video icon-sub')"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
2023-04-30 00:30:14 +02:00
|
|
|
</button>
|
2019-03-19 09:26:07 +01:00
|
|
|
</template>
|
|
|
|
|
2022-01-18 15:06:16 +01:00
|
|
|
<script lang="ts" setup>
|
2023-04-08 02:01:42 +02:00
|
|
|
import { computed } from "vue";
|
2024-02-12 16:40:46 +01:00
|
|
|
import type { entities } from "firefish-js";
|
2023-04-08 02:01:42 +02:00
|
|
|
import ImgWithBlurhash from "@/components/MkImgWithBlurhash.vue";
|
2023-10-17 03:57:20 +02:00
|
|
|
import icon from "@/scripts/icon";
|
2019-03-19 09:26:07 +01:00
|
|
|
|
2024-03-25 05:29:06 +01:00
|
|
|
const props = withDefaults(
|
|
|
|
defineProps<{
|
|
|
|
file: entities.DriveFile;
|
|
|
|
fit: string;
|
2024-03-28 06:26:09 +01:00
|
|
|
showAltIndicator?: boolean;
|
2024-03-25 05:29:06 +01:00
|
|
|
}>(),
|
|
|
|
{
|
2024-03-25 15:32:20 +01:00
|
|
|
showAltIndicator: false,
|
2024-03-28 06:26:09 +01:00
|
|
|
},
|
2024-03-25 05:29:06 +01:00
|
|
|
);
|
2019-03-19 09:26:07 +01:00
|
|
|
|
2022-01-18 15:06:16 +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";
|
2022-01-18 15:06:16 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
const isThumbnailAvailable = computed(() => {
|
|
|
|
return props.file.thumbnailUrl
|
2023-04-08 02:01:42 +02:00
|
|
|
? is.value === ("image" as const) || is.value === "video"
|
2022-01-18 15:06:16 +01:00
|
|
|
: false;
|
2019-03-19 09:26:07 +01:00
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
2020-01-29 20:37:25 +01:00
|
|
|
<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;
|
2022-06-20 10:38:49 +02:00
|
|
|
background: var(--panel);
|
2021-12-10 02:46:29 +01:00
|
|
|
border-radius: 8px;
|
2022-07-13 14:41:06 +02:00
|
|
|
overflow: clip;
|
2023-04-30 00:30:14 +02:00
|
|
|
border: 0;
|
|
|
|
padding: 0;
|
|
|
|
cursor: pointer;
|
2023-07-21 16:50:09 +02:00
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
2019-03-19 09:26:07 +01:00
|
|
|
|
2020-01-29 20:37:25 +01:00
|
|
|
> .icon-sub {
|
|
|
|
position: absolute;
|
|
|
|
width: 30%;
|
|
|
|
height: auto;
|
|
|
|
margin: 0;
|
|
|
|
right: 4%;
|
|
|
|
bottom: 4%;
|
|
|
|
}
|
2019-03-19 09:26:07 +01:00
|
|
|
|
2020-07-18 17:24:07 +02:00
|
|
|
> .icon {
|
|
|
|
pointer-events: none;
|
2021-12-10 02:46:29 +01:00
|
|
|
margin: auto;
|
|
|
|
font-size: 32px;
|
|
|
|
color: #777;
|
2020-01-29 20:37:25 +01:00
|
|
|
}
|
|
|
|
}
|
2019-03-19 09:26:07 +01:00
|
|
|
</style>
|