Feature/select rate vertical data flow * add fix from SW-2666 * use translations for room packages * move types to it's own file * Merge branch 'master' of bitbucket.org:scandic-swap/web into feature/select-rate-vertical-data-flow * merge * feature/select-rate: double rate for campaing rates * revert NODE_ENV check in Cookiebot script * revert testing values * fix(SW-3171): fix all filter selected in price details * fix(SW-3166): multiroom anchoring when changing filter * fix(SW-3172): check hotelType, show correct breakfast message * Merge branch 'feature/select-rate-vertical-data-flow' of bitbucket.org:scandic-swap/web into feature/select-rate-vertical-data-flow * fix: show special needs icons for subsequent roomTypes SW-3167 * fix: Display strike through text when logged in SW-3168 * fix: Reinstate the scrollToView behaviour when selecting a rate SW-3169 * merge * . * PR fixes * fix: don't return notFound() * . * always include defaults for room packages * merge * merge * merge * Remove floating h1 for new select-rate Approved-by: Anton Gunnarsson
56 lines
1.4 KiB
TypeScript
56 lines
1.4 KiB
TypeScript
import * as Sentry from "@sentry/nextjs"
|
|
import React from "react"
|
|
|
|
import { logger } from "@scandic-hotels/common/logger"
|
|
|
|
type ErrorBoundaryProps = {
|
|
children: React.ReactNode
|
|
fallback?: React.ReactNode
|
|
}
|
|
type ErrorBoundaryState = { hasError: boolean; error?: Error }
|
|
|
|
export class ErrorBoundary extends React.Component<
|
|
ErrorBoundaryProps,
|
|
ErrorBoundaryState
|
|
> {
|
|
constructor(props: ErrorBoundaryProps) {
|
|
super(props)
|
|
this.state = { hasError: false }
|
|
}
|
|
|
|
static getDerivedStateFromError(error: Error) {
|
|
return { hasError: true, error }
|
|
}
|
|
|
|
componentDidCatch(error: Error, errorInfo: React.ErrorInfo) {
|
|
logger.error("ErrorBoundary caught an error:", error, errorInfo)
|
|
Sentry.captureException(error, { extra: { errorInfo } })
|
|
}
|
|
|
|
render() {
|
|
if (this.state.hasError) {
|
|
const hasFallback = !!this.props.fallback
|
|
|
|
return (
|
|
<>
|
|
{hasFallback && this.props.fallback}
|
|
{!hasFallback && (
|
|
// eslint-disable-next-line formatjs/no-literal-string-in-jsx
|
|
<h2>Something went wrong.</h2>
|
|
)}
|
|
{process.env.NODE_ENV === "development" && (
|
|
// eslint-disable-next-line formatjs/no-literal-string-in-jsx
|
|
<button onClick={() => this.setState({ hasError: false })}>
|
|
Reset
|
|
</button>
|
|
)}
|
|
</>
|
|
)
|
|
|
|
return this.props.fallback
|
|
}
|
|
|
|
return this.props.children
|
|
}
|
|
}
|