Summary:
Moves the LogBox images from base64 data to files since base64 is not supported everywhere.

Changelog: [Internal]

Reviewed By: fkgozali

Differential Revision: D19879323

fbshipit-source-id: 2dc03eebfc712ed863ed76322e133fcad5b00bb4
This commit is contained in:
Rick Hanlon 2020-02-17 08:14:48 -08:00
Родитель c5ecc6ffff
Коммит 90e21dfd65
11 изменённых файлов: 50 добавлений и 95 удалений

Просмотреть файл

@ -1,65 +0,0 @@
/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @flow strict-local
* @format
*/
'use strict';
import PixelRatio from '../../Utilities/PixelRatio';
const scale = PixelRatio.get();
/**
* We use inline images for LogBox in order to avoid display latency due to
* resource contention with symbolicating stack traces.
*
* The following steps were used to create these:
*
* 1. Download SVG files from: https://feathericons.com
* 2. Rasterize SVG files to PNG files at 16dp, 36dp, and 48dp.
* 3. Convert to Base64: https://www.google.com/search?q=base64+image+encoder
*
* @see https://github.com/feathericons/feather
* @copyright 2013-2017 Cole Bemis
* @license MIT
*/
const LogBoxImageSource = {
alertTriangle: ((scale > 2
? ''
: scale > 1
? ''
: ''): string),
check: ((scale > 2
? ''
: scale > 1
? ''
: ''): string),
chevronLeft: ((scale > 2
? ''
: scale > 1
? ''
: ''): string),
chevronRight: ((scale > 2
? ''
: scale > 1
? ''
: ''): string),
// TOOO: properly scale
close: ((scale > 2
? ''
: scale > 1
? ''
: ''): string),
loader: ((scale > 2
? ''
: scale > 1
? ''
: ''): string),
};
export default LogBoxImageSource;

Двоичные данные
Libraries/LogBox/UI/LogBoxImages/alert-triangle.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 885 B

Двоичные данные
Libraries/LogBox/UI/LogBoxImages/chevron-left.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 201 B

Двоичные данные
Libraries/LogBox/UI/LogBoxImages/chevron-right.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 189 B

Двоичные данные
Libraries/LogBox/UI/LogBoxImages/close.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 312 B

Двоичные данные
Libraries/LogBox/UI/LogBoxImages/loader.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 550 B

Просмотреть файл

