1import { Image, ImageSource } from 'expo-image'; 2import * as React from 'react'; 3import { 4 SectionList, 5 SectionListData, 6 SectionListRenderItemInfo, 7 StyleSheet, 8 View, 9 Platform, 10} from 'react-native'; 11 12import HeadingText from '../../components/HeadingText'; 13import { Colors } from '../../constants'; 14 15const data: SectionListData<ImageSource>[] = [ 16 { 17 title: 'Animated WebP', 18 data: [ 19 { 20 uri: 'https://mathiasbynens.be/demo/animated-webp-supported.webp', 21 }, 22 ], 23 }, 24 { 25 title: 'Animated PNG (APNG)', 26 data: [ 27 { 28 uri: 'https://apng.onevcat.com/assets/elephant.png', 29 }, 30 ], 31 }, 32 { 33 title: 'GIF', 34 data: [ 35 { 36 uri: 'https://apng.onevcat.com/assets/elephant.gif', 37 }, 38 ], 39 }, 40 { 41 title: 'Animated AVIF', 42 data: [ 43 { 44 uri: 'https://colinbendell.github.io/webperf/animated-gif-decode/2.avif', 45 }, 46 ], 47 }, 48 { 49 title: 'HEIC', 50 data: [ 51 { 52 uri: 'https://nokiatech.github.io/heif/content/images/ski_jump_1440x960.heic', 53 }, 54 ], 55 }, 56 { 57 title: 'Animated HEIC', 58 data: [ 59 { 60 uri: 'https://nokiatech.github.io/heif/content/image_sequences/starfield_animation.heic', 61 }, 62 ], 63 }, 64 { 65 title: 'JPEG', 66 data: [ 67 { 68 uri: 'https://picsum.photos/id/1069/700/466.jpg', 69 }, 70 ], 71 }, 72 { 73 title: 'JPEG (base64)', 74 data: [ 75 { 76 uri: '', 77 }, 78 ], 79 }, 80 { 81 title: 'SVG', 82 data: [ 83 { 84 uri: 'https://icon-icons.com/downloadimage.php?id=98748&root=1446/SVG/&file=22221cat_98748.svg', 85 }, 86 ], 87 }, 88 { 89 title: 'SVG (base64)', 90 data: [ 91 { 92 uri: '', 93 }, 94 ], 95 }, 96 { 97 title: 'ICO', 98 data: [ 99 { 100 uri: 'https://icon-icons.com/downloadimage.php?id=132404&root=2148/ICO/512/&file=expo_icon_132404.ico', 101 }, 102 ], 103 }, 104 Platform.OS === 'ios' && { 105 title: 'ICNS', 106 data: [ 107 { 108 uri: 'https://icon-icons.com/downloadimage.php?id=214748&root=3398/ICNS/512/&file=react_logo_icon_214748.icns', 109 }, 110 ], 111 }, 112].filter(Boolean) as SectionListData<ImageSource>[]; 113 114function keyExtractor(item: any, index: number) { 115 return '' + index; 116} 117 118function renderItem({ item }: SectionListRenderItemInfo<ImageSource>) { 119 return <Image style={styles.image} contentFit="contain" source={item} />; 120} 121 122function renderSectionHeader({ section }: { section: SectionListData<ImageSource> }) { 123 return ( 124 <View style={styles.header}> 125 <HeadingText style={styles.title}>{section.title}</HeadingText> 126 </View> 127 ); 128} 129 130export default function ImageFormatsScreen() { 131 return ( 132 <SectionList 133 sections={data} 134 keyExtractor={keyExtractor} 135 renderItem={renderItem} 136 renderSectionHeader={renderSectionHeader} 137 /> 138 ); 139} 140 141const styles = StyleSheet.create({ 142 image: { 143 marginVertical: 10, 144 width: '100%', 145 height: 160, 146 }, 147 header: { 148 paddingHorizontal: 10, 149 paddingVertical: 6, 150 backgroundColor: Colors.greyBackground, 151 borderTopColor: Colors.border, 152 borderTopWidth: StyleSheet.hairlineWidth, 153 }, 154 title: { 155 marginTop: -12, 156 }, 157}); 158