66 lines
2.0 KiB
TypeScript
66 lines
2.0 KiB
TypeScript
import {ActivityIndicator, StyleSheet, Text, View} from 'react-native';
|
|
import Button from '@/components/Button';
|
|
import ImageViewer from '@/components/ImageViewer';
|
|
import * as ImagePicker from 'expo-image-picker';
|
|
import {RestService} from '@/services/RestService';
|
|
import useService from '@/hooks/useService';
|
|
|
|
const PlaceholderImage = require('@/assets/images/GarfieldCharakter.webp');
|
|
|
|
import * as WebBrowser from "expo-web-browser";
|
|
|
|
WebBrowser.maybeCompleteAuthSession();
|
|
|
|
export default function Index() {
|
|
const {data: usersData, loading: userLoading, error: userError} = useService(RestService.fetchAllUser);
|
|
|
|
const pickImageAsync = async () => {
|
|
let result = await ImagePicker.launchImageLibraryAsync({
|
|
mediaTypes: ['images'],
|
|
allowsEditing: true,
|
|
quality: 1,
|
|
});
|
|
|
|
if (!result.canceled) {
|
|
console.log(result);
|
|
} else {
|
|
alert('You did not select any image.');
|
|
}
|
|
};
|
|
|
|
console.log(usersData);
|
|
return (
|
|
<View style={styles.container}>
|
|
<View style={styles.imageContainer}>
|
|
<ImageViewer imgSource={PlaceholderImage}/>
|
|
</View>
|
|
<View style={styles.footerContainer}>
|
|
{userLoading && <ActivityIndicator/>}
|
|
{userError && <Text>Error: {userError.message}</Text>}
|
|
{usersData && (
|
|
<Text>
|
|
{usersData.users.map((item) => item.name).join('; ')}
|
|
</Text>
|
|
)}
|
|
<Button label="Choose a photo" theme="primary" onPress={pickImageAsync}/>
|
|
<Button label="Use this photo"/>
|
|
</View>
|
|
</View>
|
|
);
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
container: {
|
|
flex: 1,
|
|
backgroundColor: '#25292e',
|
|
alignItems: 'center',
|
|
},
|
|
imageContainer: {
|
|
flex: 1,
|
|
},
|
|
footerContainer: {
|
|
flex: 1 / 3,
|
|
alignItems: 'center',
|
|
},
|
|
});
|