mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-28 12:11:08 -04:00
207 lines
5.3 KiB
JavaScript
207 lines
5.3 KiB
JavaScript
import { useAuthStore } from '@/scripts/admin/stores/auth'
|
|
import { useNotificationStore } from '@/scripts/stores/notification'
|
|
|
|
export const handleError = (err) => {
|
|
const authStore = useAuthStore()
|
|
const notificationStore = useNotificationStore()
|
|
|
|
if (!err.response) {
|
|
notificationStore.showNotification({
|
|
type: 'error',
|
|
message:
|
|
'Please check your internet connection or wait until servers are back online.',
|
|
})
|
|
} else {
|
|
if (
|
|
err.response.data &&
|
|
(err.response.statusText === 'Unauthorized' ||
|
|
err.response.data === ' Unauthorized.')
|
|
) {
|
|
// Unauthorized and log out
|
|
const msg = err.response.data.message
|
|
? err.response.data.message
|
|
: 'Unauthorized'
|
|
|
|
showToaster(msg)
|
|
|
|
authStore.logout()
|
|
} else if (err.response.data.errors) {
|
|
// Show a notification per error
|
|
const errors = JSON.parse(JSON.stringify(err.response.data.errors))
|
|
for (const i in errors) {
|
|
showError(errors[i][0])
|
|
}
|
|
} else if (err.response.data.error) {
|
|
if (typeof err.response.data.error == 'boolean') showError(err.response.data?.message)
|
|
else showError(err.response.data.error)
|
|
} else {
|
|
showError(err.response.data.message)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const showError = (error) => {
|
|
switch (error) {
|
|
case 'These credentials do not match our records.':
|
|
showToaster('errors.login_invalid_credentials')
|
|
break
|
|
case 'invalid_key':
|
|
showToaster('errors.invalid_provider_key')
|
|
break
|
|
|
|
case 'This feature is available on Starter plan and onwards!':
|
|
showToaster('errors.starter_plan')
|
|
break
|
|
|
|
case 'taxes_attached':
|
|
showToaster('settings.tax_types.already_in_use')
|
|
break
|
|
|
|
case 'expense_attached':
|
|
showToaster('settings.expense_category.already_in_use')
|
|
break
|
|
|
|
case 'payments_attached':
|
|
showToaster('settings.payment_modes.payments_attached')
|
|
break
|
|
|
|
case 'expenses_attached':
|
|
showToaster('settings.payment_modes.expenses_attached')
|
|
break
|
|
|
|
case 'role_attached_to_users':
|
|
showToaster('settings.roles.already_in_use')
|
|
break
|
|
|
|
case 'items_attached':
|
|
showToaster('settings.customization.items.already_in_use')
|
|
break
|
|
|
|
case 'payment_attached_message':
|
|
showToaster('invoices.payment_attached_message')
|
|
break
|
|
|
|
case 'The email has already been taken.':
|
|
showToaster('validation.email_already_taken')
|
|
break
|
|
|
|
case 'Relation estimateItems exists.':
|
|
showToaster('items.item_attached_message')
|
|
break
|
|
|
|
case 'Relation invoiceItems exists.':
|
|
showToaster('items.item_attached_message')
|
|
break
|
|
|
|
case 'Relation taxes exists.':
|
|
showToaster('settings.tax_types.already_in_use')
|
|
break
|
|
|
|
case 'Relation taxes exists.':
|
|
showToaster('settings.tax_types.already_in_use')
|
|
break
|
|
|
|
case 'Relation payments exists.':
|
|
showToaster('errors.payment_attached')
|
|
break
|
|
|
|
case 'The estimate number has already been taken.':
|
|
showToaster('errors.estimate_number_used')
|
|
break
|
|
|
|
case 'The payment number has already been taken.':
|
|
showToaster('errors.estimate_number_used')
|
|
break
|
|
|
|
case 'The invoice number has already been taken.':
|
|
showToaster('errors.invoice_number_used')
|
|
break
|
|
|
|
case 'The name has already been taken.':
|
|
showToaster('errors.name_already_taken')
|
|
break
|
|
|
|
case 'total_invoice_amount_must_be_more_than_paid_amount':
|
|
showToaster('invoices.invalid_due_amount_message')
|
|
break
|
|
|
|
case 'you_cannot_edit_currency':
|
|
showToaster('customers.edit_currency_not_allowed')
|
|
break
|
|
|
|
case 'receipt_does_not_exist':
|
|
showToaster('errors.receipt_does_not_exist')
|
|
break
|
|
|
|
case 'customer_cannot_be_changed_after_payment_is_added':
|
|
showToaster('errors.customer_cannot_be_changed_after_payment_is_added')
|
|
break
|
|
|
|
case 'invalid_credentials':
|
|
showToaster('errors.invalid_credentials')
|
|
break
|
|
|
|
case 'not_allowed':
|
|
showToaster('errors.not_allowed')
|
|
break
|
|
|
|
case 'invalid_key':
|
|
showToaster('errors.invalid_key')
|
|
break
|
|
|
|
case 'invalid_state':
|
|
showToaster('errors.invalid_state')
|
|
break
|
|
|
|
case 'invalid_city':
|
|
showToaster('errors.invalid_city')
|
|
break
|
|
|
|
case 'invalid_postal_code':
|
|
showToaster('errors.invalid_postal_code')
|
|
break
|
|
|
|
case 'invalid_format':
|
|
showToaster('errors.invalid_format')
|
|
break
|
|
|
|
case 'api_error':
|
|
showToaster('errors.api_error')
|
|
break
|
|
|
|
case 'feature_not_enabled':
|
|
showToaster('errors.feature_not_enabled')
|
|
break
|
|
|
|
case 'request_limit_met':
|
|
showToaster('errors.request_limit_met')
|
|
break
|
|
|
|
case 'address_incomplete':
|
|
showToaster('errors.address_incomplete')
|
|
break
|
|
|
|
case 'invalid_address':
|
|
showToaster('errors.invalid_address')
|
|
break
|
|
|
|
case 'Email could not be sent to this email address.':
|
|
showToaster('errors.email_could_not_be_sent')
|
|
break
|
|
|
|
default:
|
|
showToaster(error, false)
|
|
break
|
|
}
|
|
}
|
|
|
|
export const showToaster = (msg, t = true) => {
|
|
const { global } = window.i18n
|
|
const notificationStore = useNotificationStore()
|
|
|
|
notificationStore.showNotification({
|
|
type: 'error',
|
|
message: t ? global.t(msg) : msg,
|
|
})
|
|
}
|