2016-05-02 11:06:25 +03:00
|
|
|
import React, { PropTypes } from 'react';
|
2016-02-13 17:28:47 +02:00
|
|
|
|
2016-05-02 11:04:23 +03:00
|
|
|
import errorsDict from 'services/errorsDict';
|
2016-02-13 17:28:47 +02:00
|
|
|
import { PanelBodyHeader } from 'components/ui/Panel';
|
|
|
|
|
2016-05-22 17:01:31 +03:00
|
|
|
let autoHideTimer;
|
|
|
|
function resetTimer() {
|
|
|
|
if (autoHideTimer) {
|
|
|
|
clearTimeout(autoHideTimer);
|
|
|
|
autoHideTimer = null;
|
|
|
|
}
|
|
|
|
}
|
2016-05-02 11:06:25 +03:00
|
|
|
export default function AuthError({error, onClose = function() {}}) {
|
2016-05-22 17:01:31 +03:00
|
|
|
resetTimer();
|
|
|
|
|
2016-05-22 18:16:51 +03:00
|
|
|
if (error.payload && error.payload.canRepeatIn) {
|
2016-05-22 17:01:31 +03:00
|
|
|
if (error.payload && error.payload.canRepeatIn) {
|
|
|
|
error.payload.msLeft = error.payload.canRepeatIn * 1000;
|
|
|
|
setTimeout(onClose, error.payload.msLeft - Date.now() + 1500); // 1500 to let the user see, that time is elapsed
|
|
|
|
} else {
|
|
|
|
// TODO: it would be greate to log this case, when we will setup frontend logging
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-02 11:06:25 +03:00
|
|
|
return (
|
2016-05-22 17:01:31 +03:00
|
|
|
<PanelBodyHeader type="error" onClose={() => {
|
|
|
|
resetTimer();
|
|
|
|
onClose();
|
|
|
|
}}>
|
2016-05-02 11:06:25 +03:00
|
|
|
{errorsDict.resolve(error)}
|
|
|
|
</PanelBodyHeader>
|
|
|
|
);
|
2016-02-13 17:28:47 +02:00
|
|
|
}
|
2016-05-02 11:06:25 +03:00
|
|
|
|
|
|
|
AuthError.displayName = 'AuthError';
|
|
|
|
AuthError.propTypes = {
|
2016-05-22 17:01:31 +03:00
|
|
|
error: PropTypes.oneOfType([PropTypes.string, PropTypes.shape({
|
|
|
|
type: PropTypes.string,
|
|
|
|
payload: PropTypes.object
|
|
|
|
})]).isRequired,
|
2016-05-02 11:06:25 +03:00
|
|
|
onClose: PropTypes.func
|
|
|
|
};
|