mirror of
https://github.com/getredash/redash.git
synced 2025-12-23 20:01:59 -05:00
* ErrorMessage is not centered * Adjust ErrorMessage size on large screens Co-authored-by: Gabriel Dutra <nesk.frz@gmail.com> Co-authored-by: Gabriel Dutra <nesk.frz@gmail.com>
58 lines
1.5 KiB
JavaScript
58 lines
1.5 KiB
JavaScript
import { isObject, get } from "lodash";
|
||
import React from "react";
|
||
import PropTypes from "prop-types";
|
||
|
||
import "./ErrorMessage.less";
|
||
|
||
function getErrorMessageByStatus(status, defaultMessage) {
|
||
switch (status) {
|
||
case 404:
|
||
return "It seems like the page you're looking for cannot be found.";
|
||
case 401:
|
||
case 403:
|
||
return "It seems like you don’t have permission to see this page.";
|
||
default:
|
||
return defaultMessage;
|
||
}
|
||
}
|
||
|
||
function getErrorMessage(error) {
|
||
const message = "It seems like we encountered an error. Try refreshing this page or contact your administrator.";
|
||
if (isObject(error)) {
|
||
// HTTP errors
|
||
if (error.isAxiosError && isObject(error.response)) {
|
||
return getErrorMessageByStatus(error.response.status, get(error, "response.data.message", message));
|
||
}
|
||
// Router errors
|
||
if (error.status) {
|
||
return getErrorMessageByStatus(error.status, message);
|
||
}
|
||
}
|
||
return message;
|
||
}
|
||
|
||
export default function ErrorMessage({ error }) {
|
||
if (!error) {
|
||
return null;
|
||
}
|
||
|
||
console.error(error);
|
||
|
||
return (
|
||
<div className="error-message-container" data-test="ErrorMessage">
|
||
<div className="error-state bg-white tiled">
|
||
<div className="error-state__icon">
|
||
<i className="zmdi zmdi-alert-circle-o" />
|
||
</div>
|
||
<div className="error-state__details">
|
||
<h4>{getErrorMessage(error)}</h4>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
);
|
||
}
|
||
|
||
ErrorMessage.propTypes = {
|
||
error: PropTypes.object.isRequired,
|
||
};
|