move CRUD operations to helpers

This commit is contained in:
Thomas Ruoff
2021-06-07 23:32:54 +02:00
parent 865bbb20fa
commit 92477e5325
9 changed files with 102 additions and 93 deletions

View File

@@ -1,7 +1,8 @@
import React, { useEffect, useReducer } from 'react'
import { useRouter } from 'next/router'
import { clearBookingData, loadBookingData } from '../../../helpers/storage'
import { ValidationError } from './validationError'
import { createBooking } from '../../../helpers/booking'
interface WizardFormData {
startDate: string
@@ -136,33 +137,6 @@ const initialState: WizardStoreState = {
dataStoredLoaded: undefined,
}
async function createBooking(formData: WizardFormData) {
const response = await fetch('/api/booking', {
method: 'POST',
mode: 'cors',
cache: 'no-cache',
credentials: 'same-origin',
headers: {
'Content-Type': 'application/json',
},
referrerPolicy: 'no-referrer',
body: JSON.stringify(formData),
})
if (response.status === 400) {
const error = await response.json()
throw new ValidationError(error.errors)
}
if (!response.ok) {
throw Error(
'Sorry, konnte nicht gespeichert werden. Bitte versuch es später nochmal!'
)
}
return response.json()
}
export default function WizardStore({ children }) {
const router = useRouter()
const [state, dispatch] = useReducer(reducer, initialState)

View File

@@ -1,11 +1,18 @@
import { MILAGE_TARIFS } from '../db/enums'
import { AdditionalCost } from '../db/bill'
import { AdditionalCost, Bill } from '../db/bill'
import fetch from './fetch'
function roundToCent(amount: number): number {
return Math.round(amount * 100) / 100
}
export function getMilageCosts({ tarif, km }: { tarif: MILAGE_TARIFS; km: number }): number {
export function getMilageCosts({
tarif,
km,
}: {
tarif: MILAGE_TARIFS
km: number
}): number {
if (tarif === MILAGE_TARIFS.NOCHARGE) {
return 0
}
@@ -63,3 +70,23 @@ export function getBillTotal({
return roundToCent(milageCosts + additionalCostsSum)
}
export async function createBill(
bookingUuid: string,
bill: Bill
): Promise<Bill> {
return fetch(`/api/admin/booking/${bookingUuid}/bill`, {
method: 'POST',
body: bill,
})
}
export async function patchBill(
bookingUuid: string,
bill: Bill
): Promise<Bill> {
return fetch(`/api/admin/booking/${bookingUuid}/bill`, {
method: 'POST',
body: bill,
})
}

View File

@@ -1,4 +1,5 @@
import { BOOKING_STATUS } from '../db/enums'
import fetch from './fetch'
export function getBookingStatus(status: BOOKING_STATUS) {
switch (status) {
@@ -14,3 +15,24 @@ export function getBookingStatus(status: BOOKING_STATUS) {
return 'Unbekannt - bitte kontaktieren Sie uns!'
}
}
export async function createBooking(formData: object) {
return fetch('/api/booking', {
method: 'POST',
body: formData,
})
}
export async function cancelBooking(uuid: string) {
return fetch(`/api/booking/${uuid}`, {
method: 'PATCH',
body: { status: BOOKING_STATUS.CANCELED },
})
}
export async function patchBooking(uuid: string, bookingData: object) {
return fetch(`/api/admin/booking/${uuid}`, {
method: 'PATCH',
body: { ...bookingData },
})
}

40
helpers/fetch.ts Normal file
View File

@@ -0,0 +1,40 @@
import { ValidationError } from './validationError'
const DEFAULT_FETCH_OPTIONS = {
method: 'GET',
mode: 'cors' as RequestMode,
cache: 'no-cache' as RequestCache,
credentials: 'same-origin' as RequestCredentials,
headers: {
'Content-Type': 'application/json',
},
referrerPolicy: 'no-referrer' as ReferrerPolicy,
}
export type FetchOptions = Omit<RequestInit, 'body'> & {
body?: object
}
export default async function fetchJSON(
url: string,
options: FetchOptions = {}
) {
const response = await fetch(url, {
...DEFAULT_FETCH_OPTIONS,
...options,
body: !!options.body ? JSON.stringify(options.body) : undefined,
})
if (response.status === 400) {
const error = await response.json()
throw new ValidationError(error.errors)
}
if (!response.ok) {
throw Error(
'Sorry, konnte nicht gespeichert werden. Bitte versuch es später nochmal!'
)
}
return response.json()
}

View File

@@ -1,6 +1,7 @@
import useSWR from 'swr'
import fetch from './fetch'
const fetcher = (path: string) => fetch(path).then((r) => r.json())
const fetcher = (path: string) => fetch(path)
function useDaysBooked() {
const { data: daysBooked, error: daysBookedError } = useSWR(

View File

@@ -1,4 +1,4 @@
import { VALIDATION_ERRORS } from '../../../db/enums'
import { VALIDATION_ERRORS } from '../db/enums'
interface ValidationErrors {
[key: string]: { properties: { message: string }; kind: string }

View File

@@ -3,12 +3,11 @@ import Footer from '../../../../components/footer'
import Header from '../../../../components/header'
import Input from '../../../../components/input'
import Select from '../../../../components/select'
import { AdditionalCost, Bill } from '../../../../db/bill'
import { Booking } from '../../../../db/booking'
import { BILL_STATUS, MILAGE_TARIFS } from '../../../../db/enums'
import { getMilageMax } from '../../../../db/index'
import { daysFormatFrontend } from '../../../../helpers/date'
import { getBillTotal } from '../../../../helpers/bill'
import { getBillTotal, createBill, patchBill } from '../../../../helpers/bill'
import { getBookingStatus } from '../../../../helpers/booking'
import withSession, {
isAdminSession,
@@ -79,31 +78,6 @@ function getBillStatusLabel(status: BILL_STATUS) {
}
}
async function saveBill(
booking: Booking,
bill: {
milageStart: number
milageEnd: number
milage?: number
tarif: MILAGE_TARIFS
additionalCosts: AdditionalCost[]
status: BILL_STATUS
}
): Promise<Bill> {
const response = await fetch(`/api/admin/booking/${booking.uuid}/bill`, {
method: !!booking.bill ? 'PATCH' : 'POST',
mode: 'cors',
cache: 'no-cache',
credentials: 'same-origin',
headers: {
'Content-Type': 'application/json',
},
referrerPolicy: 'no-referrer',
body: JSON.stringify(bill),
})
return response.json()
}
export default function BookingBillPage({
booking: bookingProp,
milageMax,
@@ -136,7 +110,8 @@ export default function BookingBillPage({
setStoringError(null)
try {
const bill = await saveBill(booking, {
const saveBill = !!booking.bill ? createBill : patchBill
const bill = await saveBill(booking.uuid, {
milageStart,
milageEnd,
milage,

View File

@@ -11,7 +11,7 @@ import withSession, {
} from '../../../../lib/session'
import { getServerSideBooking } from '../../../../lib/getServerSideProps'
import { Booking } from '../../../../db/booking'
import { getBookingStatus } from '../../../../helpers/booking'
import { getBookingStatus, patchBooking } from '../../../../helpers/booking'
import { daysFormatFrontend } from '../../../../helpers/date'
import { BOOKING_STATUS } from '../../../../db/enums'
@@ -36,21 +36,6 @@ export const getServerSideProps: GetServerSideProps = withSession(
}
)
async function patchBooking(uuid: string, bookingData: any) {
const response = await fetch(`/api/admin/booking/${uuid}`, {
method: 'PATCH',
mode: 'cors',
cache: 'no-cache',
credentials: 'same-origin',
headers: {
'Content-Type': 'application/json',
},
referrerPolicy: 'no-referrer',
body: JSON.stringify({ ...bookingData }),
})
return response.json()
}
export default function ShowBookingAdmin({
booking: bookingProp,
}: {

View File

@@ -5,25 +5,10 @@ import { getServerSideBooking } from '../../../lib/getServerSideProps'
import { Booking } from '../../../db/booking'
import { BOOKING_STATUS } from '../../../db/enums'
import { daysFormatFrontend } from '../../../helpers/date'
import { getBookingStatus } from '../../../helpers/booking'
import { getBookingStatus, cancelBooking } from '../../../helpers/booking'
export const getServerSideProps = getServerSideBooking
async function cancelBooking(booking: Booking) {
const response = await fetch(`/api/booking/${booking.uuid}`, {
method: 'PATCH',
mode: 'cors',
cache: 'no-cache',
credentials: 'same-origin',
headers: {
'Content-Type': 'application/json',
},
referrerPolicy: 'no-referrer',
body: JSON.stringify({ status: BOOKING_STATUS.CANCELED }),
})
return response.json()
}
export default function ShowBooking({
booking: bookingProp,
}: {
@@ -44,7 +29,7 @@ export default function ShowBooking({
try {
setStoringBookingError(null)
setStoringBooking(true)
const updatedBooking = await cancelBooking(booking)
const updatedBooking = await cancelBooking(booking.uuid)
setBooking(updatedBooking)
} catch (error) {
setStoringBookingError(