Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/coslynx/fitness-tracker-personalized-mvp

Project: Track fitness goals, log workouts, and share progress with friends. Created at https://coslynx.com
https://github.com/coslynx/fitness-tracker-personalized-mvp

api-integration code-generation data-analytics developer-tools devops fitness-tracker goal-setting machine-learning mvp mvp-development nextjs postgresql prisma progress-tracking social-sharing software-development tailwindcss typescript user-authentication zustand

Last synced: about 1 month ago
JSON representation

Project: Track fitness goals, log workouts, and share progress with friends. Created at https://coslynx.com

Awesome Lists containing this project

README

        




fitness-tracker-personalized-mvp


A personalized fitness tracker built with React and Node.js, providing goal setting, progress tracking, and a social community feature.


Developed with the software and tools below.



Framework-React-blue
Frontend-Javascript,_Html,_Css-red
Backend-Node.js-blue
Database-PostgreSQL-blue


git-last-commit
GitHub commit activity
GitHub top language

## ๐Ÿ“‘ Table of Contents
- ๐Ÿ“ Overview
- ๐Ÿ“ฆ Features
- ๐Ÿ“‚ Structure
- ๐Ÿ’ป Installation
- ๐Ÿ—๏ธ Usage
- ๐ŸŒ Hosting
- ๐Ÿ“„ License
- ๐Ÿ‘ Authors

## ๐Ÿ“ Overview
The repository contains a Minimum Viable Product (MVP) called "fitness-tracker-personalized-mvp" that provides a comprehensive solution using the following tech stack: React, JavaScript, HTML, CSS, Node.js, PostgreSQL, and NextAuth.js.

## ๐Ÿ“ฆ Features
| | Feature | Description |
|----|--------------------|--------------------------------------------------------------------------------------------------------------------|
| โš™๏ธ | **Architecture** | The codebase follows a modular architectural pattern with separate directories for different functionalities, ensuring easier maintenance and scalability. |
| ๐Ÿ“„ | **Documentation** | The repository includes a README file that provides a detailed overview of the MVP, its dependencies, and usage instructions.|
| ๐Ÿ”— | **Dependencies** | The codebase relies on various external libraries and packages such as React, Zustand, NextAuth.js, Tailwind CSS, and Prisma, which are essential for building and styling the UI components, handling user authentication, and interacting with the database.|
| ๐Ÿงฉ | **Modularity** | The modular structure allows for easier maintenance and reusability of the code, with separate directories and files for different functionalities such as components, pages, styles, and utils.|
| ๐Ÿงช | **Testing** | Implement unit tests using frameworks like Jest or React Testing Library to ensure the reliability and robustness of the codebase. |
| โšก๏ธ | **Performance** | The performance of the system can be optimized based on factors such as the browser and hardware being used. Consider implementing performance optimizations for better efficiency.|
| ๐Ÿ” | **Security** | Enhance security by implementing measures such as input validation, data encryption, and secure communication protocols.|
| ๐Ÿ”€ | **Version Control**| Utilizes Git for version control with GitHub Actions workflow files for automated build and release processes.|
| ๐Ÿ”Œ | **Integrations** | The application integrates with external services through HTTP requests, and includes features like user authentication and database interactions.|
| ๐Ÿ“ถ | **Scalability** | Design the system to handle increased user load and data volume, utilizing caching strategies and cloud-based solutions for better scalability. |

## ๐Ÿ“‚ Structure
```text
โ”œโ”€โ”€ components
โ”‚ โ”œโ”€โ”€ Button.tsx
โ”‚ โ”œโ”€โ”€ Header.tsx
โ”‚ โ”œโ”€โ”€ Layout.tsx
โ”‚ โ”œโ”€โ”€ GoalInput.tsx
โ”‚ โ”œโ”€โ”€ ProgressChart.tsx
โ”‚ โ””โ”€โ”€ SocialShareButton.tsx
โ”œโ”€โ”€ pages
โ”‚ โ”œโ”€โ”€ api
โ”‚ โ”‚ โ”œโ”€โ”€ auth.ts
โ”‚ โ”‚ โ”œโ”€โ”€ goals.ts
โ”‚ โ”‚ โ””โ”€โ”€ progress.ts
โ”‚ โ”œโ”€โ”€ _app.tsx
โ”‚ โ”œโ”€โ”€ index.tsx
โ”‚ โ”œโ”€โ”€ dashboard.tsx
โ”‚ โ””โ”€โ”€ login.tsx
โ”œโ”€โ”€ styles
โ”‚ โ””โ”€โ”€ global.css
โ”œโ”€โ”€ utils
โ”‚ โ”œโ”€โ”€ helpers.ts
โ”‚ โ”œโ”€โ”€ api.ts
โ”‚ โ”œโ”€โ”€ auth.ts
โ”‚ โ””โ”€โ”€ validation.ts
โ”œโ”€โ”€ config
โ”‚ โ””โ”€โ”€ next-auth.config.ts
โ”œโ”€โ”€ middleware
โ”‚ โ””โ”€โ”€ authentication.ts
โ””โ”€โ”€ .env

```

