2024-07-03 13:55:34 +00:00
|
|
|
|
<script lang="ts" setup>
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
2024-07-03 13:55:34 +00:00
|
|
|
|
import {type AxeResponses, type QuizResponse, useQuizStore} from "~/store/quiz";
|
|
|
|
|
import Quiz from "~/pages/quiz.vue";
|
|
|
|
|
import {type Axe, useAxeStore} from "~/store/axe";
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
2024-07-03 13:55:34 +00:00
|
|
|
|
const loading = ref(true);
|
|
|
|
|
const notFound = ref(false);
|
|
|
|
|
const quiz = ref<Quiz>();
|
|
|
|
|
const axes = ref<Axe[]>();
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
2024-07-03 13:55:34 +00:00
|
|
|
|
onMounted(() => {
|
|
|
|
|
if (!useRoute().query.quiz) {
|
|
|
|
|
navigateTo("/dashboard");
|
2022-10-07 14:15:53 +00:00
|
|
|
|
}
|
2024-07-03 13:55:34 +00:00
|
|
|
|
loading.value = true;
|
|
|
|
|
notFound.value = false;
|
|
|
|
|
const quizId = Number.parseInt(useRoute().query.quiz as string);
|
|
|
|
|
useQuizStore().findById(quizId)
|
|
|
|
|
.then((result: Quiz) => {
|
|
|
|
|
quiz.value = result;
|
|
|
|
|
})
|
|
|
|
|
.then(() => {
|
|
|
|
|
useAxeStore().findAxes().then(result => {
|
|
|
|
|
axes.value = result.filter(axe => {
|
|
|
|
|
return quiz.value.axes.filter(axeResponse => axeResponse.axeIdentifier === axe.identifier).length > 0;
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
.catch(() => {
|
|
|
|
|
notFound.value = true;
|
|
|
|
|
})
|
|
|
|
|
.finally(() => {
|
|
|
|
|
loading.value = false;
|
|
|
|
|
});
|
|
|
|
|
});
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
2024-07-03 13:55:34 +00:00
|
|
|
|
function getAverage(axe: Axe): number {
|
|
|
|
|
const axeResponses = quiz.value.axes.filter((response: AxeResponses) => response.axeIdentifier === axe.identifier);
|
|
|
|
|
if (axeResponses.length === 1) {
|
|
|
|
|
return axeResponses[0].average;
|
2022-10-07 14:15:53 +00:00
|
|
|
|
}
|
2024-07-03 13:55:34 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
2024-07-03 13:55:34 +00:00
|
|
|
|
function getResponses(axe: Axe): QuizResponse[] {
|
|
|
|
|
const axeResponses = quiz.value.axes.filter((response: AxeResponses) => response.axeIdentifier === axe.identifier);
|
|
|
|
|
if (axeResponses.length === 1) {
|
|
|
|
|
return axeResponses[0].responses;
|
2022-10-07 14:15:53 +00:00
|
|
|
|
}
|
2024-07-03 13:55:34 +00:00
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function print() {
|
|
|
|
|
window.print();
|
2022-10-07 14:15:53 +00:00
|
|
|
|
}
|
|
|
|
|
</script>
|
2024-07-03 13:55:34 +00:00
|
|
|
|
<template>
|
|
|
|
|
<section v-if="!loading">
|
|
|
|
|
<span class="date">{{ formatDateTime(quiz.createdDate) }}</span>
|
|
|
|
|
<quiz-axe-details
|
|
|
|
|
v-for="axe in axes"
|
|
|
|
|
:axe="axe"
|
|
|
|
|
:average="getAverage(axe)"
|
|
|
|
|
:responses="getResponses(axe)"/>
|
|
|
|
|
</section>
|
|
|
|
|
<section v-else-if="notFound">
|
|
|
|
|
<p class="center">Le quizz demandé n'existe pas !</p>
|
|
|
|
|
</section>
|
|
|
|
|
<loader v-else class="center"/>
|
|
|
|
|
<div class="button-container">
|
|
|
|
|
<nuxt-link class="button gray button-back" to="/dashboard" aria-label="Retour à l'accueil">❮</nuxt-link>
|
|
|
|
|
<button class="button orange button-print" @click="print">Imprimer</button>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
2024-07-03 13:55:34 +00:00
|
|
|
|
section {
|
|
|
|
|
margin: $small 0;
|
|
|
|
|
}
|
2022-10-07 14:15:53 +00:00
|
|
|
|
|
|
|
|
|
.date {
|
|
|
|
|
font-weight: 700;
|
|
|
|
|
font-size: $tertiary-font-size;
|
|
|
|
|
color: $gray_4;
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-03 13:55:34 +00:00
|
|
|
|
@media print {
|
|
|
|
|
.button-container {
|
|
|
|
|
display: none;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-07 14:15:53 +00:00
|
|
|
|
</style>
|