mirror of
https://github.com/aljazceru/btcpayserver.git
synced 2025-12-19 06:54:19 +01:00
Store setup: Restructuring basics
This commit is contained in:
@@ -301,11 +301,12 @@ namespace BTCPayServer.Tests
|
|||||||
await s.StartAsync();
|
await s.StartAsync();
|
||||||
var alice = s.RegisterNewUser();
|
var alice = s.RegisterNewUser();
|
||||||
var storeData = s.CreateNewStore();
|
var storeData = s.CreateNewStore();
|
||||||
|
var onchainHint = "A store requires a wallet to receive on-chain payments.";
|
||||||
|
var offchainHint = "A connection to a Lightning node is required if you want to receive Lightning payments.";
|
||||||
|
|
||||||
// verify that hints are displayed on the store page
|
// verify that hints are displayed on the store page
|
||||||
Assert.True(s.Driver.PageSource.Contains("Wallet not setup for the store, please provide Derviation Scheme"),
|
Assert.True(s.Driver.PageSource.Contains(onchainHint), "Wallet hint not present");
|
||||||
"Wallet hint not present");
|
Assert.True(s.Driver.PageSource.Contains(offchainHint), "Lightning hint not present");
|
||||||
Assert.True(s.Driver.PageSource.Contains("Review settings if you want to receive Lightning payments"),
|
|
||||||
"Lightning hint not present");
|
|
||||||
|
|
||||||
s.GoToStores();
|
s.GoToStores();
|
||||||
Assert.True(s.Driver.PageSource.Contains("warninghint_" + storeData.storeId),
|
Assert.True(s.Driver.PageSource.Contains("warninghint_" + storeData.storeId),
|
||||||
@@ -314,7 +315,7 @@ namespace BTCPayServer.Tests
|
|||||||
s.GoToStore(storeData.storeId);
|
s.GoToStore(storeData.storeId);
|
||||||
s.AddDerivationScheme(); // wallet hint should be dismissed
|
s.AddDerivationScheme(); // wallet hint should be dismissed
|
||||||
s.Driver.AssertNoError();
|
s.Driver.AssertNoError();
|
||||||
Assert.False(s.Driver.PageSource.Contains("Wallet not setup for the store, please provide Derviation Scheme"),
|
Assert.False(s.Driver.PageSource.Contains(onchainHint),
|
||||||
"Wallet hint not dismissed on derivation scheme add");
|
"Wallet hint not dismissed on derivation scheme add");
|
||||||
|
|
||||||
s.Driver.FindElement(By.Id("dismissLightningHint")).Click(); // dismiss lightning hint
|
s.Driver.FindElement(By.Id("dismissLightningHint")).Click(); // dismiss lightning hint
|
||||||
@@ -380,8 +381,7 @@ namespace BTCPayServer.Tests
|
|||||||
s.Driver.FindElement(By.Id("Stores")).Click();
|
s.Driver.FindElement(By.Id("Stores")).Click();
|
||||||
|
|
||||||
// there shouldn't be any hints now
|
// there shouldn't be any hints now
|
||||||
Assert.False(s.Driver.PageSource.Contains("Review settings if you want to receive Lightning payments"),
|
Assert.False(s.Driver.PageSource.Contains(offchainHint), "Lightning hint should be dismissed at this point");
|
||||||
"Lightning hint should be dismissed at this point");
|
|
||||||
|
|
||||||
s.Driver.FindElement(By.LinkText("Remove")).Click();
|
s.Driver.FindElement(By.LinkText("Remove")).Click();
|
||||||
s.Driver.FindElement(By.Id("continue")).Click();
|
s.Driver.FindElement(By.Id("continue")).Click();
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ namespace BTCPayServer.Models.StoreViewModels
|
|||||||
}
|
}
|
||||||
|
|
||||||
public bool CanDelete { get; set; }
|
public bool CanDelete { get; set; }
|
||||||
|
[Display(Name = "Store ID")]
|
||||||
public string Id { get; set; }
|
public string Id { get; set; }
|
||||||
[Display(Name = "Store Name")]
|
[Display(Name = "Store Name")]
|
||||||
[Required]
|
[Required]
|
||||||
|
|||||||
@@ -73,10 +73,12 @@
|
|||||||
<input id="DerivationSchemeFormat" asp-for="DerivationSchemeFormat" type="hidden" />
|
<input id="DerivationSchemeFormat" asp-for="DerivationSchemeFormat" type="hidden" />
|
||||||
<input id="AccountKey" asp-for="AccountKey" type="hidden" />
|
<input id="AccountKey" asp-for="AccountKey" type="hidden" />
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<h5>Derivation scheme</h5>
|
<h5>
|
||||||
|
Derivation scheme
|
||||||
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Wallet/#what-is-a-derivation-scheme" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
|
</h5>
|
||||||
<p>
|
<p>
|
||||||
The derivation scheme represents the destination of the funds received by your invoice.
|
A derivation scheme facilitates generation of the destination addresses for your invoices so funds can be received on-chain.
|
||||||
It is generated by your wallet software.
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
@using System.Text.RegularExpressions
|
@using System.Text.RegularExpressions
|
||||||
@model StoreViewModel
|
@model StoreViewModel
|
||||||
@{
|
@{
|
||||||
Layout = "../Shared/_NavLayout.cshtml";
|
Layout = "../Shared/_NavLayout.cshtml";
|
||||||
@@ -10,268 +10,276 @@
|
|||||||
@if (!ViewContext.ModelState.IsValid)
|
@if (!ViewContext.ModelState.IsValid)
|
||||||
{
|
{
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6">
|
<div class="col-md-8">
|
||||||
<div asp-validation-summary="All" class="text-danger"></div>
|
<div asp-validation-summary="All" class="text-danger"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-8">
|
<div class="col-lg-10 col-xl-9">
|
||||||
<div>
|
<h4 class="mb-3">
|
||||||
<h4 class="mb-3">Wallet <span class="text-muted small">On-chain payments</span></h4>
|
<span class="mr-1">Wallet</span>
|
||||||
@if (Model.HintWallet)
|
<span class="text-muted small">On-chain payments</span>
|
||||||
{
|
</h4>
|
||||||
<p class="alert alert-warning">
|
@if (Model.HintWallet)
|
||||||
<span class="fa fa-warning"></span>
|
{
|
||||||
Wallet not setup for the store, please provide Derviation Scheme
|
<div class="alert alert-warning d-flex align-items-start mb-2">
|
||||||
<button type="button" class="close only-for-js" data-dismiss="alert" aria-label="Close"
|
<span class="fa fa-warning mt-1"></span>
|
||||||
onclick="return dismissHint('Wallet', '@Model.Id');">
|
<p class="mb-0 mx-3 flex-fill">
|
||||||
<span aria-hidden="true">×</span>
|
A store requires a wallet to receive on-chain payments.
|
||||||
</button>
|
Optionally, you can have a store that only receives Lightning payments, see the next section for more details.
|
||||||
</p>
|
</p>
|
||||||
}
|
<button type="button" class="close only-for-js" data-dismiss="alert" aria-label="Close" onclick="return dismissHint('Wallet', '@Model.Id');">
|
||||||
<p>
|
<span aria-hidden="true">×</span>
|
||||||
The Derivation Scheme <a href="https://docs.btcpayserver.org/FAQ/FAQ-Wallet/#what-is-a-derivation-scheme" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
</button>
|
||||||
facilitates generation of the destination addresses for your invoices so funds can be received on-chain.
|
</div>
|
||||||
</p>
|
}
|
||||||
<p>
|
<table class="table table-sm mt-0 mb-5">
|
||||||
Until wallet is defined, no invoices can be created for this store.
|
<thead>
|
||||||
Optionally, you can have a store that only receives Lightning payments, see the next section for more details.
|
<tr>
|
||||||
</p>
|
<th>Crypto</th>
|
||||||
|
<th>Derivation Scheme</th>
|
||||||
<table class="table table-sm table-responsive-md mt-0 mb-5">
|
<th class="text-center w-100px">Enabled</th>
|
||||||
<thead>
|
<th class="text-right w-100px">Actions</th>
|
||||||
<tr>
|
</tr>
|
||||||
<th>Crypto</th>
|
</thead>
|
||||||
<th>Derivation Scheme</th>
|
<tbody>
|
||||||
<th style="text-align:center;">Enabled</th>
|
@foreach (var scheme in Model.DerivationSchemes.OrderBy(scheme => scheme.Collapsed))
|
||||||
<th style="text-align:right;">Actions</th>
|
{
|
||||||
|
<tr class="@(@scheme.Collapsed? "collapsed": "")">
|
||||||
|
<td>
|
||||||
|
@scheme.Crypto
|
||||||
|
@if (!string.IsNullOrWhiteSpace(scheme.Value) && scheme.WalletSupported)
|
||||||
|
{
|
||||||
|
<span> - </span>
|
||||||
|
<a asp-action="WalletTransactions" asp-controller="Wallets" asp-route-walletId="@scheme.WalletId">Wallet</a>
|
||||||
|
}
|
||||||
|
</td>
|
||||||
|
<td title="@scheme.Value" data-toggle="tooltip" class="d-flex">
|
||||||
|
@if (string.IsNullOrEmpty(scheme.Value))
|
||||||
|
{
|
||||||
|
<span class="smMaxWidth">Not set</span>
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
<code class="text-truncate" style="max-width:25ch">
|
||||||
|
@scheme.Value
|
||||||
|
</code>
|
||||||
|
<code>
|
||||||
|
@if (scheme.Value.Length > 20)
|
||||||
|
{
|
||||||
|
var match = Regex.Match(scheme.Value, @"((?:-\[(?:[^\]])+\])+|\S{6})$");
|
||||||
|
@match.Value;
|
||||||
|
}
|
||||||
|
</code>
|
||||||
|
}
|
||||||
|
</td>
|
||||||
|
<td class="text-center">
|
||||||
|
@if (scheme.Enabled)
|
||||||
|
{
|
||||||
|
<span class="text-success fa fa-check"></span>
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
<span class="text-danger fa fa-times"></span>
|
||||||
|
}
|
||||||
|
</td>
|
||||||
|
<td class="text-right">
|
||||||
|
<a asp-action="AddDerivationScheme" asp-route-cryptoCode="@scheme.Crypto" asp-route-storeId="@Context.GetRouteValue("storeId")" id="@($"Modify{scheme.Crypto}")">
|
||||||
|
@(scheme.Enabled ? "Modify" : "Setup")
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
}
|
||||||
|
@if (Model.DerivationSchemes.Any(scheme => scheme.Collapsed))
|
||||||
|
{
|
||||||
|
<tr class="only-for-js">
|
||||||
|
<td colspan="4"><button class="btn btn-link" id="toggle-assets" type="button">Show additional assets</button></td>
|
||||||
|
</tr>
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<h4 class="mb-3">
|
||||||
|
<span class="mr-1">Lightning</span>
|
||||||
|
<span class="text-muted small">Off-chain payments</span>
|
||||||
|
</h4>
|
||||||
|
@if (Model.HintLightning)
|
||||||
|
{
|
||||||
|
<div class="alert alert-warning d-flex align-items-start mb-2">
|
||||||
|
<span class="fa fa-warning mt-1"></span>
|
||||||
|
<p class="mb-0 mx-3 flex-fill">
|
||||||
|
A connection to a Lightning node is required if you want to receive Lightning payments.
|
||||||
|
</p>
|
||||||
|
<button id="dismissLightningHint" type="button" class="close only-for-js" data-dismiss="alert" aria-label="Close" onclick="return dismissHint('Lightning', '@Model.Id');">
|
||||||
|
<span aria-hidden="true">×</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
|
||||||
|
<div class="table-responsive-md">
|
||||||
|
<table class="table table-sm mb-5">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th class="w-100px">Crypto</th>
|
||||||
|
<th>Address</th>
|
||||||
|
<th class="text-center w-100px">Enabled</th>
|
||||||
|
<th class="text-right w-100px">Actions</th>
|
||||||
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@foreach (var scheme in Model.DerivationSchemes.OrderBy(scheme => scheme.Collapsed))
|
@foreach (var scheme in Model.LightningNodes)
|
||||||
{
|
{
|
||||||
<tr class="@(@scheme.Collapsed? "collapsed": "")">
|
|
||||||
<td>@scheme.Crypto</td>
|
|
||||||
<td title="@scheme.Value" data-toggle="tooltip" class="d-flex">
|
|
||||||
@if (string.IsNullOrEmpty(scheme.Value))
|
|
||||||
{
|
|
||||||
<span class="smMaxWidth">Not set</span>
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
<code class="text-truncate" style="max-width:25ch">
|
|
||||||
@scheme.Value
|
|
||||||
</code>
|
|
||||||
<code>
|
|
||||||
@if (scheme.Value.Length > 20)
|
|
||||||
{
|
|
||||||
var match = Regex.Match(scheme.Value, @"((?:-\[(?:[^\]])+\])+|\S{6})$");
|
|
||||||
@match.Value;
|
|
||||||
}
|
|
||||||
</code>
|
|
||||||
}
|
|
||||||
</td>
|
|
||||||
<td style="text-align:center;">
|
|
||||||
@if (scheme.Enabled)
|
|
||||||
{
|
|
||||||
<span class="text-success fa fa-check"></span>
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
<span class="text-danger fa fa-times"></span>
|
|
||||||
}
|
|
||||||
</td>
|
|
||||||
<td style="text-align:right">
|
|
||||||
@if (!string.IsNullOrWhiteSpace(scheme.Value) && scheme.WalletSupported)
|
|
||||||
{
|
|
||||||
<a asp-action="WalletTransactions" asp-controller="Wallets" asp-route-walletId="@scheme.WalletId">Wallet</a><span> - </span>
|
|
||||||
}
|
|
||||||
<a asp-action="AddDerivationScheme" asp-route-cryptoCode="@scheme.Crypto" asp-route-storeId="@this.Context.GetRouteValue("storeId")" id="@($"Modify{scheme.Crypto}")">Modify</a>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
}
|
|
||||||
|
|
||||||
@if (Model.DerivationSchemes.Any(scheme => scheme.Collapsed))
|
|
||||||
{
|
|
||||||
<tr class="only-for-js">
|
|
||||||
<td colspan="4"><button class="btn btn-link" id="toggle-assets" type="button">Show additional assets</button></td>
|
|
||||||
</tr>
|
|
||||||
}
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<h4 class="mt-5 mb-3">Lightning <span class="text-muted small">Off-chain payments</span></h4>
|
|
||||||
@if (Model.HintLightning)
|
|
||||||
{
|
|
||||||
<p class="alert alert-warning">
|
|
||||||
<span class="fa fa-warning"></span>
|
|
||||||
Review settings if you want to receive Lightning payments
|
|
||||||
<button id="dismissLightningHint" type="button" class="close only-for-js" data-dismiss="alert" aria-label="Close"
|
|
||||||
onclick="return dismissHint('Lightning', '@Model.Id');">
|
|
||||||
<span aria-hidden="true">×</span>
|
|
||||||
</button>
|
|
||||||
</p>
|
|
||||||
}
|
|
||||||
<p>
|
|
||||||
A connection to a Lightning Node is required to generate Lightning Network enabled invoices.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<table class="table table-sm table-responsive-md">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
<tr>
|
||||||
<th>Crypto</th>
|
<td>@scheme.CryptoCode</td>
|
||||||
<th>Address</th>
|
<td class="smMaxWidth text-truncate">@scheme.Address</td>
|
||||||
<th style="text-align:center;">Enabled</th>
|
<td class="text-center">
|
||||||
<th style="text-align:right">Actions</th>
|
@if (scheme.Enabled)
|
||||||
|
{
|
||||||
|
<span class="text-success fa fa-check"></span>
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
<span class="text-danger fa fa-times"></span>
|
||||||
|
}
|
||||||
|
</td>
|
||||||
|
<td class="text-right">
|
||||||
|
<a asp-action="AddLightningNode" asp-route-cryptoCode="@scheme.CryptoCode" asp-route-storeId="@Context.GetRouteValue("storeId")" id="@($"Modify-Lightning{scheme.CryptoCode}")">
|
||||||
|
@(scheme.Enabled ? "Modify" : "Setup")
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
}
|
||||||
<tbody>
|
|
||||||
@foreach (var scheme in Model.LightningNodes)
|
|
||||||
{
|
|
||||||
<tr>
|
|
||||||
<td>@scheme.CryptoCode</td>
|
|
||||||
<td class="smMaxWidth text-truncate">@scheme.Address</td>
|
|
||||||
<td style="text-align:center;">
|
|
||||||
@if (scheme.Enabled)
|
|
||||||
{
|
|
||||||
<span class="text-success fa fa-check"></span>
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
<span class="text-danger fa fa-times"></span>
|
|
||||||
}
|
|
||||||
</td>
|
|
||||||
<td style="text-align:right"><a asp-action="AddLightningNode" asp-route-cryptoCode="@scheme.CryptoCode" asp-route-storeId="@this.Context.GetRouteValue("storeId")" id="@($"Modify-Lightning{scheme.CryptoCode}")">Modify</a></td>
|
|
||||||
</tr>
|
|
||||||
}
|
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
</div>
|
||||||
|
|
||||||
<form method="post">
|
<form method="post" class="mb-5">
|
||||||
<div class="form-group mb-5">
|
<h4 class="mb-3">General</h4>
|
||||||
<label asp-for="LightningDescriptionTemplate"></label>
|
<div class="form-group">
|
||||||
<input asp-for="LightningDescriptionTemplate" class="form-control" />
|
<label asp-for="Id"></label>
|
||||||
<span asp-validation-for="LightningDescriptionTemplate" class="text-danger"></span>
|
<input asp-for="Id" readonly class="form-control" />
|
||||||
<p class="form-text text-muted">
|
</div>
|
||||||
Available placeholders:
|
<div class="form-group">
|
||||||
<code>{StoreName} {ItemDescription} {OrderId}</code>
|
<label asp-for="StoreName"></label>
|
||||||
</p>
|
<input asp-for="StoreName" class="form-control" />
|
||||||
</div>
|
<span asp-validation-for="StoreName" class="text-danger"></span>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="StoreWebsite"></label>
|
||||||
|
<input asp-for="StoreWebsite" class="form-control" />
|
||||||
|
<span asp-validation-for="StoreWebsite" class="text-danger"></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
<h4 class="mt-5 mb-3">Store settings</h4>
|
<h4 class="mt-5 mb-3">Payment</h4>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label asp-for="Id"></label>
|
<div class="form-check">
|
||||||
<input asp-for="Id" readonly class="form-control" />
|
<input asp-for="AnyoneCanCreateInvoice" type="checkbox" class="form-check-input" />
|
||||||
|
<label asp-for="AnyoneCanCreateInvoice" class="form-check-label"></label>
|
||||||
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#allow-anyone-to-create-invoice" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
</div>
|
||||||
<label asp-for="StoreName"></label>
|
<div class="form-group">
|
||||||
<input asp-for="StoreName" class="form-control" />
|
<div class="form-check">
|
||||||
<span asp-validation-for="StoreName" class="text-danger"></span>
|
<input asp-for="PayJoinEnabled" type="checkbox" class="form-check-input" />
|
||||||
|
<label asp-for="PayJoinEnabled" class="form-check-label"></label>
|
||||||
|
<a href="https://docs.btcpayserver.org/Payjoin/" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
|
<span asp-validation-for="PayJoinEnabled" class="text-danger"></span>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
</div>
|
||||||
<label asp-for="StoreWebsite"></label>
|
<div class="form-group">
|
||||||
<input asp-for="StoreWebsite" class="form-control" />
|
<label asp-for="NetworkFeeMode"></label>
|
||||||
<span asp-validation-for="StoreWebsite" class="text-danger"></span>
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#add-network-fee-to-invoice-vary-with-mining-fees" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
|
<select asp-for="NetworkFeeMode" class="form-control">
|
||||||
|
<option value="MultiplePaymentsOnly">... only if the customer makes more than one payment for the invoice</option>
|
||||||
|
<option value="Always">... on every payment</option>
|
||||||
|
<option value="Never">Never add network fee</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="mb-2">
|
||||||
|
<label asp-for="InvoiceExpiration" class="d-inline"></label>
|
||||||
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#invoice-expires-if-the-full-amount-has-not-been-paid-after-minutes" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="input-group">
|
||||||
|
<input asp-for="InvoiceExpiration" class="form-control" style="max-width:10ch;" />
|
||||||
|
<div class="input-group-append">
|
||||||
|
<span class="input-group-text">minutes</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<span asp-validation-for="InvoiceExpiration" class="text-danger"></span>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="mb-2">
|
||||||
|
<label asp-for="MonitoringExpiration" class="d-inline"></label>
|
||||||
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#payment-invalid-if-transactions-fails-to-confirm-minutes-after-invoice-expiration" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
|
</div>
|
||||||
|
<div class="input-group">
|
||||||
|
<input asp-for="MonitoringExpiration" class="form-control" style="max-width:10ch;" />
|
||||||
|
<div class="input-group-append">
|
||||||
|
<span class="input-group-text">minutes</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<span asp-validation-for="MonitoringExpiration" class="text-danger"></span>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="mb-2">
|
||||||
|
<label asp-for="PaymentTolerance" class="d-inline"></label>
|
||||||
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#consider-the-invoice-paid-even-if-the-paid-amount-is-less-than-expected" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
||||||
|
</div>
|
||||||
|
<div class="input-group">
|
||||||
|
<input asp-for="PaymentTolerance" class="form-control" style="max-width:10ch;" />
|
||||||
|
<div class="input-group-append">
|
||||||
|
<span class="input-group-text">percent</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<span asp-validation-for="PaymentTolerance" class="text-danger"></span>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="mb-2">
|
||||||
|
<label asp-for="SpeedPolicy" class="d-inline"></label>
|
||||||
|
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#consider-the-invoice-confirmed-when-the-payment-transaction" target="_blank">
|
||||||
|
<span class="fa fa-question-circle-o" title="More information..."></span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<script>
|
||||||
|
function handleSpeedPolicyChange(select) {
|
||||||
|
document.getElementById('unconfirmed-warning').hidden = select.value !== '0';
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<select asp-for="SpeedPolicy" class="form-control w-auto" onchange="handleSpeedPolicyChange(this)">
|
||||||
|
<option value="0">Is unconfirmed</option>
|
||||||
|
<option value="1">Has at least 1 confirmation</option>
|
||||||
|
<option value="3">Has at least 2 confirmations</option>
|
||||||
|
<option value="2">Has at least 6 confirmations</option>
|
||||||
|
</select>
|
||||||
|
<div class="alert alert-warning my-2" hidden="@(Model.SpeedPolicy != 0)" id="unconfirmed-warning" role="alert">
|
||||||
|
Choosing to accept an unconfirmed invoice can lead to double-spending and is strongly discouraged.
|
||||||
|
</div>
|
||||||
|
<span asp-validation-for="SpeedPolicy" class="text-danger"></span>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="LightningDescriptionTemplate"></label>
|
||||||
|
<input asp-for="LightningDescriptionTemplate" class="form-control" />
|
||||||
|
<span asp-validation-for="LightningDescriptionTemplate" class="text-danger"></span>
|
||||||
|
<p class="form-text text-muted">
|
||||||
|
Available placeholders:
|
||||||
|
<code>{StoreName} {ItemDescription} {OrderId}</code>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<button name="command" type="submit" class="btn btn-primary" value="Save" id="Save">Save Store Settings</button>
|
||||||
<div class="form-check">
|
</form>
|
||||||
<input asp-for="AnyoneCanCreateInvoice" type="checkbox" class="form-check-input" />
|
|
||||||
<label asp-for="AnyoneCanCreateInvoice" class="form-check-label"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#allow-anyone-to-create-invoice" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<div class="form-check">
|
|
||||||
<input asp-for="PayJoinEnabled" type="checkbox" class="form-check-input" />
|
|
||||||
<label asp-for="PayJoinEnabled" class="form-check-label"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/Payjoin/" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
|
||||||
<span asp-validation-for="PayJoinEnabled" class="text-danger"></span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label asp-for="NetworkFeeMode"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#add-network-fee-to-invoice-vary-with-mining-fees" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
|
||||||
<select asp-for="NetworkFeeMode" class="form-control">
|
|
||||||
<option value="MultiplePaymentsOnly">... only if the customer makes more than one payment for the invoice</option>
|
|
||||||
<option value="Always">... on every payment</option>
|
|
||||||
<option value="Never">Never add network fee</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<div class="mb-2">
|
|
||||||
<label asp-for="InvoiceExpiration" class="d-inline"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#invoice-expires-if-the-full-amount-has-not-been-paid-after-minutes" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
|
||||||
</div>
|
|
||||||
<div class="input-group">
|
|
||||||
<input asp-for="InvoiceExpiration" class="form-control" style="max-width:10ch;" />
|
|
||||||
<div class="input-group-append">
|
|
||||||
<span class="input-group-text">minutes</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<span asp-validation-for="InvoiceExpiration" class="text-danger"></span>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<div class="mb-2">
|
|
||||||
<label asp-for="MonitoringExpiration" class="d-inline"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#payment-invalid-if-transactions-fails-to-confirm-minutes-after-invoice-expiration" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
|
||||||
</div>
|
|
||||||
<div class="input-group">
|
|
||||||
<input asp-for="MonitoringExpiration" class="form-control" style="max-width:10ch;" />
|
|
||||||
<div class="input-group-append">
|
|
||||||
<span class="input-group-text">minutes</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<span asp-validation-for="MonitoringExpiration" class="text-danger"></span>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<div class="mb-2">
|
|
||||||
<label asp-for="PaymentTolerance" class="d-inline"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#consider-the-invoice-paid-even-if-the-paid-amount-is-less-than-expected" target="_blank"><span class="fa fa-question-circle-o" title="More information..."></span></a>
|
|
||||||
</div>
|
|
||||||
<div class="input-group">
|
|
||||||
<input asp-for="PaymentTolerance" class="form-control" style="max-width:10ch;" />
|
|
||||||
<div class="input-group-append">
|
|
||||||
<span class="input-group-text">percent</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<span asp-validation-for="PaymentTolerance" class="text-danger"></span>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<div class="mb-2">
|
|
||||||
<label asp-for="SpeedPolicy" class="d-inline"></label>
|
|
||||||
<a href="https://docs.btcpayserver.org/FAQ/FAQ-Stores/#consider-the-invoice-confirmed-when-the-payment-transaction" target="_blank">
|
|
||||||
<span class="fa fa-question-circle-o" title="More information..."></span>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
<script>
|
|
||||||
function handleSpeedPolicyChange(select) {
|
|
||||||
document.getElementById('unconfirmed-warning').hidden = select.value !== '0';
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
<select asp-for="SpeedPolicy" class="form-control w-auto" onchange="handleSpeedPolicyChange(this)">
|
|
||||||
<option value="0">Is unconfirmed</option>
|
|
||||||
<option value="1">Has at least 1 confirmation</option>
|
|
||||||
<option value="3">Has at least 2 confirmations</option>
|
|
||||||
<option value="2">Has at least 6 confirmations</option>
|
|
||||||
</select>
|
|
||||||
<div class="alert alert-warning my-2" hidden="@(Model.SpeedPolicy != 0)" id="unconfirmed-warning" role="alert">
|
|
||||||
Choosing to accept an unconfirmed invoice can lead to double-spending and is strongly discouraged.
|
|
||||||
</div>
|
|
||||||
<span asp-validation-for="SpeedPolicy" class="text-danger"></span>
|
|
||||||
<button name="command" type="submit" class="btn btn-primary mt-3" value="Save" id="Save">Save Store Settings</button>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
|
|
||||||
<h4 class="mt-5 mb-3">Additional Payment methods</h4>
|
<h4 class="mb-3">Additional payment methods</h4>
|
||||||
<table class="table table-sm table-responsive-md mt-1 mb-5">
|
<div class="table-responsive-md">
|
||||||
|
<table class="table table-sm mt-1 mb-5">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Provider</th>
|
<th>Provider</th>
|
||||||
<th class="text-center">Enabled</th>
|
<th class="text-center w-100px">Enabled</th>
|
||||||
<th class="text-right">Actions</th>
|
<th class="text-right w-100px">Actions</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@@ -289,39 +297,51 @@
|
|||||||
<span class="text-danger fa fa-times"></span>
|
<span class="text-danger fa fa-times"></span>
|
||||||
}
|
}
|
||||||
</td>
|
</td>
|
||||||
<td class="text-right"><a asp-action="@scheme.Action" id='Modify-@scheme.Provider' asp-route-storeId="@this.Context.GetRouteValue("storeId")">Modify</a></td>
|
<td class="text-right">
|
||||||
|
<a asp-action="@scheme.Action" id='Modify-@scheme.Provider' asp-route-storeId="@Context.GetRouteValue("storeId")">
|
||||||
|
@(scheme.Enabled ? "Modify" : "Setup")
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
}
|
}
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
</div>
|
||||||
|
|
||||||
<h4 class="mt-5 mb-3">Services</h4>
|
<h4 class="mt-5 mb-3">Services</h4>
|
||||||
<table class="table table-sm table-responsive-md mt-1 mb-5">
|
<div class="table-responsive-md">
|
||||||
|
<table class="table table-sm mt-1 mb-5">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Service</th>
|
<th>Service</th>
|
||||||
<th style="text-align:right">Actions</th>
|
<th class="text-right w-100px">Actions</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
Email
|
Email
|
||||||
</td>
|
</td>
|
||||||
<td style="text-align:right"><a asp-action="Emails" asp-route-storeId="@this.Context.GetRouteValue("storeId")">Modify</a></td>
|
<td class="text-right">
|
||||||
</tr>
|
<a asp-action="Emails" asp-route-storeId="@Context.GetRouteValue("storeId")">
|
||||||
|
Setup
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
@if (Model.CanDelete)
|
|
||||||
{
|
|
||||||
<h4 class="mt-5 mb-3">Other actions</h4>
|
|
||||||
<p><a href="#danger-zone" data-toggle="collapse"><b>Click here to see more actions</b></a></p>
|
|
||||||
<div id="danger-zone" class="collapse">
|
|
||||||
<a class="btn btn-outline-danger mb-5" asp-action="DeleteStore" asp-route-storeId="@Model.Id">Delete this store</a>
|
|
||||||
</div>
|
|
||||||
}
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@if (Model.CanDelete)
|
||||||
|
{
|
||||||
|
<h4 class="mt-5 mb-3">Other actions</h4>
|
||||||
|
<button class="btn btn-link text-secondary mb-3 p-0" type="button" data-toggle="collapse" data-target="#danger-zone">
|
||||||
|
See more actions
|
||||||
|
</button>
|
||||||
|
<div id="danger-zone" class="collapse">
|
||||||
|
<a class="btn btn-outline-danger mb-5" asp-action="DeleteStore" asp-route-storeId="@Model.Id">Delete this store</a>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
@@ -3769,11 +3769,10 @@ input[type="button"].btn-block {
|
|||||||
font-size: 1.5rem;
|
font-size: 1.5rem;
|
||||||
font-weight: 700;
|
font-weight: 700;
|
||||||
line-height: 1;
|
line-height: 1;
|
||||||
color: var(--btcpay-color-dark-accent);
|
color: inherit;
|
||||||
text-shadow: 0 1px 0 var(--btcpay-color-white);
|
text-shadow: 0 1px 0 var(--btcpay-color-white);
|
||||||
opacity: .5; }
|
opacity: .5; }
|
||||||
.close:hover {
|
.close:hover {
|
||||||
color: var(--btcpay-color-dark-accent);
|
|
||||||
text-decoration: none; }
|
text-decoration: none; }
|
||||||
.close:not(:disabled):not(.disabled):hover, .close:not(:disabled):not(.disabled):focus {
|
.close:not(:disabled):not(.disabled):hover, .close:not(:disabled):not(.disabled):focus {
|
||||||
opacity: .75; }
|
opacity: .75; }
|
||||||
|
|||||||
Reference in New Issue
Block a user