2021-03-16 19:57:34 +01:00
|
|
|
<template lang="pug">
|
2022-07-01 15:55:09 +02:00
|
|
|
v-card.h-event.event.d-flex(itemscope itemtype="https://schema.org/Event")
|
|
|
|
nuxt-link(:to='`/event/${event.slug || event.id}`' itemprop="url")
|
|
|
|
MyPicture(:event='event' thumb :lazy='lazy')
|
|
|
|
v-icon.float-right.mr-1(v-if='event.parentId' color='success' v-text='mdiRepeat')
|
2022-09-05 00:02:33 +02:00
|
|
|
.title.p-name(itemprop="name") {{ event.title }}
|
2020-10-07 13:03:15 +02:00
|
|
|
|
2022-07-01 15:55:09 +02:00
|
|
|
v-card-text.body.pt-0.pb-0
|
2022-09-05 00:02:33 +02:00
|
|
|
time.dt-start.subtitle-1(:datetime='event.start_datetime | unixFormat("YYYY-MM-DD HH:mm")' itemprop="startDate" :content="event.start_datetime | unixFormat('YYYY-MM-DDTHH:mm')") <v-icon v-text='mdiCalendar'></v-icon> {{ event | when }}
|
|
|
|
.d-none.dt-end(itemprop="endDate" :content="event.end_datetime | unixFormat('YYYY-MM-DDTHH:mm')") {{ event.end_datetime | unixFormat('YYYY-MM-DD HH:mm') }}
|
|
|
|
nuxt-link.place.d-block.p-location.pl-0(text color='primary' :to='`/place/${event.place.name}`' itemprop="location" itemscope itemtype="https://schema.org/Place") <v-icon v-text='mdiMapMarker'></v-icon> <span itemprop='name'>{{ event.place.name }}</span>
|
|
|
|
.d-none(itemprop='address') {{ event.place.address }}
|
2020-10-25 00:30:28 +02:00
|
|
|
|
2022-07-01 15:55:09 +02:00
|
|
|
v-card-actions.pt-0.actions.justify-space-between
|
|
|
|
.tags
|
2022-09-05 00:02:33 +02:00
|
|
|
v-chip.ml-1.mt-1(v-for='tag in event.tags.slice(0, 6)' small :to='`/tag/${tag}`'
|
|
|
|
:key='tag' outlined color='primary') {{ tag }}
|
2020-10-07 13:03:15 +02:00
|
|
|
|
2022-07-01 15:55:09 +02:00
|
|
|
client-only
|
|
|
|
v-menu(offset-y eager)
|
2022-09-05 00:02:33 +02:00
|
|
|
template(v-slot:activator="{ on }")
|
2022-07-01 15:55:09 +02:00
|
|
|
v-btn.align-self-end(icon v-on='on' color='primary' title='more' aria-label='more')
|
|
|
|
v-icon(v-text='mdiDotsVertical')
|
|
|
|
v-list(dense)
|
|
|
|
v-list-item-group
|
|
|
|
v-list-item(@click='clipboard(`${settings.baseurl}/event/${event.slug || event.id}`)')
|
|
|
|
v-list-item-icon
|
|
|
|
v-icon(v-text='mdiContentCopy')
|
|
|
|
v-list-item-content
|
2022-09-05 00:02:33 +02:00
|
|
|
v-list-item-title {{ $t('common.copy_link') }}
|
2022-07-01 15:55:09 +02:00
|
|
|
v-list-item(:href='`/api/event/${event.slug || event.id}.ics`')
|
|
|
|
v-list-item-icon
|
|
|
|
v-icon(v-text='mdiCalendarExport')
|
|
|
|
v-list-item-content
|
2022-09-05 00:02:33 +02:00
|
|
|
v-list-item-title {{ $t('common.add_to_calendar') }}
|
2022-07-01 15:55:09 +02:00
|
|
|
v-list-item(v-if='is_mine' :to='`/add/${event.id}`')
|
|
|
|
v-list-item-icon
|
|
|
|
v-icon(v-text='mdiPencil')
|
|
|
|
v-list-item-content
|
2022-09-05 00:02:33 +02:00
|
|
|
v-list-item-title {{ $t('common.edit') }}
|
2022-07-01 15:55:09 +02:00
|
|
|
v-list-item(v-if='is_mine' @click='remove(false)')
|
|
|
|
v-list-item-icon
|
|
|
|
v-icon(color='error' v-text='mdiDeleteForever')
|
|
|
|
v-list-item-content
|
2022-09-05 00:02:33 +02:00
|
|
|
v-list-item-title {{ $t('common.remove') }}
|
2022-07-01 15:55:09 +02:00
|
|
|
template(#placeholder)
|
|
|
|
v-btn.align-self-end(icon color='primary' aria-label='more')
|
|
|
|
v-icon(v-text='mdiDotsVertical')
|
2019-04-03 00:25:12 +02:00
|
|
|
</template>
|
|
|
|
<script>
|
2021-03-16 19:57:34 +01:00
|
|
|
import { mapState } from 'vuex'
|
2021-12-06 15:58:12 +01:00
|
|
|
import clipboard from '../assets/clipboard'
|
2022-04-27 12:34:58 +02:00
|
|
|
import MyPicture from '~/components/MyPicture'
|
2022-09-05 00:02:33 +02:00
|
|
|
import {
|
|
|
|
mdiRepeat, mdiPencil, mdiDotsVertical, mdiContentCopy,
|
|
|
|
mdiCalendarExport, mdiDeleteForever, mdiCalendar, mdiMapMarker
|
|
|
|
} from '@mdi/js'
|
2019-04-03 00:25:12 +02:00
|
|
|
|
|
|
|
export default {
|
2022-09-05 00:02:33 +02:00
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
mdiRepeat, mdiPencil, mdiDotsVertical, mdiContentCopy, mdiCalendarExport,
|
|
|
|
mdiDeleteForever, mdiMapMarker, mdiCalendar
|
|
|
|
}
|
2022-02-08 14:45:19 +01:00
|
|
|
},
|
2022-04-27 12:34:58 +02:00
|
|
|
components: {
|
|
|
|
MyPicture
|
|
|
|
},
|
2019-05-30 12:04:14 +02:00
|
|
|
props: {
|
2022-02-04 22:35:15 +01:00
|
|
|
event: { type: Object, default: () => ({}) },
|
|
|
|
lazy: Boolean
|
2021-03-16 19:57:34 +01:00
|
|
|
},
|
2021-12-06 15:58:12 +01:00
|
|
|
mixins: [clipboard],
|
2021-06-06 23:59:12 +02:00
|
|
|
computed: {
|
|
|
|
...mapState(['settings']),
|
2022-09-05 00:02:33 +02:00
|
|
|
is_mine() {
|
2021-06-06 23:59:12 +02:00
|
|
|
if (!this.$auth.user) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
this.event.userId === this.$auth.user.id || this.$auth.user.is_admin
|
|
|
|
)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2022-09-05 00:02:33 +02:00
|
|
|
async remove() {
|
2021-06-06 23:59:12 +02:00
|
|
|
const ret = await this.$root.$confirm('event.remove_confirmation')
|
|
|
|
if (!ret) { return }
|
|
|
|
await this.$axios.delete(`/event/${this.event.id}`)
|
|
|
|
this.$emit('destroy', this.event.id)
|
2022-04-29 17:56:28 +02:00
|
|
|
this.$root.$message('admin.event_remove_ok')
|
2022-09-05 00:02:33 +02:00
|
|
|
|
2021-06-06 23:59:12 +02:00
|
|
|
}
|
|
|
|
}
|
2019-04-03 00:25:12 +02:00
|
|
|
}
|
2021-04-13 18:04:53 +02:00
|
|
|
</script>
|