mirror of
https://github.com/tomru/pfadi-bussle.git
synced 2026-03-03 06:27:11 +01:00
throw custom ValidationError
contains an message formatter, displaying all messages concatinated.
This commit is contained in:
25
components/wizard/context/validationError.ts
Normal file
25
components/wizard/context/validationError.ts
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
interface ValidationErrors {
|
||||||
|
[key: string]: { properties: { message: string } }
|
||||||
|
}
|
||||||
|
|
||||||
|
export class ValidationError extends Error {
|
||||||
|
private errors: ValidationErrors
|
||||||
|
|
||||||
|
constructor(errors: ValidationErrors) {
|
||||||
|
super()
|
||||||
|
|
||||||
|
if (Error.captureStackTrace) {
|
||||||
|
Error.captureStackTrace(this, ValidationError)
|
||||||
|
}
|
||||||
|
this.name = this.constructor.name
|
||||||
|
this.errors = errors
|
||||||
|
}
|
||||||
|
|
||||||
|
get message() {
|
||||||
|
return Object.entries<{ properties: { message: string } }>(this.errors)
|
||||||
|
.map(([_key, value]) => {
|
||||||
|
return `${value?.properties?.message}`
|
||||||
|
})
|
||||||
|
.join(',')
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -4,6 +4,7 @@ import {
|
|||||||
loadBookingData,
|
loadBookingData,
|
||||||
storeBookingData,
|
storeBookingData,
|
||||||
} from '../../../helpers/storage'
|
} from '../../../helpers/storage'
|
||||||
|
import { ValidationError } from './validationError'
|
||||||
|
|
||||||
interface WizardFormData {
|
interface WizardFormData {
|
||||||
startDate: string
|
startDate: string
|
||||||
@@ -163,7 +164,7 @@ async function createBooking(formData: WizardFormData) {
|
|||||||
|
|
||||||
if (response.status === 400) {
|
if (response.status === 400) {
|
||||||
const error = await response.json()
|
const error = await response.json()
|
||||||
throw Error(error.message)
|
throw new ValidationError(error.errors)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!response.ok) {
|
if (!response.ok) {
|
||||||
|
|||||||
Reference in New Issue
Block a user