Skip to content

Ecommerce shop that sells serviceable lights and locks. Fullstack desktop application made using PyQt5, MySQL and MongoDB

License

Notifications You must be signed in to change notification settings

BrendanCheong/Lights-And-Locks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Welcome to Lights and Locks!

Python Flask MySQL MongoDB

About

With the advent and popularity of ecommerce, more and more consumers are purchasing smart-home equipment online. A company that focuses its business on smart home equipment has decided to incorporate a new Online Smart Home Ecommerce System. The company’s in-house IT team is expected to deliver a database software application (named “OSHES”) to manage product sales, administration, and maintenance.

Details

This project is part of the module BT2102: Data Management and Visualisation assignment 1, where students are tasked to create an OSHES (Online Smart Home Ecommerce System) using only python, MySQL and MongoDB

Lights and Locks sells state of the art Lights and Locks. Customers can search for products based on product category and model and specify product and item attributes when searching before purchasing a Light or a Lock. Customers can also send their purchased items for servicing, but will have to pay a service fee IF they request to service an item that is out of warranty. As an added feature, customers can request to service the item more than one time. Customers can also cancel their requests, but not when the item is already undergoing servicing by the Admin.

Meanwhile, Admins can also search for products like customers but will get to see more information on the items like how much it cost to produce the item. Admins can also approve of requests and can choose to service those approved requests.

Setup

to install dependencies

pip install -r requirements.txt

Ensure that MySQL is set up locally with the following credentials:

user: 'root'
password: 'password'
port: 3306
mysql_db: 'OSHES'
host: '127.0.0.1'

Ensure that MongoDB is set up locally with the following credentials:

mongo_uri: 'mongodb://localhost:27017'
cluster_name: 'admin'

you can configure all this in the db_config.py file under the Backend folder

Usage

Make sure you have python version 3.7.5 and above

Make sure your console starts off from this before performing the commands below

.../BT2102-OSHES-Group16/
  1. run the local Backend Flask server under Backend/main.py
cd Backend\ Server/ && python main.py
  1. run the GUI under GUI/LoginForm.py (you need to open a seperate terminal to run the GUI below)
# open a seperate terminal and make sure you are on the .../BT2102-OSHES-Group16/ directory before performing the command below
cd GUI && python LoginForm.py

Creating an administrator requires the admin key of "group16". You will need to login as an admin to initialise the database by pressing the initialise database button on the admin homepage

Tech Stack

Libraries and Frameworks Used Backend/Frontend
PyQt5 Frontend GUI
Flask Backend Server
MySQL Database
MongoDB Database

About

Ecommerce shop that sells serviceable lights and locks. Fullstack desktop application made using PyQt5, MySQL and MongoDB

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages