2019-01-14 22:43:29 +01:00
@using BTCPayServer.Services.PaymentRequests
2022-11-18 05:24:57 +01:00
@using Microsoft.AspNetCore.Html
@using Microsoft.AspNetCore.Mvc.TagHelpers
@using BTCPayServer.Components
2023-12-01 09:12:02 +01:00
@using BTCPayServer.Client
2019-01-14 22:43:29 +01:00
@model BTCPayServer.Models.PaymentRequestViewModels.ListPaymentRequestsViewModel
@{
Layout = "_Layout";
2019-11-15 14:43:36 +01:00
ViewData["Title"] = "Payment Requests";
2023-07-06 09:02:23 +01:00
var storeId = Context.GetStoreData().Id;
var statusFilterCount = CountArrayFilter("status") + (HasBooleanFilter("includearchived") ? 1 : 0);
}
@functions
{
private int CountArrayFilter(string type) =>
Model.Search.ContainsFilter(type) ? Model.Search.GetFilterArray(type).Length : 0;
private bool HasArrayFilter(string type, string key = null) =>
Model.Search.ContainsFilter(type) && (key is null || Model.Search.GetFilterArray(type).Contains(key));
private bool HasBooleanFilter(string key) =>
Model.Search.ContainsFilter(key) && Model.Search.GetFilterBool(key) is true;
2019-01-14 22:43:29 +01:00
}
2021-04-08 15:32:42 +02:00
2024-06-19 15:23:10 +02:00
<div class="sticky-header">
<h2>
2021-12-11 04:32:23 +01:00
@ViewData["Title"]
2023-02-13 00:25:24 -08:00
<a href="#descriptor" data-bs-toggle="collapse">
<vc:icon symbol="info" />
</a>
2021-12-11 04:32:23 +01:00
</h2>
2024-07-25 15:23:28 +09:00
<a id="page-primary" asp-action="EditPaymentRequest" asp-route-storeId="@storeId" class="btn btn-primary mt-3 mt-sm-0" role="button" permission="@Policies.CanModifyPaymentRequests">
2023-07-06 09:02:23 +01:00
Create Request
2021-12-11 04:32:23 +01:00
</a>
</div>
2020-07-19 16:49:13 -05:00
2023-02-13 00:25:24 -08:00
<div id="descriptor" class="collapse">
<div class="d-flex px-4 py-4 mb-4 bg-tile rounded">
<div class="flex-fill">
<p class="mb-2">Payment requests are persistent shareable pages that enable the receiver to pay at their convenience. Funds are paid to a payment request at the current exchange rate.</p>
<p class="mb-3">Requests may be paid in partial. They will remain valid until time expires or when paid what is due.</p>
<a href="https://docs.btcpayserver.org/PaymentRequests/" target="_blank" rel="noreferrer noopener">Learn More</a>
</div>
<button type="button" class="btn-close ms-auto" data-bs-toggle="collapse" data-bs-target="#descriptor" aria-expanded="false" aria-label="Close">
<vc:icon symbol="close" />
</button>
</div>
</div>
2022-02-21 03:05:42 +01:00
<partial name="_StatusMessage" />
2023-11-02 08:12:28 +01:00
<form asp-action="GetPaymentRequests" method="get" class="d-flex flex-wrap flex-sm-nowrap align-items-center gap-3 mb-4 col-xxl-8">
2023-07-06 09:02:23 +01:00
<input type="hidden" asp-for="Count" />
<input type="hidden" asp-for="TimezoneOffset" />
<input asp-for="SearchTerm" type="hidden" value="@Model.Search.WithoutSearchText()"/>
<input asp-for="SearchText" class="form-control" placeholder="Search…" />
<div class="dropdown">
<button id="StatusOptionsToggle" class="btn btn-secondary dropdown-toggle dropdown-toggle-custom-caret" type="button" data-bs-toggle="dropdown" aria-expanded="false">
@if (statusFilterCount > 0)
{
<span>@statusFilterCount Status</span>
}
else
{
<span>All Status</span>
}
</button>
<div class="dropdown-menu" aria-labelledby="StatusOptionsToggle">
<a asp-action="GetPaymentRequests" asp-route-storeId="@storeId" asp-route-count="@Model.Count" asp-route-searchTerm="@Model.Search.Toggle("status", "pending")" class="dropdown-item @(HasArrayFilter("status", "pending") ? "custom-active" : "")">Pending</a>
<a asp-action="GetPaymentRequests" asp-route-storeId="@storeId" asp-route-count="@Model.Count" asp-route-searchTerm="@Model.Search.Toggle("status", "completed")" class="dropdown-item @(HasArrayFilter("status", "completed") ? "custom-active" : "")">Settled</a>
<a asp-action="GetPaymentRequests" asp-route-storeId="@storeId" asp-route-count="@Model.Count" asp-route-searchTerm="@Model.Search.Toggle("status", "expired")" class="dropdown-item @(HasArrayFilter("status", "expired") ? "custom-active" : "")">Expired</a>
<div role="separator" class="dropdown-divider"></div>
<a asp-action="GetPaymentRequests" asp-route-storeId="@storeId" asp-route-count="@Model.Count" asp-route-searchTerm="@Model.Search.Toggle("includearchived", "true")" class="dropdown-item @(HasBooleanFilter("includearchived") ? "custom-active" : "")" id="StatusOptionsIncludeArchived">Archived</a>
</div>
2021-12-11 04:32:23 +01:00
</div>
2023-07-06 09:02:23 +01:00
</form>
2020-08-24 06:57:07 +02:00
2023-07-06 09:02:23 +01:00
@if (Model.Items.Any())
{
2023-11-02 08:12:28 +01:00
<div class="table-responsive-md">
<table class="table table-hover">
<thead>
2023-07-06 09:02:23 +01:00
<tr>
2023-11-02 08:12:28 +01:00
<th>Title</th>
<th class="date-col">
<div class="d-flex align-items-center gap-1">
Expiry
2024-05-20 01:57:46 +02:00
<button type="button" class="btn btn-link p-0 switch-time-format only-for-js" title="Switch date format">
<vc:icon symbol="time" />
</button>
2023-07-06 09:02:23 +01:00
</div>
2023-11-02 08:12:28 +01:00
</th>
<th>Status</th>
<th class="amount-col">Amount</th>
<th></th>
2023-07-06 09:02:23 +01:00
</tr>
2023-11-02 08:12:28 +01:00
</thead>
<tbody>
@foreach (var item in Model.Items)
{
<tr class="mass-action-row">
<td>
<a asp-action="EditPaymentRequest" asp-route-storeId="@item.StoreId" asp-route-payReqId="@item.Id" id="Edit-@item.Id">@item.Title</a>
</td>
<td class="date-col">
@(item.ExpiryDate?.ToBrowserDate() ?? new HtmlString("<span class=\"text-muted\">No Expiry</span>"))
</td>
<td>
<span class="badge badge-@item.Status.ToLower() status-badge">@item.Status</span>
</td>
<td class="text-end">
<span data-sensitive>@item.AmountFormatted</span>
</td>
<td class="text-end">
<div class="d-inline-flex align-items-center gap-3">
2023-11-20 02:45:43 +01:00
<a asp-action="ViewPaymentRequest" asp-route-payReqId="@item.Id" id="PaymentRequest-@item.Id" target="_blank">View</a>
2023-11-02 08:12:28 +01:00
<div class="dropdown">
<button class="btn btn-link dropdown-toggle p-0 dropdown-toggle-no-caret text-body" type="button" data-bs-toggle="dropdown" aria-expanded="false" id="ToggleActions-@item.Id">
<vc:icon symbol="dots" />
</button>
<ul class="dropdown-menu" aria-labelledby="actionDropdown">
2023-12-01 09:12:02 +01:00
<li><a class="dropdown-item" permission="@Policies.CanViewInvoices" asp-controller="UIInvoice" asp-action="ListInvoices" asp-route-storeId="@item.StoreId" asp-route-searchterm="@($"orderid:{PaymentRequestRepository.GetOrderIdForPaymentRequest(item.Id)}")">Invoices</a></li>
<li><a class="dropdown-item" permission="@Policies.CanModifyPaymentRequests" asp-action="ClonePaymentRequest" asp-route-storeId="@item.StoreId" asp-route-payReqId="@item.Id" id="Clone-@item.Id">Clone</a></li>
2023-11-02 08:12:28 +01:00
<li class="dropdown-divider"></li>
2023-12-01 09:12:02 +01:00
<li><a class="dropdown-item" permission="@Policies.CanModifyPaymentRequests" asp-action="TogglePaymentRequestArchival" asp-route-storeId="@item.StoreId" asp-route-payReqId="@item.Id" id="ToggleArchival-@item.Id">@(item.Archived ? "Unarchive" : "Archive")</a></li>
2023-11-02 08:12:28 +01:00
</ul>
</div>
</div>
</td>
</tr>
}
</tbody>
</table>
</div>
2019-06-06 18:47:31 +09:00
2023-07-06 09:02:23 +01:00
<vc:pager view-model="Model" />
}
else
{
<p class="text-secondary mt-3">
There are no payment requests matching your criteria.
</p>
}