2023-09-09 20:52:50 +00:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<title>delphi.market</title>
|
|
|
|
<link rel="icon" type="image/x-icon" href="/favicon.ico" />
|
|
|
|
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png" />
|
|
|
|
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png" />
|
|
|
|
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png" />
|
|
|
|
<link rel="manifest" href="/site.webmanifest" />
|
|
|
|
<link rel="stylesheet" href="/index.css" />
|
|
|
|
<link rel="stylesheet" href="/market.css" />
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
|
|
<meta name="theme-color" content="#091833" />
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<header class="flex flex-row text-center justify-center pt-1">
|
|
|
|
<nav>
|
|
|
|
<a href="/">home</a>
|
|
|
|
{{ if .session }}
|
|
|
|
<form action='/logout' method='post'>
|
|
|
|
<button type='submit'>logout</button>
|
|
|
|
</form>
|
|
|
|
{{ else }} <a href="/login">login</a> {{ end }}
|
|
|
|
</nav>
|
|
|
|
</header>
|
|
|
|
<div class="container flex flex-column text-center">
|
|
|
|
<code>
|
|
|
|
<strong>
|
|
|
|
<pre>
|
|
|
|
_ _
|
|
|
|
_ __ ___ __ _ _ __| | _____| |_
|
|
|
|
| '_ ` _ \ / _` | '__| |/ / _ \ __|
|
|
|
|
| | | | | | (_| | | | < __/ |_
|
|
|
|
|_| |_| |_|\__,_|_| |_|\_\___|\__|</pre>
|
|
|
|
</strong>
|
|
|
|
</code>
|
|
|
|
<div class="font-mono mb-1">{{.Description}}</div>
|
|
|
|
<div class="flex flex-row justify-center mb-1">
|
2023-09-09 20:52:50 +00:00
|
|
|
{{ range .Shares }} {{ if eq .Description "YES" }}
|
2023-09-09 20:52:50 +00:00
|
|
|
<button id="yes-order" class="order-button sx-1 yes">YES</button>
|
|
|
|
{{ else }}
|
|
|
|
<button id="no-order" class="order-button sx-1 no">NO</button>
|
|
|
|
{{ end }}
|
|
|
|
{{ end }}
|
|
|
|
</div>
|
2023-09-09 20:52:50 +00:00
|
|
|
{{ range .Shares }} {{ if eq .Description "YES" }}
|
2023-09-09 20:52:50 +00:00
|
|
|
<form id="yes-form" class="order-form" hidden action="/api/market/{{$.Id}}/order" method="post">
|
|
|
|
<button id="yes-buy" type="button" class="order-button yes w-100p selected">BUY</button>
|
|
|
|
<button id="yes-sell" type="button" class="order-button no w-100p">SELL</button>
|
2023-09-09 20:52:50 +00:00
|
|
|
<input hidden name="share_id" value="{{.Id}}" />
|
2023-09-09 20:52:50 +00:00
|
|
|
<input id="yes-side" hidden name="side" value="BUY" />
|
2023-09-09 20:52:50 +00:00
|
|
|
<label>shares</label>
|
|
|
|
<input id="yes-quantity" type="number" name="quantity" placeholder="quantity" />
|
|
|
|
<label id="yes-cost-label">cost [sats]</label>
|
|
|
|
<input id="yes-cost" type="number" name="cost" disabled />
|
|
|
|
<label id="yes-submit-label">BUY YES shares</label>
|
2023-09-09 20:52:50 +00:00
|
|
|
<button type="submit">SUBMIT</button>
|
|
|
|
</form>
|
|
|
|
{{ else }}
|
|
|
|
<form id="no-form" class="order-form" hidden action="/api/market/{{$.Id}}/order" method="post">
|
|
|
|
<button id="no-buy" type="button" class="order-button yes w-100p selected">BUY</button>
|
|
|
|
<button id="no-sell" type="button" class="order-button no w-100p">SELL</button>
|
2023-09-09 20:52:50 +00:00
|
|
|
<input hidden name="share_id" value="{{.Id}}" />
|
2023-09-09 20:52:50 +00:00
|
|
|
<input id="no-side" hidden name="side" value="BUY" />
|
2023-09-09 20:52:50 +00:00
|
|
|
<label>shares</label>
|
|
|
|
<input id="no-quantity" type="number" name="quantity" placeholder="quantity" />
|
|
|
|
<label id="no-cost-label">cost [sats]</label>
|
|
|
|
<input id="no-cost" type="number" name="cost" disabled />
|
|
|
|
<label id="no-submit-label">BUY NO shares</label>
|
2023-09-09 20:52:50 +00:00
|
|
|
<button type="submit">SUBMIT</button>
|
|
|
|
</form>
|
|
|
|
{{ end }}
|
|
|
|
{{ end }}
|
|
|
|
</div>
|
|
|
|
</body>
|
|
|
|
<script>
|
|
|
|
const yesOrderBtn = document.querySelector("#yes-order")
|
|
|
|
const yesForm = document.querySelector("#yes-form")
|
|
|
|
const yesBuyBtn = document.querySelector("#yes-buy")
|
|
|
|
const yesSellBtn = document.querySelector("#yes-sell")
|
|
|
|
const yesSideInput = document.querySelector("#yes-side")
|
|
|
|
const yesQuantityInput = document.querySelector("#yes-quantity")
|
2023-09-09 20:52:50 +00:00
|
|
|
const yesCostDisplay = document.querySelector("#yes-cost")
|
|
|
|
const yesCostLabel = document.querySelector("#yes-cost-label")
|
2023-09-09 20:52:50 +00:00
|
|
|
const yesSubmitLabel = document.querySelector("#yes-submit-label")
|
|
|
|
|
|
|
|
const noOrderBtn = document.querySelector("#no-order")
|
|
|
|
const noForm = document.querySelector("#no-form")
|
|
|
|
const noBuyBtn = document.querySelector("#no-buy")
|
|
|
|
const noSellBtn = document.querySelector("#no-sell")
|
|
|
|
const noSideInput = document.querySelector("#no-side")
|
|
|
|
const noQuantityInput = document.querySelector("#no-quantity")
|
2023-09-09 20:52:50 +00:00
|
|
|
const noCostDisplay = document.querySelector("#no-cost")
|
|
|
|
const noCostLabel = document.querySelector("#no-cost-label")
|
2023-09-09 20:52:50 +00:00
|
|
|
const noSubmitLabel = document.querySelector("#no-submit-label")
|
|
|
|
|
|
|
|
yesOrderBtn.onclick = function () {
|
|
|
|
yesOrderBtn.classList.add("selected")
|
|
|
|
yesForm.style.display = "grid"
|
|
|
|
noOrderBtn.classList.remove("selected")
|
|
|
|
noForm.style.display = "none"
|
|
|
|
}
|
|
|
|
yesBuyBtn.onclick = function () {
|
|
|
|
yesSideInput.value = "BUY"
|
|
|
|
yesBuyBtn.classList.add("selected")
|
|
|
|
yesSellBtn.classList.remove("selected")
|
2023-09-09 20:52:50 +00:00
|
|
|
yesCostLabel.textContent = 'cost [sats]'
|
|
|
|
yesSubmitLabel.textContent = 'BUY YES shares'
|
|
|
|
yesQuantityInput.value = undefined
|
|
|
|
yesCostDisplay.value = undefined
|
2023-09-09 20:52:50 +00:00
|
|
|
}
|
|
|
|
yesSellBtn.onclick = function () {
|
|
|
|
yesSideInput.value = "SELL"
|
|
|
|
yesBuyBtn.classList.remove("selected")
|
|
|
|
yesSellBtn.classList.add("selected")
|
2023-09-09 20:52:50 +00:00
|
|
|
yesCostLabel.textContent = 'payout [sats]'
|
|
|
|
yesSubmitLabel.textContent = 'SELL NO shares'
|
|
|
|
yesQuantityInput.value = undefined
|
|
|
|
yesCostDisplay.value = undefined
|
2023-09-09 20:52:50 +00:00
|
|
|
}
|
2023-09-09 20:52:50 +00:00
|
|
|
yesQuantityInput.onchange = async function(e) {
|
|
|
|
const quantity = parseInt(e.target.value, 10)
|
2023-09-09 20:52:50 +00:00
|
|
|
const body = {
|
2023-09-09 20:52:50 +00:00
|
|
|
share_id: "{{(index .Shares 0).Id}}",
|
|
|
|
quantity,
|
2023-09-09 20:52:50 +00:00
|
|
|
side: yesSideInput.value
|
|
|
|
}
|
2023-09-09 20:52:50 +00:00
|
|
|
const rBody = await fetch("/api/market/{{.Id}}/cost", {
|
2023-09-09 20:52:50 +00:00
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
"Content-type": "application/json"
|
|
|
|
},
|
|
|
|
body: JSON.stringify(body)
|
|
|
|
})
|
|
|
|
.then(r => r.json())
|
|
|
|
.catch((err) => {
|
|
|
|
console.error(err);
|
|
|
|
return null
|
|
|
|
})
|
|
|
|
if (!rBody) return null;
|
2023-09-09 20:52:50 +00:00
|
|
|
yesCostDisplay.value = parseFloat(Math.abs(rBody.cost)).toFixed(3)
|
2023-09-09 20:52:50 +00:00
|
|
|
}
|
|
|
|
noOrderBtn.onclick = function () {
|
|
|
|
noOrderBtn.classList.add("selected")
|
|
|
|
noForm.style.display = "grid"
|
|
|
|
yesOrderBtn.classList.remove("selected")
|
|
|
|
yesForm.style.display = "none"
|
|
|
|
}
|
|
|
|
noBuyBtn.onclick = function () {
|
|
|
|
noSideInput.value = "BUY"
|
|
|
|
noBuyBtn.classList.add("selected")
|
|
|
|
noSellBtn.classList.remove("selected")
|
2023-09-09 20:52:50 +00:00
|
|
|
noCostLabel.textContent = 'cost [sats]'
|
|
|
|
noSubmitLabel.textContent = 'BUY NO shares'
|
|
|
|
noQuantityInput.value = undefined
|
|
|
|
noCostDisplay.value = undefined
|
2023-09-09 20:52:50 +00:00
|
|
|
}
|
|
|
|
noSellBtn.onclick = function () {
|
|
|
|
noSideInput.value = "SELL"
|
|
|
|
noBuyBtn.classList.remove("selected")
|
|
|
|
noSellBtn.classList.add("selected")
|
2023-09-09 20:52:50 +00:00
|
|
|
noCostLabel.textContent = 'payout [sats]'
|
|
|
|
noSubmitLabel.textContent = 'SELL YES shares'
|
|
|
|
noQuantityInput.value = undefined
|
|
|
|
noCostDisplay.value = undefined
|
2023-09-09 20:52:50 +00:00
|
|
|
}
|
2023-09-09 20:52:50 +00:00
|
|
|
noQuantityInput.onchange = async function(e) {
|
|
|
|
const quantity = parseInt(e.target.value, 10)
|
2023-09-09 20:52:50 +00:00
|
|
|
const body = {
|
2023-09-09 20:52:50 +00:00
|
|
|
share_id: "{{(index .Shares 1).Id}}",
|
|
|
|
quantity,
|
2023-09-09 20:52:50 +00:00
|
|
|
side: noSideInput.value
|
|
|
|
}
|
2023-09-09 20:52:50 +00:00
|
|
|
const rBody = await fetch("/api/market/{{.Id}}/cost", {
|
2023-09-09 20:52:50 +00:00
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
"Content-type": "application/json"
|
|
|
|
},
|
|
|
|
body: JSON.stringify(body)
|
|
|
|
})
|
|
|
|
.then(r => r.json())
|
|
|
|
.catch((err) => {
|
|
|
|
console.error(err);
|
|
|
|
return null
|
|
|
|
})
|
|
|
|
if (!rBody) return null;
|
2023-09-09 20:52:50 +00:00
|
|
|
noCostDisplay.value = parseFloat(Math.abs(rBody.cost)).toFixed(3)
|
2023-09-09 20:52:50 +00:00
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</html>
|