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