mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-12 23:35:58 +00:00
Move event location name to an own component
This commit is contained in:
parent
ed2cdff830
commit
04290921fc
52
webapp/components/LocationTeaser/LocationTeaser.vue
Normal file
52
webapp/components/LocationTeaser/LocationTeaser.vue
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
<template>
|
||||||
|
<ds-text class="location-teaser" align="left" color="soft" :size="size">
|
||||||
|
<base-icon name="map-marker" data-test="map-marker" />
|
||||||
|
<span v-if="venue">{{ venue }}</span>
|
||||||
|
<span v-if="venue"> — </span>
|
||||||
|
<span v-if="!isOnline">
|
||||||
|
{{ locationName }}
|
||||||
|
</span>
|
||||||
|
<span v-else>
|
||||||
|
{{ $t('post.viewEvent.eventIsOnline') }}
|
||||||
|
</span>
|
||||||
|
</ds-text>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'LocationTeaser',
|
||||||
|
props: {
|
||||||
|
/**
|
||||||
|
* The size used for the text.
|
||||||
|
* @options small|base|large|x-large|xx-large|xxx-large
|
||||||
|
*/
|
||||||
|
size: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
validator: (value) => {
|
||||||
|
return value.match(/(small|base|large|x-large|xx-large|xxx-large)/)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
venue: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
},
|
||||||
|
locationName: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
},
|
||||||
|
isOnline: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss">
|
||||||
|
.location-teaser {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: 2px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@ -32,15 +32,13 @@
|
|||||||
>
|
>
|
||||||
<ds-flex>
|
<ds-flex>
|
||||||
<ds-flex-item>
|
<ds-flex-item>
|
||||||
<ds-text align="left" size="small" color="soft" class="event-info">
|
<location-teaser
|
||||||
<base-icon name="map-marker" data-test="map-marker" />
|
class="event-info"
|
||||||
<span v-if="post.eventIsOnline">
|
size="small"
|
||||||
{{ $t('post.viewEvent.eventIsOnline') }}
|
:venue="post.eventVenue"
|
||||||
</span>
|
:locationName="post.eventLocationName"
|
||||||
<span v-else-if="post.eventLocationName">
|
:isOnline="post.eventIsOnline"
|
||||||
{{ post.eventLocationName }}
|
/>
|
||||||
</span>
|
|
||||||
</ds-text>
|
|
||||||
</ds-flex-item>
|
</ds-flex-item>
|
||||||
<ds-flex-item>
|
<ds-flex-item>
|
||||||
<date-time-range
|
<date-time-range
|
||||||
@ -116,6 +114,7 @@ import ContentMenu from '~/components/ContentMenu/ContentMenu'
|
|||||||
import CounterIcon from '~/components/_new/generic/CounterIcon/CounterIcon'
|
import CounterIcon from '~/components/_new/generic/CounterIcon/CounterIcon'
|
||||||
import DateTimeRange from '~/components/DateTimeRange/DateTimeRange'
|
import DateTimeRange from '~/components/DateTimeRange/DateTimeRange'
|
||||||
import HcRibbon from '~/components/Ribbon'
|
import HcRibbon from '~/components/Ribbon'
|
||||||
|
import LocationTeaser from '~/components/LocationTeaser/LocationTeaser'
|
||||||
import UserTeaser from '~/components/UserTeaser/UserTeaser'
|
import UserTeaser from '~/components/UserTeaser/UserTeaser'
|
||||||
import { mapGetters } from 'vuex'
|
import { mapGetters } from 'vuex'
|
||||||
import PostMutations from '~/graphql/PostMutations'
|
import PostMutations from '~/graphql/PostMutations'
|
||||||
@ -129,6 +128,7 @@ export default {
|
|||||||
CounterIcon,
|
CounterIcon,
|
||||||
DateTimeRange,
|
DateTimeRange,
|
||||||
HcRibbon,
|
HcRibbon,
|
||||||
|
LocationTeaser,
|
||||||
UserTeaser,
|
UserTeaser,
|
||||||
},
|
},
|
||||||
props: {
|
props: {
|
||||||
|
|||||||
@ -60,17 +60,12 @@
|
|||||||
margin-bottom="small"
|
margin-bottom="small"
|
||||||
style="padding: 10px"
|
style="padding: 10px"
|
||||||
>
|
>
|
||||||
<ds-text align="left" color="soft">
|
<location-teaser
|
||||||
<base-icon name="map-marker" data-test="map-marker" />
|
class="event-info"
|
||||||
<span v-if="post.eventVenue">{{ post.eventVenue }}</span>
|
:venue="post.eventVenue"
|
||||||
<span v-if="post.eventVenue">—</span>
|
:locationName="post.eventLocationName"
|
||||||
<span v-if="!post.eventIsOnline">
|
:isOnline="post.eventIsOnline"
|
||||||
{{ post.eventLocationName }}
|
/>
|
||||||
</span>
|
|
||||||
<span v-else>
|
|
||||||
{{ $t('post.viewEvent.eventIsOnline') }}
|
|
||||||
</span>
|
|
||||||
</ds-text>
|
|
||||||
<date-time-range
|
<date-time-range
|
||||||
class="event-info"
|
class="event-info"
|
||||||
:startDate="post.eventStart"
|
:startDate="post.eventStart"
|
||||||
@ -155,12 +150,13 @@
|
|||||||
import ContentViewer from '~/components/Editor/ContentViewer'
|
import ContentViewer from '~/components/Editor/ContentViewer'
|
||||||
import HcCategory from '~/components/Category'
|
import HcCategory from '~/components/Category'
|
||||||
import HcHashtag from '~/components/Hashtag/Hashtag'
|
import HcHashtag from '~/components/Hashtag/Hashtag'
|
||||||
|
import CommentForm from '~/components/CommentForm/CommentForm'
|
||||||
|
import CommentList from '~/components/CommentList/CommentList'
|
||||||
import ContentMenu from '~/components/ContentMenu/ContentMenu'
|
import ContentMenu from '~/components/ContentMenu/ContentMenu'
|
||||||
import DateTimeRange from '~/components/DateTimeRange/DateTimeRange'
|
import DateTimeRange from '~/components/DateTimeRange/DateTimeRange'
|
||||||
import UserTeaser from '~/components/UserTeaser/UserTeaser'
|
import UserTeaser from '~/components/UserTeaser/UserTeaser'
|
||||||
import HcShoutButton from '~/components/ShoutButton.vue'
|
import HcShoutButton from '~/components/ShoutButton.vue'
|
||||||
import CommentForm from '~/components/CommentForm/CommentForm'
|
import LocationTeaser from '~/components/LocationTeaser/LocationTeaser'
|
||||||
import CommentList from '~/components/CommentList/CommentList'
|
|
||||||
import PageParamsLink from '~/components/_new/features/PageParamsLink/PageParamsLink.vue'
|
import PageParamsLink from '~/components/_new/features/PageParamsLink/PageParamsLink.vue'
|
||||||
import {
|
import {
|
||||||
postMenuModalsData,
|
postMenuModalsData,
|
||||||
@ -188,6 +184,7 @@ export default {
|
|||||||
HcCategory,
|
HcCategory,
|
||||||
HcHashtag,
|
HcHashtag,
|
||||||
HcShoutButton,
|
HcShoutButton,
|
||||||
|
LocationTeaser,
|
||||||
PageParamsLink,
|
PageParamsLink,
|
||||||
UserTeaser,
|
UserTeaser,
|
||||||
},
|
},
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user