Alisa/web/src/components/ListViewElement.vue

128 lines
3 KiB
Vue
Raw Normal View History

<template>
<v-sheet
elevation="4"
width="96vw"
rounded="lg"
class="mt-3"
style="border-left: 0.5rem outset #0fa4af"
>
<v-expansion-panels>
<v-expansion-panel>
<v-expansion-panel-title>
<div class="mr-3">
{{ props.licenseName }}
</div>
<div
class="mr-3 d-flex align-self-center"
style="align-items: center"
>
<KeyRound class="mr-1" />
{{ props.licenseKey }}
</div>
<div
class="mr-3 d-flex align-self-center"
style="align-items: center"
>
<CalendarCheck />
<span
v-if="
props.startDate == null ||
props.startDate == undefined ||
props.startDate.length == 0
"
>
Verfügbar
</span>
<span v-else>
{{ props.startDate }}
</span>
</div>
<div
class="mr-3 d-flex align-self-center"
style="align-items: center"
>
<CalendarX />
<span
v-if="
props.endDate == null ||
props.endDate == undefined ||
props.endDate.length == 0
"
>
Ewig Verfügbar
</span>
<span v-else>
{{ props.endDate }}
</span>
</div>
<div
class="mr-3 d-flex align-self-center"
style="align-items: center"
>
<img
src="../assets/doublekey.svg"
alt="logo"
class="logo mr-1"
width="24"
/>
<span v-if="props.amount == null || props.amount == undefined">
<Infinity />
</span>
<span v-else>
{{ props.amount }}
</span>
</div>
</v-expansion-panel-title>
<v-expansion-panel-text>
2024-07-11 10:59:22 +02:00
<v-row
class="flex-nowrap bg-surface-variant"
2024-07-11 10:59:22 +02:00
no-gutters
>
<v-col
class="flex-grow-0 flex-shrink-0"
cols="7"
2024-07-11 10:59:22 +02:00
>
Notes: {{ props.notes }}
2024-07-11 10:59:22 +02:00
</v-col>
2024-07-11 10:59:22 +02:00
<v-col
class="flex-grow-0 flex-shrink-1"
cols="5"
2024-07-11 10:59:22 +02:00
>
I'm 5 column wide and I shrink if there's not enough space
2024-07-11 10:59:22 +02:00
</v-col>
</v-row>
</v-expansion-panel-text>
</v-expansion-panel>
</v-expansion-panels>
</v-sheet>
</template>
<script setup lang="ts">
import { Infinity, KeyRound, CalendarCheck, CalendarX } from "lucide-vue-next";
const props = defineProps({
licenseName: String,
licenseKey: String,
startDate: String,
endDate: String,
amount: Number,
notes: String,
});
</script>
<style scoped>
.values {
display: flex;
align-items: center;
}
</style>