/* 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 */ import { AuditorRecord, CurrencyRecord, ExchangeForCurrencyRecord, } from "../../dbTypes"; import { getCurrencies, updateCurrency, } from "../wxApi"; import * as React from "react"; import * as ReactDOM from "react-dom"; interface CurrencyListState { currencies?: CurrencyRecord[]; } class CurrencyList extends React.Component<{}, CurrencyListState> { 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(); this.state = {} as any; } async update() { const currencies = await getCurrencies(); console.log("currencies: ", currencies); this.setState({ currencies }); } async confirmRemoveAuditor(c: CurrencyRecord, a: AuditorRecord) { if (window.confirm(`Do you really want to remove auditor ${a.baseUrl} for currency ${c.name}?`)) { c.auditors = c.auditors.filter((x) => x.auditorPub !== a.auditorPub); await updateCurrency(c); } } async confirmRemoveExchange(c: CurrencyRecord, e: ExchangeForCurrencyRecord) { if (window.confirm(`Do you really want to remove exchange ${e.baseUrl} for currency ${c.name}?`)) { c.exchanges = c.exchanges.filter((x) => x.baseUrl !== e.baseUrl); await updateCurrency(c); } } renderAuditors(c: CurrencyRecord): any { if (c.auditors.length === 0) { return

No trusted auditors for this currency.

; } return (

Trusted Auditors:

); } renderExchanges(c: CurrencyRecord): any { if (c.exchanges.length === 0) { return

No trusted exchanges for this currency.

; } return (

Trusted Exchanges:

); } render(): JSX.Element { const currencies = this.state.currencies; if (!currencies) { return ...; } return (
{currencies.map((c) => (

Currency {c.name}

Displayed with {c.fractionalDigits} fractional digits.

Auditors

{this.renderAuditors(c)}

Exchanges

{this.renderExchanges(c)}
))}
); } } function main() { ReactDOM.render(, document.getElementById("container")!); } document.addEventListener("DOMContentLoaded", main);