/* 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 */ import { i18n, Timestamp } from "@gnu-taler/taler-util"; import { ProviderInfo } from "@gnu-taler/taler-wallet-core"; import { formatDuration, intervalToDuration } from "date-fns"; import { JSX, VNode } from "preact"; import { useBackupStatus } from "../hooks/useProvidersByCurrency"; import { Pages } from "./popup"; interface Props { onAddProvider: () => void; } export function BackupPage({ onAddProvider }: Props): VNode { const status = useBackupStatus() if (!status) { return
Loading...
} return ; } export interface ViewProps { providers: ProviderInfo[], onAddProvider: () => void; } export function BackupView({ providers, onAddProvider }: ViewProps): VNode { return (
{!!providers.length &&
{providers.map((provider, idx) => { return })}
} {!providers.length &&
There is not backup providers configured, add one with the button below
}
) } interface TransactionLayoutProps { status?: any; timestamp?: Timestamp; title: string; id: number; subtitle?: string; active?: boolean; } function BackupLayout(props: TransactionLayoutProps): JSX.Element { const date = !props.timestamp ? undefined : new Date(props.timestamp.t_ms); const dateStr = date?.toLocaleString([], { dateStyle: "medium", timeStyle: "short", } as any); return (
{props.title}
{dateStr &&
Last time synced: {dateStr}
} {!dateStr &&
never synced
}
{!props.status ? "missing" : ( props.status?.type === 'paid' ? daysUntil(props.status.paidUntil) : 'unpaid' )}
); } function daysUntil(d: Timestamp) { if (d.t_ms === 'never') return undefined const duration = intervalToDuration({ start: d.t_ms, end: new Date(), }) const str = formatDuration(duration, { delimiter: ', ', format: [ duration?.years ? 'years' : ( duration?.months ? 'months' : ( duration?.days ? 'days' : ( duration.hours ? 'hours' : 'minutes' ) ) ) ] }) return `${str} left` }