Material-UI: componente di valutazione, cambia colore in base al valore
Obbiettivo
Per cambiare il colore delle valutazioni (un componente dell'interfaccia utente del materiale) in base al valore durante il passaggio del mouse. Ad esempio, se mi muovo sulla prima stella, il colore diventa rosso, se sulla quinta stella diventa verde.

Ho provato a creare un componente personalizzato che cambia colore al passaggio del mouse, come questo -
const StyledRating = withStyles({
root: {
color: "#ff6d75",
},
iconFilled: {
color: '#ff6d75',
},
iconHover: {
color: '#fff',
backgroundColor: "#000",
},
})(Rating);
Ma cambia tutto il colore delle icone.
Qualcuno può guidarmi, come cambiare icone specifiche nel colore delle valutazioni in base al valore che seleziono o su cui mi metto il mouse.
Collegamento sandbox corrente .
Risposte
Puoi usare lo stile dinamico ( sovrascrivere gli stili con le classi )
const useStyles = makeStyles({
root: {
// ...
},
'icon-1': { color: 'red' },
'icon-2': { color: 'coral' },
'icon-3': { color: 'orange' },
'icon-4': { color: 'skyblue' },
'icon-5': { color: 'green' }
});
export default function HoverRating() {
// ...
return (
<div className={classes.root}>
<Rating
classes={{
iconHover: classes[`icon-${Math.ceil(hover)}`]
}}
//...
/>
...
</div>
);
}
Ho formato una risposta per le persone dattiloscritte in cui dobbiamo aver dichiarato lo stato.
https://codesandbox.io/s/ratings-vksqc?file=/demo.tsx
<div className={classes.root}>
<Rating
name="hover-feedback"
value={value}
precision={1}
onChange={(event, newValue) => {
console.log(event, "This is th e event");
setValue(newValue);
switch (true) {
case newValue <= 1: {
setIconFilled(classes.iconFilled1);
break;
}
case newValue <= 2 && newValue > 1: {
setIconFilled(classes.iconFilled2);
break;
}
case newValue <= 3 && newValue > 2: {
setIconFilled(classes.iconFilled3);
break;
}
case newValue <= 4 && newValue > 3: {
setIconFilled(classes.iconFilled4);
break;
}
case newValue > 4: {
setIconFilled(classes.iconFilled5);
break;
}
}
}}
onChangeActive={(event, newHover) => {
switch (true) {
case newHover <= 1: {
setIconHover(classes.iconHover1);
break;
}
case newHover <= 2 && newHover > 1: {
setIconHover(classes.iconHover2);
break;
}
case newHover <= 3 && newHover > 2: {
setIconHover(classes.iconHover3);
break;
}
case newHover <= 4 && newHover > 3: {
setIconHover(classes.iconHover4);
break;
}
case newHover > 4: {
setIconHover(classes.iconHover5);
break;
}
}
}}
defaultValue={2}
icon={<FiberManualRecordIcon fontSize="inherit" />}
classes={{
iconFilled: iconFilledVar,
iconHover: iconHoverVar
}}
/>
</div>