mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-17 18:44:45 +02:00
50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
import useAsyncEffect from '@joplin/lib/hooks/useAsyncEffect';
|
|
import Logger from '@joplin/utils/Logger';
|
|
import RepositoryApi, { InstallMode } from '@joplin/lib/services/plugins/RepositoryApi';
|
|
import Setting from '@joplin/lib/models/Setting';
|
|
import { useMemo } from 'react';
|
|
import shim from '@joplin/lib/shim';
|
|
|
|
const logger = Logger.create('useRepoApi');
|
|
|
|
interface Props {
|
|
reloadRepoCounter: number;
|
|
setRepoApiError: (error: string|null)=> void;
|
|
onRepoApiLoaded: (repoApi: RepositoryApi)=> void;
|
|
}
|
|
|
|
let repoApi_: RepositoryApi|null = null;
|
|
|
|
export const resetRepoApi = () => {
|
|
repoApi_ = null;
|
|
};
|
|
|
|
const useRepoApi = ({ reloadRepoCounter, setRepoApiError, onRepoApiLoaded }: Props) => {
|
|
const repoApi = useMemo(() => {
|
|
const installMode = shim.mobilePlatform() === 'ios' ? InstallMode.Restricted : InstallMode.Default;
|
|
repoApi_ ??= RepositoryApi.ofDefaultJoplinRepo(Setting.value('tempDir'), installMode);
|
|
return repoApi_;
|
|
}, []);
|
|
|
|
useAsyncEffect(async event => {
|
|
if (reloadRepoCounter > 0) {
|
|
logger.info(`Reloading the plugin repository -- try #${reloadRepoCounter + 1}`);
|
|
}
|
|
|
|
setRepoApiError(null);
|
|
try {
|
|
await repoApi.initialize();
|
|
} catch (error) {
|
|
logger.error(error);
|
|
setRepoApiError(error);
|
|
}
|
|
if (!event.cancelled) {
|
|
onRepoApiLoaded(repoApi);
|
|
}
|
|
}, [setRepoApiError, reloadRepoCounter, repoApi]);
|
|
|
|
return repoApi;
|
|
};
|
|
|
|
export default useRepoApi;
|