Much simpler using prizeDistribution endpoints.

This commit is contained in:
2021-02-18 21:44:33 +01:00
parent eaf57115e8
commit 8bd41cc691

View File

@@ -1,21 +1,23 @@
<template> <template>
<div class="container"> <div>
<div v-if="!posted"> <div v-if="!posted" class="container">
<h1 v-if="name">Gratulerer {{name}}!</h1> <h1 v-if="name">Gratulerer {{ name }}!</h1>
<p v-if="name"> <p v-if="name">
Her er valgene for dagens lotteri, du har 10 minutter å velge etter du fikk SMS-en. Her er valgene for dagens lotteri, du har 10 minutter å velge etter du fikk SMS-en.
</p> </p>
<h1 v-else-if="!turn && !existing" class="sent-container">Finner ikke noen vinner her..</h1>
<h1 v-else-if="!turn && wines.length" class="sent-container">Finner ikke noen vinner her..</h1>
<h1 v-else-if="!turn" class="sent-container">Du vente tur..</h1> <h1 v-else-if="!turn" class="sent-container">Du vente tur..</h1>
<div class="wines-container" v-if="name"> <div class="wines-container" v-if="name">
<Wine :wine="wine" v-for="wine in wines" :key="wine"> <Wine :wine="wine" v-for="wine in wines" :key="wine">
<button <button @click="chooseWine(wine)" class="vin-button select-wine">Velg denne vinnen</button>
@click="chooseWine(wine.name)"
class="vin-button select-wine"
>Velg denne vinnen</button>
</Wine> </Wine>
</div> </div>
</div> </div>
<div v-else-if="posted" class="sent-container"> <div v-else-if="posted" class="sent-container">
<h1>Valget ditt er sendt inn!</h1> <h1>Valget ditt er sendt inn!</h1>
<p>Du får mer info om henting snarest!</p> <p>Du får mer info om henting snarest!</p>
@@ -24,15 +26,13 @@
</template> </template>
<script> <script>
import { getAmIWinner, postWineChosen, prelottery } from "@/api";
import Wine from "@/ui/Wine"; import Wine from "@/ui/Wine";
export default { export default {
components: { Wine }, components: { Wine },
data() { data() {
return { return {
id: null, id: null,
existing: false,
fetched: false,
turn: false, turn: false,
name: null, name: null,
wines: [], wines: [],
@@ -40,30 +40,43 @@ export default {
}; };
}, },
async mounted() { async mounted() {
this.id = this.$router.currentRoute.params.id; const { id } = this.$router.currentRoute.params;
let winnerObject = await getAmIWinner(this.id); this.id = id;
this.fetched = true; this.getPrizes(id);
if (!winnerObject || !winnerObject.existing) {
console.error("non existing", winnerObject);
return;
}
this.existing = true;
if (winnerObject.existing && !winnerObject.turn) {
console.error("not your turn yet", winnerObject);
return;
}
this.turn = true;
this.name = winnerObject.name;
this.wines = await prelottery();
}, },
methods: { methods: {
chooseWine: async function(name) { getPrizes(id) {
let posted = await postWineChosen(this.id, name); fetch(`/api/lottery/prize-distribution/prizes/${id}`)
console.log("response", posted); .then(resp => resp.json())
if (posted.success) { .then(response => {
this.posted = true; if (response.success) {
} this.wines = response.wines;
this.name = response.winner.name;
this.turn = true;
}
});
},
chooseWine(wine) {
const options = {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify({ wine })
};
fetch(`/api/lottery/prize-distribution/prize/${this.id}`, options)
.then(resp => resp.json())
.then(response => {
if (response.success) {
this.$toast.info({ title: `Valgt vin: ${wine.name}` });
this.posted = true;
} else {
this.$toast.error({
title: "Klarte ikke velge vin :(",
description: response.message
});
}
});
} }
} }
}; };
@@ -74,9 +87,19 @@ export default {
.container { .container {
display: flex; display: flex;
justify-content: center; justify-content: center;
align-items: center;
flex-direction: column;
margin-top: 2rem; margin-top: 2rem;
padding: 2rem; padding: 2rem;
width: 80%;
margin: 0 auto;
max-width: 2000px;
} }
.wines-container {
width: 100%;
}
.sent-container { .sent-container {
width: 100%; width: 100%;
height: 90vh; height: 90vh;
@@ -90,11 +113,4 @@ export default {
.select-wine { .select-wine {
margin-top: 1rem; margin-top: 1rem;
} }
</style>
.wines-container {
display: flex;
flex-wrap: wrap;
justify-content: space-evenly;
align-items: flex-start;
}
</style>