Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/spm999/medical-portal
It is a comprehensive web application designed to streamline healthcare management between doctors and patients. Built using React for the frontend and Node.js with PostgreSQL (NeonDB) for the backend, the system facilitates secure doctor registration, patient signup, login functionalities, and robust management of PDF documents.
https://github.com/spm999/medical-portal
bcryptjs cors css doctor jwt-authentication medical-care multer neondb nodejs nodemon npm postgres react react-router-dom
Last synced: 12 days ago
JSON representation
It is a comprehensive web application designed to streamline healthcare management between doctors and patients. Built using React for the frontend and Node.js with PostgreSQL (NeonDB) for the backend, the system facilitates secure doctor registration, patient signup, login functionalities, and robust management of PDF documents.
- Host: GitHub
- URL: https://github.com/spm999/medical-portal
- Owner: spm999
- License: apache-2.0
- Created: 2024-07-18T18:08:43.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-07-19T18:05:18.000Z (6 months ago)
- Last Synced: 2024-11-15T07:08:31.556Z (2 months ago)
- Topics: bcryptjs, cors, css, doctor, jwt-authentication, medical-care, multer, neondb, nodejs, nodemon, npm, postgres, react, react-router-dom
- Language: JavaScript
- Homepage: https://medical-portal-cyan.vercel.app
- Size: 117 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Medical Care
This project is a full-stack web application built to manage doctors and patients, enabling doctor registration, patient signup, login functionalities, PDF uploads, and patient-doctor associations.
## Features
* **Doctor Registration** : Allows doctors to register with their name, email, password, and specialty.
* **Patient Registration** : Enables patients to sign up with their name, email, and password.
* **Authentication and Authorization** : Uses JWT tokens for secure authentication and authorization.
* **PDF Upload** : Doctors can upload PDF documents, which are stored and managed using Cloudinary.
* **Patient-Doctor Association** : Doctors can link/unlink patients to/from their profiles.
* **Database Operations** : Utilizes PostgreSQL (NeonDB) for persistent storage of doctor, patient, and PDF data.
* **Responsive UI** : The frontend is built using React, ensuring a user-friendly experience across devices.## Technologies Used
### Frontend
* **React** : JavaScript library for building user interfaces.
* **React Router** : For routing within the single-page application.
* **Axios** : HTTP client for making API requests from React.
* **CSS (or styled-components)** : Styling the components.
* **Cloudinary** : For managing file uploads (PDFs).### Backend
* **Node.js** : JavaScript runtime for server-side logic.
* **Express.js** : Web application framework for Node.js.
* **PostgreSQL (NeonDB)** : Relational database management system for storing application data.
* **bcrypt** : For hashing passwords securely.
* **JWT (JSON Web Tokens)** : For authentication and authorization.
* **Multer** : Middleware for handling file uploads to Cloudinary.## Project Structure
The project follows a structured approach for frontend and backend separation:
* **`/app`** : Contains the React frontend.
* **`/server`** : Contains the Node.js backend.## Installation
1. **Clone the repository: `git clone https://github.com/spm999/Medical-Portal.git`**
2. **Install dependencies:*** For client (React):
```
cd app
npm install
```
* For server (Node.js):```
cd server
npm install
```
3. **Set up environment variables:*** Create `.env` files in both `client` and `server` directories.
* Example `.env` file for the server:```
PGHOST=
PGDATABASE=
PGUSER=
PGPASSWORD=
ENDPOINT_ID=JWT_SECRET=
CLOUDINARY_CLOUD_NAME=
CLOUDINARY_API_KEY=
CLOUDINARY_API_SECRET=
```
4. **Start the development servers:*** For client (React) : `npm run dev`
* For server (Node.js): `npm start`## Usage
* Access the application in your browser at `http://localhost:5173`.
* Register as a doctor or patient, then log in to manage your profile and associated data.
* Doctors can upload PDFs, link/unlink patients, and manage their profile details.
* Patients can view the doctors they are associated with and manage their own profile information.## Contributing
Contributions are welcome! Please fork the repository and create a pull request with your proposed changes.
## License
This project is licensed under the Apache License - see the LICENSE.md file for details.