Chatty is a user-friendly mobile chat app built React Native offering a smooth messaging experience together with the possiblility to chare images and location.
Create a serverless, progressive web application (PWA) in React following the test-driven development (TDD) approach, integrating with Google Calendar API to fetch and showcase upcoming events.
- React Native
- Expo (toolchain for building native apps in JS)
- React Native Gifted Chat library
- Google Firestore DB (storing messages)
- Google Firebase Authentication
- AsyncStorage caching (offline use)
- Firebase Cloud Storage (storing images)
- Expo ImagePicker and MediaLibrary (additional communication features)
- A page where users can enter their name and choose a background color for the chat screen before joining the chat
- A page displaying the conversation, as well as an input field and submit button
- The chat must provide users with two additional communication features: sending images and location data
- Data gets stored online and offline
-
The app must be written in React Native
-
The app must be developed using Expo
-
The app must be styled according to the given screen design
-
Chat conversations must be stored in Google Firestore Database
-
The app must authenticate users anonymously via Google Firebase authentication
-
Chat conversations must be stored locally
-
The app must let users pick and send images from the phone’s image library
-
The app must let users take pictures with the device’s camera app, and send them
-
The app must store images in Firebase Cloud Storage
-
The app must be able to read the user’s location data
-
Location data must be sent via the chat in a map view
-
The chat interface and functionality must be created using the Gifted Chat library
-
The app’s codebase must contain comments
-
Clone repository
-
npm install - expo-cli Install Expo
-
Install All Required Packages
npx expo start or npm start Start Expo
- Sign-up or sign in to Firebase and add a new project
- Navigate to 'Build' > 'Firestore Database': create a new database in production mode
- Navigate to 'Project Settings' > 'General' > 'Your apps' and select the web app option symbol (</>) and follow the instruction to create a Firebase web app
- Install firebase to add firebase connection into your project directory:
npm install firebase
- Copy the Firebase Config from the project setting tab and paste into you App.js file
- Navigate to the rules tab in the console. To allow read and write access to the database, change the code:
allow read, write: if false;
to:allow read, write: if true;
. Click publish
Packages to install:
npm install --save @react-navigation/native @react-navigation/native-stack
expo install react-native-screens react-native-safe-area-context
npm install react-native-gifted-chat --save
npm install [email protected] --save
expo install @react-native-async-storage/async-storage
expo install @react-native-community/netinfo
expo install expo-image-picker
expo install expo-location
expo install react-native-maps
Laure Lincker
- GitHub: @LoulouLinck
This was a solo project guided by tutors and mentors from CareerFoundry.