- Modify planned payment - minor bug fixes
Where's My Money
Where's My Money is a personal finance management app designed to help you keep track of your finances and plan your expenses efficiently. Built using .NET MAUI, this solution consists of two projects:
- WheresMyMoney.Maui - The main .NET MAUI project responsible for the UI and overall app behavior.
- WheresMyMoney.Maui.Core - A .NET MAUI Class Library containing the Repository class and POCO representations of the database structure.
Features
- Track Your Balance: Monitor your financial balance with precision.
- Planned Payments: Keep an eye on recurring or one-time payments.
Planned Features
- Categorization: Categorize payments and expenses for better insights.
- Sync Online: Synchronize your data across multiple devices via cloud.
- Localization: Support for multiple languages.
Technical Overview
This project is built using the .NET SDK 9.0 and is designed to run on Android devices with .NET MAUI. Below is an overview of the Repository class and its corresponding database schema:
Database Schema
CREATE TABLE IF NOT EXISTS planned_payment (
  id INTEGER PRIMARY KEY AUTOINCREMENT,
  amount INTEGER NOT NULL,
  name TEXT NOT NULL,
  date_start TEXT NOT NULL,
  date_end TEXT NULL,
  is_subscription BOOLEAN NOT NULL,
  reoccurences INTEGER NULL,
  reoccurence_type INTEGER NULL CHECK(CASE reoccurences IS NOT NULL AND reoccurence_type IS NOT NULL WHEN TRUE THEN is_subscription ELSE NOT is_subscription END)
);
CREATE TABLE IF NOT EXISTS balance (
  id INTEGER PRIMARY KEY AUTOINCREMENT,
  amount INTEGER NOT NULL,
  date TEXT NOT NULL
);
CREATE TABLE IF NOT EXISTS settings (
  id INTEGER PRIMARY KEY AUTOINCREMENT,
  payday TINYINT NOT NULL CHECK(payday BETWEEN 1 AND 31)
);
POCO Classes
PlannedPayment
public class PlannedPayment
{
    public int Id { get; set; }
    public int Amount { get; set; }
    public string Name { get; set; }
    public DateTime DateStart { get; set; }
    public DateTime? DateEnd { get; set; }
    public bool IsSubscription { get; set; }
    public int? Reoccurences { get; set; }
    public int? ReoccurenceType { get; set; }
}
Balance
public class Balance
{
    public int Id { get; set; }
    public int Amount { get; set; }
    public DateTime Date { get; set; }
}
Settings
public class Settings
{
    public int Id { get; set; }
    public byte Payday { get; set; }
}
Repository Class
The Repository class provides an abstraction layer for data access and manipulation, ensuring seamless integration between the app and the SQLite database. It uses asynchronous methods for CRUD operations to enhance app performance.
How to Build and Run
- Ensure you have .NET SDK 9.0 installed on your system.
- Clone the repository and open the solution in your preferred IDE (e.g., JetBrains Rider, Visual Studio).
- Set WheresMyMoney.Mauias the startup project.
- Build and deploy the app to an Android emulator or physical device.
Contributing
Contributions are welcome! Feel free to submit issues, feature requests, or pull requests to improve this project.
Credits
- Font Awesome Free
 Icons and font resources are provided by Font Awesome.
 License: Creative Commons Attribution 4.0 International (CC BY 4.0).
 Version: 6.7.2.
License
This project is licensed under the MIT License. See the LICENSE file for more details.