/health-facilities

Geospatial solution for showing health facilities in Kenya with the use of GeoDjango, Nginx and Node

Primary LanguagePythonMIT LicenseMIT

Health Facilities App

Health facilities is a full-stack web application that leverages GeoDjango, Nginx, Node, and React to visualize the health facilities located in Kenya. The goal of this project is to showcase, to especially beginners and mid-level web developers, the use of backend and frontend technologies in crafting an interactive web application.

health-facilities

Table of Contents

Features

  • Interactive map
  • Spatial database
  • Scalable frontend and backend apps
  • Reverse proxy server
  • Containerized services

Technologies Used

Frontend

  • Node
  • React
  • Leaflet
  • Bootstrap5

Backend

  • Python
  • Django
  • GeoDjango
  • PostGIS

Note: Data used in this project has been sourced from The Humanitarian Data Exchange Find data repository.

API Gateway

  • Nginx proxy server

Getting Started

  1. Clone the repository:

    git clone https://github.com/jkariukidev/health-facilities.git
    cd health-facilities
    
  2. Install Docker with these instructions.

  3. Rename the .env_sample file to .env

  4. Populate the .env file with respective values.

  5. Build images

    make build
  6. Start Postgis, nginx, Django, and client services

    make start services
  7. Create tables in the PostGIS database via Django's migrate command.

    make migrate
  8. Populate tables with health facilities data

    make load-facilities-data
  9. Navigate to http://127.0.0.1/ to view the client app and http://127.0.0.1:8000/api/v1/healthfacilites to view the API.

Usage

  1. Django Backend

  2. React Frontend

    • Access the React frontend at: http://127.0.0.1/
    • Navigate through the user interface to interact with the app's features.
    • Make HTTP requests to the Django API using libraries like axios or fetch from the frontend code.

Interacting with Both:

  • Use the React frontend to send requests to the Django backend's API endpoints.
  • Fetch data from the Django backend and display it in the React components.

API Documentation

This project's API documentation has been generated using:

Contributing

Contributions are welcome! Here's how you can get involved:

  1. Fork the repository and create a new branch.
  2. Make your changes and test thoroughly.
  3. Open a pull request with a clear description of your changes.

License

This project is licensed under the MIT License.