54 lines
1.4 KiB
TypeScript
54 lines
1.4 KiB
TypeScript
/// <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>`;
|
|
}
|
|
});
|
|
|
|
});
|
|
});
|
|
|
|
|