1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { useRouter } from 'vue-router'
- import { redirectToError } from '#shared/router/error.ts'
- import type { GraphQLHandlerError } from '#shared/types/error.ts'
- import { ErrorStatusCodes, GraphQLErrorTypes } from '#shared/types/error.ts'
- interface ErrorMessages {
- notFound?: string
- forbidden?: string
- }
- export const useErrorHandler = () => {
- const router = useRouter()
- const createQueryErrorHandler = (messages: ErrorMessages) => {
- return (errorHandler: GraphQLHandlerError) => {
- let title: string
- let message: string | undefined
- let messagePlaceholder: string[] = []
- let statusCode: number
- if (errorHandler.type === GraphQLErrorTypes.RecordNotFound) {
- title = __('Not Found')
- message = messages.notFound
- statusCode = ErrorStatusCodes.NotFound
- } else if (errorHandler.type === GraphQLErrorTypes.Forbidden) {
- title = __('Forbidden')
- message = messages.forbidden
- statusCode = ErrorStatusCodes.Forbidden
- } else if (errorHandler.type !== GraphQLErrorTypes.NotAuthorized) {
- title = __('Internal Error')
- message = errorHandler.message
- ? __('Something went wrong. Received message: %s')
- : __('Something went wrong.')
- messagePlaceholder = errorHandler.message ? [errorHandler.message] : []
- statusCode = ErrorStatusCodes.InternalError
- } else {
- return true
- }
- redirectToError(router, {
- title,
- message,
- messagePlaceholder,
- statusCode,
- })
- // don't show the notification
- return false
- }
- }
- return {
- createQueryErrorHandler,
- }
- }
|