Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sandesh300/expense-tracker-app
Developed an Expense Tracker App in ASP.NET Core 6 MVC using SyncFusion Components and SQL Server.
https://github.com/sandesh300/expense-tracker-app
csharp dotnet-core mvc rest-api sql-server synfusion-library
Last synced: 14 days ago
JSON representation
Developed an Expense Tracker App in ASP.NET Core 6 MVC using SyncFusion Components and SQL Server.
- Host: GitHub
- URL: https://github.com/sandesh300/expense-tracker-app
- Owner: sandesh300
- Created: 2024-04-08T11:54:26.000Z (9 months ago)
- Default Branch: master
- Last Pushed: 2024-04-09T19:34:51.000Z (9 months ago)
- Last Synced: 2024-11-06T05:30:19.397Z (2 months ago)
- Topics: csharp, dotnet-core, mvc, rest-api, sql-server, synfusion-library
- Language: HTML
- Homepage:
- Size: 8.84 MB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Expense Tracker App
This is an Expense Tracker App in Asp.Net Core MVC using SyncFusion Components.## Introduction
Developed the Expense Tracker App, a web application developed in ASP.NET Core 6 MVC utilizing SyncFusion Components and SQL Server database. This application aims to assist users in efficiently managing their expenses by providing features for tracking transactions, organizing expenses into categories, and visualizing spending patterns.## Technologies
- **ASP.NET Core 6 MVC**: The application's backend and frontend are developed using ASP.NET Core 6 MVC framework.
- **SyncFusion Components**: SyncFusion Components are utilized for creating interactive UI elements such as grids, charts, and sidebars.
- **SQL Server Database**: SQL Server is used as the backend database for storing categories and transactions data.
- **C# Programming Language**: C# is the primary programming language used for server-side logic.
- **Entity Framework Core**: Entity Framework Core is employed for database access and management.## Features
1. **CRUD Operations**: Implemented CRUD (Create, Read, Update, Delete) operations for both categories and transactions to allow users to manage their data effectively.
2. **Grid with Paging & Sorting**: Utilized SyncFusion grid component with paging and sorting functionalities to enhance data presentation and accessibility.
3. **Dashboard with Chart Elements**: Created a dashboard featuring chart elements to provide users with visual insights into their spending patterns.
4. **Side Menu within Dockable Sidebar**: Integrated a side menu within a dockable sidebar for easy navigation across different sections of the application.
5. **Login and Logout Authentication**: Implemented authentication features to ensure secure access to the application, allowing users to log in to their accounts and log out when done.## Architecture
The Expense Tracker App follows a Model-View-Controller (MVC) architecture:
- **Model**: Represents the data and business logic of the application. It includes entities such as categories and transactions, as well as services for data manipulation.
- **View**: Displays the user interface of the application to the users. It includes HTML templates rendered by the server and served to the client.
- **Controller**: Handles user requests, processes input, and interacts with the model and view components to generate appropriate responses.## Modules
1. Authentication Module:
- Responsible for handling user authentication and authorization.
- Includes features such as user registration, login, logout, and password management.
- Utilizes ASP.NET Core Identity framework for user management and role-based access control.2. Expense Tracking Module:
- Core module for managing expense transactions and categories.
- Allows users to record, view, edit, and delete expense transactions.
- Supports categorization of expenses into custom categories for better organization.
- Provides functionalities for filtering, sorting, and searching expenses.3. Dashboard Module:
- Provides a customizable dashboard for users to view key metrics and summaries of their expenses.
- Includes charts, graphs, and summaries to visualize spending patterns and trends.
- Allows users to configure dashboard widgets and personalize their dashboard layout.4. Category Management Module:
- Handles the management of expense categories.
- Supports CRUD operations (Create, Read, Update, Delete) for managing categories.
- Allows users to create, edit, and delete custom categories for organizing expenses.5. User Profile Module:
- Manages user profiles and account settings.
- Allows users to view and update their profile information, such as name, email, and password.
- Provides options for configuring account preferences and settings.## Flow of the App
1. **Authentication**: Users are required to log in to access the application.
2. **Dashboard**: Upon successful login, users are directed to the dashboard, where they can view visualizations of their spending patterns.
3. **Category Management**: Users can navigate to the category management section to create, update, or delete expense categories as needed.
4. **Transaction Tracking**: Users can record their transactions, specifying the date, amount, description, and category for each transaction.
5. **Navigation**: Users can navigate between different sections of the application using the sidebar menu.
6. **Logout**: Users can log out of their accounts to securely end their session and protect their data.## Users
The Expense Tracker App caters to individuals or businesses looking to manage their expenses effectively. Users can be anyone who wants to track their spending habits, categorize expenses, and gain insights into their financial activities.## Additional Points
- **Security**: Implement appropriate authentication and authorization mechanisms to ensure data privacy and prevent unauthorized access.
- **Localization**: Consider adding support for multiple languages to make the application accessible to a broader audience.
- **Scalability**: Design the application with scalability in mind to accommodate potential growth in data volume and user base.
- **Performance Optimization**: Optimize database queries, frontend rendering, and server-side processing to enhance application performance and responsiveness.
- **Error Handling**: Implement robust error handling mechanisms to provide users with meaningful error messages and ensure smooth application operation.
- **Documentation**: Provide comprehensive documentation, including installation instructions, usage guidelines, and troubleshooting tips, to assist users in utilizing the application effectively.## Video
https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/89735de4-f801-4d0a-9203-dd4d1f315a56## Images
![Screenshot (1069)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/5d20d458-9808-419f-bf8c-ccccf9b05dfd)
![Screenshot (1070)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/3988c7a0-01c7-482f-b7ec-906e7188edbc)
![Screenshot (1071)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/837aa6a5-eec0-409f-9cc9-3e49150b0847)
![Screenshot (1072)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/a11d86bb-2891-4372-8d96-ad8d00923b5f)
![Screenshot (1073)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/a8f34619-fe8a-4ee5-8189-8219ca86c71f)
![Screenshot (1074)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/8ba82e4a-629e-411d-8630-5a8d44d5e674)
![Screenshot (1075)](https://github.com/sandesh300/Expense-Tracker-App/assets/92014891/073c9bbc-1066-4baa-a017-61c633a11d25)