Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
21_22-J 38
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
21_22-J 38
21_22-J 38
Commits
f6d496d8
Commit
f6d496d8
authored
May 01, 2022
by
W.D.R.P. Sandeepa
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
http://gitlab.sliit.lk/21_22-j-38/21_22j-38
into it18218640
parents
6450a215
bda0abe1
Changes
15
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
766 additions
and
102 deletions
+766
-102
API/__pycache__/app.cpython-39.pyc
API/__pycache__/app.cpython-39.pyc
+0
-0
API/app.py
API/app.py
+15
-10
frontend/src/component/reading/ReadCategory.js
frontend/src/component/reading/ReadCategory.js
+1
-2
frontend/src/router/router.js
frontend/src/router/router.js
+1
-1
frontend/src/screen/Read.js
frontend/src/screen/Read.js
+0
-3
frontend/src/screen/Start.js
frontend/src/screen/Start.js
+53
-53
frontend/src/screen/auth/Login.js
frontend/src/screen/auth/Login.js
+2
-0
frontend/src/screen/profile.js
frontend/src/screen/profile.js
+1
-1
frontend/src/screen/reading/ReadActivity.js
frontend/src/screen/reading/ReadActivity.js
+4
-0
frontend/src/screen/reading/advanced/ReadActivityBird.js
frontend/src/screen/reading/advanced/ReadActivityBird.js
+30
-27
frontend/src/screen/reading/basic/ReadActivityGo.js
frontend/src/screen/reading/basic/ReadActivityGo.js
+218
-0
frontend/src/screen/reading/basic/ReadActivityHe.js
frontend/src/screen/reading/basic/ReadActivityHe.js
+218
-0
frontend/src/screen/reading/basic/ReadActivityNo.js
frontend/src/screen/reading/basic/ReadActivityNo.js
+218
-0
frontend/src/screen/report.js
frontend/src/screen/report.js
+1
-1
frontend/src/screen/sideMenu.js
frontend/src/screen/sideMenu.js
+4
-4
No files found.
API/__pycache__/app.cpython-39.pyc
View file @
f6d496d8
No preview for this file type
API/app.py
View file @
f6d496d8
...
@@ -155,14 +155,14 @@ def login():
...
@@ -155,14 +155,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"
:
user
Id
,
"token"
:
token
,
"token"
:
token
,
"message"
:
"Success"
,
"message"
:
"Success"
,
"status"
:
200
"status"
:
200
...
@@ -176,11 +176,11 @@ def logout():
...
@@ -176,11 +176,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
)
@
app
.
route
(
"/readingSession"
,
methods
=
[
'POST'
])
@
app
.
route
(
"/readingSession"
,
methods
=
[
'POST'
])
...
@@ -188,25 +188,30 @@ def reading_session():
...
@@ -188,25 +188,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
)
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
...
...
frontend/src/component/reading/ReadCategory.js
View file @
f6d496d8
...
@@ -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
(
'
toke
n
'
,
token
);
AsyncStorage
.
setItem
(
'
readingSessio
n
'
,
token
);
}
catch
(
error
)
{
}
catch
(
error
)
{
console
.
log
(
error
);
console
.
log
(
error
);
}
}
navigation
.
navigate
(
path
);
navigation
.
navigate
(
path
);
}
}
})
})
...
...
frontend/src/router/router.js
View file @
f6d496d8
...
@@ -3,7 +3,7 @@ import {NavigationContainer} from '@react-navigation/native';
...
@@ -3,7 +3,7 @@ import {NavigationContainer} from '@react-navigation/native';
import
{
createNativeStackNavigator
}
from
'
@react-navigation/native-stack
'
;
import
{
createNativeStackNavigator
}
from
'
@react-navigation/native-stack
'
;
import
Colors
from
'
../constants/Colors
'
;
import
Colors
from
'
../constants/Colors
'
;
import
Home
from
'
../screen/
h
ome
'
;
import
Home
from
'
../screen/
H
ome
'
;
import
Start
from
'
../screen/Start
'
;
import
Start
from
'
../screen/Start
'
;
import
Register
from
'
../screen/auth/Register
'
;
import
Register
from
'
../screen/auth/Register
'
;
import
Login
from
'
../screen/auth/Login
'
;
import
Login
from
'
../screen/auth/Login
'
;
...
...
frontend/src/screen/Read.js
View file @
f6d496d8
...
@@ -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
'
}
...
...
frontend/src/screen/Start.js
View file @
f6d496d8
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
'
;
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
>
);
);
}
}
...
...
frontend/src/screen/auth/Login.js
View file @
f6d496d8
...
@@ -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
'
);
}
}
})
})
...
...
frontend/src/screen/profile.js
View file @
f6d496d8
import
React
from
"
react
"
;
import
React
from
"
react
"
;
import
{
StyleSheet
,
View
,
Text
,
Pressable
}
from
'
react-native
'
;
import
{
StyleSheet
,
View
,
Text
,
Pressable
}
from
'
react-native
'
;
export
default
function
pr
ofile
({
navigation
}){
export
default
function
P
ofile
({
navigation
}){
const
onPressHandler
=
()
=>
{
const
onPressHandler
=
()
=>
{
navigation
.
navigate
(
'
Start
'
);
navigation
.
navigate
(
'
Start
'
);
...
...
frontend/src/screen/reading/ReadActivity.js
View file @
f6d496d8
...
@@ -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
;
...
...
frontend/src/screen/reading/advanced/ReadActivityBird.js
View file @
f6d496d8
...
@@ -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
'
}}
>
...
...
frontend/src/screen/reading/basic/ReadActivityGo.js
0 → 100644
View file @
f6d496d8
import
{
useNavigation
}
from
'
@react-navigation/native
'
;
import
Orientation
from
'
react-native-orientation-locker
'
;
import
React
,
{
useEffect
,
useState
}
from
'
react
'
;
import
{
Text
,
TouchableOpacity
,
StyleSheet
,
View
,
ImageButton
,
SafeAreaView
,
ImageBackground
,
Button
,
Image
,
TouchableHighlight
,
}
from
'
react-native
'
;
import
Voice
from
'
@react-native-voice/voice
'
;
import
{
DummyReadResult
}
from
'
../../assets/read/data/ReadData
'
;
export
default
function
ReadActivityGo
()
{
const
[
pitch
,
setPitch
]
=
useState
(
''
);
const
[
error
,
setError
]
=
useState
(
''
);
const
[
end
,
setEnd
]
=
useState
(
''
);
const
[
started
,
setStarted
]
=
useState
(
''
);
const
[
results
,
setResults
]
=
useState
([]);
const
[
partialResults
,
setPartialResults
]
=
useState
([]);
useEffect
(()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
},
[]);
useEffect
(()
=>
{
Voice
.
onSpeechStart
=
onSpeechStartHandler
;
Voice
.
onSpeechEnd
=
onSpeechEndHandler
;
Voice
.
onSpeechResults
=
onSpeechResultsHandler
;
Voice
.
onSpeechError
=
onSpeechError
;
Voice
.
onSpeechPartialResults
=
onSpeechPartialResults
;
Voice
.
onSpeechVolumeChanged
=
onSpeechVolumeChanged
;
return
()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
};
},
[]);
const
onSpeechStartHandler
=
e
=>
{
console
.
log
(
'
start handler =>>
'
,
e
);
};
const
onSpeechEndHandler
=
e
=>
{
console
.
log
(
'
end handler =>>
'
,
e
);
};
const
onSpeechResultsHandler
=
e
=>
{
console
.
log
(
'
result handler =>>
'
,
e
);
};
const
onSpeechError
=
e
=>
{
console
.
log
(
'
onSpeechError:
'
,
e
);
setError
(
JSON
.
stringify
(
e
.
error
));
const
result
=
DummyReadResult
.
value
;
if
(
result
.
includes
(
'
hello
'
))
{
console
.
log
(
'
correct
'
);
}
};
const
onSpeechPartialResults
=
e
=>
{
console
.
log
(
'
onSpeechPartialResults:
'
,
e
);
setPartialResults
(
e
.
value
);
};
const
onSpeechVolumeChanged
=
e
=>
{
console
.
log
(
'
onSpeechVolumeChanged:
'
,
e
);
setPitch
(
e
.
value
);
};
const
startRecording
=
async
()
=>
{
try
{
await
Voice
.
start
(
'
en-US
'
);
}
catch
(
error
)
{
console
.
log
(
'
error =>>
'
,
error
);
}
};
const
stopRecording
=
async
()
=>
{
try
{
await
Voice
.
stop
();
}
catch
(
error
)
{
console
.
log
(
error
);
}
};
return
(
<
SafeAreaView
>
<
View
style
=
{{
flexDirection
:
'
column
'
}}
>
<
ImageBackground
style
=
{
styles
.
image
}
source
=
{
require
(
'
../../assets/read/image/activity-2-backg.jpeg
'
)}
>
<
View
style
=
{
styles
.
imageContainer
}
>
<
View
style
=
{
styles
.
imageView
}
>
<
View
style
=
{
styles
.
robo
}
>
<
Image
source
=
{
require
(
'
../../assets/read/image/activity-2-rob.png
'
)}
><
/Image
>
<
/View
>
<
/View
>
<
View
style
=
{
styles
.
textBody
}
>
<
Text
style
=
{
styles
.
text
}
>
Pronounce
this
Word
!<
/Text
>
<
/View
>
<
/View
>
{
/* <View style={styles.textBody}>
<Text style={styles.text}>Pronounce this Word!</Text>
</View>
<View style={styles.robo}>
<Image
source={require('../../assets/read/activity-2-rob.png')}></Image>
</View> */
}
<
View
>
<
Image
style
=
{
styles
.
blackboard
}
source
=
{
require
(
'
../../assets/read/image/backboard3.png
'
)}
><
/Image
>
<
/View
>
<
View
style
=
{
styles
.
horizontalView
}
>
<
TouchableHighlight
onPress
=
{
startRecording
}
>
<
Image
style
=
{
styles
.
imageButton
}
source
=
{{
uri
:
'
https://raw.githubusercontent.com/AboutReact/sampleresource/master/microphone.png
'
,
}}
/
>
<
/TouchableHighlight
>
<
/View
>
<
/ImageBackground
>
<
/View
>
<
/SafeAreaView
>
);
}
const
styles
=
StyleSheet
.
create
({
imageContainer
:
{
flexDirection
:
'
row
'
,
marginTop
:
70
,
},
imageView
:
{
width
:
180
,
height
:
300
,
// borderWidth:1,
// borderColor: "#000",
marginHorizontal
:
1
,
marginVertical
:
100
,
},
body
:
{
flex
:
1
,
},
image
:
{
width
:
'
100%
'
,
height
:
'
100%
'
,
},
box
:
{
width
:
180
,
height
:
180
,
// borderColor: "#000000",
backgroundColor
:
'
blue
'
,
marginTop
:
-
370
,
marginLeft
:
455
,
borderRadius
:
100
,
},
blackboard
:
{
marginTop
:
-
320
,
marginLeft
:
200
,
width
:
'
50%
'
,
height
:
300
,
},
robo
:
{
marginTop
:
90
,
marginLeft
:
5
,
width
:
150
,
height
:
200
,
},
textBody
:
{
marginTop
:
150
,
marginLeft
:
-
30
,
// backgroundColor: '#00008B',
width
:
150
,
borderRadius
:
50
,
padding
:
5
,
},
text
:
{
fontSize
:
25
,
justifyContent
:
'
center
'
,
alignItems
:
'
center
'
,
color
:
'
#00008B
'
,
borderRadius
:
10
,
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
textAlign
:
'
center
'
,
fontWeight
:
'
bold
'
,
},
button
:
{
padding
:
10
,
marginLeft
:
5
,
color
:
'
#000000
'
,
},
imageButton
:
{
width
:
50
,
height
:
50
,
},
horizontalView
:
{
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
borderRadius
:
50
,
flexDirection
:
'
row
'
,
position
:
'
absolute
'
,
bottom
:
0
,
flexDirection
:
'
row
'
,
marginBottom
:
140
,
marginLeft
:
50
,
padding
:
7
,
},
});
frontend/src/screen/reading/basic/ReadActivityHe.js
0 → 100644
View file @
f6d496d8
import
{
useNavigation
}
from
'
@react-navigation/native
'
;
import
Orientation
from
'
react-native-orientation-locker
'
;
import
React
,
{
useEffect
,
useState
}
from
'
react
'
;
import
{
Text
,
TouchableOpacity
,
StyleSheet
,
View
,
ImageButton
,
SafeAreaView
,
ImageBackground
,
Button
,
Image
,
TouchableHighlight
,
}
from
'
react-native
'
;
import
Voice
from
'
@react-native-voice/voice
'
;
import
{
DummyReadResult
}
from
'
../../assets/read/data/ReadData
'
;
export
default
function
ReadActivityHe
()
{
const
[
pitch
,
setPitch
]
=
useState
(
''
);
const
[
error
,
setError
]
=
useState
(
''
);
const
[
end
,
setEnd
]
=
useState
(
''
);
const
[
started
,
setStarted
]
=
useState
(
''
);
const
[
results
,
setResults
]
=
useState
([]);
const
[
partialResults
,
setPartialResults
]
=
useState
([]);
useEffect
(()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
},
[]);
useEffect
(()
=>
{
Voice
.
onSpeechStart
=
onSpeechStartHandler
;
Voice
.
onSpeechEnd
=
onSpeechEndHandler
;
Voice
.
onSpeechResults
=
onSpeechResultsHandler
;
Voice
.
onSpeechError
=
onSpeechError
;
Voice
.
onSpeechPartialResults
=
onSpeechPartialResults
;
Voice
.
onSpeechVolumeChanged
=
onSpeechVolumeChanged
;
return
()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
};
},
[]);
const
onSpeechStartHandler
=
e
=>
{
console
.
log
(
'
start handler =>>
'
,
e
);
};
const
onSpeechEndHandler
=
e
=>
{
console
.
log
(
'
end handler =>>
'
,
e
);
};
const
onSpeechResultsHandler
=
e
=>
{
console
.
log
(
'
result handler =>>
'
,
e
);
};
const
onSpeechError
=
e
=>
{
console
.
log
(
'
onSpeechError:
'
,
e
);
setError
(
JSON
.
stringify
(
e
.
error
));
const
result
=
DummyReadResult
.
value
;
if
(
result
.
includes
(
'
hello
'
))
{
console
.
log
(
'
correct
'
);
}
};
const
onSpeechPartialResults
=
e
=>
{
console
.
log
(
'
onSpeechPartialResults:
'
,
e
);
setPartialResults
(
e
.
value
);
};
const
onSpeechVolumeChanged
=
e
=>
{
console
.
log
(
'
onSpeechVolumeChanged:
'
,
e
);
setPitch
(
e
.
value
);
};
const
startRecording
=
async
()
=>
{
try
{
await
Voice
.
start
(
'
en-US
'
);
}
catch
(
error
)
{
console
.
log
(
'
error =>>
'
,
error
);
}
};
const
stopRecording
=
async
()
=>
{
try
{
await
Voice
.
stop
();
}
catch
(
error
)
{
console
.
log
(
error
);
}
};
return
(
<
SafeAreaView
>
<
View
style
=
{{
flexDirection
:
'
column
'
}}
>
<
ImageBackground
style
=
{
styles
.
image
}
source
=
{
require
(
'
../../assets/read/image/activity-2-backg.jpeg
'
)}
>
<
View
style
=
{
styles
.
imageContainer
}
>
<
View
style
=
{
styles
.
imageView
}
>
<
View
style
=
{
styles
.
robo
}
>
<
Image
source
=
{
require
(
'
../../assets/read/image/activity-2-rob.png
'
)}
><
/Image
>
<
/View
>
<
/View
>
<
View
style
=
{
styles
.
textBody
}
>
<
Text
style
=
{
styles
.
text
}
>
Pronounce
this
Word
!<
/Text
>
<
/View
>
<
/View
>
{
/* <View style={styles.textBody}>
<Text style={styles.text}>Pronounce this Word!</Text>
</View>
<View style={styles.robo}>
<Image
source={require('../../assets/read/activity-2-rob.png')}></Image>
</View> */
}
<
View
>
<
Image
style
=
{
styles
.
blackboard
}
source
=
{
require
(
'
../../assets/read/image/backboard3.png
'
)}
><
/Image
>
<
/View
>
<
View
style
=
{
styles
.
horizontalView
}
>
<
TouchableHighlight
onPress
=
{
startRecording
}
>
<
Image
style
=
{
styles
.
imageButton
}
source
=
{{
uri
:
'
https://raw.githubusercontent.com/AboutReact/sampleresource/master/microphone.png
'
,
}}
/
>
<
/TouchableHighlight
>
<
/View
>
<
/ImageBackground
>
<
/View
>
<
/SafeAreaView
>
);
}
const
styles
=
StyleSheet
.
create
({
imageContainer
:
{
flexDirection
:
'
row
'
,
marginTop
:
70
,
},
imageView
:
{
width
:
180
,
height
:
300
,
// borderWidth:1,
// borderColor: "#000",
marginHorizontal
:
1
,
marginVertical
:
100
,
},
body
:
{
flex
:
1
,
},
image
:
{
width
:
'
100%
'
,
height
:
'
100%
'
,
},
box
:
{
width
:
180
,
height
:
180
,
// borderColor: "#000000",
backgroundColor
:
'
blue
'
,
marginTop
:
-
370
,
marginLeft
:
455
,
borderRadius
:
100
,
},
blackboard
:
{
marginTop
:
-
320
,
marginLeft
:
200
,
width
:
'
50%
'
,
height
:
300
,
},
robo
:
{
marginTop
:
90
,
marginLeft
:
5
,
width
:
150
,
height
:
200
,
},
textBody
:
{
marginTop
:
150
,
marginLeft
:
-
30
,
// backgroundColor: '#00008B',
width
:
150
,
borderRadius
:
50
,
padding
:
5
,
},
text
:
{
fontSize
:
25
,
justifyContent
:
'
center
'
,
alignItems
:
'
center
'
,
color
:
'
#00008B
'
,
borderRadius
:
10
,
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
textAlign
:
'
center
'
,
fontWeight
:
'
bold
'
,
},
button
:
{
padding
:
10
,
marginLeft
:
5
,
color
:
'
#000000
'
,
},
imageButton
:
{
width
:
50
,
height
:
50
,
},
horizontalView
:
{
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
borderRadius
:
50
,
flexDirection
:
'
row
'
,
position
:
'
absolute
'
,
bottom
:
0
,
flexDirection
:
'
row
'
,
marginBottom
:
140
,
marginLeft
:
50
,
padding
:
7
,
},
});
frontend/src/screen/reading/basic/ReadActivityNo.js
0 → 100644
View file @
f6d496d8
import
{
useNavigation
}
from
'
@react-navigation/native
'
;
import
Orientation
from
'
react-native-orientation-locker
'
;
import
React
,
{
useEffect
,
useState
}
from
'
react
'
;
import
{
Text
,
TouchableOpacity
,
StyleSheet
,
View
,
ImageButton
,
SafeAreaView
,
ImageBackground
,
Button
,
Image
,
TouchableHighlight
,
}
from
'
react-native
'
;
import
Voice
from
'
@react-native-voice/voice
'
;
import
{
DummyReadResult
}
from
'
../../assets/read/data/ReadData
'
;
export
default
function
ReadActivityNo
()
{
const
[
pitch
,
setPitch
]
=
useState
(
''
);
const
[
error
,
setError
]
=
useState
(
''
);
const
[
end
,
setEnd
]
=
useState
(
''
);
const
[
started
,
setStarted
]
=
useState
(
''
);
const
[
results
,
setResults
]
=
useState
([]);
const
[
partialResults
,
setPartialResults
]
=
useState
([]);
useEffect
(()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
},
[]);
useEffect
(()
=>
{
Voice
.
onSpeechStart
=
onSpeechStartHandler
;
Voice
.
onSpeechEnd
=
onSpeechEndHandler
;
Voice
.
onSpeechResults
=
onSpeechResultsHandler
;
Voice
.
onSpeechError
=
onSpeechError
;
Voice
.
onSpeechPartialResults
=
onSpeechPartialResults
;
Voice
.
onSpeechVolumeChanged
=
onSpeechVolumeChanged
;
return
()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
};
},
[]);
const
onSpeechStartHandler
=
e
=>
{
console
.
log
(
'
start handler =>>
'
,
e
);
};
const
onSpeechEndHandler
=
e
=>
{
console
.
log
(
'
end handler =>>
'
,
e
);
};
const
onSpeechResultsHandler
=
e
=>
{
console
.
log
(
'
result handler =>>
'
,
e
);
};
const
onSpeechError
=
e
=>
{
console
.
log
(
'
onSpeechError:
'
,
e
);
setError
(
JSON
.
stringify
(
e
.
error
));
const
result
=
DummyReadResult
.
value
;
if
(
result
.
includes
(
'
hello
'
))
{
console
.
log
(
'
correct
'
);
}
};
const
onSpeechPartialResults
=
e
=>
{
console
.
log
(
'
onSpeechPartialResults:
'
,
e
);
setPartialResults
(
e
.
value
);
};
const
onSpeechVolumeChanged
=
e
=>
{
console
.
log
(
'
onSpeechVolumeChanged:
'
,
e
);
setPitch
(
e
.
value
);
};
const
startRecording
=
async
()
=>
{
try
{
await
Voice
.
start
(
'
en-US
'
);
}
catch
(
error
)
{
console
.
log
(
'
error =>>
'
,
error
);
}
};
const
stopRecording
=
async
()
=>
{
try
{
await
Voice
.
stop
();
}
catch
(
error
)
{
console
.
log
(
error
);
}
};
return
(
<
SafeAreaView
>
<
View
style
=
{{
flexDirection
:
'
column
'
}}
>
<
ImageBackground
style
=
{
styles
.
image
}
source
=
{
require
(
'
../../assets/read/image/activity-2-backg.jpeg
'
)}
>
<
View
style
=
{
styles
.
imageContainer
}
>
<
View
style
=
{
styles
.
imageView
}
>
<
View
style
=
{
styles
.
robo
}
>
<
Image
source
=
{
require
(
'
../../assets/read/image/activity-2-rob.png
'
)}
><
/Image
>
<
/View
>
<
/View
>
<
View
style
=
{
styles
.
textBody
}
>
<
Text
style
=
{
styles
.
text
}
>
Pronounce
this
Word
!<
/Text
>
<
/View
>
<
/View
>
{
/* <View style={styles.textBody}>
<Text style={styles.text}>Pronounce this Word!</Text>
</View>
<View style={styles.robo}>
<Image
source={require('../../assets/read/activity-2-rob.png')}></Image>
</View> */
}
<
View
>
<
Image
style
=
{
styles
.
blackboard
}
source
=
{
require
(
'
../../assets/read/image/backboard3.png
'
)}
><
/Image
>
<
/View
>
<
View
style
=
{
styles
.
horizontalView
}
>
<
TouchableHighlight
onPress
=
{
startRecording
}
>
<
Image
style
=
{
styles
.
imageButton
}
source
=
{{
uri
:
'
https://raw.githubusercontent.com/AboutReact/sampleresource/master/microphone.png
'
,
}}
/
>
<
/TouchableHighlight
>
<
/View
>
<
/ImageBackground
>
<
/View
>
<
/SafeAreaView
>
);
}
const
styles
=
StyleSheet
.
create
({
imageContainer
:
{
flexDirection
:
'
row
'
,
marginTop
:
70
,
},
imageView
:
{
width
:
180
,
height
:
300
,
// borderWidth:1,
// borderColor: "#000",
marginHorizontal
:
1
,
marginVertical
:
100
,
},
body
:
{
flex
:
1
,
},
image
:
{
width
:
'
100%
'
,
height
:
'
100%
'
,
},
box
:
{
width
:
180
,
height
:
180
,
// borderColor: "#000000",
backgroundColor
:
'
blue
'
,
marginTop
:
-
370
,
marginLeft
:
455
,
borderRadius
:
100
,
},
blackboard
:
{
marginTop
:
-
320
,
marginLeft
:
200
,
width
:
'
50%
'
,
height
:
300
,
},
robo
:
{
marginTop
:
90
,
marginLeft
:
5
,
width
:
150
,
height
:
200
,
},
textBody
:
{
marginTop
:
150
,
marginLeft
:
-
30
,
// backgroundColor: '#00008B',
width
:
150
,
borderRadius
:
50
,
padding
:
5
,
},
text
:
{
fontSize
:
25
,
justifyContent
:
'
center
'
,
alignItems
:
'
center
'
,
color
:
'
#00008B
'
,
borderRadius
:
10
,
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
textAlign
:
'
center
'
,
fontWeight
:
'
bold
'
,
},
button
:
{
padding
:
10
,
marginLeft
:
5
,
color
:
'
#000000
'
,
},
imageButton
:
{
width
:
50
,
height
:
50
,
},
horizontalView
:
{
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
borderRadius
:
50
,
flexDirection
:
'
row
'
,
position
:
'
absolute
'
,
bottom
:
0
,
flexDirection
:
'
row
'
,
marginBottom
:
140
,
marginLeft
:
50
,
padding
:
7
,
},
});
frontend/src/screen/report.js
View file @
f6d496d8
...
@@ -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
>
)
)
...
...
frontend/src/screen/sideMenu.js
View file @
f6d496d8
...
@@ -8,8 +8,8 @@ import {
...
@@ -8,8 +8,8 @@ import {
Image
,
Image
,
}
from
"
react-native
"
;
}
from
"
react-native
"
;
import
home
from
"
./h
ome
"
;
import
Home
from
"
./H
ome
"
;
import
profile
from
"
./p
rofile
"
;
import
Profile
from
"
./P
rofile
"
;
import
{
NavigationContainer
}
from
"
@react-navigation/native
"
;
import
{
NavigationContainer
}
from
"
@react-navigation/native
"
;
import
{
createDrawerNavigator
}
from
"
@react-navigation/drawer
"
;
import
{
createDrawerNavigator
}
from
"
@react-navigation/drawer
"
;
...
@@ -22,11 +22,11 @@ function sideMenu(){
...
@@ -22,11 +22,11 @@ function sideMenu(){
<
NavigationContainer
>
<
NavigationContainer
>
<
Drawer
.
Navigator
>
<
Drawer
.
Navigator
>
<
Drawer
.
Screen
name
=
"
home
"
<
Drawer
.
Screen
name
=
"
home
"
component
=
{
h
ome
}
component
=
{
H
ome
}
/
>
/
>
<
Drawer
.
Screen
name
=
"
profile
"
<
Drawer
.
Screen
name
=
"
profile
"
component
=
{
p
rofile
}
component
=
{
P
rofile
}
/
>
/
>
<
/Drawer.Navigator
>
<
/Drawer.Navigator
>
<
/NavigationContainer
>
<
/NavigationContainer
>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment