-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApp.js
52 lines (41 loc) · 1.25 KB
/
App.js
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
52
import React, { useState } from 'react';
import { StyleSheet, Text, View, TextInput, Button, ScrollView, FlatList } from 'react-native';
import GoalOutput from './components/GoalOutput';
import GoalInput from './components/GoalInput';
export default function App() {
const [ lockdownGoals, setLockdownGoals ] = useState([]);
const [ isAddMode, setIsAddMode ] = useState(false);
const addGoal = (userDataInput) => {
setLockdownGoals((currentGoal) => [ ...currentGoal, { id: Math.random().toString(), val: userDataInput } ]);
setIsAddMode(false);
};
const delGoal = (id) => {
return setLockdownGoals((currentGoal) => {
return currentGoal.filter((goal) => goal.id !== id);
});
};
const cancelGoalAddMode = () => {
setIsAddMode(false);
};
return (
<View style={styles.screen}>
<Button
title="Add New Goal"
onPress={() => setIsAddMode(true)} />
<GoalInput
visible={isAddMode}
onAdd={addGoal}
onCancel={cancelGoalAddMode} />
<FlatList
data={lockdownGoals}
keyExtractor={(item, index) => item.id}
renderItem={(itemData) => (
<GoalOutput id={itemData.item.id} onDelete={delGoal} output={itemData.item.val} />
)}
/>
</View>
);
}
const styles = StyleSheet.create({
screen: { padding: 30 }
});