mirror of
https://github.com/sussy-code/smov.git
synced 2024-12-21 14:47:41 +01:00
27 lines
990 B
JavaScript
27 lines
990 B
JavaScript
import React from 'react';
|
|
// import { Arrow } from './Arrow';
|
|
import './NumberSelector.css'
|
|
import { PercentageOverlay } from './PercentageOverlay';
|
|
|
|
// setType: (txt: string) => void
|
|
// choices: { label: string, value: string }[]
|
|
// selected: string
|
|
export function NumberSelector({ setType, choices, selected }) {
|
|
const handleKeyPress = choice => event => {
|
|
if (event.code === 'Space' || event.code === 'Enter'){
|
|
setType(choice);
|
|
}
|
|
}
|
|
return (
|
|
<div className="numberSelector">
|
|
{choices.map(v=>(
|
|
<div key={v.value} className="choiceWrapper" tabIndex={0} onKeyPress={handleKeyPress(v.value)}>
|
|
<div className={`choice ${selected&&selected===v.value?'selected':''}`} onClick={() => setType(v.value)}>
|
|
{v.label}
|
|
<PercentageOverlay percentage={v.percentage} />
|
|
</div>
|
|
</div>
|
|
))}
|
|
</div>
|
|
)
|
|
}
|