## ๐Ÿ’ป Installation
### ๐Ÿ”ง Prerequisites
- Node.js
- npm
- Docker

### ๐Ÿš€ Setup Instructions
1. Clone the repository:
- `git clone https://github.com/coslynx/fitness-tracker-personalized-mvp.git`
2. Navigate to the MVP directory:
- `cd fitness-tracker-personalized-mvp`
3. Install dependencies:
- `npm install`
4. Set up environment variables:
- Create a `.env` file in the root directory and add the following:
```
NEXTAUTH_URL=http://localhost:3000
NEXTAUTH_SECRET=YOUR_SECRET_KEY
DATABASE_URL=postgres://username:password@localhost:5432/database_name
```
Replace `YOUR_SECRET_KEY` with a strong secret key and replace the database details accordingly.
5. Start the development server:
- `npm run dev`
6. Open your browser and navigate to [http://localhost:3000](http://localhost:3000).

## ๐Ÿ—๏ธ Usage
### ๐Ÿƒโ€โ™‚๏ธ Running the MVP
1. Start the development server:
- `npm run dev`
2. Open your browser and navigate to [http://localhost:3000](http://localhost:3000).

### โš™๏ธ Configuration
Adjust configuration settings in `next-auth.config.ts` or `.env`.

### ๐Ÿ“š Examples
- ๐Ÿ“ **Example 1**: Create a new fitness goal by clicking on the "Create Goal" button on the dashboard. Enter the goal details (name, target, deadline) and submit the form. The new goal will be saved to your profile.
- ๐Ÿ“ **Example 2**: Log a workout by clicking on the "Log Workout" button on the dashboard. Select the activity type, duration, and intensity, and submit the workout log. This data will be used to track your progress towards your fitness goals.
- ๐Ÿ“ **Example 3**: Share your workout progress with your friends by clicking on the "Share" button next to a workout entry. Select the social media platform you want to share on.

## ๐ŸŒ Hosting
### ๐Ÿš€ Deployment Instructions
#### Vercel
1. Create a Vercel account.
2. Install the Vercel CLI: `npm install -g vercel`
3. Log in to Vercel: `vercel login`
4. Deploy the project: `vercel`

#### Netlify
1. Create a Netlify account.
2. Install the Netlify CLI: `npm install -g netlify-cli`
3. Log in to Netlify: `netlify login`
4. Deploy the project: `netlify init`

#### GitHub Pages
1. Create a new branch named `gh-pages` in your repository.
2. Build the application for production: `npm run build`
3. Move the built files to the `gh-pages` branch: `mv out/* gh-pages/`
4. Commit and push the changes: `git add . && git commit -m "Deploy to GitHub Pages" && git push origin gh-pages`
5. Go to your repository settings on GitHub and configure GitHub Pages to use the `gh-pages` branch.

### ๐Ÿ”‘ Environment Variables
- `NEXTAUTH_URL`: The URL of your deployed application (e.g., `https://your-app.vercel.app`).
- `NEXTAUTH_SECRET`: A secret key used for authentication. You can generate a random key or use a secure key from a service like `random.org`.
- `DATABASE_URL`: The connection string for your PostgreSQL database.

## ๐Ÿ“œ API Documentation
### ๐Ÿ” Endpoints
- **GET /api/auth/session**: Fetches the current user's session data.
- **POST /api/auth/login**: Authenticates a user with email and password.
- **POST /api/auth/signup**: Creates a new user account.
- **POST /api/goals**: Creates a new fitness goal.
- **GET /api/goals**: Retrieves a list of fitness goals for the current user.
- **PUT /api/goals/:id**: Updates an existing fitness goal.
- **DELETE /api/goals/:id**: Deletes a fitness goal.
- **POST /api/workouts**: Logs a new workout.
- **GET /api/workouts**: Retrieves a list of workout logs for the current user.

### ๐Ÿ”’ Authentication
The application uses NextAuth.js for secure user authentication and session management.

### ๐Ÿ“ Examples
- `curl -X GET http://localhost:3000/api/auth/session`

## ๐Ÿ“œ License
This MVP is licensed under the [MIT License](https://choosealicense.com/licenses/mit/).

## ๐Ÿ‘ฅ Authors
- **Author Name** - [CosLynx.com](https://coslynx.com)
- **Creator Name** - [CosLynxAI](https://github.com/coslynx)


๐ŸŒ CosLynx.com


Create Your Custom MVP in Minutes With CosLynxAI!



Developers-Drix10,_Kais_Radwan-red
Website-CosLynx.com-blue
Backed_by-Google,_Microsoft_&_Amazon_for_Startups-red
Finalist-Backdrop_Build_v4-black