designtopack/src/components/project/cards/VirtualSample.vue

32 lines
863 B
Vue
Raw Normal View History

2024-12-20 08:05:55 +01:00
<template>
<Images
v-if="step.files.dynamic || step.files.static"
:step="step"
:images="images"
:uri="uri"
/>
2024-12-20 08:05:55 +01:00
</template>
<script setup>
import Images from "./Images.vue";
import { computed } from "vue";
const { step } = defineProps({ step: Object });
const images = computed(() => {
return step.files?.dynamic?.map((track) => getFrontView(track)) ?? [];
2024-12-20 08:05:55 +01:00
});
const uri = "/" + step.uri;
2024-12-20 08:05:55 +01:00
function getFrontView(track) {
if (track.files.length === 1) return track.files[0];
const xMax = parseInt(
track.files[track.files.length - 1].name.split("_")[1].split(".")[0]
);
const xFrontView = (xMax + 1) / 2;
const extension = track.files[0].name.split(".")[1];
const frontViewName = "0_" + xFrontView + "." + extension;
const frontView = track.files.find((file) => file.name === frontViewName);
return frontView;
}
</script>