mirror of
https://github.com/btcpayserver/btcpayserver.git
synced 2025-02-23 06:35:13 +01:00
Moves the `ViewsRazor` extension into Abstractions, so that it can be used by plugins. Separated out of #2701, prerequisite for the LNbank plugin integration.
85 lines
3.8 KiB
Text
85 lines
3.8 KiB
Text
@using BTCPayServer.Views.Stores
|
|
@using BTCPayServer.Abstractions.Extensions
|
|
@model BTCPayServer.Plugins.Shopify.Models.ShopifySettings
|
|
@{
|
|
Layout = "../Shared/_NavLayout.cshtml";
|
|
|
|
ViewData["NavPartialName"] = "../Stores/_Nav";
|
|
ViewData.SetActivePageAndTitle(StoreNavPages.Integrations, "Integrations");
|
|
|
|
var shopifyCredsSet = Model?.IntegratedAt.HasValue is true;
|
|
var shopifyUrl = Model?.ShopifyUrl;
|
|
}
|
|
<form method="post" id="shopifyForm">
|
|
<h4 class="mb-3">
|
|
Shopify
|
|
<small>
|
|
<a href="https://docs.btcpayserver.org/Shopify" target="_blank" rel="noreferrer noopener">
|
|
<span class="fa fa-question-circle-o text-secondary" title="More information..."></span>
|
|
</a>
|
|
</small>
|
|
</h4>
|
|
@if (!shopifyCredsSet)
|
|
{
|
|
<p class="alert alert-info">Create a Shopify Private App with the permissions "Orders - Read and write"</p>
|
|
|
|
<div class="form-group">
|
|
<label class="form-label" for="exampleUrl">Example Url from Shopify Private App</label>
|
|
<input class="form-control" id="exampleUrl" name="exampleUrl">
|
|
</div>
|
|
|
|
<button name="command" type="submit" class="btn btn-primary" value="ShopifySaveCredentials">Connect to Shopify</button>
|
|
}
|
|
else
|
|
{
|
|
<div class="form-group">
|
|
<label asp-for="ShopName" class="form-label"></label>
|
|
<div class="input-group">
|
|
@if (!Model?.ShopName?.Contains(".") is true)
|
|
{
|
|
<span class="input-group-text">https://</span>
|
|
}
|
|
<input asp-for="ShopName" class="form-control" readonly="@shopifyCredsSet" />
|
|
|
|
@if (!Model?.ShopName?.Contains(".") is true)
|
|
{
|
|
<span class="input-group-text">.myshopify.com</span>
|
|
}
|
|
</div>
|
|
<span asp-validation-for="ShopName" class="text-danger"></span>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label asp-for="ApiKey" class="form-label"></label>
|
|
<input asp-for="ApiKey" class="form-control" readonly="@shopifyCredsSet" />
|
|
<span asp-validation-for="ApiKey" class="text-danger"></span>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label asp-for="Password" class="form-label"></label>
|
|
<input asp-for="Password" class="form-control" type="password" value="@Model?.Password" readonly="@shopifyCredsSet" />
|
|
<span asp-validation-for="Password" class="text-danger"></span>
|
|
</div>
|
|
<div class="alert alert-warning">
|
|
<p>
|
|
In Shopify please paste following script at <a href="@shopifyUrl/admin/settings/checkout#PolarisTextField1" target="_blank" class="fw-bold" rel="noreferrer noopener"> Settings > Checkout > Order Processing > Additional Scripts</a>
|
|
</p>
|
|
<kbd style="display: block; word-break: break-all;">
|
|
@($"<script src='{Url.Action("ShopifyJavascript", "Shopify", new {storeId = Context.GetRouteValue("storeId")}, Context.Request.Scheme)}'></script>")
|
|
</kbd>
|
|
</div>
|
|
<p class="alert alert-warning">
|
|
In Shopify please add a payment method at <a target="_blank" href="@shopifyUrl/admin/settings/payments" class="fw-bold" rel="noreferrer noopener"> Settings > Payments > Manual Payment Methods</a> with the name <kbd>Bitcoin with BTCPay Server</kbd>
|
|
</p>
|
|
|
|
<p class="alert alert-success">
|
|
Orders on <b>@Model.ShopName</b>.myshopify.com will be marked as paid on successful invoice payment.
|
|
Started: @Model.IntegratedAt.Value.ToBrowserDate()
|
|
</p>
|
|
|
|
<button name="command" type="submit" class="btn btn-danger" value="ShopifyClearCredentials">
|
|
Stop Shopify calls and clear credentials
|
|
</button>
|
|
}
|
|
|
|
</form>
|