You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

199 lines
4.9 KiB
Vue

<template>
<div class="popup" @click="$emit('closePopup')">
<div class="Order" @click.stop v-show="!showNewTimes">
<div class="center">
{{ order.center_name }}
</div>
<div class="user">
{{ order.user.firstname }} {{ order.user.lastname }}
</div>
<div class="date">
{{ formatDate(order.startDate) }}
</div>
<div class="time">
{{ formatTime(order.startDate) }} -
{{ formatTime(order.endDate) }}
</div>
<div class="price">
{{ formatPrice(order.price) }}
</div>
<div class="buttons">
<div class="moveButton" @click="moveOrder()" v-if="showButtons">
Flyt tid
</div>
<div class="cancelButton" @click="cancelOrder(order.id)" v-if="showButtons">
Aflys
</div>
</div>
<div class="closeButton" @click="$emit('closePopup')">x</div>
</div>
<TrainerNewTime :order="order" @closePopup="$emit('closePopup')" @refreshList="$emit('refreshList')" v-if="showNewTimes"></TrainerNewTime>
</div>
</template>
<script lang="ts">
import TrainerNewTime from '@/components/TrainerNewTime.vue'
import type { PropType } from 'vue';
import dayjs from 'dayjs';
import LocalizedFormat from "dayjs/plugin/localizedFormat"
import utc from "dayjs/plugin/utc"
import { } from "dayjs/locale/da";
import type { TrainerOrder as Order } from '@/interfaces/order';
dayjs.extend(LocalizedFormat);
dayjs.extend(utc);
export default {
name: "UserOrderPopup",
emits: ["closePopup", "refreshList"],
components: {
TrainerNewTime
},
props: {
order: {
type: Object as PropType<Order>,
required: true
}
},
data() {
return {
showNewTimes: false
};
},
computed: {
showButtons(): boolean {
return this.order.status !== 'CancelledByTrainer' && this.order.status !== 'CancelledByUser' && (new Date(this.order.startDate.split("Z")[0])).getTime() > (new Date()).getTime();
}
},
methods: {
moveOrder() {
this.showNewTimes = true;
},
async cancelOrder(id: number) {
if (id === undefined) return;
const res = await fetch(`${import.meta.env.VITE_BASE_API_URL}/trainer/order/${id}/cancel`, {
credentials: import.meta.env.DEV ? "include" : undefined,
method: "POST"
});
if (res.status === 401) {
this.$router.push({ path: "/login", query: { ref: this.$route.path } });
}
else if (res.status === 204) {
this.$emit('refreshList');
this.$emit('closePopup');
}
},
formatDate(date: string): string {
let output: string = dayjs(date).locale("da").format("dddd D. MMM YYYY");
let outputStringArray = output.split("");
outputStringArray[0] = outputStringArray[0].toLocaleUpperCase();
output = outputStringArray.join("");
return output;
},
formatTime(date: string): string {
let output: string = dayjs(date).utcOffset(0).locale("da").format("HH:mm");
return output;
},
formatPrice(price: number): string {
const DanishKrone = new Intl.NumberFormat('dk', {
style: 'currency',
currency: 'DKK',
});
return DanishKrone.format(price / 100);
}
}
}
</script>
<style scoped>
.popup {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: #000a;
display: flex;
justify-content: center;
align-items: center;
z-index: 10;
}
.Order {
background-color: white;
border-radius: 0.5rem;
padding: 30px;
display: flex;
flex-direction: column;
min-width: 50%;
position: relative;
}
.center {
font-size: 1.8em;
}
.user {
opacity: 0.8;
font-size: 1.25em;
}
.date {
font-size: 1em;
}
.time {
font-size: 1em;
}
.price {
font-size: 1.25em;
}
.buttons {
align-self: flex-end;
display: flex;
gap: 20px;
}
.cancelButton {
border: 1px solid #cbd5e1;
border-radius: 0.5rem;
padding: 10px;
cursor: pointer;
font-size: 1.25em;
}
.cancelButton:hover {
text-decoration: underline;
border-color: black;
}
.moveButton {
border: 1px solid #cbd5e1;
border-radius: 0.5rem;
padding: 10px;
cursor: pointer;
font-size: 1.25em;
}
.moveButton:hover {
text-decoration: underline;
border-color: black;
}
.closeButton {
position: absolute;
top: 10px;
right: 20px;
font-size: 2em;
cursor: pointer;
}
.closeButton:hover {
text-decoration: underline;
}
</style>