/* This file is part of TALER (C) 2017 Inria TALER is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. TALER is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with TALER; see the file COPYING. If not, see */ /** * View and edit auditors. * * @author Florian Dold */ /** * Imports. */ import { ReserveRecord, } from "../../dbTypes"; import { ImplicitStateComponent, StateHolder } from "../components"; import { renderAmount } from "../renderHtml"; import { getPaybackReserves, withdrawPaybackReserve, } from "../wxApi"; import * as React from "react"; import * as ReactDOM from "react-dom"; class Payback extends ImplicitStateComponent<{}> { private reserves: StateHolder = this.makeState(null); constructor(props: {}) { super(props); const port = chrome.runtime.connect(); port.onMessage.addListener((msg: any) => { if (msg.notify) { console.log("got notified"); this.update(); } }); this.update(); } async update() { const reserves = await getPaybackReserves(); this.reserves(reserves); } withdrawPayback(pub: string) { withdrawPaybackReserve(pub); } render(): JSX.Element { const reserves = this.reserves(); if (!reserves) { return loading ...; } if (reserves.length === 0) { return No reserves with payback available.; } return (
{reserves.map((r) => (

Reserve for ${renderAmount(r.current_amount!)}

  • Exchange: ${r.exchange_base_url}
))}
); } } function main() { ReactDOM.render(, document.getElementById("container")!); } document.addEventListener("DOMContentLoaded", main);