btcpayserver/BTCPayServer/Views/Wallets/WalletSend.cshtml

228 lines
13 KiB
Plaintext
Raw Normal View History

2020-03-26 11:59:28 +01:00
@addTagHelper *, BundlerMinifier.TagHelpers
@using Microsoft.AspNetCore.Mvc.ModelBinding
2020-05-07 22:34:39 +02:00
@using BTCPayServer.Views
@model WalletSendModel
2018-02-12 19:27:36 +01:00
@{
Layout = "../Shared/_NavLayout.cshtml";
ViewData["Title"] = "Manage wallet";
2018-07-26 15:32:24 +02:00
ViewData.SetActivePageAndTitle(WalletsNavPages.Send);
2018-02-12 19:27:36 +01:00
}
@if (TempData.HasStatusMessage())
{
<div class="row">
<div class="col-md-10 text-center">
<partial name="_StatusMessage" />
</div>
</div>
}
2020-03-26 11:59:28 +01:00
<partial name="WalletCameraScanner"/>
2019-11-01 22:15:02 +01:00
<div class="row">
2020-03-26 11:59:28 +01:00
<div class="@(!Model.InputSelection && Model.Outputs.Count==1? "col-lg-6 transaction-output-form": "col-lg-8")">
<form method="post">
<input type="hidden" asp-for="InputSelection" />
<input type="hidden" asp-for="Divisibility" />
2020-01-21 09:33:12 +01:00
<input type="hidden" asp-for="NBXSeedAvailable" />
<input type="hidden" asp-for="Fiat" />
<input type="hidden" asp-for="Rate" />
<input type="hidden" asp-for="CurrentBalance" />
<input type="hidden" asp-for="CryptoCode" />
<input type="hidden" name="BIP21" id="BIP21" />
<ul class="text-danger">
@foreach (var errors in ViewData.ModelState.Where(pair => pair.Key == string.Empty && pair.Value.ValidationState == ModelValidationState.Invalid))
{
foreach (var error in
errors.Value.Errors)
{
<li>@error.ErrorMessage</li>
}
}
</ul>
@if (Model.InputSelection)
{
2020-03-19 10:08:33 +01:00
<div class="form-group hide-when-js">
<label asp-for="SelectedInputs"></label>
2020-04-08 13:15:03 +02:00
<select multiple="multiple" asp-for="SelectedInputs" class="form-control">
2020-03-19 10:08:33 +01:00
@foreach (var input in Model.InputsAvailable)
{
2020-04-08 13:15:03 +02:00
<option value="@input.Outpoint" class="text-truncate" asp-selected="@(Model.SelectedInputs?.Contains(input.Outpoint)??false)">(@input.Amount) @input.Outpoint</option>
2020-03-19 10:08:33 +01:00
}
</select>
</div>
<partial name="CoinSelection" />
<br>
}
@if (Model.Outputs.Count == 1)
{
<div class="form-group">
<label asp-for="Outputs[0].DestinationAddress"></label>
<input asp-for="Outputs[0].DestinationAddress" class="form-control" />
<span asp-validation-for="Outputs[0].DestinationAddress" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Outputs[0].Amount"></label>
<div class="input-group">
<input asp-for="Outputs[0].Amount" type="number" step="any" asp-format="{0}" class="form-control output-amount" />
<div class="input-group-prepend">
2019-11-08 22:31:21 +01:00
<span class="input-group-text fiat-value" style="display:none;"></span>
</div>
</div>
<span asp-validation-for="Outputs[0].Amount" class="text-danger"></span>
<p class="form-text text-muted crypto-info">
Your current balance is
<button type="button" class="crypto-balance-link btn btn-link p-0 align-baseline">@Model.CurrentBalance</button> <span>@Model.CryptoCode</span>.
</p>
</div>
}
else
{
<div class="list-group-item ">
<h5 class="mb-1">Destinations</h5>
</div>
<div class="list-group mb-2">
@for (var index = 0; index < Model.Outputs.Count; index++)
{
<div class="list-group-item transaction-output-form p-0 pl-lg-2">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-10 py-2 ">
2019-05-21 12:04:39 +02:00
<div class="form-group">
<label asp-for="Outputs[index].DestinationAddress" class="control-label"></label>
<input asp-for="Outputs[index].DestinationAddress" class="form-control" />
<span asp-validation-for="Outputs[index].DestinationAddress" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Outputs[index].Amount" class="control-label"></label>
<div class="input-group">
<input asp-for="Outputs[index].Amount" type="number" step="any" asp-format="{0}" class="form-control output-amount" />
<div class="input-group-prepend">
2019-11-08 22:31:21 +01:00
<span class="input-group-text fiat-value" style="display:none;"></span>
</div>
</div>
<p class="form-text text-muted crypto-info">
Your current balance is
<button type="button" class="crypto-balance-link btn btn-link p-0 align-baseline">@Model.CurrentBalance</button> <span>@Model.CryptoCode</span>.
</p>
<span asp-validation-for="Outputs[index].Amount" class="text-danger"></span>
</div>
<div class="form-group">
<div class="form-check">
<input type="checkbox" asp-for="Outputs[index].SubtractFeesFromOutput" class="form-check-input subtract-fees" />
<label asp-for="Outputs[index].SubtractFeesFromOutput" class="form-check-label"></label>
<span asp-validation-for="Outputs[index].SubtractFeesFromOutput" class="text-danger"></span>
</div>
</div>
</div>
<div class="col-sm-12 col-md-12 col-lg-2 pull-right">
<button type="submit" title="Remove Destination" name="command" value="@($"remove-output:{index}")"
class="d-block d-lg-none d-xl-none btn btn-danger mb-2 ml-2">
Remove Destination
</button>
<button type="submit" title="Remove Destination" name="command" value="@($"remove-output:{index}")"
class="d-none d-lg-block remove-destination-btn text-decoration-none h-100 align-middle btn text-danger btn-link fa fa-times rounded-0 pull-right"></button>
</div>
</div>
</div>
}
</div>
}
2018-03-23 08:24:57 +01:00
<div class="form-group">
<label asp-for="FeeSatoshiPerByte"></label>
<input asp-for="FeeSatoshiPerByte" type="number" step="any" class="form-control" />
<span asp-validation-for="FeeSatoshiPerByte" class="text-danger"></span>
2018-03-23 08:24:57 +01:00
<span id="FeeRate-Error" class="text-danger"></span>
2020-05-07 22:34:39 +02:00
@if (Model.RecommendedSatoshiPerByte.Any())
{
<div class="text-left mt-1" >
<span class="text-muted">
Confirm in the next
</span>
<div class="btn-group btn-group-toggle feerate-options" data-toggle="buttons">
@for (var index = 0; index < Model.RecommendedSatoshiPerByte.Count; index++)
{
var feeRateOption = Model.RecommendedSatoshiPerByte[index];
<button type="button" class="btn btn-sm btn-outline-primary crypto-fee-link" value="@feeRateOption.FeeRate" data-toggle="tooltip" title="@feeRateOption.FeeRate sat/b">
@feeRateOption.Target.TimeString()
</button>
<input type="hidden" asp-for="RecommendedSatoshiPerByte[index].Target" />
<input type="hidden" asp-for="RecommendedSatoshiPerByte[index].FeeRate" />
2020-05-07 22:34:39 +02:00
}
</div>
</div>
}
2018-03-23 08:24:57 +01:00
</div>
@if (Model.Outputs.Count == 1)
{
<div class="form-group">
<div class="form-check">
<input type="checkbox" asp-for="Outputs[0].SubtractFeesFromOutput" class="form-check-input subtract-fees" />
<label asp-for="Outputs[0].SubtractFeesFromOutput" class="form-check-label"></label>
<span asp-validation-for="Outputs[0].SubtractFeesFromOutput" class="text-danger"></span>
</div>
</div>
}
<div class="card">
<button id="advancedSettings" class="btn btn-light collapsed" type="button" data-toggle="collapse" data-target="#accordian-advanced" aria-expanded="false" aria-controls="accordian-advanced">
2019-11-08 22:31:21 +01:00
Advanced settings
</button>
<div id="accordian-advanced" class="collapse" aria-labelledby="accordian-advanced-header" data-parent="#accordian-advanced">
<div class="card-body">
<div class="form-check">
<input asp-for="NoChange" class="form-check-input" />
<label asp-for="NoChange" class="form-check-label"></label>
<a href="https://docs.btcpayserver.org/features/wallet#make-sure-no-change-utxo-is-created-expert-mode" target="_blank">
<span class="fa fa-question-circle-o" title="More information..."></span>
</a>
</div>
@if (Model.SupportRBF)
{
<div class="form-check">
<input asp-for="DisableRBF" class="form-check-input" />
<label asp-for="DisableRBF" class="form-check-label"></label>
<a href="https://bitcoin.org/en/glossary/rbf" target="_blank">
<span class="fa fa-question-circle-o" title="More information..."></span>
</a>
</div>
}
2020-01-06 13:57:32 +01:00
@if (!string.IsNullOrEmpty(Model.PayJoinEndpointUrl))
{
<div class="form-group">
<label asp-for="PayJoinEndpointUrl" class="control-label"></label>
<input asp-for="PayJoinEndpointUrl" class="form-control" />
2020-01-06 13:57:32 +01:00
<span asp-validation-for="PayJoinEndpointUrl" class="text-danger"></span>
</div>
}
<div class="form-group">
<button id="toggleInputSelection" type="submit" name="command" value="toggle-input-selection" class="btn btn-sm btn-secondary">Toggle coin selection</button>
</div>
</div>
</div>
</div>
<div class="form-group d-flex mt-2">
<partial name="WalletSigningMenu" model="@((Model.CryptoCode, Model.NBXSeedAvailable))"/>
<button type="submit" name="command" value="add-output" class="ml-1 btn btn-secondary">Add another destination</button>
2020-03-27 10:18:20 +01:00
<button type="button" id="bip21parse" class="ml-1 btn btn-secondary" title="Paste BIP21/Address"><i class="fa fa-paste"></i></button>
2020-03-26 11:59:28 +01:00
<button type="button" id="scanqrcode" class="ml-1 btn btn-secondary only-for-js" data-toggle="modal" data-target="#scanModal" title="Scan BIP21/Address with camera"><i class="fa fa-camera"></i></button>
</div>
2018-03-23 08:24:57 +01:00
</form>
</div>
2018-02-12 19:27:36 +01:00
</div>
2020-03-26 11:59:28 +01:00
@section HeadScripts
{
<bundle name="wwwroot/bundles/wallet-send-bundle.min.js" asp-append-version="true"></bundle>
<style>
.remove-destination-btn{
font-size: 1.5rem;
border-radius: 0;
}
.remove-destination-btn:hover{
background-color: #CCCCCC;
}
</style>
2018-07-26 16:23:28 +02:00
}