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

Merge pull request #1 from lexogrine/refactor

Added option to replace avatars as team logos
This commit is contained in:
Hubert Walczak 2023-10-19 12:00:07 +02:00 committed by GitHub
commit 44f173f23c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 50 additions and 6 deletions

View File

@ -63,6 +63,21 @@
"name":"right_image", "name":"right_image",
"label":"Right box's image logo" "label":"Right box's image logo"
}, },
{
"type":"select",
"name":"replace_avatars",
"label":"Use team logos as player avatars",
"values": [
{
"label": "Only if player has no avatar",
"name": "if_missing"
},
{
"label": "Always",
"name": "always"
}
]
},
{ {
"type": "action", "type": "action",
"name": "boxesState", "name": "boxesState",

View File

@ -5,9 +5,12 @@ import PlayerCamera from "./../Camera/Camera";
import { avatars } from './../../api/avatars'; import { avatars } from './../../api/avatars';
import { Skull } from './../../assets/Icons'; import { Skull } from './../../assets/Icons';
import { configs } from '../../App';
import { apiUrl } from '../../api/api';
interface IProps { interface IProps {
steamid: string, steamid: string,
teamId?: string | null,
slot?: number, slot?: number,
height?: number, height?: number,
width?: number, width?: number,
@ -15,13 +18,39 @@ interface IProps {
showCam?: boolean, showCam?: boolean,
sidePlayer?: boolean sidePlayer?: boolean
} }
export default class Avatar extends React.Component<IProps> { export default class Avatar extends React.Component<IProps, { replaceAvatar: 'never' | 'if_missing' | 'always' }> {
constructor(props: IProps){
super(props);
this.state = {
replaceAvatar: 'never'
}
}
componentDidMount() {
const onDataChange = (data:any) => {
if(!data) return;
const display = data.display_settings;
if(!display) return;
this.setState({
replaceAvatar: display.replace_avatars || 'never'
})
};
configs.onChange(onDataChange);
onDataChange(configs.data);
}
getAvatarUrl = () => {
const avatarData = avatars[this.props.steamid] && avatars[this.props.steamid].url ? avatars[this.props.steamid].url : null;
if(this.state.replaceAvatar === 'always' || (this.state.replaceAvatar === 'if_missing' && !avatarData)){
return this.props.teamId ? `${apiUrl}api/teams/logo/${this.props.teamId}` : avatarData || null;
}
return avatarData || null;
}
render() { render() {
const { showCam, steamid, width, height, showSkull, sidePlayer } = this.props; const { showCam, steamid, width, height, showSkull, sidePlayer } = this.props;
//const url = avatars.filter(avatar => avatar.steamid === this.props.steamid)[0]; //const url = avatars.filter(avatar => avatar.steamid === this.props.steamid)[0];
const avatarData = avatars[this.props.steamid]; const avatarUrl = this.getAvatarUrl();
if (!avatarData || !avatarData.url) { if (!avatarUrl) {
return null; return null;
} }
@ -31,7 +60,7 @@ export default class Avatar extends React.Component<IProps> {
showCam ? ( sidePlayer ? <div className="videofeed"><PlayerCamera steamid={steamid} visible={true} /></div> : <CameraContainer observedSteamid={steamid} />) : null showCam ? ( sidePlayer ? <div className="videofeed"><PlayerCamera steamid={steamid} visible={true} /></div> : <CameraContainer observedSteamid={steamid} />) : null
} }
{ {
showSkull ? <Skull height={height} width={width} /> : <img src={avatarData.url} height={height} width={width} alt={'Avatar'} /> showSkull ? <Skull height={height} width={width} /> : <img src={avatarUrl} height={height} width={width} alt={'Avatar'} />
} }
</div> </div>

View File

@ -58,7 +58,7 @@ export default class Observed extends React.Component<{ player: Player | null, v
return ( return (
<div className={`observed ${player.team.side}`}> <div className={`observed ${player.team.side}`}>
<div className="main_row"> <div className="main_row">
{<Avatar steamid={player.steamid} height={140} width={140} showCam={this.state.showCam} slot={player.observer_slot} />} {<Avatar teamId={player.team.id} steamid={player.steamid} height={140} width={140} showCam={this.state.showCam} slot={player.observer_slot} />}
<TeamLogo team={player.team} height={35} width={35} /> <TeamLogo team={player.team} height={35} width={35} />
<div className="username_container"> <div className="username_container">
<div className="username">{player.name}</div> <div className="username">{player.name}</div>

View File

@ -76,7 +76,7 @@ const Player = ({ player, isObserved }: IProps) => {
return ( return (
<div className={`player ${player.state.health === 0 ? "dead" : ""} ${isObserved ? 'active' : ''}`}> <div className={`player ${player.state.health === 0 ? "dead" : ""} ${isObserved ? 'active' : ''}`}>
<div className="player_data"> <div className="player_data">
<Avatar steamid={player.steamid} height={57} width={57} showSkull={false} showCam={false} sidePlayer={true} /> <Avatar teamId={player.team.id} steamid={player.steamid} height={57} width={57} showSkull={false} showCam={false} sidePlayer={true} />
<div className="dead-stats"> <div className="dead-stats">
<div className="labels"> <div className="labels">
<div className="stat-label">K</div> <div className="stat-label">K</div>