Commit eef3fe0a authored by Lihinikaduwa D.N.R.  's avatar Lihinikaduwa D.N.R.

Created reading session

parent 46256e77
...@@ -134,14 +134,14 @@ def login(): ...@@ -134,14 +134,14 @@ def login():
userId = user[0] userId = user[0]
if userId == 0: if userId == 0:
data = { data = {
"body": [], "userId": [],
"message": "Failed", "message": "Failed",
"status": 404 "status": 404
} }
else: else:
token = saveUserSession(userId) token = saveUserSession(userId)
data = { data = {
"body": user, "body": userId,
"token": token, "token": token,
"message": "Success", "message": "Success",
"status": 200 "status": 200
...@@ -156,11 +156,11 @@ def logout(): ...@@ -156,11 +156,11 @@ def logout():
req = request.get_json() req = request.get_json()
token = req['token'] token = req['token']
if(logoutUser(token) == 1): if(logoutUser(token) == 1):
data = { response = {
"message": "Success", "message": "Success",
"status": 200 "status": 200
} }
body = jsonify(data) body = jsonify(response)
return make_response(body) return make_response(body)
...@@ -169,25 +169,30 @@ def reading_session(): ...@@ -169,25 +169,30 @@ def reading_session():
req = request.get_json() req = request.get_json()
userId = req['userId'] userId = req['userId']
token = save_session_details(userId, 1) token = save_session_details(userId, 1)
data = { response = {
"token": token, "token": token,
"message": "Success", "message": "Success",
"status": 200 "status": 200
} }
body = jsonify(data) body = jsonify(response)
return make_response(body) return make_response(body)
@app.route("/reading", methods=['POST']) @app.route("/reading/<readingToken>", methods=['POST'])
def reading(): def reading(readingToken):
assert readingToken == request.view_args['readingToken']
token = readingToken
req = request.get_json() req = request.get_json()
word = req['word'] word = req['word']
userId = req['userId'] userId = req['userId']
token = req['token']
level = req['level'] level = req['level']
triedCount = req['triedCount'] triedCount = req['triedCount']
result = save_activity_details(userId, word, token, level, triedCount) result = save_activity_details(userId, word, token, level, triedCount)
body = jsonify(word) response = {
"message": "Success",
"status": 200
}
body = jsonify(response)
return make_response(body) return make_response(body)
......
...@@ -33,11 +33,10 @@ const ReadCategory = props => { ...@@ -33,11 +33,10 @@ const ReadCategory = props => {
console.log(res.data); console.log(res.data);
const token = res.data.token; const token = res.data.token;
try { try {
AsyncStorage.setItem('token', token); AsyncStorage.setItem('readingSession', token);
} catch (error) { } catch (error) {
console.log(error); console.log(error);
} }
navigation.navigate(path); navigation.navigate(path);
} }
}) })
......
...@@ -51,19 +51,16 @@ export default function Read() { ...@@ -51,19 +51,16 @@ export default function Read() {
</View> */} </View> */}
<TouchableOpacity style={styles.screen}> <TouchableOpacity style={styles.screen}>
<ReadCategory <ReadCategory
id={1}
title={'Basic'} title={'Basic'}
image={ImagePaths.roundOne} image={ImagePaths.roundOne}
path={'ReadActivity'} path={'ReadActivity'}
/> />
<ReadCategory <ReadCategory
id={1}
title={'Advanced'} title={'Advanced'}
image={ImagePaths.roundTwo} image={ImagePaths.roundTwo}
path={'ReadActivityBird'} path={'ReadActivityBird'}
/> />
<ReadCategory <ReadCategory
id={1}
title={'Result & Summery'} title={'Result & Summery'}
image={ImagePaths.summery} image={ImagePaths.summery}
path={'ReadActivity'} path={'ReadActivity'}
......
import React from "react"; import React from "react";
import { SafeAreaView, ScrollView, View, Text } from "react-native"; import {SafeAreaView, ScrollView, View, Text, Button} from 'react-native';
import { NavigationContainer } from "@react-navigation/native"; import { NavigationContainer } from "@react-navigation/native";
import { createDrawerNavigator, DrawerItem } from "@react-navigation/drawer"; import { createDrawerNavigator, DrawerItem } from "@react-navigation/drawer";
import FontAwesome5 from 'react-native-vector-icons/FontAwesome5'; import FontAwesome5 from 'react-native-vector-icons/FontAwesome5';
...@@ -7,70 +7,70 @@ import FontAwesome5 from 'react-native-vector-icons/FontAwesome5'; ...@@ -7,70 +7,70 @@ import FontAwesome5 from 'react-native-vector-icons/FontAwesome5';
import Home from "./home"; import Home from "./home";
import profile from "./profile"; import profile from "./profile";
import report from "./report"; import report from "./report";
import Login from "./auth/Login";
const Drawer = createDrawerNavigator(); const Drawer = createDrawerNavigator();
function Start() { function Start() {
return ( return (
<Drawer.Navigator <Drawer.Navigator
initialRouteName="Home" initialRouteName="Home"
screenOptions={{ screenOptions={{
hearderTitleAlign: 'right', hearderTitleAlign: 'right',
alignItems: 'center', alignItems: 'center',
justifyContent: 'center', justifyContent: 'center',
headerStyle:{ headerStyle: {
backgroundColor: '#1DCE92' backgroundColor: '#1DCE92',
}, },
headerTintColor: '#ffffff' headerTintColor: '#ffffff',
}}> }}>
<Drawer.Screen
<Drawer.Screen name="Home" name="Home"
component={Home} component={Home}
options={{ options={{
title: 'Home', title: 'Home',
drawerIcon: ({focused}) => ( drawerIcon: ({focused}) => (
<FontAwesome5 <FontAwesome5
name="home" name="home"
size={focused ? 25:20} size={focused ? 25 : 20}
color={focused ? '#1DCE92' : '#0096FF'} color={focused ? '#1DCE92' : '#0096FF'}
/> />
) ),
}} }}
/> />
<Drawer.Screen name="Profile" <Drawer.Screen
name="Profile"
component={profile} component={profile}
options={{ options={{
title: 'Profile', title: 'Profile',
drawerIcon: ({focused}) => ( drawerIcon: ({focused}) => (
<FontAwesome5 <FontAwesome5
name="users" name="users"
size={focused ? 25:20} size={focused ? 25 : 20}
color={focused ? '#1DCE92' : '#0096FF'} color={focused ? '#1DCE92' : '#0096FF'}
/> />
) ),
}} }}
/> />
<Drawer.Screen name="Report" <Drawer.Screen
name="Report"
component={report} component={report}
options={{ options={{
title: 'Report', title: 'Report',
drawerIcon: ({focused}) => ( drawerIcon: ({focused}) => (
<FontAwesome5 <FontAwesome5
name="chart-line" name="chart-line"
size={focused ? 25:20} size={focused ? 25 : 20}
color={focused ? '#1DCE92' : '#0096FF'} color={focused ? '#1DCE92' : '#0096FF'}
/> />
) ),
}} }}
/> />
</Drawer.Navigator> </Drawer.Navigator>
); );
} }
......
...@@ -98,7 +98,9 @@ const Login = () => { ...@@ -98,7 +98,9 @@ const Login = () => {
} }
if (response.data.status == 200) { if (response.data.status == 200) {
const userToken = res.data.token; const userToken = res.data.token;
const userId = res.data.userId;
AsyncStorage.setItem('userToken', userToken); AsyncStorage.setItem('userToken', userToken);
AsyncStorage.setItem('userId', userId);
return navigation.navigate('Start'); return navigation.navigate('Start');
} }
}) })
......
...@@ -24,6 +24,10 @@ export default function ReadActivity() { ...@@ -24,6 +24,10 @@ export default function ReadActivity() {
const [results, setResults] = useState([]); const [results, setResults] = useState([]);
const [partialResults, setPartialResults] = useState([]); const [partialResults, setPartialResults] = useState([]);
useEffect(() => {
Voice.destroy().then(Voice.removeAllListeners);
}, []);
useEffect(() => { useEffect(() => {
Voice.onSpeechStart = onSpeechStartHandler; Voice.onSpeechStart = onSpeechStartHandler;
Voice.onSpeechEnd = onSpeechEndHandler; Voice.onSpeechEnd = onSpeechEndHandler;
......
...@@ -21,11 +21,12 @@ import AsyncStorage from '@react-native-async-storage/async-storage'; ...@@ -21,11 +21,12 @@ import AsyncStorage from '@react-native-async-storage/async-storage';
import {Authorize} from '../../auth/AuthenticateUser'; import {Authorize} from '../../auth/AuthenticateUser';
export default function ReadActivityBird() { export default function ReadActivityBird() {
const userToken = Authorize(); // const userToken = Authorize();
const navigation = useNavigation();
const [error, setError] = useState(''); const [error, setError] = useState('');
const [readingData, setReadingData] = useState({activity: ''}); const [readingData, setReadingData] = useState({activity: ''});
const readToken = AsyncStorage.getItem('readingSession'); // let user = AsyncStorage.getItem('readingSession');
// useEffect(() => { // useEffect(() => {
// if (Authorize) { // if (Authorize) {
// } // }
...@@ -42,15 +43,33 @@ export default function ReadActivityBird() { ...@@ -42,15 +43,33 @@ export default function ReadActivityBird() {
}; };
}, []); }, []);
useEffect(() => { const getToken = data => {
AsyncStorage.getItem('token') AsyncStorage.getItem('readingSession')
.then(value => { .then(readingSession => {
console.log(value);
sendRedingData(data, readingSession);
}) })
.catch(error => { .catch(error => {
console.log(error); console.log(error);
}); });
}, []); };
const sendRedingData = (data, readingSession) => {
console.log('itemValue', data);
Client.post('reading/'+readingSession, JSON.stringify(data), {
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
},
})
.then(res => {
console.log(res.data);
navigation.navigate('ReadActivity');
})
.catch(error => {
console.log(error);
});
};
const onSpeechStartHandler = e => { const onSpeechStartHandler = e => {
console.log('start handler =>> ', e); console.log('start handler =>> ', e);
...@@ -65,20 +84,19 @@ export default function ReadActivityBird() { ...@@ -65,20 +84,19 @@ export default function ReadActivityBird() {
}; };
const onSpeechError = e => { const onSpeechError = e => {
console.log('onSpeechError: ', e);
setError(JSON.stringify(e.error)); setError(JSON.stringify(e.error));
const result = DummyReadResult.value; const result = DummyReadResult.value;
const data = { const data = {
word: 'bird', word: 'bird',
userId: 1, userId: 1,
token: readToken,
level: 1, level: 1,
triedCount: 1, triedCount: 1,
}; };
if (result.includes('hello')) { if (result.includes('hello')) {
setReadingData(data); setReadingData(data);
console.log(localStorage.getItem('readingSession')); console.log('data', getToken());
sendRedingData(data); console.log('readingData:', readingData);
getToken(data);
} }
}; };
...@@ -90,21 +108,6 @@ export default function ReadActivityBird() { ...@@ -90,21 +108,6 @@ export default function ReadActivityBird() {
} }
}; };
const sendRedingData = data => {
Client.post('reading', JSON.stringify(data), {
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
},
})
.then(res => {
console.log(res.data);
})
.catch(error => {
console.log(error);
});
};
return ( return (
<SafeAreaView> <SafeAreaView>
<View style={{flexDirection: 'column'}}> <View style={{flexDirection: 'column'}}>
......
...@@ -9,7 +9,7 @@ export default function report({ navigation }){ ...@@ -9,7 +9,7 @@ export default function report({ navigation }){
return ( return (
<View> <View>
<Text>report</Text>
</View> </View>
) )
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment