Я пытаюсь применить активный цвет для значка, по которому щелкнули (Список и Сетка), но не смог найти правильного решения с тех пор, как перешел в RN. Я вставил код компонента отдельно для справки.
КОД:
export default class Gallery extends Component {
state = {
loading: true,
gridView: true,
iconColor: "#ccc"
};
changeViewList = () => {
this.setState({ gridView: false });
};
changeViewGrid = () => {
this.setState({ gridView: true });
};
render() {
const { imageData, loading } = this.state;
return (
<View style={{ flex: 1 }}>
<TouchableOpacity activeOpacity={0.8} onPress={this.changeViewGrid}>
<Icon name="th-large" size={25} color={this.state.iconColor} />
</TouchableOpacity>
<TouchableOpacity activeOpacity={0.8} onPress={this.changeViewList}>
<Icon name="list" size={25} style={styles.iconAlign} color= {this.state.iconColor} />
</TouchableOpacity>
</View>
);
}
}
const styles = StyleSheet.create({
btnDesign: {
padding: 10,
backgroundColor: "#e45",
width: "30%",
alignSelf: "center",
marginBottom: 10
},
btnText: {
color: "#fff",
textAlign: "center",
alignSelf: "center"
}
});
Ссылка на изображение:
data:image/s3,"s3://crabby-images/10c26/10c26d40efdfd96e4ab5deca1c99146bb2f24f83" alt="app image"
Ожидается:
Список
data:image/s3,"s3://crabby-images/626cd/626cdf2d48c42b75287d9c28d3438160a73a890a" alt="enter image description here"
Вид сетки
data:image/s3,"s3://crabby-images/b66a6/b66a6f0c038dd8368ef5046d2822953295846c46" alt="enter image description here"