From 4a0b1c3cda356bd1ebcc7a8fa25de7a3a2f3dd6b Mon Sep 17 00:00:00 2001 From: Jannik Hollenbach Date: Sat, 23 Sep 2023 12:31:43 +0200 Subject: [PATCH] Show a more helpful error message when the max instance limit is reached Closes UI: Improve Feedback for Maximum Instances Limit Reached in Juice-Shop #179 --- juice-balancer/ui/src/pages/JoinPage.js | 44 ++++++++++++++++++++----- 1 file changed, 36 insertions(+), 8 deletions(-) diff --git a/juice-balancer/ui/src/pages/JoinPage.js b/juice-balancer/ui/src/pages/JoinPage.js index a48d0c0cd..558bda07a 100644 --- a/juice-balancer/ui/src/pages/JoinPage.js +++ b/juice-balancer/ui/src/pages/JoinPage.js @@ -7,17 +7,36 @@ import { BodyCard, H2, Label, Input, Form, Button } from '../Components'; import { InstanceRestartingCard } from '../cards/InstanceRestartingCard'; import { InstanceNotFoundCard } from '../cards/InstanceNotFoundCard'; import { TeamDisplayCard } from '../cards/TeamDisplayCard'; +import styled from 'styled-components'; const messages = defineMessages({ teamnameValidationConstraints: { id: 'teamname_validation_constraints', - defaultMessage: "Teamnames must have at least 3 characters and consist of lowercase letters, numbers or '-'", + defaultMessage: + "Teamnames must have at least 3 characters and consist of lowercase letters, numbers or '-'", }, }); +const ErrorBox = styled.div` + border: 1px solid red; + border-radius: 4px; + margin: 1rem 0; + padding: 0.5rem; + background-color: rgba(255, 0, 0, 0.1); + + display: flex; + flex-direction: column; + align-items: center; + gap: 0.5rem; + + p { + margin: 0; + } +`; + export const JoinPage = injectIntl(({ intl }) => { const [teamname, setTeamname] = useState(''); - const [failed, setFailed] = useState(false); + const [failureMessage, setFailureMessage] = useState(null); const navigate = useNavigate(); const location = useLocation(); @@ -41,15 +60,23 @@ export const JoinPage = injectIntl(({ intl }) => { passcode, }); - navigate(`/teams/${teamname}/joined/`, { state: { passcode: data.passcode }}); + setFailureMessage(null); + navigate(`/teams/${teamname}/joined/`, { state: { passcode: data.passcode } }); } catch (error) { if ( error.response.status === 401 && error.response.data.message === 'Team requires authentication to join' ) { navigate(`/teams/${teamname}/joining/`); + } else if ( + error.response.status === 500 && + error.response.data.message === 'Reached Maximum Instance Count' + ) { + setFailureMessage( + 'Max instances reached, contact admin or join another team to participate.' + ); } else { - setFailed(true); + setFailureMessage('Unexpected error. Please contact an admin.'); } } } @@ -85,15 +112,16 @@ export const JoinPage = injectIntl(({ intl }) => { }} /> - {failed ? ( -

+ {failureMessage !== null ? ( + -

+

{failureMessage}

+ ) : null}