Feat/SW-755 price change non happy * fix(SW-755): dont show field error if checkbox has no children * feat(SW-755): Price change route + dialog WIP * fix(SW-755): minor refactoring * fix(SW-755): added logging to price change route * fix(SW-755): remove redundant search param logic * fix(SW-755): moved enum cast to zod instead * fix(SW-755): move prop type to types folder * fix(SW-755): Added suspense to Payment and refactored payment options hook * fix(SW-755): seperated terms and conditions copy from the checkbox label * fix(SW-755): add currency format and fixed wrong translation * fix(SW-755): change from undefined to null * fix(SW-755): added extra type safety to payment options Approved-by: Christian Andolf Approved-by: Simon.Emanuelsson
49 lines
1.5 KiB
TypeScript
49 lines
1.5 KiB
TypeScript
"use client"
|
|
|
|
import { usePathname, useRouter, useSearchParams } from "next/navigation"
|
|
import { useCallback, useEffect } from "react"
|
|
import { useIntl } from "react-intl"
|
|
|
|
import { PaymentErrorCodeEnum } from "@/constants/booking"
|
|
|
|
import { toast } from "@/components/TempDesignSystem/Toasts"
|
|
|
|
export function usePaymentFailedToast() {
|
|
const intl = useIntl()
|
|
const searchParams = useSearchParams()
|
|
const pathname = usePathname()
|
|
const router = useRouter()
|
|
|
|
const getErrorMessage = useCallback(
|
|
(errorCode: PaymentErrorCodeEnum) => {
|
|
switch (errorCode) {
|
|
case PaymentErrorCodeEnum.Cancelled:
|
|
return intl.formatMessage({ id: "payment.error.cancelled" })
|
|
default:
|
|
return intl.formatMessage({ id: "payment.error.failed" })
|
|
}
|
|
},
|
|
[intl]
|
|
)
|
|
|
|
const errorCodeString = searchParams.get("errorCode")
|
|
const errorCode = Number(errorCodeString) as PaymentErrorCodeEnum
|
|
const errorMessage = getErrorMessage(errorCode)
|
|
|
|
useEffect(() => {
|
|
if (!errorCode) return
|
|
|
|
// setTimeout is needed to show toasts on page load: https://sonner.emilkowal.ski/toast#render-toast-on-page-load
|
|
setTimeout(() => {
|
|
const toastType =
|
|
errorCode === PaymentErrorCodeEnum.Cancelled ? "warning" : "error"
|
|
|
|
toast[toastType](errorMessage)
|
|
})
|
|
|
|
const queryParams = new URLSearchParams(searchParams.toString())
|
|
queryParams.delete("errorCode")
|
|
router.push(`${pathname}?${queryParams.toString()}`)
|
|
}, [searchParams, pathname, errorCode, errorMessage, router])
|
|
}
|