diff options
Diffstat (limited to 'extension/pages/confirm-contract.tsx')
-rw-r--r-- | extension/pages/confirm-contract.tsx | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/extension/pages/confirm-contract.tsx b/extension/pages/confirm-contract.tsx new file mode 100644 index 000000000..e12fdfd2d --- /dev/null +++ b/extension/pages/confirm-contract.tsx @@ -0,0 +1,53 @@ +/// <reference path="../decl/handlebars/handlebars.d.ts" /> +"use strict"; + +let url = URI(document.location.href); +let query: any = URI.parseQuery(url.query()); + +let $_ = (x) => document.getElementById(x); + +function renderContract(contract) { + let showAmount = document.getElementById("show-amount"); + $_('merchant-name').innerText = contract.merchant.name; +} + +function clone(obj) { + // This is faster than it looks ... + return JSON.parse(JSON.stringify(obj)); +} + + +Handlebars.registerHelper('prettyAmount', function(amount) { + let v = amount.value + amount.fraction / 10e6; + return v.toFixed(2) + " " + amount.currency; +}); + + +document.addEventListener("DOMContentLoaded", (e) => { + let contract = JSON.parse(query.contract); + console.dir(contract); + + let source = $_("contract-template").innerHTML; + let template = Handlebars.compile(source); + let html = template(contract.contract); + + $_("render-contract").innerHTML = html; + + + document.getElementById("confirm-purchase").addEventListener("click", (e) => { + let d = clone(query); + chrome.runtime.sendMessage({type:'confirm-purchase', detail: d}, (resp) => { + if (resp.success === true) { + document.location.href = resp.backlink; + } else { + document.body.innerHTML = + `Oops, something went wrong. + Here is some more info: + <pre>${resp.text}</pre>`; + } + }); + + }); +}); + + |