FinanceFlow is a MERN stack (MongoDB, Express.js, React, Node.js) application designed to help users manage their budgets and expenses efficiently. With an intuitive user interface and robust backend, FinanceFlow simplifies personal finance management by allowing users to track their spending, set budget limits, and gain insights into their financial habits.
- User Authentication: Secure login and registration system with password hashing.
- Budget Management: Create, update, and delete budgets for different categories.
- Expense Tracking: Record and categorize expenses with details like amount, date, and description.
- Responsive Design: Built with TailwindCSS for a seamless experience across devices.
- Real-Time Updates: Dynamic updates to budgets and expenses without page reloads.
- Toast Notifications: User-friendly notifications for actions like successful login, budget creation, or expense addition.
The project is divided into two main parts:
- frontend: The client-side of the application built with Vite React.
- backend: The server-side of the application built with Node.js and Express.
To get started with FinanceFlow, clone the repository to your local machine:
 ```sh
 git clone https://github.com/rudra-xi/FinanceFlow.git
 cd FinanceFlow
 ```
Before running the application, ensure you have the following installed:
- Node.js (v16 or higher)
- npm (v8 or higher)
- MongoDB (for database storage)
- 
Navigate to the frontenddirectory:```sh cd frontend ```
- 
Install dependencies: ```sh npm install ```
- 
Start the development server: ```sh npm run dev ```
The frontend will be available at http://localhost:5173.
- axios: Promise-based HTTP client for making API requests.
- react-datepicker: A simple and reusable datepicker component for selecting dates.
- react-hot-toast: A lightweight library for displaying toast notifications.
- tailwindcss: A utility-first CSS framework for rapid UI development.
- 
Navigate to the backenddirectory:```sh cd backend ```
- 
Install dependencies: ```sh npm install ```
- 
Start the development server: ```sh npm run dev ```
The backend server will run on http://localhost:5000.
- bcryptjs: Library for hashing passwords securely.
- body-parser: Middleware for parsing incoming request bodies.
- cors: Middleware to enable Cross-Origin Resource Sharing (CORS).
- express: Web framework for building the backend API.
- mongoose: MongoDB object modeling tool for asynchronous database operations.
The SignIn page allows users to log into their accounts using their credentials. It includes a form for entering the username and password. Upon successful login, users are redirected to the Budget page.
The Budget page enables users to create and manage their budgets. Users can:
Set budget limits for different categories (e.g., groceries, entertainment, utilities). View a summary of their spending against the budget. Edit or delete existing budgets.
The Expense page allows users to record their expenses. Users can:
Add new expenses with details like amount, date, category, and description. View a list of all recorded expenses. Filter expenses by category or date range.
The About page provides information about the FinanceFlow application, its features, and the team behind it. It also includes links to documentation and support.
The backend exposes the following RESTful API endpoints:
- 
Auth POST /api/auth/register: Register a new user.POST /api/auth/login: Log in an existing user.POST /api/auth/logout: Log out the current user.
- 
Budgets GET /api/budgets: Fetch all budgets for the logged-in user.POST /api/budgets: Create a new budget.PUT /api/budgets/:id: Update an existing budget.DELETE /api/budgets/:id: Delete a budget.
- 
Expenses GET /api/expenses: Fetch all expenses for the logged-in user.POST /api/expenses: Add a new expense.DELETE /api/expenses/:id: Delete an expense.
To run the application, you need to set up the following environment variables:
- 
Create a .envfile in thebackenddirectory and add the following:```env PORT=5000 MONGO_URI=<your-mongodb-connection-string> JWT_SECRET=<your-jwt-secret-key> ```
- 
Create a .envfile in thefrontenddirectory and add the following:```env VITE_API_BASE_URL=http://localhost:5000 ```
FinanceFlow is an open-source project, and contributions are welcome! If you'd like to contribute, please follow these steps:
- 
Fork the repository. 
- 
Create a new branch for your feature or bugfix: ```sh git checkout -b feature/your-feature-name ```
- 
Commit your changes: ```sh git commit -m "Add your commit message here" ```
- 
Push your changes to your forked repository: ```sh git push origin feature/your-feature-name ```
- 
Open a pull request with a detailed description of your changes. 
- Data Visualization: Add charts and graphs to visualize spending patterns.
- Reports: Generate monthly or yearly financial reports.
- Multi-User Support: Allow families or teams to share budgets and expenses.
- Mobile App: Develop a cross-platform mobile app using React Native.
- Export Data: Allow users to export their budget and expense data as CSV or PDF.
- Dark Mode: Add a dark mode option for better user experience.
- Special thanks to the open-source community for providing the tools and libraries that made this project possible.
- Rudra-Xi: Developer and maintainer of FinanceFlow.
This project is licensed under the MIT License. See the  file for more information.