2023-09-14 01:35:27 +02:00
|
|
|
<script>
|
|
|
|
import Euro from '../util/Euro.svelte';
|
2023-09-14 14:29:05 +02:00
|
|
|
import LoadingIndicator from '../util/LoadingIndicator.svelte';
|
2023-09-14 01:35:27 +02:00
|
|
|
|
2023-09-14 14:29:05 +02:00
|
|
|
let loading = false
|
|
|
|
let amount = 20
|
2023-09-14 01:35:27 +02:00
|
|
|
let country = null
|
|
|
|
|
2023-09-14 14:29:05 +02:00
|
|
|
$: credit_micro = amount*1e6
|
|
|
|
$: vat_micro = country === null ? 0 : (amount*1e6)*(country.vat/100)
|
|
|
|
|
2023-09-14 01:35:27 +02:00
|
|
|
let countries = [
|
2023-11-29 12:33:04 +01:00
|
|
|
{name: "Austria", flag: "🇦🇹", vat: 20},
|
|
|
|
{name: "Belgium", flag: "🇧🇪", vat: 21},
|
|
|
|
{name: "Bulgaria", flag: "🇧🇬", vat: 20},
|
|
|
|
{name: "Croatia", flag: "🇭🇷", vat: 25},
|
|
|
|
{name: "Cyprus", flag: "🇨🇾", vat: 19},
|
|
|
|
{name: "Czechia", flag: "🇨🇿", vat: 21},
|
|
|
|
{name: "Denmark", flag: "🇩🇰", vat: 25},
|
|
|
|
{name: "Estonia", flag: "🇪🇪", vat: 20},
|
|
|
|
{name: "Finland", flag: "🇫🇮", vat: 24},
|
|
|
|
{name: "France", flag: "🇫🇷", vat: 20},
|
|
|
|
{name: "Germany", flag: "🇩🇪", vat: 19},
|
|
|
|
{name: "Greece", flag: "🇬🇷", vat: 24},
|
|
|
|
{name: "Hungary", flag: "🇭🇺", vat: 27},
|
|
|
|
{name: "Ireland", flag: "🇮🇪", vat: 23},
|
|
|
|
{name: "Italy", flag: "🇮🇹", vat: 22},
|
|
|
|
{name: "Latvia", flag: "🇱🇻", vat: 21},
|
|
|
|
{name: "Lithuania", flag: "🇱🇹", vat: 21},
|
|
|
|
{name: "Luxembourg", flag: "🇱🇺", vat: 16},
|
|
|
|
{name: "Malta", flag: "🇲🇹", vat: 18},
|
|
|
|
{name: "Netherlands", flag: "🇳🇱", vat: 21},
|
|
|
|
{name: "Poland", flag: "🇵🇱", vat: 23},
|
|
|
|
{name: "Portugal", flag: "🇵🇹", vat: 23},
|
|
|
|
{name: "Romania", flag: "🇷🇴", vat: 19},
|
|
|
|
{name: "Slovakia", flag: "🇸🇰", vat: 20},
|
|
|
|
{name: "Slovenia", flag: "🇸🇮", vat: 22},
|
|
|
|
{name: "Spain", flag: "🇪🇸", vat: 21},
|
|
|
|
{name: "Sweden", flag: "🇸🇪", vat: 25},
|
|
|
|
{name: "Other", flag: "🌐", vat: 0},
|
2023-09-14 01:35:27 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
let amounts = [10, 20, 50, 100, 200, 500, 1000, 2000, 5000]
|
|
|
|
|
2023-09-14 14:29:05 +02:00
|
|
|
const checkout = async () => {
|
|
|
|
loading = true
|
|
|
|
|
|
|
|
if (amount < 10) {
|
|
|
|
alert("Amount needs to be at least €10")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
const form = new FormData()
|
|
|
|
form.set("amount", amount*1e6)
|
|
|
|
form.set("network", "mollie")
|
|
|
|
form.set("country", country.name)
|
|
|
|
|
|
|
|
try {
|
|
|
|
const resp = await fetch(
|
|
|
|
window.api_endpoint+"/user/invoice",
|
|
|
|
{method: "POST", body: form},
|
|
|
|
)
|
|
|
|
if(resp.status >= 400) {
|
|
|
|
let json = await resp.json()
|
|
|
|
throw json.message
|
|
|
|
}
|
|
|
|
|
|
|
|
window.location = (await resp.json()).checkout_url
|
|
|
|
} catch (err) {
|
|
|
|
alert(err)
|
|
|
|
} finally {
|
|
|
|
loading = false
|
|
|
|
}
|
2023-09-14 01:35:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<div class="highlight_border">
|
2023-09-14 14:29:05 +02:00
|
|
|
<LoadingIndicator loading={loading}/>
|
|
|
|
|
2023-09-14 01:35:27 +02:00
|
|
|
{#if country === null}
|
|
|
|
|
2023-11-27 16:31:49 +01:00
|
|
|
<div>
|
|
|
|
Please pick your country of residence
|
|
|
|
</div>
|
2023-09-14 01:35:27 +02:00
|
|
|
<div class="countries">
|
|
|
|
{#each countries as c}
|
|
|
|
<button on:click={() => country = c}>
|
2024-01-08 12:01:10 +01:00
|
|
|
<span style="font-size: 1.6em; line-height: 1em;">{c.flag}</span>
|
2023-09-14 01:35:27 +02:00
|
|
|
<span>{c.name}</span>
|
|
|
|
</button>
|
|
|
|
{/each}
|
|
|
|
</div>
|
2023-09-14 14:29:05 +02:00
|
|
|
<div>
|
2023-11-27 16:31:49 +01:00
|
|
|
We support the following payment processors
|
|
|
|
</div>
|
|
|
|
<div class="processors">
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/paypal.svg" alt="PayPal" title="PayPal"/>
|
|
|
|
PayPal
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/ideal.svg" alt="iDEAL" title="iDEAL"/>
|
|
|
|
iDEAL
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/klarna.svg" alt="Klarna" title="Klarna"/>
|
|
|
|
Klarna
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/bancontact.svg" alt="Bancontact" title="Bancontact"/>
|
|
|
|
Bancontact
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/banktransfer.svg" alt="SEPA" title="SEPA"/>
|
|
|
|
SEPA
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/sofort.svg" alt="SOFORT" title="SOFORT"/>
|
|
|
|
SOFORT
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/kbc.svg" alt="KBC/CBC" title="CBC"/>
|
|
|
|
KBC/CBC
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/belfius.svg" alt="Belfius" title="Belfius"/>
|
|
|
|
Belfius
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/giropay.svg" alt="Giropay" title="Giropay"/>
|
|
|
|
Giropay
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/eps.svg" alt="EPS" title="EPS"/>
|
|
|
|
EPS
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<img class="bankicon" src="/res/img/payment_providers/przelewy24.svg" alt="Przelewy24" title="Przelewy24"/>
|
|
|
|
Przelewy24
|
|
|
|
</div>
|
2023-09-14 14:29:05 +02:00
|
|
|
</div>
|
2023-09-14 01:35:27 +02:00
|
|
|
|
|
|
|
{:else}
|
|
|
|
|
|
|
|
<div style="display: flex;">
|
|
|
|
<button on:click={() => country = null} style="flex: 0 0 auto;">
|
|
|
|
<i class="icon">chevron_left</i>
|
|
|
|
Back
|
|
|
|
</button>
|
|
|
|
<div style="flex: 1 1 auto;"></div>
|
|
|
|
<div style="flex: 0 0 auto; display: flex; gap: 0.25em; align-items: center;">
|
|
|
|
<span>Paying from</span>
|
2023-11-29 12:33:04 +01:00
|
|
|
<span style="font-size: 1.5em; line-height: 1em;">{country.flag}</span>
|
2023-09-14 01:35:27 +02:00
|
|
|
<span>{country.name} ({country.vat}% VAT)</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<form class="amount_grid" on:submit|preventDefault={checkout}>
|
|
|
|
<div class="span3">Please choose an amount</div>
|
|
|
|
{#each amounts as a}
|
2023-11-27 16:31:49 +01:00
|
|
|
<button
|
|
|
|
on:click|preventDefault={() => amount = a}
|
|
|
|
class="amount_button"
|
|
|
|
class:button_highlight={amount === a}
|
|
|
|
>
|
|
|
|
€ {a}
|
2023-09-14 01:35:27 +02:00
|
|
|
</button>
|
|
|
|
{/each}
|
|
|
|
|
|
|
|
<div class="span3 mollie_checkout">
|
|
|
|
<div>Custom amount €</div>
|
2023-09-14 14:29:05 +02:00
|
|
|
<input type="number" bind:value={amount} min="10"/>
|
2023-09-14 01:35:27 +02:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="span2" style="text-align: initial;">
|
|
|
|
Total including VAT:
|
|
|
|
<Euro amount={credit_micro + vat_micro}/>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<button type="submit" class="button_highlight">
|
|
|
|
<i class="icon">paid</i> Checkout
|
|
|
|
</button>
|
|
|
|
</form>
|
|
|
|
{/if}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
.countries {
|
|
|
|
display: grid;
|
2023-11-27 16:31:49 +01:00
|
|
|
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
|
2023-09-14 01:35:27 +02:00
|
|
|
}
|
|
|
|
.countries > button {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
text-align: left;
|
2023-11-27 16:31:49 +01:00
|
|
|
gap: 5px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.processors {
|
|
|
|
display: grid;
|
|
|
|
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
|
2023-09-14 01:35:27 +02:00
|
|
|
}
|
2023-11-27 16:31:49 +01:00
|
|
|
.processors > div {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
gap: 5px;
|
|
|
|
margin: 3px;
|
2023-09-14 01:35:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
.amount_grid {
|
|
|
|
max-width: 500px;
|
|
|
|
gap: 4px;
|
|
|
|
display: inline-grid;
|
|
|
|
align-items: center;
|
|
|
|
grid-template-columns: 1fr 1fr 1fr;
|
|
|
|
}
|
2023-11-27 16:31:49 +01:00
|
|
|
.amount_button {
|
|
|
|
font-size: 1.1em;
|
|
|
|
line-height: 1.6em;
|
|
|
|
justify-content: center;
|
|
|
|
}
|
2023-09-14 01:35:27 +02:00
|
|
|
|
|
|
|
.span2 {
|
|
|
|
grid-column: span 2;
|
|
|
|
}
|
|
|
|
.span3 {
|
|
|
|
grid-column: span 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
.mollie_checkout {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
}
|
|
|
|
.mollie_checkout > div {
|
|
|
|
display: flex;
|
|
|
|
flex: 0 0 auto;
|
|
|
|
align-items: center;
|
|
|
|
}
|
|
|
|
.mollie_checkout > input[type="number"] {
|
|
|
|
flex: 1 1 auto;
|
|
|
|
}
|
2023-09-14 14:29:05 +02:00
|
|
|
|
|
|
|
.bankicon {
|
|
|
|
width: 40px;
|
|
|
|
height: 30px;
|
|
|
|
}
|
2023-09-14 01:35:27 +02:00
|
|
|
</style>
|