YellowBox: Use Feather Icons for Navigation

Summary: Changes YellowBox to use feather icons for the left and right navigation so that we are not dependent on the system's (sometimes funky) unicode icons.

Reviewed By: ejanzer

Differential Revision: D9759134

fbshipit-source-id: b957c24afdccc04bfe78ae4750777c387c2acef4
This commit is contained in:
Tim Yung 2018-09-11 20:38:57 -07:00 committed by Facebook Github Bot
parent 686ff70d96
commit 5e6e5e92ca
2 changed files with 23 additions and 10 deletions

View File

@ -41,6 +41,18 @@ const YellowBoxImageSource = {
: scale > 1 : scale > 1
? '' ? ''
: '', : '',
chevronLeft:
scale > 2
? ''
: scale > 1
? ''
: '',
chevronRight:
scale > 2
? ''
: scale > 1
? ''
: '',
loader: loader:
scale > 2 scale > 2
? '' ? ''

View File

@ -10,13 +10,14 @@
'use strict'; 'use strict';
const Image = require('Image');
const Platform = require('Platform'); const Platform = require('Platform');
const React = require('React'); const React = require('React');
const SafeAreaView = require('SafeAreaView'); const SafeAreaView = require('SafeAreaView');
const StyleSheet = require('StyleSheet'); const StyleSheet = require('StyleSheet');
const Text = require('Text'); const Text = require('Text');
const UTFSequence = require('UTFSequence');
const View = require('View'); const View = require('View');
const YellowBoxImageSource = require('YellowBoxImageSource');
const YellowBoxPressable = require('YellowBoxPressable'); const YellowBoxPressable = require('YellowBoxPressable');
const YellowBoxStyle = require('YellowBoxStyle'); const YellowBoxStyle = require('YellowBoxStyle');
@ -42,7 +43,7 @@ const YellowBoxInspectorHeader = (props: Props): React.Node => {
<View style={styles.header}> <View style={styles.header}>
<YellowBoxInspectorHeaderButton <YellowBoxInspectorHeaderButton
disabled={props.warnings[prevIndex] == null} disabled={props.warnings[prevIndex] == null}
label={UTFSequence.TRIANGLE_LEFT} image={YellowBoxImageSource.chevronLeft}
onPress={() => props.onSelectIndex(prevIndex)} onPress={() => props.onSelectIndex(prevIndex)}
/> />
<View style={styles.headerTitle}> <View style={styles.headerTitle}>
@ -50,7 +51,7 @@ const YellowBoxInspectorHeader = (props: Props): React.Node => {
</View> </View>
<YellowBoxInspectorHeaderButton <YellowBoxInspectorHeaderButton
disabled={props.warnings[nextIndex] == null} disabled={props.warnings[nextIndex] == null}
label={UTFSequence.TRIANGLE_RIGHT} image={YellowBoxImageSource.chevronRight}
onPress={() => props.onSelectIndex(nextIndex)} onPress={() => props.onSelectIndex(nextIndex)}
/> />
</View> </View>
@ -61,7 +62,7 @@ const YellowBoxInspectorHeader = (props: Props): React.Node => {
const YellowBoxInspectorHeaderButton = ( const YellowBoxInspectorHeaderButton = (
props: $ReadOnly<{| props: $ReadOnly<{|
disabled: boolean, disabled: boolean,
label: React.Node, image: string,
onPress?: ?() => void, onPress?: ?() => void,
|}>, |}>,
): React.Node => ( ): React.Node => (
@ -73,7 +74,10 @@ const YellowBoxInspectorHeaderButton = (
onPress={props.disabled ? null : props.onPress} onPress={props.disabled ? null : props.onPress}
style={styles.headerButton}> style={styles.headerButton}>
{props.disabled ? null : ( {props.disabled ? null : (
<Text style={styles.headerButtonText}>{props.label}</Text> <Image
source={{height: 16, uri: props.image, width: 16}}
style={styles.headerButtonImage}
/>
)} )}
</YellowBoxPressable> </YellowBoxPressable>
); );
@ -94,11 +98,8 @@ const styles = StyleSheet.create({
aspectRatio: 1, aspectRatio: 1,
justifyContent: 'center', justifyContent: 'center',
}, },
headerButtonText: { headerButtonImage: {
color: YellowBoxStyle.getTextColor(1), tintColor: YellowBoxStyle.getTextColor(1),
fontSize: 16,
includeFontPadding: false,
lineHeight: 20,
}, },
headerTitle: { headerTitle: {
alignItems: 'center', alignItems: 'center',