Skip to content

Commit

Permalink
Merge branch 'develop' of https://github.com/FYP-2024-IQMA/fyp2024 in…
Browse files Browse the repository at this point in the history
…to SCRUM-156-Do-up-charts-in-Tableau
  • Loading branch information
xuanli286 committed Oct 14, 2024
2 parents 8f5bbcd + 91574a8 commit 49b4d1e
Show file tree
Hide file tree
Showing 2 changed files with 146 additions and 1 deletion.
140 changes: 140 additions & 0 deletions frontend/iQMA-Skills-Builder/app/EditProfile.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
import {
Text,
View,
TextInput,
ActivityIndicator,
TouchableOpacity,
StyleSheet,
Alert,
} from 'react-native';
import {useState, useContext, useEffect} from 'react';
import axios from 'axios';
import {AuthContext} from '@/context/AuthContext';

export default function EditProfile() {
const {currentUser, isLoading} = useContext(AuthContext);

const [firstName, setFirstName] = useState<string>('');
const [lastName, setLastName] = useState<string>('');
const [loading, setLoading] = useState<boolean>(true);

const fetchUserData = async () => {
try {
const url = `${process.env.EXPO_PUBLIC_LOCALHOST_URL}/accounts/getaccountbyid/${currentUser.sub}`;
const response = await axios.get(url);
const userData = response.data;
setFirstName(userData.firstName);
setLastName(userData.lastName);
} catch (error) {
console.error('Failed to fetch user data:', error);
} finally {
setLoading(false); // Ensure loading state is reset
}
};

const handleSave = async () => {
const url = `${process.env.EXPO_PUBLIC_LOCALHOST_URL}/accounts/updateaccount`;
try {
await axios.patch(
url,
{
"userID": `${currentUser.sub}`,
"firstName": `${firstName}`,
"lastName": `${lastName}`
},
);
Alert.alert('Success', 'Profile updated successfully.');
} catch (error) {
console.error('Failed to update profile:', error);
Alert.alert('Error', 'Failed to update profile. Please try again.');
}
};

useEffect(() => {
if (currentUser) {
fetchUserData();
}
}, [currentUser]);

if (isLoading || loading) {
return (
<View style={{flex: 1, justifyContent: 'center', alignItems: 'center'}}>
<ActivityIndicator size="large" color="#8A2BE2" />
</View>
);
}

return (
<View style={styles.container}>
<View style={styles.header}>
<Text style={styles.headerTitle}>Edit Profile</Text>
</View>
<View style={styles.form}>
<Text style={styles.label}>FIRST NAME</Text>
<TextInput
style={styles.input}
value={firstName}
onChangeText={(text) => setFirstName(text)}
/>
<Text style={styles.label}>LAST NAME</Text>
<TextInput
style={styles.input}
value={lastName}
onChangeText={(text) => setLastName(text)}
/>
<TouchableOpacity style={styles.button} onPress={handleSave}>
<Text style={styles.buttonText}>SAVE</Text>
</TouchableOpacity>
</View>
</View>
);
}

const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#ffffff',
},
header: {
backgroundColor: '#c1a5ff',
paddingVertical: 15,
justifyContent: 'center',
alignItems: 'center',
},
headerTitle: {
color: '#ffffff',
fontSize: 18,
fontWeight: 'bold',
},
form: {
padding: 20,
},
label: {
color: '#6a51b2',
fontSize: 12,
fontWeight: 'bold',
marginBottom: 5,
},
input: {
height: 40,
borderWidth: 1,
borderColor: '#d4d4d4',
borderRadius: 5,
paddingHorizontal: 10,
marginBottom: 20,
},
button: {
backgroundColor: '#ffffff',
borderRadius: 10,
borderColor: '#6a51b2',
borderWidth: 1,
paddingVertical: 10,
justifyContent: 'center',
alignItems: 'center',
},
buttonText: {
color: '#6a51b2',
fontSize: 16,
fontWeight: 'bold',
},
});
7 changes: 6 additions & 1 deletion frontend/iQMA-Skills-Builder/app/screens/Settings.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
import { StyleSheet, Text, View } from 'react-native';
import { StyleSheet, Text, View ,Button,Alert} from 'react-native';
import React, { useContext, useEffect, useState } from 'react';
import CustomSwitch from '@/components/CustomSwitch';
import { CustomButton } from '@/components/CustomButton';
import { AuthContext } from '@/context/AuthContext';
import AsyncStorage from '@react-native-async-storage/async-storage';
import { LoadingIndicator } from '@/components/LoadingIndicator';
import {router}from 'expo-router';

export default function Settings() {
const { logOut } = useContext(AuthContext);
Expand Down Expand Up @@ -78,6 +79,10 @@ export default function Settings() {
<Text style={styles.label}>All Notifications</Text>
<CustomSwitch isEnabled={isNotificationsEnabled} onToggle={toggleNotifications} />
</View>
<Button
title="Press Me"
onPress={() => router.push('EditProfile')}
/>

<CustomButton
label="Log out"
Expand Down

0 comments on commit 49b4d1e

Please sign in to comment.