summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorSanto Cariotti <santo@dcariotti.me>2024-08-30 21:21:17 +0200
committerSanto Cariotti <santo@dcariotti.me>2024-08-30 21:21:17 +0200
commit509785982a1b4ac9ab145bac90d97be7044228c4 (patch)
tree2ab074c254f0f88788b103a400ce0e308c044ec4 /app
parent7103a17512b77b816d7daa972b7fc14bdcab5e6b (diff)
Init alert list page
Diffstat (limited to 'app')
-rw-r--r--app/(tabs)/_layout.tsx6
-rw-r--r--app/(tabs)/alerts.tsx46
-rw-r--r--app/(tabs)/index.tsx1
3 files changed, 49 insertions, 4 deletions
diff --git a/app/(tabs)/_layout.tsx b/app/(tabs)/_layout.tsx
index fcc94db..97e98de 100644
--- a/app/(tabs)/_layout.tsx
+++ b/app/(tabs)/_layout.tsx
@@ -23,15 +23,15 @@ export default function TabLayout() {
),
}}
/>
- {/*<Tabs.Screen
- name="explore"
+ <Tabs.Screen
+ name="alerts"
options={{
title: 'Alerts',
tabBarIcon: ({ color, focused }) => (
<TabBarIcon name={focused ? 'map' : 'map-outline'} color={color} />
),
}}
- />*/}
+ />
</Tabs>
);
}
diff --git a/app/(tabs)/alerts.tsx b/app/(tabs)/alerts.tsx
new file mode 100644
index 0000000..135771f
--- /dev/null
+++ b/app/(tabs)/alerts.tsx
@@ -0,0 +1,46 @@
+import { Alert, Platform, Pressable, StyleSheet, Text, TextInput, View } from 'react-native';
+import ParallaxScrollView from '@/components/ParallaxScrollView';
+import { ThemedText } from '@/components/ThemedText';
+import { ThemedView } from '@/components/ThemedView';
+import React, { useState, useEffect, useRef } from 'react';
+import AsyncStorage from '@react-native-async-storage/async-storage';
+import MapView, { Marker } from 'react-native-maps';
+import { useFocusEffect } from '@react-navigation/native';
+import { router } from 'expo-router';
+
+export default function AlertsScreen() {
+ const [token, setToken] = useState('');
+ const [userId, setUserId] = useState('');
+
+ const checkAuth = async () => {
+ const storedToken = Platform.OS === 'web' ? localStorage.getItem('token') : await AsyncStorage.getItem('token');
+ const storedUserId = Platform.OS === 'web' ? localStorage.getItem('userId') : await AsyncStorage.getItem('userId');
+
+ setToken(storedToken || '');
+ setUserId(storedUserId || '');
+
+ if (!storedToken || !storedUserId) {
+ Alert.alert('Login required', 'You must log in to the system if you want to see alerts list', [
+ {
+ text: 'Ok',
+ onPress: () => router.push('/')
+ }
+ ]);
+ }
+ };
+
+ useFocusEffect(
+ React.useCallback(() => {
+ checkAuth();
+ }, [])
+ );
+
+
+ return (
+ <ParallaxScrollView>
+ </ParallaxScrollView>
+ );
+}
+
+const styles = StyleSheet.create({
+});
diff --git a/app/(tabs)/index.tsx b/app/(tabs)/index.tsx
index b1eac11..d8fcccd 100644
--- a/app/(tabs)/index.tsx
+++ b/app/(tabs)/index.tsx
@@ -213,7 +213,6 @@ const styles = StyleSheet.create({
},
text: {
marginBottom: 8,
- color: '#333',
},
formContainer: {
marginTop: 20,