EventList.vue 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <template>
  2. <div>
  3. <v-list height="420">
  4. <v-list-item v-for="event in events" :key="event.id" class="event-item">
  5. <template #prepend>
  6. <v-avatar color="grey-lighten-1">
  7. <UiImage :image-id="event.image" :width="50" />
  8. </v-avatar>
  9. </template>
  10. <template #default>
  11. <div class="flex-grow-1" @click="$emit('edit', event.id)">
  12. <span class="text-subtitle-1">{{ event.name }}</span>
  13. <br />
  14. <span class="text-subtitle-2">{{
  15. date.format(event.datetimeStart, 'fullDateWithWeekday')
  16. }}</span>
  17. </div>
  18. </template>
  19. <template #append>
  20. <v-avatar class="edit-btn" @click="$emit('edit', event.id)">
  21. <v-icon>fas fa-pencil</v-icon>
  22. </v-avatar>
  23. <UiButtonDelete :entity="event" class="delete-btn">
  24. <v-avatar>
  25. <v-icon>fas fa-trash</v-icon>
  26. </v-avatar>
  27. </UiButtonDelete>
  28. </template>
  29. </v-list-item>
  30. </v-list>
  31. <div
  32. v-if="events.length > 0"
  33. class="d-flex justify-space-between px-4 py-2 pagination mb-5"
  34. >
  35. <v-btn
  36. variant="flat"
  37. class="pagination-btn"
  38. :disabled="!pagination.first || !pagination.previous"
  39. @click="$emit('load', pagination.first)"
  40. >
  41. <v-avatar>
  42. <v-icon>fas fa-angles-left</v-icon>
  43. </v-avatar>
  44. </v-btn>
  45. <v-btn
  46. variant="flat"
  47. class="pagination-btn"
  48. :disabled="!pagination.previous"
  49. @click="$emit('load', pagination.previous)"
  50. >
  51. <v-avatar>
  52. <v-icon>fas fa-angle-left</v-icon>
  53. </v-avatar>
  54. </v-btn>
  55. <v-btn
  56. variant="flat"
  57. class="pagination-btn"
  58. :disabled="!pagination.next"
  59. @click="$emit('load', pagination.next)"
  60. >
  61. <v-avatar>
  62. <v-icon>fas fa-angle-right</v-icon>
  63. </v-avatar>
  64. </v-btn>
  65. <v-btn
  66. variant="flat"
  67. class="pagination-btn"
  68. :disabled="pagination.last == 1"
  69. @click="$emit('load', pagination.last)"
  70. >
  71. <v-avatar>
  72. <v-icon>fas fa-angles-right</v-icon>
  73. </v-avatar>
  74. </v-btn>
  75. </div>
  76. </div>
  77. </template>
  78. <script lang="ts" setup>
  79. import { defineProps, defineEmits } from 'vue'
  80. import type { Collection } from 'pinia-orm'
  81. import type Event from '~/models/Freemium/Event'
  82. import type { Pagination } from '~/types/data'
  83. import { useDate } from 'vuetify'
  84. const props = defineProps<{
  85. events: Collection<Event>
  86. pagination: Pagination
  87. }>()
  88. const emits = defineEmits(['edit', 'load'])
  89. const date = useDate()
  90. </script>
  91. <style scoped lang="scss">
  92. .event-item {
  93. margin-top: 20px;
  94. color: rgb(var(--v-theme-on-neutral));
  95. .text-subtitle-2 {
  96. text-transform: capitalize !important;
  97. color: rgb(var(--v-theme-on-neutral--sub));
  98. }
  99. }
  100. .pagination-btn[disabled] {
  101. opacity: 0.3;
  102. }
  103. .edit-btn {
  104. cursor: pointer;
  105. }
  106. :deep(.v-list-item):hover {
  107. cursor: pointer;
  108. background-color: rgb(var(--v-theme-neutral));
  109. }
  110. </style>