aboutsummaryrefslogtreecommitdiff
path: root/extension/pages/confirm-contract.js
blob: 2c12211f654ec2c38891f3997b88435cf4ac9dea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/// <reference path="../decl/handlebars/handlebars.d.ts" />
"use strict";
let url = URI(document.location.href);
let query = 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 offer = JSON.parse(query.offer);
    console.dir(offer);
    let source = $_("contract-template").innerHTML;
    let template = Handlebars.compile(source);
    $_("render-contract").innerHTML = template(offer.contract);
    document.getElementById("confirm-pay").addEventListener("click", (e) => {
        console.log("Query:", JSON.stringify(query));
        let d = {
            offer: JSON.parse(query.offer),
            merchantPageUrl: query.merchantPageUrl
        };
        chrome.runtime.sendMessage({ type: 'confirm-pay', detail: d }, (resp) => {
            if (!resp.success) {
                let source = $_("error-template").innerHTML;
                let template = Handlebars.compile(source);
                $_("status").innerHTML = template(resp);
                return;
            }
            document.location.href = URI(d.offer.exec_url)
                .absoluteTo(query.merchantPageUrl)
                .addQuery({ H_contract: d.offer.H_contract })
                .href();
        });
    });
});