/*
 This file is part of TALER
 (C) 2016 GNUnet e.V.
 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 
      {props.children}
     
  );
}
function WalletNavBar({ current }: { current?: string }) {
  return (
    
  );
}
/**
 * Render an amount as a large number with a small currency symbol.
 */
function bigAmount(amount: AmountJson): JSX.Element {
  const v = amount.value + amount.fraction / amountFractionalBase;
  return (
    
      {v} {" "}
      {amount.currency} 
     
  );
}
function EmptyBalanceView(): JSX.Element {
  return (
    
      You have no balance to show. Need some{" "}
      help  getting started?
     
  );
}
class WalletBalanceView extends Component {
  private balance?: BalancesResponse;
  private gotError = false;
  private canceler: (() => void) | undefined = undefined;
  private unmount = false;
  private updateBalanceRunning = false;
  componentWillMount(): void {
    this.canceler = wxApi.onUpdateNotification(() => this.updateBalance());
    this.updateBalance();
  }
  componentWillUnmount(): void {
    console.log("component WalletBalanceView will unmount");
    if (this.canceler) {
      this.canceler();
    }
    this.unmount = true;
  }
  async updateBalance(): Promise {
    if (this.updateBalanceRunning) {
      return;
    }
    this.updateBalanceRunning = true;
    let balance: BalancesResponse;
    try {
      balance = await wxApi.getBalance();
    } catch (e) {
      if (this.unmount) {
        return;
      }
      this.gotError = true;
      console.error("could not retrieve balances", e);
      this.setState({});
      return;
    } finally {
      this.updateBalanceRunning = false;
    }
    if (this.unmount) {
      return;
    }
    this.gotError = false;
    console.log("got balance", balance);
    this.balance = balance;
    this.setState({});
  }
  formatPending(entry: Balance): JSX.Element {
    let incoming: JSX.Element | undefined;
    let payment: JSX.Element | undefined;
    const available = Amounts.parseOrThrow(entry.available);
    const pendingIncoming = Amounts.parseOrThrow(entry.pendingIncoming);
    const pendingOutgoing = Amounts.parseOrThrow(entry.pendingOutgoing);
    console.log(
      "available: ",
      entry.pendingIncoming ? renderAmount(entry.available) : null,
    );
    console.log(
      "incoming: ",
      entry.pendingIncoming ? renderAmount(entry.pendingIncoming) : null,
    );
    if (!Amounts.isZero(pendingIncoming)) {
      incoming = (
        
          
            {"+"}
            {renderAmount(entry.pendingIncoming)}
           {" "}
          incoming
         
      );
    }
    const l = [incoming, payment].filter((x) => x !== undefined);
    if (l.length === 0) {
      return ({l}) ;
    }
    return (
      
        ({l[0]}, {l[1]})
       
    );
  }
  render(): JSX.Element {
    const wallet = this.balance;
    if (this.gotError) {
      return (
        
          {i18n.str`Error: could not retrieve balance information.`}
          
            Click here  for help and
            diagnostics.
          
         
      );
    }
    if (!wallet) {
      return 
          {bigAmount(av)} {this.formatPending(entry)}
        
      );
    });
    return listing.length > 0 ? (
      {listing}
    ) : (
      
      
        {sign}
        {amount}
      
      {currency}
     
  );
}
interface TransactionLayoutProps {
  debitCreditIndicator: "debit" | "credit" | "unknown";
  amount: AmountString | "unknown";
  timestamp: Timestamp;
  title: string;
  subtitle: string;
  iconPath: string;
  pending: boolean;
}
function TransactionLayout(props: TransactionLayoutProps): JSX.Element {
  const date = new Date(props.timestamp.t_ms);
  const dateStr = date.toLocaleString([], {
    dateStyle: "medium",
    timeStyle: "short",
  } as any);
  return (
    
      
        {dateStr}
        
          {props.title} 
          {props.pending ? (
             (Pending) 
          ) : null}
        
        {props.subtitle}
       
       
  );
}
function TransactionItem(props: { tx: Transaction }): JSX.Element {
  const tx = props.tx;
  switch (tx.type) {
    case TransactionType.Withdrawal:
      return (
         => {
      const res = await wxApi.getTransactions();
      setTransactions(res);
    };
    fetchData();
  }, []);
  if (!transactions) {
    return Loading ...
;
  }
  const txs = [...transactions.transactions].reverse();
  return (
    
      {txs.map((tx, i) => (
        
  );
}
class WalletSettings extends Component {
  render(): JSX.Element {
    return (
      
    );
  }
}
function reload(): void {
  try {
    chrome.runtime.reload();
    window.close();
  } catch (e) {
    // Functionality missing in firefox, ignore!
  }
}
async function confirmReset(): Promise {
  if (
    confirm(
      "Do you want to IRREVOCABLY DESTROY everything inside your" +
      " wallet and LOSE ALL YOUR COINS?",
    )
  ) {
    await wxApi.resetDb();
    window.close();
  }
}
function WalletDebug(props: any): JSX.Element {
  return (
    
      Debug tools:
      wallet tab 
      
      reset 
      reload chrome extension 
     
  );
}
function openExtensionPage(page: string) {
  return () => {
    chrome.tabs.create({
      url: chrome.extension.getURL(page),
    });
  };
}
// function openTab(page: string) {
//   return (evt: React.SyntheticEvent) => {
//     evt.preventDefault();
//     chrome.tabs.create({
//       url: page,
//     });
//   };
// }
function makeExtensionUrlWithParams(
  url: string,
  params?: { [name: string]: string | undefined },
): string {
  const innerUrl = new URL(chrome.extension.getURL("/" + url));
  if (params) {
    for (const key in params) {
      const p = params[key];
      if (p) {
        innerUrl.searchParams.set(key, p);
      }
    }
  }
  return innerUrl.href;
}
function actionForTalerUri(talerUri: string): string | undefined {
  const uriType = classifyTalerUri(talerUri);
  switch (uriType) {
    case TalerUriType.TalerWithdraw:
      return makeExtensionUrlWithParams("static/withdraw.html", {
        talerWithdrawUri: talerUri,
      });
    case TalerUriType.TalerPay:
      return makeExtensionUrlWithParams("static/pay.html", {
        talerPayUri: talerUri,
      });
    case TalerUriType.TalerTip:
      return makeExtensionUrlWithParams("static/tip.html", {
        talerTipUri: talerUri,
      });
    case TalerUriType.TalerRefund:
      return makeExtensionUrlWithParams("static/refund.html", {
        talerRefundUri: talerUri,
      });
    case TalerUriType.TalerNotifyReserve:
      // FIXME: implement
      break;
    default:
      console.warn(
        "Response with HTTP 402 has Taler header, but header value is not a taler:// URI.",
      );
      break;
  }
  return undefined;
}
async function findTalerUriInActiveTab(): Promise {
  return new Promise((resolve, reject) => {
    chrome.tabs.executeScript(
      {
        code: `
        (() => {
          let x = document.querySelector("a[href^='taler://'");
          return x ? x.href.toString() : null;
        })();
      `,
        allFrames: false,
      },
      (result) => {
        if (chrome.runtime.lastError) {
          console.error(chrome.runtime.lastError);
          resolve(undefined);
          return;
        }
        console.log("got result", result);
        resolve(result[0]);
      },
    );
  });
}
export function WalletPopup(): JSX.Element {
  const [talerActionUrl, setTalerActionUrl] = useState(
    undefined,
  );
  const [dismissed, setDismissed] = useState(false);
  useEffect(() => {
    async function check(): Promise {
      const talerUri = await findTalerUriInActiveTab();
      if (talerUri) {
        const actionUrl = actionForTalerUri(talerUri);
        setTalerActionUrl(actionUrl);
      }
    }
    check();
  });
  if (talerActionUrl && !dismissed) {
    return (
      
        Taler Action 
        This page has a Taler action. 
        
           {
              window.open(talerActionUrl, "_blank");
            }}
          >
            Open
           
        
        
           setDismissed(true)}>Dismiss 
        
       
    );
  }
  return (
    
  );
}
enum Pages {
  balance = '/popup/balance',
  settings = '/popup/settings',
  debug = '/popup/debug',
  history = '/popup/history',
}
export function Redirect({ to }: { to: string }): null {
  useEffect(() => {
    route(to, true)
  })
  return null
}