35 lines
956 B
TypeScript
35 lines
956 B
TypeScript
|
import { ProviderInfo } from "@gnu-taler/taler-wallet-core";
|
||
|
import { useEffect, useState } from "preact/hooks";
|
||
|
import * as wxApi from "../wxApi";
|
||
|
|
||
|
export interface ProviderStatus {
|
||
|
info?: ProviderInfo;
|
||
|
sync: () => Promise<void>;
|
||
|
}
|
||
|
|
||
|
export function useProviderStatus(url: string): ProviderStatus | undefined {
|
||
|
const [status, setStatus] = useState<ProviderStatus | undefined>(undefined);
|
||
|
|
||
|
useEffect(() => {
|
||
|
async function run() {
|
||
|
//create a first list of backup info by currency
|
||
|
const status = await wxApi.getBackupInfo();
|
||
|
|
||
|
const providers = status.providers.filter(p => p.syncProviderBaseUrl === url);
|
||
|
const info = providers.length ? providers[0] : undefined;
|
||
|
|
||
|
async function sync() {
|
||
|
console.log("que tiene info", info)
|
||
|
if (info) {
|
||
|
await wxApi.syncOneProvider(info.syncProviderBaseUrl);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
setStatus({ info, sync });
|
||
|
}
|
||
|
run();
|
||
|
}, []);
|
||
|
|
||
|
return status;
|
||
|
}
|