2019-05-07 08:01:37 +00:00
@using System.Globalization
2022-07-18 20:51:53 +02:00
@using BTCPayServer.Abstractions.Extensions
2022-07-15 05:38:33 +02:00
@using BTCPayServer.Abstractions.Models
2022-07-18 20:51:53 +02:00
@using BTCPayServer.TagHelpers
@using BTCPayServer.Views.Apps
@using Microsoft.AspNetCore.Mvc.TagHelpers
2024-02-21 13:41:21 +00:00
@using BTCPayServer.Forms
@inject FormDataService FormDataService
2023-03-08 17:57:36 +09:00
@inject BTCPayServer.Security.ContentSecurityPolicies Csp
2022-07-18 20:51:53 +02:00
@model BTCPayServer.Plugins.Crowdfund.Models.UpdateCrowdfundViewModel
2018-12-11 16:36:25 +01:00
@{
2022-01-24 18:07:52 -08:00
ViewData.SetActivePage(AppsNavPages.Update, "Update Crowdfund", Model.AppId);
2023-03-08 17:57:36 +09:00
Csp.UnsafeEval();
2024-02-21 13:41:21 +00:00
var checkoutFormOptions = await FormDataService.GetSelect(Model.StoreId, Model.FormId);
2018-12-11 16:36:25 +01:00
}
2021-05-19 04:39:27 +02:00
@section PageHeadContent {
2022-03-11 08:41:48 +01:00
<link href="~/vendor/summernote/summernote-bs5.css" rel="stylesheet" asp-append-version="true" />
2023-11-02 19:58:03 +01:00
<style>.flatpickr-wrapper { flex-grow: 1; }</style>
2021-05-19 04:39:27 +02:00
}
@section PageFootContent {
<partial name="_ValidationScriptsPartial" />
2022-03-11 08:41:48 +01:00
<script src="~/vendor/summernote/summernote-bs5.js" asp-append-version="true"></script>
2023-11-02 19:58:03 +01:00
<script src="~/crowdfund/admin.js" asp-append-version="true"></script>
2021-05-19 04:39:27 +02:00
}
2022-02-07 10:37:45 +01:00
<form method="post">
2022-02-21 03:05:42 +01:00
<div class="sticky-header d-sm-flex align-items-center justify-content-between">
2022-02-07 10:37:45 +01:00
<h2 class="mb-0">@ViewData["Title"]</h2>
<div class="d-flex gap-3 mt-3 mt-sm-0">
<button type="submit" class="btn btn-primary order-sm-1" id="SaveSettings">Save</button>
2023-09-11 02:59:17 +02:00
@if (Model.Archived)
2022-02-07 10:37:45 +01:00
{
2023-09-11 02:59:17 +02:00
<button type="submit" class="btn btn-outline-secondary" name="Archived" value="False">Unarchive</button>
}
else if (Model.ModelWithMinimumData)
{
<a class="btn btn-secondary" asp-controller="UICrowdfund" asp-action="ViewCrowdfund" asp-route-appId="@Model.AppId" id="ViewApp" target="_blank">View</a>
2022-02-07 10:37:45 +01:00
}
</div>
2022-02-21 03:05:42 +01:00
</div>
2021-04-08 15:32:42 +02:00
2022-02-07 10:37:45 +01:00
<partial name="_StatusMessage" />
2021-04-08 15:32:42 +02:00
2021-12-11 04:32:23 +01:00
<input type="hidden" asp-for="StoreId" />
2023-09-11 02:59:17 +02:00
<input type="hidden" asp-for="Archived" />
2023-12-21 15:43:12 +01:00
<div asp-validation-summary="ModelOnly"></div>
2021-07-29 22:31:44 -07:00
2021-12-11 04:32:23 +01:00
<div class="row">
2023-01-26 01:27:31 +01:00
<div class="col-sm-10 col-md-9 col-xl-7 col-xxl-6">
<div class="row">
<div class="col-sm-6">
<div class="form-group">
<label asp-for="AppName" class="form-label" data-required></label>
<input asp-for="AppName" class="form-control" required />
<span asp-validation-for="AppName" class="text-danger"></span>
</div>
</div>
<div class="col-sm-6">
<div class="form-group">
<label asp-for="Title" class="form-label" data-required></label>
<input asp-for="Title" class="form-control" required />
<span asp-validation-for="Title" class="text-danger"></span>
</div>
</div>
2021-12-11 04:32:23 +01:00
</div>
<div class="form-group">
<label asp-for="Tagline" class="form-label"></label>
<input asp-for="Tagline" class="form-control" />
<span asp-validation-for="Tagline" class="text-danger"></span>
</div>
2023-02-10 16:26:09 +01:00
<div class="form-group">
<label asp-for="MainImageUrl" class="form-label"></label>
<input asp-for="MainImageUrl" class="form-control" />
<span asp-validation-for="MainImageUrl" class="text-danger"></span>
</div>
2022-06-28 05:03:13 +02:00
<div class="form-group">
<div class="d-flex align-items-center">
2022-04-13 21:09:37 -07:00
<input asp-for="Enabled" type="checkbox" class="btcpay-toggle me-3"/>
2022-06-28 05:03:13 +02:00
<div>
<label asp-for="Enabled" class="form-label mb-0"></label>
<span asp-validation-for="Enabled" class="text-danger"></span>
2023-01-26 01:27:31 +01:00
<div class="text-muted">The crowdfund will be visible to anyone.</div>
2022-06-28 05:03:13 +02:00
</div>
2021-07-29 22:31:44 -07:00
</div>
2021-12-11 04:32:23 +01:00
</div>
</div>
2022-01-28 08:45:56 +01:00
</div>
2023-01-26 01:27:31 +01:00
<div class="row mt-3">
<div class="col-xl-10 col-xxl-constrain">
<div class="form-group">
<label asp-for="Description" class="form-label" data-required></label>
<textarea asp-for="Description" rows="20" cols="40" class="form-control richtext"></textarea>
<span asp-validation-for="Description" class="text-danger"></span>
</div>
</div>
</div>
2022-02-14 10:14:21 +01:00
<div class="row">
2022-06-28 05:03:13 +02:00
<div class="col-xl-10 col-xxl-constrain">
2022-02-14 10:14:21 +01:00
<h3 class="mt-5 mb-4">Goal</h3>
2022-06-28 05:03:13 +02:00
<div class="d-flex flex-wrap gap-3 mb-3">
<div class="form-group w-250px mb-0">
2022-02-14 10:14:21 +01:00
<label asp-for="TargetAmount" class="form-label"></label>
2022-03-25 22:09:58 -06:00
<input inputmode="decimal" asp-for="TargetAmount" class="form-control" />
2022-02-14 10:14:21 +01:00
<span asp-validation-for="TargetAmount" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="TargetCurrency" class="form-label"></label>
2022-09-26 03:26:13 +02:00
<input asp-for="TargetCurrency" class="form-control w-auto" currency-selection />
2022-12-04 10:01:38 +01:00
<div class="form-text">Uses the store's default currency (@Model.StoreDefaultCurrency) if empty.</div>
2022-02-14 10:14:21 +01:00
<span asp-validation-for="TargetCurrency" class="text-danger"></span>
</div>
</div>
2022-06-28 05:03:13 +02:00
<div class="d-flex flex-wrap gap-3 align-items-center mb-4">
<div class="form-group mb-0 w-250px">
<label asp-for="StartDate" class="form-label"></label>
<div class="input-group flex-nowrap">
<input type="datetime-local" asp-for="StartDate"
value="@(Model.StartDate?.ToString("u", CultureInfo.InvariantCulture))"
class="form-control flatdtpicker"
placeholder="No start date has been set" />
<button class="btn btn-secondary input-group-clear px-3" type="button" title="Clear">
<vc:icon symbol="close"/>
</button>
2022-02-14 10:14:21 +01:00
</div>
2022-06-19 19:55:47 -07:00
</div>
2022-06-28 05:03:13 +02:00
<div class="form-group mb-0 w-250px">
<label asp-for="EndDate" class="form-label"></label>
<div class="input-group flex-nowrap">
<input type="datetime-local" asp-for="EndDate"
value="@(Model.EndDate?.ToString("u", CultureInfo.InvariantCulture))"
class="form-control flatdtpicker"
placeholder="No end date has been set" />
<button class="btn btn-secondary input-group-clear px-3" type="button" title="Clear">
<vc:icon symbol="close"/>
</button>
2022-02-14 10:14:21 +01:00
</div>
</div>
2022-09-09 03:26:11 -07:00
<span asp-validation-for="StartDate" class="text-danger"></span>
<span asp-validation-for="EndDate" class="text-danger"></span>
2022-06-19 19:55:47 -07:00
</div>
2022-06-28 05:03:13 +02:00
<div class="form-group mt-4" id="ResetRow" hidden="@(Model.StartDate == null)">
<div class="d-flex align-items-center mb-3">
<input asp-for="IsRecurring" type="checkbox" class="btcpay-toggle me-3" data-bs-toggle="collapse" data-bs-target="#ResetEverySettings" aria-expanded="@(Model.IsRecurring)" aria-controls="ResetEverySettings" />
<div>
<label asp-for="IsRecurring" class="form-label mb-0">Recurring Goal</label>
<span asp-validation-for="IsRecurring" class="text-danger"></span>
<div class="text-muted">Reset goal after a specific period of time, based on your crowdfund's start date.</div>
</div>
</div>
<div class="collapse @(Model.IsRecurring ? "show" : "")" id="ResetEverySettings">
<div class="form-group mb-0 pt-2 w-250px">
<label asp-for="ResetEveryAmount" class="form-label"></label>
<div class="d-flex align-items-center">
<input type="number" inputmode="numeric" asp-for="ResetEveryAmount" placeholder="Amount" class="form-control me-3" min="0">
<select class="form-select w-auto" asp-for="ResetEvery">
@foreach (var opt in Model.ResetEveryValues)
{
<option value="@opt">@opt</option>
}
</select>
</div>
<span asp-validation-for="ResetEveryAmount" class="text-danger"></span>
</div>
2022-02-14 10:14:21 +01:00
</div>
</div>
</div>
2022-06-19 19:55:47 -07:00
</div>
2023-11-09 10:27:33 +01:00
<div id="perks" class="row">
<div class="col-xxl-constrain">
<partial name="TemplateEditor" model="@(nameof(Model.PerksTemplate), Model.PerksTemplate, "Perks", Model.TargetCurrency ?? Model.StoreDefaultCurrency)" />
</div>
2022-06-19 19:55:47 -07:00
</div>
<div class="row">
<div class="col-xl-8 col-xxl-constrain">
2022-01-17 17:19:27 -08:00
<h3 class="mt-5 mb-4">Contributions</h3>
2021-12-11 04:32:23 +01:00
<div class="form-check mb-3">
<input asp-for="SortPerksByPopularity" type="checkbox" class="form-check-input" />
<label asp-for="SortPerksByPopularity" class="form-check-label"></label>
<span asp-validation-for="SortPerksByPopularity" class="text-danger"></span>
</div>
<div class="form-check mb-3">
<input asp-for="DisplayPerksRanking" type="checkbox" class="form-check-input" />
<label asp-for="DisplayPerksRanking" class="form-check-label"></label>
<span asp-validation-for="DisplayPerksRanking" class="text-danger"></span>
</div>
<div class="form-check mb-3">
<input asp-for="DisplayPerksValue" type="checkbox" class="form-check-input" />
<label asp-for="DisplayPerksValue" class="form-check-label"></label>
<span asp-validation-for="DisplayPerksValue" class="text-danger"></span>
</div>
<div class="form-check mb-3">
<input asp-for="EnforceTargetAmount" type="checkbox" class="form-check-input" />
<label asp-for="EnforceTargetAmount" class="form-check-label"></label>
<span asp-validation-for="EnforceTargetAmount" class="text-danger"></span>
</div>
2022-02-07 10:37:45 +01:00
2022-01-17 17:19:27 -08:00
<h3 class="mt-5 mb-4">Crowdfund Behavior</h3>
2021-12-11 04:32:23 +01:00
<div class="form-check">
<input asp-for="UseAllStoreInvoices" type="checkbox" class="form-check-input" />
<label asp-for="UseAllStoreInvoices" class="form-check-label"></label>
<span asp-validation-for="UseAllStoreInvoices" class="text-danger"></span>
</div>
2024-02-21 13:41:21 +00:00
<h3 class="mt-5 mb-4">Checkout</h3>
<div class="form-group">
<label asp-for="FormId" class="form-label"></label>
<select asp-for="FormId" class="form-select w-auto" asp-items="@checkoutFormOptions"></select>
<span asp-validation-for="FormId" class="text-danger"></span>
</div>
2021-07-29 22:31:44 -07:00
2022-01-17 17:19:27 -08:00
<h3 class="mt-5 mb-2">Additional Options</h3>
2021-12-11 04:32:23 +01:00
<div class="form-group">
<div class="accordion" id="additional">
2022-06-28 05:03:13 +02:00
<div class="accordion-item">
<h2 class="accordion-header" id="additional-sound-header">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#additional-sound" aria-expanded="false" aria-controls="additional-sound">
Sound
<vc:icon symbol="caret-down" />
</button>
</h2>
<div id="additional-sound" class="accordion-collapse collapse" aria-labelledby="additional-sound-header">
<div class="accordion-body">
<div class="form-group mb-0">
<div class="d-flex align-items-center">
<input asp-for="SoundsEnabled" type="checkbox" class="btcpay-toggle me-3" data-bs-toggle="collapse" data-bs-target="#SoundsEnabledSettings" aria-expanded="@Model.SoundsEnabled" aria-controls="SoundsEnabledSettings"/>
<label asp-for="SoundsEnabled" class="form-label mb-0"></label>
<span asp-validation-for="SoundsEnabled" class="text-danger"></span>
</div>
</div>
<div class="collapse @(Model.SoundsEnabled ? "show" : "")" id="SoundsEnabledSettings">
<div class="form-group mb-0 pt-3">
<label asp-for="Sounds" class="form-label"></label>
<textarea asp-for="Sounds" class="form-control" rows="5"></textarea>
<span asp-validation-for="Sounds" class="text-danger"></span>
</div>
</div>
</div>
</div>
</div>
<div class="accordion-item">
<h2 class="accordion-header" id="additional-animation-header">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#additional-animation" aria-expanded="false" aria-controls="additional-animation">
Animation
<vc:icon symbol="caret-down" />
</button>
</h2>
<div id="additional-animation" class="accordion-collapse collapse" aria-labelledby="additional-animation-header">
<div class="accordion-body">
<div class="form-group mb-0">
<div class="d-flex align-items-center">
<input asp-for="AnimationsEnabled" type="checkbox" class="btcpay-toggle me-3" data-bs-toggle="collapse" data-bs-target="#AnimationsEnabledSettings" aria-expanded="@Model.AnimationsEnabled" aria-controls="AnimationsEnabledSettings"/>
<label asp-for="AnimationsEnabled" class="form-label mb-0"></label>
<span asp-validation-for="AnimationsEnabled" class="text-danger"></span>
</div>
</div>
<div class="collapse @(Model.AnimationsEnabled ? "show" : "")" id="AnimationsEnabledSettings">
<div class="form-group mb-0 pt-3">
<label asp-for="AnimationColors" class="form-label"></label>
<textarea asp-for="AnimationColors" class="form-control" rows="5"></textarea>
<span asp-validation-for="AnimationColors" class="text-danger"></span>
</div>
</div>
</div>
</div>
</div>
<div class="accordion-item">
<h2 class="accordion-header" id="additional-discussion-header">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#additional-discussion" aria-expanded="false" aria-controls="additional-discussion">
Discussion
<vc:icon symbol="caret-down" />
</button>
</h2>
<div id="additional-discussion" class="accordion-collapse collapse" aria-labelledby="additional-discussion-header">
<div class="accordion-body">
<div class="form-group mb-0">
<div class="d-flex align-items-center">
<input asp-for="DisqusEnabled" type="checkbox" class="btcpay-toggle me-3" data-bs-toggle="collapse" data-bs-target="#DisqusEnabledSettings" aria-expanded="@Model.DisqusEnabled" aria-controls="DisqusEnabledSettings"/>
<label asp-for="DisqusEnabled" class="form-label mb-0"></label>
<span asp-validation-for="DisqusEnabled" class="text-danger"></span>
</div>
</div>
<div class="collapse @(Model.DisqusEnabled ? "show" : "")" id="DisqusEnabledSettings">
<div class="form-group mb-0 pt-3">
<label asp-for="DisqusShortname" class="form-label"></label>
<input asp-for="DisqusShortname" class="form-control" />
<span asp-validation-for="DisqusShortname" class="text-danger"></span>
</div>
</div>
</div>
</div>
</div>
2022-02-14 10:14:21 +01:00
<div class="accordion-item">
<h2 class="accordion-header" id="additional-notification-header">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#additional-notification" aria-expanded="false" aria-controls="additional-notification">
Notification URL Callbacks
<vc:icon symbol="caret-down" />
</button>
</h2>
<div id="additional-notification" class="accordion-collapse collapse" aria-labelledby="additional-notification-header">
<div class="accordion-body">
<div class="form-group">
<label asp-for="NotificationUrl" class="form-label"></label>
<input asp-for="NotificationUrl" class="form-control" />
<span asp-validation-for="NotificationUrl" class="text-danger"></span>
</div>
</div>
</div>
</div>
2024-02-23 13:42:00 +01:00
@* We are deprecating the custom CSS options in favor of the store branding approach.
Display this section only if these values are set. *@
@if (!string.IsNullOrWhiteSpace(Model.CustomCSSLink) || !string.IsNullOrWhiteSpace(Model.EmbeddedCSS))
{
<div class="accordion-item">
<h2 class="accordion-header" id="additional-custom-css-header">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#additional-custom-css" aria-expanded="false" aria-controls="additional-custom-css">
Custom CSS
<vc:icon symbol="caret-down" />
</button>
</h2>
<div id="additional-custom-css" class="accordion-collapse collapse" aria-labelledby="additional-custom-css-header">
<div class="accordion-body">
<div class="form-group">
<label asp-for="CustomCSSLink" class="form-label"></label>
<a href="https://docs.btcpayserver.org/Development/Theme/#2-bootstrap-themes" target="_blank" rel="noreferrer noopener" title="More information...">
<vc:icon symbol="info" />
</a>
<input asp-for="CustomCSSLink" class="form-control" />
<span asp-validation-for="CustomCSSLink" class="text-danger"></span>
</div>
<div class="form-group mb-4">
<label asp-for="EmbeddedCSS" class="form-label"></label>
<textarea asp-for="EmbeddedCSS" rows="10" cols="40" class="form-control"></textarea>
<span asp-validation-for="EmbeddedCSS" class="text-danger"></span>
</div>
</div>
</div>
</div>
}
2021-07-29 22:31:44 -07:00
</div>
2021-12-11 04:32:23 +01:00
</div>
</div>
2022-01-28 08:45:56 +01:00
</div>
2021-12-11 04:32:23 +01:00
</form>
2021-12-19 05:05:10 +01:00
2023-11-09 10:27:33 +01:00
<div class="d-grid d-sm-flex flex-wrap gap-3 mt-3">
2022-02-21 03:05:42 +01:00
<a class="btn btn-secondary" asp-action="ListInvoices" asp-controller="UIInvoice" asp-route-storeId="@Model.StoreId" asp-route-searchterm="@Model.SearchTerm">Invoices</a>
2023-09-11 02:59:17 +02:00
<form method="post" asp-controller="UIApps" asp-action="ToggleArchive" asp-route-appId="@Model.AppId">
2023-11-09 10:27:33 +01:00
<button type="submit" class="w-100 btn btn-outline-secondary" id="btn-archive-toggle">
2023-09-11 02:59:17 +02:00
@if (Model.Archived)
{
<span class="text-nowrap">Unarchive this app</span>
}
else
{
<span class="text-nowrap" data-bs-toggle="tooltip" title="Archive this app so that it does not appear in the apps list by default">Archive this app</span>
}
</button>
</form>
2023-01-22 03:08:12 +09:00
<a id="DeleteApp" class="btn btn-outline-danger" asp-controller="UIApps" asp-action="DeleteApp" asp-route-appId="@Model.AppId" data-bs-toggle="modal" data-bs-target="#ConfirmModal" data-description="The app <strong>@Html.Encode(Model.AppName)</strong> and its settings will be permanently deleted." data-confirm-input="DELETE">Delete this app</a>
2021-12-19 05:05:10 +01:00
</div>
<partial name="_Confirm" model="@(new ConfirmModel("Delete app", "This app will be removed from this store.", "Delete"))" />
2022-05-04 01:34:40 -07:00