You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
49 lines
1.1 KiB
49 lines
1.1 KiB
import { defineMessages } from 'react-intl'; |
|
|
|
const messages = defineMessages({ |
|
unexpectedTitle: { id: 'alert.unexpected.title', defaultMessage: 'Oops!' }, |
|
unexpectedMessage: { id: 'alert.unexpected.message', defaultMessage: 'An unexpected error occurred.' }, |
|
}); |
|
|
|
export const ALERT_SHOW = 'ALERT_SHOW'; |
|
export const ALERT_DISMISS = 'ALERT_DISMISS'; |
|
export const ALERT_CLEAR = 'ALERT_CLEAR'; |
|
|
|
export function dismissAlert(alert) { |
|
return { |
|
type: ALERT_DISMISS, |
|
alert, |
|
}; |
|
}; |
|
|
|
export function clearAlert() { |
|
return { |
|
type: ALERT_CLEAR, |
|
}; |
|
}; |
|
|
|
export function showAlert(title, message) { |
|
return { |
|
type: ALERT_SHOW, |
|
title, |
|
message, |
|
}; |
|
}; |
|
|
|
export function showAlertForError(error) { |
|
if (error.response) { |
|
const { data, status, statusText } = error.response; |
|
|
|
let message = statusText; |
|
let title = `${status}`; |
|
|
|
if (data.error) { |
|
message = data.error; |
|
} |
|
|
|
return showAlert(title, message); |
|
} else { |
|
console.error(error); |
|
return showAlert(messages.unexpectedTitle, messages.unexpectedMessage); |
|
} |
|
}
|
|
|