aboutsummaryrefslogtreecommitdiff
path: root/extension/pages/confirm-contract.tsx
blob: 968f5af7a37f45caee80c6f8769298a6a882ac19 (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
44
45
46
47
48
49
50
51
52
53
54
55
/// <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 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();
    });
  });
});