The Online Retail POS System is a web-based application developed with Django, designed to manage retail operations efficiently by handling inventory, sales, and hardware integrations. You can run it locally and access it from different devices on the same network using the system's IP address.
Before you begin, ensure you have the following prerequisites installed:
- Python 3.x
- Docker(Optional)
- Database
-
Clone this repository to your local machine,
git clone https://github.com/virajkothari7/OnlineRetailPOS.git cd path_to_dir/online-retail-pos pip install -r requirements.txt
-
If you prefer, you can also download the project as a ZIP file and extract it to your desired location.
cd path_to_dir/online-retail-pos pip install -r requirements.txt
-
- Create a .env file in the project's root directory to store your configuration variables. See .env.sample file for required variables.
-
-
Change Databse configuration in settings/dev.py according to your database requirement, I would suggest to use some cloud database so that you data is stored regardless where project is running and can have multiple POS setup.
-
There is optional setting commented out for Cloud Database with SSH tunneling. Your database host might require different way to connect. Look into settings/developement.py for further.
-
SQLite file is configured for default, change it in django settings/devlopement.py Databases if using another database setup. You can change between databses from postgres, mysql and sqlite through passing env varibales.
-
Correctly setup .env file, as well as configure Database correctly. Make sure all tweaks are done according to you.
- Go to the project folder
cd path_to_dir/online-retail-pos
- Install required python libraries, if not already done.
pip install -r requirements.txt
- Intial Database setup
python manage.py makemigrations python manage.py migrate
- Creating Superuser for access to platform
Creating your main user, to access admin panel and create more users, if running in docker, use docker shell once docker setup is done.python manage.py createsuperuser
- Superuser can create staff and users, hence you want to have one superuser. Also, you won't be able to access admin page for first time without it.
- Staff status for users who you want to provide access to admin panel, you might have to tweak their permission on admin panel. This users will be able to add new products and create department and all.
- User status for those who will just use POS for sales transaction and are not required to manuplate inventory data.
This app can be run on any device where django or docker(may require some configuration) can be run. You will need a server/local machine to run the project
- To start the Django development server, run the below command. To stop the server, you can typically use Ctrl+C in the terminal where the server is running.
python manage.py runserver 0.0.0.0:8000
- You can now access the POS system in your web browser by navigating:
- If same machine where django is running
http://127.0.0.1:8000
- Same network where django is running, this functionality may not work as expected
http://djangoserver_ip_addrs:8000
- If same machine where django is running
- Reciept Functionality
This only works on the machine where the project is running, since it requires port connection to printer.- Make sure you have receipt printer connected to django server machine.
- If your tablet can connect to POS printer than configure this project print_reciept method on tranasaction.views accordingly
- Customer Screen
You need to do a dual monitor setup on the machine where you will accesing POS system, Example:- If accesing POS from Tablet with django server running on rasp-pi or a server, you will connect second monitor to Tablet for this functionality
- If accesing POS from Window touch tablet/pc with django runnnig locally on same machine, connect second display here for this funcitonality
- Folder: images4display
In customer display there is slideshow of images, which can be used to put promotion/prices. Project uses directory images4display to slideshow phots from that directory, all photos in directory will be used. Only add photos in directory otherwise it will run into erro. More info
Docker package is provided for the repository to be pulled directly in docker. You can just pass in .env file with required varibles in the docker image, it should run as expected. Read dockerfile for better undertanding. Make sure you have docker installed for respective setup.
- Pull docker image
docker pull ghcr.io/virajkothari7/onlineretailpos:latest
- Run docker image
It will run without passing any varibles with default values, however, it will best if you provide secret_key and database configuration thorugh either passing varible or .env file in command line, read further in dockerfile.
docker run ghcr.io/virajkothari7/onlineretailpos:latest
- Passing varibles example: docker run -e "VARIABLE1=value1" -e "VARIABLE2=value2" <image_name>
- Passing .env file itself: docker run --env-file=/path/to/.env <image_name>
- <image_name> refers to docker image name you have, for example form above, it will be
ghcr.io/virajkothari7/onlineretailpos:latest
If you want to run docker setup with docker postgres associated with the app. You can download the repo and just run docker compose up from the folder.
- Make sure to update DBUSER, DBPASS and SECRET_KEY_DEV in docker compose file
- Go to project directory
- Building image
docker compose build
- Running docker
If you run into error just cancel and run 'docker compose up' again.
docker compose up
Also if you want to customize the project and still use docker, you can make changes to the code and build the docker image with that code using docker compose.
- Manage inventory and products
- Process sales transactions
- ESPPOS Receipt generation(Only Works if Printer is Connceted to Server or Your device has ESCPOS drivers and can print using those mini printers)
- Multi-device access on the same network using IP address
- Can set-up as live web app, however will have to configure accodingly. Some funcitonality may not work on prod web app.
- Run locally on touch screen device for best functionality
- Can have set up as-display images on customer facing screen, manage images4display folder in base dir of project.
This project is licensed under MIT License. For more details, refer to the License file.