2019-06-25 21:01:37 +02:00
@model PayButtonViewModel
2018-08-10 20:26:51 +02:00
@{
2018-08-22 14:05:12 +02:00
Layout = "../Shared/_NavLayout.cshtml";
2018-09-04 06:48:53 +02:00
ViewData.SetActivePageAndTitle(StoreNavPages.PayButton);
2019-11-15 14:44:08 +01:00
ViewData["Title"] = "Pay Button";
2018-08-10 20:26:51 +02:00
}
2018-08-22 14:05:12 +02:00
<div class="container" id="payButtonCtrl">
<div class="row">
<div class="col-lg-7">
<div class="form-row">
<div class="form-group col-md-8">
<label>Price</label>
<input name="price" type="text" class="form-control"
v-model="srvModel.price" v-on:change="inputChanges"
v-validate="'required|decimal|min_value:0'" :class="{'is-invalid': errors.has('price') }">
<small class="text-danger">{{ errors.first('price') }}</small>
2018-08-10 20:26:51 +02:00
</div>
2018-08-22 14:05:12 +02:00
<div class="form-group col-md-4">
<label> </label>
2019-04-04 21:32:16 +02:00
<input name="currency" type="text" class="form-control"
2018-08-23 04:17:54 +02:00
v-model="srvModel.currency" v-on:change="inputChanges"
:class="{'is-invalid': errors.has('currency') }">
2018-08-10 20:26:51 +02:00
</div>
</div>
2018-08-22 14:05:12 +02:00
<div class="form-group">
<label>Checkout Description</label>
<input name="checkoutDesc" type="text" class="form-control" placeholder="(optional)"
v-model="srvModel.checkoutDesc" v-on:change="inputChanges">
2018-08-10 20:26:51 +02:00
</div>
2018-08-22 14:05:12 +02:00
<div class="form-group">
<label>Order Id</label>
<input name="orderId" type="text" class="form-control" id="inputAddress" placeholder="(optional)"
v-model="srvModel.orderId" v-on:change="inputChanges">
</div>
2019-11-03 18:53:09 +01:00
</div>
<div class="col-lg-5">
<br />
Define parameters that define the purchase: price, currency and then optional description of purchase.
<br /><br />
Generated HTML will be displayed at the bottom of this page and all you need is to paste that HTML into your final page.
Clicking on the button will redirect customer to checkout.
</div>
</div>
<hr />
<h3>Pay button display options</h3>
<br />
<div class="row">
<div class="col-lg-7">
2018-08-22 14:05:12 +02:00
<div class="form-group">
<label>Pay Button Image Url</label>
<input name="payButtonImageUrl" type="text" class="form-control" id="inputAddress"
v-model="srvModel.payButtonImageUrl" v-on:change="inputChanges"
v-validate="'required|url'" :class="{'is-invalid': errors.has('payButtonImageUrl') }">
<small class="text-danger">{{ errors.first('payButtonImageUrl') }}</small>
2018-08-11 13:34:52 +02:00
</div>
2018-08-22 14:05:12 +02:00
<div class="form-group">
<label>Button Size</label>
<div style="vertical-align:top; font-size:12px; display:flex;">
2019-11-15 11:08:10 +01:00
<button class="btn text-nowrap" style="width:146px;height:40px;margin-right:40px;"
2018-08-22 14:05:12 +02:00
v-on:click="inputChanges($event, 0)" v-bind:class="{'btn-primary': (srvModel.buttonSize == 0) }">
146 x 40 px
</button>
2019-11-15 11:08:10 +01:00
<button class="btn text-nowrap btn-default" style="width:168px;height:46px;margin-right:40px;"
2018-08-22 14:05:12 +02:00
v-on:click="inputChanges($event, 1)" v-bind:class="{'btn-primary': (srvModel.buttonSize == 1) }">
168 x 46 px
</button>
2019-11-15 11:08:10 +01:00
<button class="btn text-nowrap btn-default" style="width:209px;height:57px;"
2018-08-22 14:05:12 +02:00
v-on:click="inputChanges($event, 2)" v-bind:class="{'btn-primary': (srvModel.buttonSize == 2) }">
209 x 57 px
</button>
</div>
2018-08-11 13:34:52 +02:00
</div>
2019-04-03 21:43:53 +02:00
<div class="form-group">
<label>Button Type</label>
<div>
<input type="radio" name="button-type" id="btn-fixed" value="0" v-model="srvModel.buttonType" v-on:change="inputChanges" checked />
<label for="btn-fixed">Fixed amount</label>
</div>
<div>
<input type="radio" name="button-type" id="btn-custom" value="1" v-model="srvModel.buttonType" v-on:change="inputChanges" />
<label for="btn-custom">Custom amount</label>
</div>
2019-04-04 20:56:12 +02:00
<div>
<input type="radio" name="button-type" id="btn-slider" value="2" v-model="srvModel.buttonType" v-on:change="inputChanges" />
<label for="btn-slider">Slider</label>
</div>
2019-04-03 21:43:53 +02:00
</div>
2019-07-31 15:58:04 +02:00
<div class="form-row" v-if="srvModel.buttonType == 1 ||srvModel.buttonType == 2">
2019-04-06 13:47:22 +02:00
<div class="form-group col-md-4">
<label>Min</label>
<input name="min" type="text" class="form-control"
v-model="srvModel.min" v-on:change="inputChanges"
v-validate="'required|decimal|min_value:1'" :class="{'is-invalid': errors.has('min') }">
<small class="text-danger">{{ errors.first('min') }}</small>
</div>
<div class="form-group col-md-4">
<label>Max</label>
<input name="max" type="text" class="form-control"
v-model="srvModel.max" v-on:change="inputChanges"
v-validate="'required|decimal|min_value:1'" :class="{'is-invalid': errors.has('max') }">
<small class="text-danger">{{ errors.first('max') }}</small>
</div>
<div class="form-group col-md-4">
<label>Step</label>
<input name="step" type="text" class="form-control"
v-model="srvModel.step" v-on:change="inputChanges"
v-validate="'required|decimal|min_value:1'" :class="{'is-invalid': errors.has('step') }">
<small class="text-danger">{{ errors.first('step') }}</small>
</div>
</div>
2019-11-03 18:53:09 +01:00
<div class="form-group" v-if="srvModel.buttonType == 1">
<div class="form-check">
<input name="simpleInput"
id="simpleInput"
type="checkbox"
class="form-check-input"
v-model="srvModel.simpleInput"
v-on:change="inputChanges"
2019-07-31 15:58:04 +02:00
:class="{'is-invalid': errors.has('simpleInput') }">
2019-11-03 18:53:09 +01:00
<label class="form-check-label" for="simpleInput">Use a simple input style</label>
2019-07-31 15:58:04 +02:00
<small class="text-danger">{{ errors.first('simpleInput') }}</small>
</div>
2019-11-03 18:53:09 +01:00
<div class="form-check">
<input name="fitButtonInline"
id="fitButtonInline"
type="checkbox"
class="form-check-input"
v-model="srvModel.fitButtonInline"
v-on:change="inputChanges"
:class="{'is-invalid': errors.has('fitButtonInline') }">
<label class="form-check-label" for="fitButtonInline">Fit button inline</label>
2019-10-29 20:59:28 +01:00
<small class="text-danger">{{ errors.first('fitButtonInline') }}</small>
2019-07-31 15:58:04 +02:00
</div>
</div>
2018-08-11 13:34:52 +02:00
</div>
2018-08-22 14:05:12 +02:00
<div class="col-lg-5">
2019-11-03 18:53:09 +01:00
<h4>Preview</h4>
<div id="preview"></div>
2018-08-22 14:05:12 +02:00
</div>
</div>
<hr />
<h3>Payment Notifications</h3>
<br />
<div class="row">
<div class="col-lg-7">
<div class="form-group">
<label>Server IPN</label>
<input name="serverIpn" type="text" class="form-control" placeholder="(optional)"
v-model="srvModel.serverIpn" v-on:change="inputChanges"
2018-08-23 04:12:25 +02:00
v-validate="'url'" :class="{'is-invalid': errors.has('serverIpn') }">
2018-08-22 14:05:12 +02:00
<small class="text-danger">{{ errors.first('serverIpn') }}</small>
2018-08-11 13:34:52 +02:00
</div>
2018-08-22 14:05:12 +02:00
<div class="form-group">
<label>Send Email Notifications to</label>
<input name="notifyEmail" type="text" class="form-control" placeholder="(optional)"
v-model="srvModel.notifyEmail" v-on:change="inputChanges"
v-validate="'email'" :class="{'is-invalid': errors.has('notifyEmail') }">
<small class="text-danger">{{ errors.first('notifyEmail') }}</small>
2018-08-11 13:34:52 +02:00
</div>
2018-08-22 14:05:12 +02:00
<div class="form-group">
<label>Browser Redirect</label>
<input name="browserRedirect" type="text" class="form-control" placeholder="(optional)"
v-model="srvModel.browserRedirect" v-on:change="inputChanges"
v-validate="'url'" :class="{'is-invalid': errors.has('browserRedirect') }">
<small class="text-danger">{{ errors.first('browserRedirect') }}</small>
2018-08-16 21:55:24 +02:00
</div>
</div>
2018-08-22 14:05:12 +02:00
<div class="col-lg-5">
<br />
These parameters allow you to influence process after purchase. <i>Server IPN</i> is location we'll query with details.
2019-09-06 21:50:34 +02:00
We can also deliver email notification to specified address.
2018-08-22 14:05:12 +02:00
<br /><br />
2019-09-06 21:50:34 +02:00
Finally <i>Browser Redirect</i> defines where BTCPayServer will redirect customer after purchase is completed.
2018-08-22 14:05:12 +02:00
</div>
</div>
2019-06-25 21:01:37 +02:00
<h3>Advanced</h3>
<br />
<div class="row">
<div class="col-lg-7">
<div class="form-group">
<label>Checkout Additional Query String</label>
<input name="checkoutQueryString" type="text" class="form-control" placeholder="(optional)"
v-model="srvModel.checkoutQueryString" v-on:change="inputChanges"
:class="{'is-invalid': errors.has('checkoutQueryString') }">
<small class="text-danger">{{ errors.first('checkoutQueryString') }}</small>
</div>
</div>
<div class="col-lg-5">
<br />
2019-07-31 15:58:04 +02:00
This parameter allows you to specify additional query string paramters that should be appended to the checkout page once the invoice is created. For example, <kbd>lang=da-DK</kbd> would load the checkout page in Danish by default.
2019-10-29 20:59:28 +01:00
2019-06-25 21:01:37 +02:00
</div>
</div>
2018-08-22 14:05:12 +02:00
<hr />
2019-10-29 20:59:28 +01:00
<br />
2018-08-22 14:05:12 +02:00
<h3>Generated code</h3>
<div class="row" v-show="!errors.any()">
2019-10-29 20:59:28 +01:00
<div class="col-lg-12">
2018-08-22 14:05:12 +02:00
<pre><code id="mainCode" class="html"></code></pre>
<button class="btn btn-primary" id="copyCode">
<i class="fa fa-copy"></i> Copy Code
</button>
<span class="copyLabelPopup" style="display:none;">Copied</span>
</div>
</div>
<div class="row" v-show="errors.any()">
<div class="col-lg-12 text-danger">
Please fix errors shown in order for code generation to successfully execute.
</div>
2018-08-10 20:26:51 +02:00
</div>
2019-04-06 15:02:02 +02:00
</div>
2018-09-04 07:00:20 +02:00
2019-04-06 15:02:02 +02:00
@section HeadScripts {
<link rel="stylesheet" href="~/vendor/highlightjs/default.min.css">
<script src="~/vendor/highlightjs/highlight.min.js"></script>
2018-08-11 13:34:52 +02:00
2019-04-06 15:02:02 +02:00
<script src="~/vendor/vuejs/vue.js"></script>
<script src="~/vendor/vuejs-vee-validate/vee-validate.js"></script>
2018-08-14 14:57:46 +02:00
2019-04-06 15:02:02 +02:00
<script src="~/vendor/clipboard.js/clipboard.js"></script>
2018-08-15 23:58:39 +02:00
2019-04-06 15:02:02 +02:00
<script src="~/paybutton/paybutton.js"></script>
}
2018-08-22 11:10:46 +02:00
2019-04-06 15:02:02 +02:00
@section Scripts {
<script type="text/javascript">
2019-08-10 07:05:11 +02:00
var srvModel = @Safe.Json(Model);
2018-08-22 11:10:46 +02:00
2018-08-14 14:57:46 +02:00
var payButtonCtrl = new Vue({
el: '#payButtonCtrl',
data: {
srvModel: srvModel
},
methods: {
2018-08-14 18:59:59 +02:00
inputChanges: function (event, buttonSize) {
2018-08-14 23:47:28 +02:00
inputChanges(event, buttonSize);
}
2018-08-14 19:40:57 +02:00
}
2018-08-15 23:58:39 +02:00
});
2019-04-06 15:02:02 +02:00
</script>
}
2019-10-31 11:31:30 +01:00
<script id="template-paybutton-styles" type="text/template">
<style type="text/css">
.btcpay-form {
display: inline-flex;
align-items: center;
justify-content: center;
}
.btcpay-form--inline {
flex-direction: row;
}
.btcpay-form--block {
flex-direction: column;
}
.btcpay-form--inline .submit {
margin-left: 15px;
}
.btcpay-form--block select {
margin-bottom: 10px;
}
.btcpay-form .btcpay-custom {
display: flex;
align-items: center;
justify-content: center;
}
.btcpay-form .plus-minus {
cursor:pointer;
font-size:25px;
line-height: 25px;
2019-11-15 11:08:10 +01:00
background: #DFE0E1;
2019-10-31 11:31:30 +01:00
height: 30px;
width: 45px;
border:none;
border-radius: 60px;
2019-11-15 11:08:10 +01:00
margin: auto 5px;
display: inline-flex;
justify-content: center;
2019-10-31 11:31:30 +01:00
}
.btcpay-form select {
-moz-appearance: none;
-webkit-appearance: none;
appearance: none;
2019-11-15 11:08:10 +01:00
color: currentColor;
2019-10-31 11:31:30 +01:00
background: transparent;
border:1px solid transparent;
display: block;
padding: 1px;
margin-left: auto;
margin-right: auto;
font-size: 11px;
cursor: pointer;
}
.btcpay-form select:hover {
border-color: #ccc;
}
#btcpay-input-price {
-moz-appearance: none;
-webkit-appearance: none;
border: none;
box-shadow: none;
text-align: center;
font-size: 25px;
margin: auto;
border-radius: 5px;
line-height: 35px;
background: #fff;
}
</style>
</script>
<script id="template-slider-styles" type="text/template">
<style type="text/css">
input[type=range].btcpay-input-range {
-webkit-appearance:none;
width:100%;
2019-11-15 11:08:10 +01:00
background: transparent;
2019-10-31 11:31:30 +01:00
}
input[type=range].btcpay-input-range:focus {
outline:0;
}
input[type=range].btcpay-input-range::-webkit-slider-runnable-track {
width:100%;
height:3.1px;
cursor:pointer;
box-shadow:0 0 1.7px #020,0 0 0 #003c00;
background:#f3f3f3;
border-radius:1px;
2019-11-15 11:08:10 +01:00
border:0;
2019-10-31 11:31:30 +01:00
}
input[type=range].btcpay-input-range::-webkit-slider-thumb {
2019-11-15 11:08:10 +01:00
box-shadow:none;
2019-10-31 11:31:30 +01:00
border:2.5px solid #cedc21;
height:22px;
width:22px;
border-radius:50%;
background:#0f3723;
cursor:pointer;
-webkit-appearance:none;
margin-top:-9.45px
}
input[type=range].btcpay-input-range:focus::-webkit-slider-runnable-track {
background:#fff;
}
input[type=range].btcpay-input-range::-moz-range-track {
width:100%;
height:3.1px;
cursor:pointer;
box-shadow:0 0 1.7px #020,0 0 0 #003c00;
background:#f3f3f3;
border-radius:1px;
2019-11-15 11:08:10 +01:00
border:0;
2019-10-31 11:31:30 +01:00
}
input[type=range].btcpay-input-range::-moz-range-thumb {
2019-11-15 11:08:10 +01:00
box-shadow:none;
2019-10-31 11:31:30 +01:00
border:2.5px solid #cedc21;
height:22px;
width:22px;
border-radius:50%;
background:#0f3723;
cursor:pointer;
}
input[type=range].btcpay-input-range::-ms-track {
width:100%;
height:3.1px;
cursor:pointer;
background:0 0;
border-color:transparent;
color:transparent;
}
input[type=range].btcpay-input-range::-ms-fill-lower {
background:#e6e6e6;
2019-11-15 11:08:10 +01:00
border:0;
2019-10-31 11:31:30 +01:00
border-radius:2px;
box-shadow:0 0 1.7px #020,0 0 0 #003c00;
}
input[type=range].btcpay-input-range::-ms-fill-upper {
background:#f3f3f3;
2019-11-15 11:08:10 +01:00
border:0;
2019-10-31 11:31:30 +01:00
border-radius:2px;
box-shadow:0 0 1.7px #020,0 0 0 #003c00;
}
input[type=range].btcpay-input-range::-ms-thumb {
2019-11-15 11:08:10 +01:00
box-shadow:none;
2019-10-31 11:31:30 +01:00
border:2.5px solid #cedc21;
height:22px;
width:22px;
border-radius:50%;
background:#0f3723;
cursor:pointer;
height:3.1px;
}
input[type=range].btcpay-input-range:focus::-ms-fill-lower {
background:#f3f3f3;
}
input[type=range].btcpay-input-range:focus::-ms-fill-upper {
background:#fff;
}
</style>
2019-04-06 15:02:02 +02:00
</script>