-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApp.tsx
51 lines (45 loc) · 1.27 KB
/
App.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import { useEffect, useState } from 'react';
import { StatusBar } from 'expo-status-bar';
import { StyleSheet, Text, SafeAreaView } from 'react-native';
import Navbar from './src/components/Navbar';
import Categories from './src/components/Categories';
import Posts from './src/components/Posts';
import { Post } from './src/interfaces/post';
export default function App() {
const [posts, setPosts] = useState<Post[]>([]);
const [startingPage, setStartingPage] = useState<number>(0);
async function fetchData() {
try {
const req = await fetch(
`https://api.yup.io/feed/dailyhits?start=${startingPage}&limit=10`
);
const data = await req.json();
setPosts((prev: Post[] | []) => {
if (prev.length <= 0) {
return data;
} else {
return [...prev, ...data];
}
});
setStartingPage((prev) => prev + 10);
} catch (error) {
console.log(error);
}
}
useEffect(() => {
fetchData();
}, []);
return (
<SafeAreaView style={styles.container}>
<Navbar />
<Categories />
<Posts fetchData={fetchData} posts={posts} />
<StatusBar style="auto" />
</SafeAreaView>
);
}
const styles = StyleSheet.create({
container: {
backgroundColor: '#fff',
},
});