Commit b8842fd5 authored by Malith Anjana's avatar Malith Anjana

add chatbot

parent b31ccf5f
......@@ -6,6 +6,7 @@ import { NavigationContainer } from '@react-navigation/native';
import { createNativeStackNavigator } from '@react-navigation/native-stack';
import {Home} from './src/screens/Home';
import AsyncStorage from '@react-native-async-storage/async-storage';
import { Chatbot } from './src/screens/Chatbot';
const Stack = createNativeStackNavigator();
// create a component
......@@ -16,7 +17,7 @@ const App = () => {
retrieveData();
});
//Onboardin check
//Onboarding check
const retrieveData = async () => {
try {
const value = await AsyncStorage.getItem('hasOnboarded');
......@@ -31,17 +32,22 @@ const App = () => {
<NavigationContainer>
<Stack.Navigator>
{<Stack.Screen
<Stack.Screen
name="Onboard"
component={Onboard}
initialParams
options={{headerShown:false}}
/>}
/>
<Stack.Screen
name="Home"
component={Home}
options={{ title: 'Welcome' }}
/>
<Stack.Screen
name="Chatbot"
component={Chatbot}
options={{headerShown:false}}
/>
</Stack.Navigator>
</NavigationContainer>
......
......@@ -83,6 +83,7 @@ project.ext.react = [
]
apply from: "../../node_modules/react-native/react.gradle"
apply from: "../../node_modules/react-native-vector-icons/fonts.gradle"
/**
* Set this to true to create two separate APKs instead of one:
......@@ -263,7 +264,7 @@ android {
dependencies {
implementation fileTree(dir: "libs", include: ["*.jar"])
implementation project(':react-native-vector-icons')
//noinspection GradleDynamicVersion
implementation "com.facebook.react:react-native:+" // From node_modules
......
......@@ -3,6 +3,10 @@ apply from: file("../node_modules/@react-native-community/cli-platform-android/n
include ':app'
includeBuild('../node_modules/react-native-gradle-plugin')
include ':react-native-vector-icons'
project(':react-native-vector-icons').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-vector-icons/android')
if (settings.hasProperty("newArchEnabled") && settings.newArchEnabled == "true") {
include(":ReactAndroid")
project(":ReactAndroid").projectDir = file('../node_modules/react-native/ReactAndroid')
......
import axios from "axios";
const RASA_BASE = "http://192.168.124.34:5005/webhooks/rest/webhook"
export async function sendToRasa (body){
return axios({
url:RASA_BASE,
method: "POST",
data: {message:body}
})
}
\ No newline at end of file
import { useNavigation } from "@react-navigation/core";
import React from "react";
import { View, Text, StyleSheet, TouchableOpacity, Image } from "react-native";
import Icon from "react-native-vector-icons/FontAwesome5";
export const ChatHeader = () => {
const navigation = useNavigation();
return (
<View style={styles.container}>
<TouchableOpacity style={styles.backButton}>
<Icon name="angle-left" size={30}/>
</TouchableOpacity>
<View style={styles.profileOptions}>
<TouchableOpacity style={styles.profile}>
<Image style={styles.image} source={{ uri: "" }} />
<View style={styles.usernameAndOnlineStatus}>
<Text style={styles.username}>"test"</Text>
<Text style={styles.onlineStatus}>"Text</Text>
</View>
</TouchableOpacity>
<View style={styles.options}>
<TouchableOpacity
style={{ paddingHorizontal: 5 }}
>
<Icon
name="phone"
size={30}
color={"white"}
/>
</TouchableOpacity>
<TouchableOpacity style={{ paddingHorizontal: 20 }}>
<Icon
name="ellipsis-v"
size={30}
color={"white"}
/>
</TouchableOpacity>
</View>
</View>
</View>
);
};
const styles = StyleSheet.create({
container: {
flexDirection: "row",
backgroundColor: "blue",
paddingTop: 10,
paddingBottom: 10,
},
backButton: {
alignSelf: "center",
paddingHorizontal: 10,
},
profileOptions: {
flex: 1,
flexDirection: "row",
justifyContent: "space-between",
alignItems: "center",
paddingHorizontal: 10,
},
profile: {
flexDirection: "row",
alignItems: "center",
borderColor: "#fff",
flex: 4,
},
image: {
height: 65,
width: 65,
borderRadius: 32.5,
},
usernameAndOnlineStatus: {
flexDirection: "column",
justifyContent: "center",
paddingHorizontal: 10,
},
username: {
color: "white",
fontSize: 18,
fontWeight: "bold",
},
onlineStatus: {
color: "white",
fontSize: 16,
},
options: {
flex: 1,
flexDirection: "row",
justifyContent: "flex-end",
alignItems: "center",
},
});
module.exports = {
dependencies: {
'react-native-vector-icons': {
platforms: {
ios: null,
},
},
},
};
\ No newline at end of file
import axios from 'axios';
import React, { useCallback, useEffect, useState } from 'react'
import { Text, View } from 'react-native'
import { GiftedChat } from 'react-native-gifted-chat';
import { sendToRasa } from '../api';
import { ChatHeader } from '../components/chatbot/ChatHeader'
export const Chatbot = () => {
const [messages, setMessages] = useState([]);
useEffect(() => {
// setMessages([
// {
// _id: 1,
// text: 'Hello how is going',
// createdAt: new Date(),
// sendTo:2,
// sentBy:1,
// user: {
// _id: 1,
// name: 'React Native',
// avatar: 'https://placeimg.com/140/140/any',
// },
// },
// {
// _id: 2,
// text: 'Hello developer',
// createdAt: new Date(),
// user: {
// _id: 2,
// name: 'React Native',
// avatar: 'https://placeimg.com/140/140/any',
// },
// },
// {
// _id: 3,
// text: 'Hello bot',
// createdAt: new Date(),
// user: {
// _id: 1,
// name: 'React Native',
// avatar: 'https://placeimg.com/140/140/any',
// },
// },
// {
// _id: 4,
// text: 'Hello user',
// createdAt: new Date(),
// user: {
// _id: 2,
// name: 'React Native',
// avatar: 'https://placeimg.com/140/140/any',
// },
// },
// ])
}, [])
const onSend = useCallback(async(msg = []) => {
console.log(msg[0].text);
setMessages(previousMessages => (GiftedChat.append(previousMessages, msg)));
try{
const res = await sendToRasa(msg[0].text);
let reply = [];
res.data.map((d)=>{
console.log(d.text);
const rp = {
text: d.text,
createdAt: new Date(),
user: {
_id: 1,
name: 'React Native',
avatar: 'https://placeimg.com/140/140/any',
},
}
reply.push(rp)
}
)
setMessages(prev=> prev.concat(reply));
}
catch(err){
console.log(err)
}
}, [])
return (
<View style={{flex:1}}>
<ChatHeader/>
<GiftedChat
messages={messages.reverse()}
onSend={msg => onSend(msg)}
user={{
_id: "132reweewa52332525252twe",
}}
/>
</View>
)
}
//import liraries
import { useNavigation } from '@react-navigation/core';
import React, { Component } from 'react';
import { View, Text, StyleSheet } from 'react-native';
import { View, Text, StyleSheet, Button } from 'react-native';
// create a component
export const Home = () => {
const navigation = useNavigation();
return (
<View style={styles.container}>
<Text style={{fontSize:20}}>Home</Text>
<Button title="Chatbot" onPress={()=> navigation.navigate('Chatbot')}/>
</View>
);
};
......
......@@ -3,22 +3,24 @@ import { Image, View, StyleSheet, TouchableOpacity, Text, Button } from 'react-n
import Onboarding from 'react-native-onboarding-swiper';
import { useNavigation } from '@react-navigation/core';
import AsyncStorage from '@react-native-async-storage/async-storage';
import { COLOR } from '../themes';
const Square = ({ isLight, selected }) => {
let backgroundColor;
if (isLight) {
backgroundColor = selected ? '#2196F3' : 'rgba(0, 0, 0, 0.3)';
backgroundColor = selected ? COLOR.primary : 'rgba(0, 0, 0, 0.3)';
} else {
backgroundColor = selected ? '#2196F3' : 'rgba(255, 255, 255, 0.5)';
backgroundColor = selected ? COLOR.primary : 'rgba(255, 255, 255, 0.5)';
}
return (
<View
style={{
width: 6,
width: 30,
height: 6,
borderRadius:6,
marginHorizontal: 3,
padding:0,
marginHorizontal:0,
Radius:6,
backgroundColor,
}}
/>
......@@ -28,13 +30,13 @@ const Square = ({ isLight, selected }) => {
const Done = ({ isLight, ...props }) => {
const navigation = useNavigation();
return ( <TouchableOpacity {...props} onPress={async ()=>{
await AsyncStorage.setItem('hasOnboarded',true
);
// await AsyncStorage.setItem('hasOnboarded',true
// );
navigation.navigate('Home')
}
}>
<View style={{
backgroundColor: '#2196F3',
backgroundColor: COLOR.primary,
alignItems: 'center',
justifyContent: 'center',
paddingVertical:"3%",
......@@ -43,7 +45,7 @@ const Done = ({ isLight, ...props }) => {
borderRadius: 20
}}
>
<Text style={{ color: 'white',fontSize:16 }}>Get Start</Text>
<Text style={{ color: COLOR.white,fontSize:16 }}>Get Start</Text>
</View>
</TouchableOpacity>
);
......@@ -58,7 +60,7 @@ const Skip = ({ ...props}) =>{
navigation.navigate('Home')
}}>
<View style={{
backgroundColor: '#ffff',
backgroundColor: COLOR.white,
alignItems: 'center',
justifyContent: 'center',
paddingVertical:"3%",
......@@ -67,7 +69,7 @@ const Skip = ({ ...props}) =>{
borderRadius: 20
}}
>
<Text style={{ color: '#2196F3',fontSize:16, fontWeight:"bold"}}>Skip</Text>
<Text style={{ color: COLOR.primary,fontSize:16, fontWeight:"bold"}}>Skip</Text>
</View>
</TouchableOpacity>
)};
......@@ -76,7 +78,7 @@ const Skip = ({ ...props}) =>{
const Next = ({ isLight, ...props }) => (
<TouchableOpacity {...props}>
<View style={{
backgroundColor: '#2196F3',
backgroundColor: COLOR.primary,
alignItems: 'center',
justifyContent: 'center',
paddingVertical:"3%",
......@@ -85,7 +87,7 @@ const Next = ({ isLight, ...props }) => (
borderRadius: 20
}}
>
<Text style={{ color: 'white',fontSize:16 }}>Next</Text>
<Text style={{ color: COLOR.white,fontSize:16 }}>Next</Text>
</View>
</TouchableOpacity>
);
......@@ -96,25 +98,25 @@ export const Onboard = () => (
NextButtonComponent={Next}
SkipButtonComponent={Skip}
DoneButtonComponent={Done}
bottomBarColor={"#fff"}
bottomBarColor={COLOR.white}
subTitleStyles={{fontSize:14,marginTop:-60,paddingHorizontal:10}}
titleStyles={{fontWeight:"bold", fontSize:24, marginTop:-120}} // set default color for the title
pages={[
{
backgroundColor: '#fff',
backgroundColor: COLOR.backgroundOnBoard,
image: <Image style={styles.image} source={require('../assets/images/onboard1.jpg')} />,
title: "Buy & Selling",
subtitle: 'Lorem Ipsum is simply dummy text of the printing and typesetting industry.',
},
{
backgroundColor: '#fff',
backgroundColor: COLOR.backgroundOnBoard,
image: <Image style={styles.image} source={require('../assets/images/onboard2.jpg')} />,
title: 'From Anywhere ',
subtitle: 'Lorem Ipsum is simply dummy text of the printing and typesetting industry.',
},
{
backgroundColor: '#fff',
backgroundColor: COLOR.backgroundOnBoard,
image: <Image style={[styles.image]} source={require('../assets/images/onboard3.jpg')} />,
title: 'Real State',
subtitle: "Lorem Ipsum is simply dummy text of the printing and typesetting industry.",
......@@ -130,6 +132,6 @@ const styles = StyleSheet.create({
margin:0
},
button:{
backgroundColor:"#ffff",
backgroundColor:COLOR.white,
}
})
\ No newline at end of file
export const COLOR = {
primary: '#14db98',
onPrimary: '#fff',
surface: '#fff',
onSurface: '#000',
backgroundOnBoard: 'white',
white:"white"
};
\ No newline at end of file
This diff is collapsed.
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