160 lines
8.5 KiB
PHP
160 lines
8.5 KiB
PHP
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>Rahul sharma</title>
|
|
<meta name="description" content="Built with Flatlogic Generator">
|
|
<meta name="keywords" content="personal finance, budget tracker, expense manager, income calculator, savings tool, money management, financial planning, interactive calculator, Built with Flatlogic Generator">
|
|
<meta property="og:title" content="Rahul sharma">
|
|
<meta property="og:description" content="Built with Flatlogic Generator">
|
|
<meta property="og:image" content="">
|
|
<meta name="twitter:card" content="summary_large_image">
|
|
<meta name="twitter:image" content="">
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css">
|
|
<link rel="stylesheet" href="assets/css/custom.css?v=<?php echo time(); ?>">
|
|
</head>
|
|
<body>
|
|
|
|
<main class="container my-5">
|
|
<div class="row justify-content-center">
|
|
<div class="col-lg-8 col-md-10">
|
|
<div class="text-center mb-5">
|
|
<h1 class="fw-bold">Personal Finance Calculator</h1>
|
|
<p class="lead text-muted">A simple way to track your income and expenses.</p>
|
|
</div>
|
|
|
|
<div class="card shadow-sm mb-4">
|
|
<div class="card-body p-4 text-center">
|
|
<div class="mb-3">
|
|
<label for="initialBalance" class="form-label">Initial Balance</label>
|
|
<input type="number" class="form-control" id="initialBalance" placeholder="Enter your starting balance">
|
|
</div>
|
|
<h6 class="text-muted mb-2">Current Balance</h6>
|
|
<h2 class="fw-bold" id="currentBalance">₹0.00</h2>
|
|
<div class="d-flex justify-content-center mt-4">
|
|
<button class="btn btn-primary me-2" data-bs-toggle="modal" data-bs-target="#incomeModal"><i class="bi bi-plus-circle"></i> Add Income</button>
|
|
<button class="btn btn-danger" data-bs-toggle="modal" data-bs-target="#expenseModal"><i class="bi bi-dash-circle"></i> Add Expense</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card shadow-sm">
|
|
<div class="card-header bg-white">
|
|
<h5 class="mb-0">Transaction History</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="row mb-3 align-items-end">
|
|
<div class="col-md-4">
|
|
<label for="startDate" class="form-label">Start Date</label>
|
|
<input type="date" class="form-control" id="startDate">
|
|
</div>
|
|
<div class="col-md-4">
|
|
<label for="endDate" class="form-label">End Date</label>
|
|
<input type="date" class="form-control" id="endDate">
|
|
</div>
|
|
<div class="col-md-4">
|
|
<button class="btn btn-primary me-2" id="searchBtn">Search</button>
|
|
<button class="btn btn-secondary" id="clearBtn">Clear</button>
|
|
</div>
|
|
</div>
|
|
<div class="table-responsive">
|
|
<table class="table table-hover mb-0">
|
|
<thead>
|
|
<tr>
|
|
<th scope="col">Date</th>
|
|
<th scope="col">Type</th>
|
|
<th scope="col">Description</th>
|
|
<th scope="col" class="text-end">Amount</th>
|
|
<th scope="col">Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="transactionHistory">
|
|
<!-- Transactions will be injected here by JavaScript -->
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</main>
|
|
|
|
<!-- Income Modal -->
|
|
<div class="modal fade" id="incomeModal" tabindex="-1" aria-labelledby="incomeModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title" id="incomeModalLabel">Add Income</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<div class="modal-body">
|
|
<form id="incomeForm">
|
|
<div class="mb-3">
|
|
<label for="incomeAmount" class="form-label">Amount</label>
|
|
<input type="number" class="form-control" id="incomeAmount" placeholder="Enter amount" required>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="incomeDate" class="form-label">Date</label>
|
|
<input type="date" class="form-control" id="incomeDate" required>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="incomeDescription" class="form-label">Description</label>
|
|
<input type="text" class="form-control" id="incomeDescription" placeholder="e.g., Salary, Freelance work" required>
|
|
</div>
|
|
<button type="submit" class="btn btn-primary w-100">Add Income</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Expense Modal -->
|
|
<div class="modal fade" id="expenseModal" tabindex="-1" aria-labelledby="expenseModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title" id="expenseModalLabel">Add Expense</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<div class="modal-body">
|
|
<form id="expenseForm">
|
|
<div class="mb-3">
|
|
<label for="expenseAmount" class="form-label">Amount</label>
|
|
<input type="number" class="form-control" id="expenseAmount" placeholder="Enter amount" required>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="expenseDate" class="form-label">Date</label>
|
|
<input type="date" class="form-control" id="expenseDate" required>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="expenseDescription" class="form-label">Description</label>
|
|
<input type="text" class="form-control" id="expenseDescription" placeholder="e.g., Groceries, Rent" required>
|
|
</div>
|
|
<button type="submit" class="btn btn-danger w-100">Add Expense</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="position-fixed bottom-0 end-0 p-3" style="z-index: 11">
|
|
<div id="liveToast" class="toast" role="alert" aria-live="assertive" aria-atomic="true">
|
|
<div class="toast-header">
|
|
<strong class="me-auto">Notification</strong>
|
|
<button type="button" class="btn-close" data-bs-dismiss="toast" aria-label="Close"></button>
|
|
</div>
|
|
<div class="toast-body">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
<script src="assets/js/main.js?v=<?php echo time(); ?>"></script>
|
|
<script>
|
|
document.getElementById('incomeDate').valueAsDate = new Date();
|
|
document.getElementById('expenseDate').valueAsDate = new Date();
|
|
</script>
|
|
</body>
|
|
</html> |