Skip to content

Commit

Permalink
Add tinted vector drawable example to RNTester (#48541)
Browse files Browse the repository at this point in the history
Summary:
Pull Request resolved: #48541

Shows how to use tintColor in conjunction with new XML file format, and serves as a good E2E test bench to ensure that drawables don't accidentally reuse the same state (if the underlying implementation isn't careful enough to call `buildCopy`, both icons will render red)

Changelog: [Internal]

Reviewed By: NickGerleman

Differential Revision: D64136753

fbshipit-source-id: 3bd0933e587364425ac14a0635690d4b274a55fe
  • Loading branch information
Abbondanzo authored and facebook-github-bot committed Jan 10, 2025
1 parent 9b646c8 commit 071506f
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 25 deletions.
File renamed without changes.
44 changes: 19 additions & 25 deletions packages/rn-tester/js/examples/Image/ImageExample.js
Original file line number Diff line number Diff line change
Expand Up @@ -612,28 +612,25 @@ class OnPartialLoadExample extends React.Component<
}
}

type VectorDrawableExampleState = {||};

type VectorDrawableExampleProps = $ReadOnly<{||}>;

class VectorDrawableExample extends React.Component<
VectorDrawableExampleProps,
VectorDrawableExampleState,
> {
state: VectorDrawableExampleState = {};

render(): React.Node {
const isEnabled = ReactNativeFeatureFlags.loadVectorDrawablesOnImages();
return (
<View style={styles.flex}>
<RNTesterText>Enabled: {isEnabled ? 'true' : 'false'}</RNTesterText>
<View style={styles.vectorDrawableRow}>
<Image source={{uri: 'ic_android'}} style={styles.vectorDrawable} />
</View>
const VectorDrawableExample = () => {
const isEnabled = ReactNativeFeatureFlags.loadVectorDrawablesOnImages();
return (
<View style={styles.flex} testID="vector-drawable-example">
<RNTesterText>Enabled: {isEnabled ? 'true' : 'false'}</RNTesterText>
<View style={styles.horizontal}>
<Image
source={require('../../assets/ic_android.xml')}
style={styles.vectorDrawable}
/>
<Image
source={require('../../assets/ic_android.xml')}
style={styles.vectorDrawable}
tintColor="red"
/>
</View>
);
}
}
</View>
);
};

function CacheControlAndroidExample(): React.Node {
const [reload, setReload] = React.useState(0);
Expand Down Expand Up @@ -934,10 +931,6 @@ const styles = StyleSheet.create({
boxShadow: '80px 0px 10px 0px hotpink',
transform: 'rotate(-15deg)',
},
vectorDrawableRow: {
flexDirection: 'row',
gap: 8,
},
vectorDrawable: {
height: 64,
width: 64,
Expand Down Expand Up @@ -1763,6 +1756,7 @@ exports.examples = [
},
{
title: 'Vector Drawable',
name: 'vector-drawable',
description:
'Demonstrating an example of loading a vector drawable asset by name',
render: function (): React.Node {
Expand Down

0 comments on commit 071506f

Please sign in to comment.