Skip to content

A real-time web chat application built with Flask and Socket.IO. Enjoy :)!

Notifications You must be signed in to change notification settings

gd03champ/Chat_Web_App

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

65 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

iChat Web Application

iChat is a real-time web chat application built with Flask and Socket.IO. It provides a seamless and interactive platform for users to communicate with each other through individual chat rooms.

Project Structure

Chat_Web_App/
    myapp/
        static/
            images/
            auth.css
            chat.css
            index.js
            styles.css
        templates/
            auth.html
            base.html
            chat.html
            visualize.html
        __init__.py
        config.py
        database.py
        views.py
    .gitignore
    gunicorn_config.py
    README.md
    requirements.txt
    server.py

Getting Started

To run the iChat web application locally, follow these steps:

  1. Clone the repository:

    git clone https://github.com/your-username/Chat_Web_App.git
  2. Install the required dependencies:

    pip install -r requirements.txt
  3. Set up the environment variables:

    • Create a .env file in the project root.

    • Add the following lines to the .env file:

      SECRET_KEY=your_secret_key_here
      DATABASE_URL=sqlite:///database.db
  4. Run the server:

    python server.py

    or

    gunicorn -c gunicorn_config.py server:app

Visit http://localhost:5000 in your web browser to access iChat.

Features

  • User Authentication: Secure user registration and login with password hashing.
  • Real-time Chat: Instant messaging in individual chat rooms.
  • Dynamic Chat List: Automatically updates the chat list with new messages.
  • Responsive Design: Works seamlessly on desktop and mobile devices.
  • Visualize User Registration Trends Visualize the user registration data using Pandas and Matplotlib. This feature aims to analyze the number of users registered on the app over time and present the findings in a graphical format.

Project Architecture

__init__.py

Initialization of the Flask application, configuration, and extension setup.

config.py

Configuration settings for the Flask application, including the secret key and database URI.

database.py

Database models and schema definition using SQLAlchemy. Includes user, chat, and message models.

views.py

Blueprint for route views, including login, registration, chat, and visualization routes.

gunicorn_config.py

Gunicorn's configuration file for deployment settings.

server.py

Entry point for running the server. Initializes the Flask application and Socket.IO communication events.

⛏️ Built With

FlaskHTML5CSS3JavaScriptBootstrapFlaskSqlalchemy

🤳 Screenshots

Register Login Add other users (Chat Window)
(Chat Window _A) (Chat Window _B) (Chat Window _C)
(Chat Window _D)

Contributing

Contributions are welcome! If you'd like to contribute to iChat, please follow the contribution guidelines.

License

This project is licensed under the MIT License.

About

A real-time web chat application built with Flask and Socket.IO. Enjoy :)!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 39.3%
  • HTML 38.3%
  • CSS 22.2%
  • JavaScript 0.2%