mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-13 07:46:06 +00:00
Merge branch 'merge-6336-into-6339-optimize-event-create-and-update' of github.com:Ocelot-Social-Community/Ocelot-Social into 6379-fix-event-teaser-date-from-start-to-end
This commit is contained in:
commit
f55464f957
@ -1,29 +1,32 @@
|
||||
import { UserInputError } from 'apollo-server'
|
||||
|
||||
export const validateEventParams = (params) => {
|
||||
let locationName = null
|
||||
if (params.postType && params.postType === 'Event') {
|
||||
const { eventInput } = params
|
||||
validateEventDate(eventInput.eventStart)
|
||||
params.eventStart = eventInput.eventStart
|
||||
|
||||
validateEventEnd(eventInput.eventStart, eventInput.eventEnd)
|
||||
params.eventEnd = eventInput.eventEnd
|
||||
if (eventInput.eventEnd) {
|
||||
validateEventEnd(eventInput.eventStart, eventInput.eventEnd)
|
||||
params.eventEnd = eventInput.eventEnd
|
||||
} else {
|
||||
params.eventEnd = null
|
||||
}
|
||||
|
||||
if (eventInput.eventLocationName && !eventInput.eventVenue) {
|
||||
throw new UserInputError('Event venue must be present if event location is given!')
|
||||
}
|
||||
params.eventVenue = eventInput.eventVenue
|
||||
params.eventLocationName = eventInput.eventLocationName
|
||||
params.eventLocationName = eventInput.eventLocationName && eventInput.eventLocationName.trim()
|
||||
if (params.eventLocationName) {
|
||||
locationName = params.eventLocationName
|
||||
} else {
|
||||
params.eventLocationName = null
|
||||
}
|
||||
params.eventIsOnline = !!eventInput.eventIsOnline
|
||||
}
|
||||
delete params.eventInput
|
||||
let locationName
|
||||
if (params.eventLocationName.trim()) {
|
||||
locationName = params.eventLocationName
|
||||
} else {
|
||||
params.eventLocationName = null
|
||||
locationName = null
|
||||
}
|
||||
return locationName
|
||||
}
|
||||
|
||||
@ -38,7 +41,6 @@ const validateEventDate = (dateString) => {
|
||||
}
|
||||
|
||||
const validateEventEnd = (start, end) => {
|
||||
if (end === null) return
|
||||
const endDate = new Date(end)
|
||||
if (endDate.toString() === 'Invalid Date')
|
||||
throw new UserInputError('Event end date must be a valid date!')
|
||||
|
||||
@ -307,6 +307,7 @@ export default {
|
||||
min: 3,
|
||||
max: 100,
|
||||
validator: (_, value = '') => {
|
||||
if (this.formData.eventIsOnline) return []
|
||||
if (!value.trim()) {
|
||||
return [new Error(this.$t('common.validations.eventLocationNameNotEmpty'))]
|
||||
}
|
||||
@ -329,7 +330,7 @@ export default {
|
||||
eventVenue: this.formData.eventVenue,
|
||||
eventEnd: this.formData.eventEnd,
|
||||
eventIsOnline: this.formData.eventIsOnline,
|
||||
eventLocationName: this.formData.eventLocationName,
|
||||
eventLocationName: !this.formData.eventIsOnline ? this.formData.eventLocationName : null,
|
||||
}
|
||||
}
|
||||
return undefined
|
||||
|
||||
@ -115,9 +115,9 @@
|
||||
"validations": {
|
||||
"categories": "es müssen eine bis drei Themen ausgewählt werden",
|
||||
"email": "muss eine gültige E-Mail-Adresse sein",
|
||||
"eventLocationNameLength": "Mindestens {min} Maximal {max}",
|
||||
"eventLocationNameLength": "Minimum {min}, Maximum {max} Zeichen",
|
||||
"eventLocationNameNotEmpty": "es dürfen nicht nur Freizeichen eingetragen werden",
|
||||
"eventVenueLength": "Mindestens {min} Maximal {max}",
|
||||
"eventVenueLength": "Minimum {min}, Maximum {max} Zeichen",
|
||||
"eventVenueNotEmpty": "es dürfen nicht nur Freizeichen eingetragen werden",
|
||||
"url": "muss eine gültige URL sein"
|
||||
},
|
||||
|
||||
@ -115,9 +115,9 @@
|
||||
"validations": {
|
||||
"categories": "at least one and at most three topics must be selected",
|
||||
"email": "must be a valid e-mail address",
|
||||
"eventLocationNameLength": "minimal {min} maximal {max}",
|
||||
"eventLocationNameLength": "minimum {min} or maximum {max} characters",
|
||||
"eventLocationNameNotEmpty": "only empty characters are not allowed",
|
||||
"eventVenueLength": "minimal {min} maximal {max}",
|
||||
"eventVenueLength": "minimum {min} or maximum {max} characters",
|
||||
"eventVenueNotEmpty": "only empty characters are not allowed",
|
||||
"url": "must be a valid URL"
|
||||
},
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user