Appointify is a Django REST project that allows patients to book appointments with doctors. It provides a user-friendly interface for patients to search for doctors, view their availability, and book appointments conveniently.
- User Registration and Authentication: Patients can create an account to access the booking functionality. Authentication is required to book appointments and manage user-specific data.
- Doctor Listings: Patients can view a list of available doctors, including their specialization and contact information. This helps patients find the right doctor for their needs.
- Appointment Booking: Patients can book an appointment with a doctor of their choice. They can select a preferred date and time from the doctor's available time slots.
- Appointment Management: Patients can view a list of their booked appointments. They can also reschedule.
- Doctor Appointment Listings: Doctors can view a list of their upcoming appointments. This helps doctors stay organized and manage their schedule effectively, and they can update status of their appointment as well.
- Appointment Confirmation: Doctors can confirm or deny an appointment based on their availability and other factors. Patients receive notifications regarding the status of their appointments.
1- To set up and run the Appointify project locally, follow these steps:
git clone https://github.com/mehdirazajaffri/appointify
2- Change to the project directory:
cd appointify
3- Create Virtual Environment:
python -m venv env
4- Activate Virtual Environment:
source env/bin/activate
5- Install dependencies:
pip install -r requirements.txt
6- Run the migrations:
python manage.py migrate
7- Create a superuser: to access the admin panel and create doctors and their Time Slots.
python manage.py createsuperuser
8- Run the server:
python manage.py runserver 0.0.0.0:8000
Note: You can access the admin panel at http://localhost:8000/admin/
docker-compose up
Note: With Docker, you can access the admin panel at http://localhost/admin/
- API documentation is available at http://localhost:8000/schema/swagger-ui/ or https://mehdijaffri.pythonanywhere.com/schema/swagger-ui/
- API documentation is available at http://localhost:8000/schema/redoc/ or https://mehdijaffri.pythonanywhere.com/schema/redoc/
- You can also download the OpenAPI OAS3 at http://localhost:8000/schema/ or https://mehdijaffri.pythonanywhere.com/schema/
- Python 3.9.5
- Django 3.2.5
- Django REST Framework 3.12.4
-
Super Admin
- Username: admin
- Password: Mehdi123
-
Patient
- Username: patient1
- Password: Mehdi123
-
Patient Token can be generated
- The frontend is built with React
cd appointify-ui
- Install dependencies:
npm install
- Run the server:
npm start
- Build the project:
npm run build
- Frontend will be available at http://localhost:3000/
If you have any questions, suggestions, or issues, please contact the project maintainer:
- Mehdi Raza (mehdirazajaffri@gmail.com)