1
0
mirror of https://github.com/lexogrine/cs2-react-hud.git synced 2025-12-10 03:52:48 +01:00

58 lines
2.2 KiB
TypeScript

import { useState } from "react";
import "./radar.scss";
import { Match, Veto } from "../../API/types";
import { Map, CSGO, Team } from 'csgogsi';
import Radar from './Radar'
import { useAction } from "../../API/contexts/actions";
interface Props { match: Match | null, map: Map, game: CSGO }
const RadarMaps = ({ match, map, game }: Props) => {
const [ radarSize, setRadarSize ] = useState(366);
const [ showBig, setShowBig ] = useState(false);
useAction('radarBigger', () => {
setRadarSize(p => p+10);
}, []);
useAction('radarSmaller', () => {
setRadarSize(p => p-10);
}, []);
useAction('toggleRadarView', () => {
setShowBig(p => !p);
}, []);
return (
<div id={`radar_maps_container`} className={` ${showBig ? 'preview':''}`}>
{match ? <MapsBar match={match} map={map} game={game} /> : null}
<Radar radarSize={showBig ? 600: radarSize} game={game} />
</div>
);
}
export default RadarMaps;
const MapsBar = ({ match, map }: Props) => {
if (!match || !match.vetos.length) return '';
const picks = match.vetos.filter(veto => veto.type !== "ban" && veto.mapName);
if (picks.length > 3) {
const current = picks.find(veto => map.name.includes(veto.mapName));
if (!current) return null;
return <div id="maps_container">
<div className="bestof">Best of {match.matchType.replace("bo", "")}</div>
{<MapEntry veto={current} map={map} team={current.type === "decider" ? null : map.team_ct.id === current.teamId ? map.team_ct : map.team_t} />}
</div>
}
return <div id="maps_container">
<div className="bestof">Best of {match.matchType.replace("bo", "")}</div>
{match.vetos.filter(veto => veto.type !== "ban").filter(veto => veto.teamId || veto.type === "decider").map(veto => <MapEntry key={veto.mapName} veto={veto} map={map} team={veto.type === "decider" ? null : map.team_ct.id === veto.teamId ? map.team_ct : map.team_t} />)}
</div>
}
const MapEntry = ({ veto, map }: { veto: Veto, map: Map, team: Team | null }) => {
return <div className="veto_entry">
<div className={`map_name ${map.name.includes(veto.mapName) ? 'active' : ''}`}>{veto.mapName.replace("de_", "")}</div>
</div>
}