Files
Nitro-V3/src/components/wired/views/actions/WiredActionGiveScoreToPredefinedTeamView.tsx
T
2026-03-21 14:27:57 +01:00

66 lines
2.8 KiB
TypeScript

import { FC, useEffect, useState } from 'react';
import { LocalizeText, WiredFurniType } from '../../../../api';
import { Slider, Text } from '../../../../common';
import { useWired } from '../../../../hooks';
import { WiredActionBaseView } from './WiredActionBaseView';
export const WiredActionGiveScoreToPredefinedTeamView: FC<{}> = props =>
{
const [ points, setPoints ] = useState(1);
const [ operation, setOperation ] = useState(0);
const [ selectedTeam, setSelectedTeam ] = useState(1);
const { trigger = null, setIntParams = null } = useWired();
const save = () => setIntParams([ points, operation, selectedTeam ]);
useEffect(() =>
{
if(trigger.intData.length >= 3)
{
setPoints(trigger.intData[0]);
setOperation(trigger.intData[1]);
setSelectedTeam(trigger.intData[2]);
}
else
{
setPoints(1);
setOperation(0);
setSelectedTeam(1);
}
}, [ trigger ]);
return (
<WiredActionBaseView hasSpecialInput={ true } requiresFurni={ WiredFurniType.STUFF_SELECTION_OPTION_NONE } save={ save }>
<div className="flex flex-col gap-1">
<Text bold>{ LocalizeText('wiredfurni.params.setpoints', [ 'points' ], [ points.toString() ]) }</Text>
<Slider
max={ 100 }
min={ 1 }
value={ points }
onChange={ event => setPoints(event) } />
</div>
<div className="flex flex-col gap-1">
<Text bold>{ LocalizeText('wiredfurni.params.choose_type') }</Text>
{ [ 0, 1 ].map(value => (
<label key={ value } className="flex items-center gap-1">
<input checked={ (operation === value) } className="form-check-input" name="pointsOperation" type="radio" onChange={ () => setOperation(value) } />
<Text>{ LocalizeText(`wiredfurni.params.points_operation.${ value }`) }</Text>
</label>
)) }
</div>
<div className="flex flex-col gap-1">
<Text bold>{ LocalizeText('wiredfurni.params.team') }</Text>
{ [ 1, 2, 3, 4 ].map(value =>
{
return (
<div key={ value } className="flex gap-1">
<input checked={ (selectedTeam === value) } className="form-check-input" id={ `selectedTeam${ value }` } name="selectedTeam" type="radio" onChange={ event => setSelectedTeam(value) } />
<Text>{ LocalizeText('wiredfurni.params.team.' + value) }</Text>
</div>
);
}) }
</div>
</WiredActionBaseView>
);
};