Files
MoneyMap/MoneyMap/Pages/AccountDetails.cshtml
AJ Isaacs 4be5658d32 Improve: Overhaul navigation with grouped dropdowns, breadcrumbs, and quick-actions
Restructure the flat 7-item navbar into logical dropdown groups (Transactions,
Receipts, Accounts), add a prominent Upload button, settings gear icon, breadcrumb
navigation on 11 deep pages, and dashboard quick-action cards with hover effects.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-15 19:41:56 -05:00

142 lines
6.0 KiB
Plaintext

@page "{id:int}"
@model MoneyMap.Pages.AccountDetailsModel
@{
ViewData["Title"] = $"Account - {Model.Account.DisplayLabel}";
ViewData["Breadcrumbs"] = new List<(string Label, string? Url)>
{
("Accounts", Url.Page("/Accounts")),
(Model.Account.DisplayLabel, null)
};
}
<div class="d-flex justify-content-between align-items-center mb-3">
<h2>@Model.Account.DisplayLabel</h2>
<div>
<a asp-page="/EditAccount" asp-route-id="@Model.Account.Id" class="btn btn-outline-primary">Edit Account</a>
<a asp-page="/Accounts" class="btn btn-outline-secondary">Back to Accounts</a>
</div>
</div>
@if (!string.IsNullOrEmpty(Model.SuccessMessage))
{
<div class="alert alert-success alert-dismissible fade show" role="alert">
@Model.SuccessMessage
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
</div>
}
@if (!string.IsNullOrEmpty(Model.ErrorMessage))
{
<div class="alert alert-danger alert-dismissible fade show" role="alert">
@Model.ErrorMessage
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
</div>
}
<!-- Account Details Card -->
<div class="card shadow-sm mb-4">
<div class="card-header">
<strong>Account Details</strong>
</div>
<div class="card-body">
<div class="row">
<div class="col-md-6">
<dl class="row">
<dt class="col-sm-4">Institution:</dt>
<dd class="col-sm-8">@Model.Account.Institution</dd>
<dt class="col-sm-4">Account Type:</dt>
<dd class="col-sm-8"><span class="badge bg-info">@Model.Account.AccountType</span></dd>
<dt class="col-sm-4">Last 4:</dt>
<dd class="col-sm-8"><code>@Model.Account.Last4</code></dd>
</dl>
</div>
<div class="col-md-6">
<dl class="row">
<dt class="col-sm-4">Owner:</dt>
<dd class="col-sm-8">@Model.Account.Owner</dd>
<dt class="col-sm-4">Nickname:</dt>
<dd class="col-sm-8">@(string.IsNullOrEmpty(Model.Account.Nickname) ? "-" : Model.Account.Nickname)</dd>
<dt class="col-sm-4">Transactions:</dt>
<dd class="col-sm-8">@Model.TransactionCount</dd>
</dl>
</div>
</div>
</div>
</div>
<!-- Linked Cards Section -->
<div class="card shadow-sm">
<div class="card-header d-flex justify-content-between align-items-center">
<strong>Linked Cards (@Model.Cards.Count)</strong>
<a asp-page="/EditCard" asp-route-accountId="@Model.Account.Id" class="btn btn-sm btn-primary">+ Add Card</a>
</div>
<div class="card-body p-0">
@if (Model.Cards.Any())
{
<div class="table-responsive">
<table class="table table-hover mb-0">
<thead>
<tr>
<th>Card</th>
<th>Owner</th>
<th class="text-end">Transactions</th>
<th style="width: 150px;">Actions</th>
</tr>
</thead>
<tbody>
@foreach (var item in Model.Cards)
{
<tr>
<td>
<div>
<strong>@item.Card.Issuer •••• @item.Card.Last4</strong>
@if (!string.IsNullOrEmpty(item.Card.Nickname))
{
<br />
<small class="text-muted">@item.Card.Nickname</small>
}
</div>
</td>
<td>@item.Card.Owner</td>
<td class="text-end">@item.TransactionCount</td>
<td>
<div class="d-flex gap-1">
<a asp-page="/EditCard" asp-route-id="@item.Card.Id" class="btn btn-sm btn-outline-primary">
Edit
</a>
@if (item.TransactionCount == 0)
{
<form method="post" asp-page-handler="DeleteCard" asp-route-cardId="@item.Card.Id"
onsubmit="return confirm('Delete this card?')" class="d-inline">
<button type="submit" class="btn btn-sm btn-outline-danger">Delete</button>
</form>
}
else
{
<button type="button" class="btn btn-sm btn-outline-secondary" disabled
title="Cannot delete - card has transactions">
Delete
</button>
}
</div>
</td>
</tr>
}
</tbody>
</table>
</div>
}
else
{
<div class="card-body">
<p class="text-muted mb-2">No cards linked to this account yet.</p>
<a asp-page="/EditCard" asp-route-accountId="@Model.Account.Id" class="btn btn-sm btn-primary">Add First Card</a>
</div>
}
</div>
</div>