UNPKG

@ledgerhq/live-common

Version:
81 lines 2.64 kB
import { scan, tap } from "rxjs/operators"; import { useCallback, useEffect, useState } from "react"; import { log } from "@ledgerhq/logs"; import { useReplaySubject } from "../../observable"; import { currentMode } from "./app"; import { getImplementation } from "./implementations"; const mapResult = ({ appsUninstalled }) => appsUninstalled; const getInitialState = (device) => ({ isLoading: !!device, requestQuitApp: false, unresponsive: false, device, deviceInfo: null, error: null, uninstallAppsRequested: false, appsUninstalled: false, }); const reducer = (state, e) => { switch (e.type) { case "unresponsiveDevice": return { ...state, unresponsive: true, isLoading: false }; case "deviceChange": return getInitialState(e.device); case "error": return { ...state, error: e.error, isLoading: false, }; case "uninstallAppsPermissionRequested": return { ...state, unresponsive: false, uninstallAppsRequested: true, isLoading: false, }; case "appsUninstalled": return { ...state, unresponsive: false, uninstallAppsRequested: false, isLoading: false, appsUninstalled: true, }; } }; export const createAction = (task) => { const useHook = (device, _) => { const [state, setState] = useState(() => getInitialState(device)); const [resetIndex, setResetIndex] = useState(0); const deviceSubject = useReplaySubject(device); const onRetry = useCallback(() => { setResetIndex(currIndex => currIndex + 1); setState(s => getInitialState(s.device)); }, []); useEffect(() => { if (state.appsUninstalled) return; const impl = getImplementation(currentMode)({ deviceSubject, task, request: {}, }); const sub = impl .pipe(tap((e) => log("actions-remove-stax-image-event", e.type, e)), scan(reducer, getInitialState())) .subscribe(setState); return () => { sub.unsubscribe(); }; }, [deviceSubject, resetIndex, state.appsUninstalled]); return { ...state, onRetry, }; }; return { useHook, mapResult, }; }; //# sourceMappingURL=uninstallAllApps.js.map