@ -17,7 +17,6 @@ import StyleSheet from '../../StyleSheet/StyleSheet';
import Text from '../../Text/Text';
import View from '../../Components/View/View';
import StatusBar from '../../Components/StatusBar/StatusBar';
import LogBoxImageSource from './LogBoxImageSource';
import LogBoxButton from './LogBoxButton';
import * as LogBoxStyle from './LogBoxStyle';
import type {LogLevel} from '../Data/LogBoxLog';
@ -54,7 +53,7 @@ function LogBoxInspectorHeader(props: Props): React.Node {
<LogBoxInspectorHeaderButton
disabled={props.total <= 1}
level={props.level}
image={LogBoxImageSource.chevronLeft}
image={require('./LogBoxImages/chevron-left.png')}
onPress={() => props.onSelectIndex(prevIndex)}
/>
<View style={styles.title}>
@ -63,7 +62,7 @@ function LogBoxInspectorHeader(props: Props): React.Node {
<LogBoxInspectorHeaderButton
disabled={props.total <= 1}
level={props.level}
image={LogBoxImageSource.chevronRight}
image={require('./LogBoxImages/chevron-right.png')}
onPress={() => props.onSelectIndex(nextIndex)}
/>
</View>
@ -94,7 +93,7 @@ const backgroundForLevel = (level: LogLevel) =>
function LogBoxInspectorHeaderButton(
props: $ReadOnly<{|
disabled: boolean,
image: string,
image: number,
level: LogLevel,
onPress?: ?() => void,
|}>,
@ -105,10 +104,7 @@ function LogBoxInspectorHeaderButton(
onPress={props.disabled ? null : props.onPress}
style={headerStyles.button}>
{props.disabled ? null : (
<Image
source={{height: 16, uri: props.image, width: 16}}
style={headerStyles.buttonImage}
/>
<Image source={props.image} style={headerStyles.buttonImage} />
)}
</LogBoxButton>
);
@ -126,6 +122,8 @@ const headerStyles = StyleSheet.create({
borderRadius: 3,
},
buttonImage: {
height: 14,
width: 8,
tintColor: LogBoxStyle.getTextColor(),
},
});

Просмотреть файл

@ -15,7 +15,6 @@ import Easing from '../../Animated/src/Easing';
import * as React from 'react';
import StyleSheet from '../../StyleSheet/StyleSheet';
import Text from '../../Text/Text';
import LogBoxImageSource from './LogBoxImageSource';
import LogBoxButton from './LogBoxButton';
import * as LogBoxStyle from './LogBoxStyle';
@ -74,11 +73,11 @@ function LogBoxInspectorSourceMapStatus(props: Props): React.Node {
let color;
switch (props.status) {
case 'FAILED':
image = LogBoxImageSource.alertTriangle;
image = require('./LogBoxImages/alert-triangle.png');
color = LogBoxStyle.getErrorColor(1);
break;
case 'PENDING':
image = LogBoxImageSource.loader;
image = require('./LogBoxImages/loader.png');
color = LogBoxStyle.getWarningColor(1);
break;
}
@ -97,7 +96,7 @@ function LogBoxInspectorSourceMapStatus(props: Props): React.Node {
onPress={props.onPress}
style={styles.root}>
<Animated.Image
source={{height: 16, uri: image, width: 16}}
source={image}
style={[
styles.image,
{tintColor: color},
@ -120,6 +119,8 @@ const styles = StyleSheet.create({
paddingHorizontal: 8,
},
image: {
height: 14,
width: 16,
marginEnd: 4,
tintColor: LogBoxStyle.getTextColor(0.4),
},

Просмотреть файл

@ -12,7 +12,6 @@
import * as React from 'react';
import Image from '../../Image/Image';
import LogBoxImageSource from './LogBoxImageSource';
import StyleSheet from '../../StyleSheet/StyleSheet';
import Text from '../../Text/Text';
import View from '../../Components/View/View';
@ -102,11 +101,7 @@ function DismissButton(props) {
onPress={props.onPress}
style={dismissStyles.press}>
<Image
source={{
width: 8,
height: 8,
uri: LogBoxImageSource.close,
}}
source={require('./LogBoxImages/close.png')}
style={dismissStyles.image}
/>
</LogBoxButton>
@ -188,6 +183,8 @@ const dismissStyles = StyleSheet.create({
justifyContent: 'center',
},
image: {
height: 8,
width: 8,
tintColor: LogBoxStyle.getBackgroundColor(1),
},
});

Просмотреть файл

@ -23,7 +23,11 @@ exports[`LogBoxInspectorHeader should render both buttons for two total 1`] = `
>
<LogBoxInspectorHeaderButton
disabled={false}
image=""
image={
Object {
"testUri": "../Libraries/LogBox/UI/LogBoxImages/chevron-left.png",
}
}
level="warn"
onPress={[Function]}
/>
@ -52,7 +56,11 @@ exports[`LogBoxInspectorHeader should render both buttons for two total 1`] = `
</View>
<LogBoxInspectorHeaderButton
disabled={false}
image=""
image={
Object {
"testUri": "../Libraries/LogBox/UI/LogBoxImages/chevron-right.png",
}
}
level="warn"
onPress={[Function]}
/>
@ -83,7 +91,11 @@ exports[`LogBoxInspectorHeader should render no buttons for one total 1`] = `
>
<LogBoxInspectorHeaderButton
disabled={true}
image=""
image={
Object {
"testUri": "../Libraries/LogBox/UI/LogBoxImages/chevron-left.png",
}
}
level="warn"
onPress={[Function]}
/>
@ -112,7 +124,11 @@ exports[`LogBoxInspectorHeader should render no buttons for one total 1`] = `
</View>
<LogBoxInspectorHeaderButton
disabled={true}
image=""
image={
Object {
"testUri": "../Libraries/LogBox/UI/LogBoxImages/chevron-right.png",
}
}
level="warn"
onPress={[Function]}
/>
@ -191,7 +207,11 @@ exports[`LogBoxInspectorHeader should render two buttons for three or more total
>
<LogBoxInspectorHeaderButton
disabled={true}
image=""
image={
Object {
"testUri": "../Libraries/LogBox/UI/LogBoxImages/chevron-left.png",
}
}
level="warn"
onPress={[Function]}
/>
@ -220,7 +240,11 @@ exports[`LogBoxInspectorHeader should render two buttons for three or more total
</View>
<LogBoxInspectorHeaderButton
disabled={true}
image=""
image={
Object {
"testUri": "../Libraries/LogBox/UI/LogBoxImages/chevron-right.png",
}
}
level="warn"
onPress={[Function]}
/>

Просмотреть файл

@ -30,16 +30,16 @@ exports[`LogBoxInspectorSourceMapStatus should render for failed 1`] = `
<ForwardRef(AnimatedComponentWrapper)
source={
Object {
"height": 16,
"uri": "",
"width": 16,
"testUri": "../Libraries/LogBox/UI/LogBoxImages/alert-triangle.png",
}
}
style={
Array [
Object {
"height": 14,
"marginEnd": 4,
"tintColor": "rgba(255, 255, 255, 0.4)",
"width": 16,
},
Object {
"tintColor": "rgba(243, 83, 105, 1)",
@ -97,16 +97,16 @@ exports[`LogBoxInspectorSourceMapStatus should render for pending 1`] = `
<ForwardRef(AnimatedComponentWrapper)
source={
Object {
"height": 16,
"uri": "",
"width": 16,
"testUri": "../Libraries/LogBox/UI/LogBoxImages/loader.png",
}
}
style={
Array [
Object {
"height": 14,
"marginEnd": 4,
"tintColor": "rgba(255, 255, 255, 0.4)",
"width": 16,
},
Object {
"tintColor": "rgba(250, 186, 48, 1)",