Skip to content

Latest commit

 

History

History
141 lines (98 loc) · 4.19 KB

README.md

File metadata and controls

141 lines (98 loc) · 4.19 KB

Lingua Link Chat App

Lingua Link is a real-time chat application that allows users to create and join chat rooms, send messages, and manage their profiles. It is built using React, Firebase, and other modern web technologies.

Live Demo: Lingua Link

Lingua Link

Table of Contents

Architecture Overview

Lingua Link follows a client-server architecture, where the client-side is built using React and the server-side is managed by Firebase services. Here's an overview of the architecture:

  • Client-side:

    • Built using React, a popular JavaScript library for building user interfaces.
    • Utilizes React Router for client-side routing.
    • Uses Firebase Authentication for user authentication.
    • Manages state using React's built-in useState and useEffect hooks, along with Firebase Firestore for real-time data synchronization.
    • Utilizes Firebase Storage for storing profile images.
    • Employs Lucide icons for the user interface's iconography.
    • Uses React Toastify for displaying notifications to users.
  • Server-side:

    • Managed by Firebase services, including Firestore for real-time database functionality and Authentication for user authentication.
    • Uses Firebase Storage for storing profile images.

Technologies Used

  • Frontend:

    • React
    • React Router DOM
    • Lucide React (for icons)
    • React Toastify
    • Tailwind CSS (for styling)
  • Backend:

    • Firebase Firestore (NoSQL database)
    • Firebase Authentication
    • Firebase Storage
  • Development Tools:

    • Vite (build tool)
    • ESLint (for code linting)
    • PostCSS (for CSS processing)
    • Tailwind CSS (utility-first CSS framework)

Setup Instructions

Prerequisites

Before getting started, ensure you have the following installed on your machine:

  • Node.js (version 14 or above)
  • npm or yarn package manager
  • Firebase account and project setup

Installation

  1. Clone the repository to your local machine:

    git clone https://github.com/Saadaan-Hassan/Lingua-Link.git
  2. Navigate to the project directory:

    cd lingua-link
  3. Install project dependencies:

    npm install

    or

    yarn install

Configuration

  1. Create a Firebase project and set up Firebase Authentication, Firestore, and Storage services.

  2. Obtain your Firebase configuration settings.

  3. Create a .env file in the root directory of the project.

  4. Add your Firebase configuration settings to the .env file:

    REACT_APP_FIREBASE_API_KEY=your-api-key
    REACT_APP_FIREBASE_AUTH_DOMAIN=your-auth-domain
    REACT_APP_FIREBASE_PROJECT_ID=your-project-id
    REACT_APP_FIREBASE_STORAGE_BUCKET=your-storage-bucket
    REACT_APP_FIREBASE_MESSAGING_SENDER_ID=your-messaging-sender-id
    REACT_APP_FIREBASE_APP_ID=your-app-id
    

Running the Application

Once you've completed the setup and configuration, you can run the application locally:

npm run dev

or

yarn dev

This command starts the development server, and you can access the application at http://localhost:5173.

Project Structure

The project structure follows a typical React application structure, with the main components being:

  • src/
    • components/: Contains React components used throughout the application.
    • context/: Contains React context providers for managing application state.
    • firebase/: Firebase configuration and initialization files.
    • styles/: Contains global styles and Tailwind CSS configuration.

Acknowledgements

This project was created as part of Saadaan's portfolio to demonstrate skills in React development, Firebase integration, and modern web development practices. Special thanks to the open-source community for providing valuable tools and resources used in this project.