import axios from 'axios';
import React, { useEffect, useState } from 'react';
+import { Helmet } from 'react-helmet';
import { useParams } from 'react-router-dom';
+import CanonicalLinks from '../common/CanonicalLinks';
import ErrorBoundary from '../common/ErrorBoundary';
import ErrorMessage from '../common/ErrorMessage';
import Loading from '../common/Loading';
patchResult,
patchRound,
patchUser,
+ removeApplication,
sortParticipants,
} from '../../helpers/Tournament';
const [tournament, setTournament] = useState(null);
useEffect(() => {
+ const ctrl = new AbortController();
setLoading(true);
axios
- .get(`/api/tournaments/${id}`)
+ .get(`/api/tournaments/${id}`, { signal: ctrl.signal })
.then(response => {
setError(null);
setLoading(false);
setTournament(sortParticipants(response.data));
- window.document.title = response.data.title;
})
.catch(error => {
setError(error);
setLoading(false);
setTournament(null);
});
+ return () => {
+ ctrl.abort();
+ };
}, [id]);
useEffect(() => {
setTournament(tournament => patchApplication(tournament, e.application));
}
})
+ .listen('ApplicationRemoved', e => {
+ if (e.application_id) {
+ setTournament(tournament => removeApplication(tournament, e.application_id));
+ }
+ })
.listen('ParticipantChanged', e => {
+ console.log(e);
if (e.participant) {
setTournament(tournament => patchParticipant(tournament, e.participant));
}
};
return <ErrorBoundary>
+ <Helmet>
+ <title>{tournament.title}</title>
+ </Helmet>
+ <CanonicalLinks base={`/tournaments/${tournament.id}`} />
<Detail addRound={addRound} tournament={tournament} />
</ErrorBoundary>;
};