mirror of
https://github.com/btcpayserver/btcpayserver.git
synced 2025-02-22 14:22:40 +01:00
* Swap bootstrap asset files * Update themes and color definitions * Move general bootstrap customizations * Theme updates Theme updates * Remove BuildBundlerMinifier This lead to an error, because BuildBundlerMinifier and BundlerMinifier.Core seem to conflict here. Details: https://stackoverflow.com/a/61119586 * Rewplace btn-block class with w-100 * Update badge classes * Remove old font family head variable * Update margin classes * Cleanups * Update float classes * Update text classes * Update padding classes * Update border classes * UPdate dropdown classes * Update select classes * Update neutral custom props * Update bootstrap and customizations * Update ChromeDriver; disable smooth scroll https://github.com/SeleniumHQ/selenium/issues/8295 * Improve alert messages * Improve bootstrap customizations * Disable reduced motion See also 7358282f * Update Bootstrap data attributes * Update file inputs * Update input groups * Replace deprecated jumbotron class * Update variables; re-add negative margin util classes * Update cards * Update form labels * Debug alerts * Fix aria-labelledby associations * Dropdown-related test fixes * Fix CanUseWebhooks test * Test fixes * Nav updates * Fix nav usage in wallet send and payouts * Update alert and modal close buttons * Re-add backdrop properties * Upgrade Bootstrap to v5 final * Update screen reader classes * Update font-weight classes * Update monospace font classes * Update accordians * Update close icon usage * Cleanup * Update scripts and style integrations * Update input group texts * Update LN node setup page * Update more form control classes * Update inline forms * Add js specific test * Upgrade Vue.js * Remove unused JS * Upgrade Bootstrap to v5.0.1 * Try container related test updates * Separate jQuery bundle * Remove jQuery from LND seed backup page * Remove unused code * Refactor email autofill js * Refactor camera scanner JS * Re-add tests * Re-add BuildBundlerMinifier * Do not minify bundles containing Bootstrap Details https://github.com/madskristensen/BundlerMinifier/issues/558 * Update bundles * Cleanup JS test * Cleanup tests involving dropdowns * Cleanup tests involving collapses * Cleanup locale additions in ConfigureCore * Cleanup bundles * Remove duplicate status message * Cleanup formatting * Fix missing validation scripts * Remove unused unminified Bootstrap js files * Fix classic theme * Fix Casa theme * Fix PoS validation
90 lines
3.8 KiB
Text
90 lines
3.8 KiB
Text
@model BTCPayServer.Models.AppViewModels.ContributeToCrowdfund
|
|
|
|
<form method="post">
|
|
@foreach (var item in Model.ViewCrowdfundViewModel.Perks)
|
|
{
|
|
<div class="card mb-4 perk expanded" id="@item.Id">
|
|
@if (Model.ViewCrowdfundViewModel.DisplayPerksRanking && Model.ViewCrowdfundViewModel.PerkCount.ContainsKey(item.Id))
|
|
{
|
|
<span class="btn btn-sm rounded-circle px-0 btn-primary perk-badge">#@(Array.IndexOf(Model.ViewCrowdfundViewModel.Perks, item) + 1)</span>
|
|
}
|
|
@if (!string.IsNullOrEmpty(item.Image))
|
|
{
|
|
<img class="card-img-top" src="@item.Image" asp-append-version="true" />
|
|
}
|
|
<div class="card-body">
|
|
<div class="card-title d-flex justify-content-between">
|
|
<label class="h5">
|
|
|
|
@if (Model.ViewCrowdfundViewModel.Started && !Model.ViewCrowdfundViewModel.Ended && (item.Price.Value > 0 || item.Custom))
|
|
{
|
|
|
|
<input type="radio" asp-for="ChoiceKey" value="@item.Id"/>
|
|
}
|
|
@(string.IsNullOrEmpty(item.Title) ? item.Id : item.Title)
|
|
</label>
|
|
<span class="text-muted">
|
|
@if (item.Price.Value > 0)
|
|
{
|
|
@item.Price.Value
|
|
if (item.Custom)
|
|
{
|
|
@Safe.Raw("or more");
|
|
}
|
|
}
|
|
else if (item.Custom)
|
|
{
|
|
@Safe.Raw("Any amount");
|
|
}
|
|
|
|
</span>
|
|
</div>
|
|
<p class="card-text overflow-hidden">@Safe.Raw(item.Description)</p>
|
|
|
|
</div>
|
|
@if (Model.ViewCrowdfundViewModel.PerkCount.ContainsKey(item.Id) || item.Inventory.HasValue)
|
|
{
|
|
<div class="card-footer d-flex justify-content-between">
|
|
@switch (item.Inventory)
|
|
{
|
|
case null:
|
|
<span></span>
|
|
break;
|
|
case int i when i <= 0:
|
|
<span>Sold out</span>
|
|
break;
|
|
default:
|
|
<span>@item.Inventory left</span>
|
|
break;
|
|
}
|
|
@if (Model.ViewCrowdfundViewModel.PerkCount.ContainsKey(item.Id))
|
|
{
|
|
<span> @Model.ViewCrowdfundViewModel.PerkCount[item.Id] Contributors</span>
|
|
}
|
|
else
|
|
{
|
|
<span></span>
|
|
}
|
|
</div>
|
|
}
|
|
</div>
|
|
}
|
|
@if (Model.ViewCrowdfundViewModel.Started && !Model.ViewCrowdfundViewModel.Ended)
|
|
{
|
|
<div class="form-group">
|
|
<label asp-for="Email"></label>
|
|
<input asp-for="Email" type="email" class="form-control"/>
|
|
<span asp-validation-for="Email" class="text-danger"></span>
|
|
</div>
|
|
<div class="form-group">
|
|
<label asp-for="Amount"></label>
|
|
<div class="input-group mb-3">
|
|
<input asp-for="Amount" type="number" step="any" class="form-control"/>
|
|
<span class="input-group-text">@Model.ViewCrowdfundViewModel.TargetCurrency.ToUpperInvariant()</span>
|
|
</div>
|
|
<span asp-validation-for="Amount" class="text-danger"></span>
|
|
</div>
|
|
<input type="hidden" asp-for="RedirectToCheckout"/>
|
|
<button type="submit" class="btn btn-primary">Contribute</button>
|
|
}
|
|
</form>
|