2024-06-04 10:57:52 +02:00
|
|
|
import { ItemEvent, OnPluginSettingChangeEvent } from '@joplin/lib/components/shared/config/plugins/types';
|
|
|
|
import useOnDeleteHandler from '@joplin/lib/components/shared/config/plugins/useOnDeleteHandler';
|
|
|
|
import useOnInstallHandler from '@joplin/lib/components/shared/config/plugins/useOnInstallHandler';
|
|
|
|
import NavService from '@joplin/lib/services/NavService';
|
2024-06-14 20:36:26 +02:00
|
|
|
import { PluginSettings, defaultPluginSetting } from '@joplin/lib/services/plugins/PluginService';
|
2024-06-04 10:57:52 +02:00
|
|
|
import RepositoryApi from '@joplin/lib/services/plugins/RepositoryApi';
|
2024-06-14 20:36:44 +02:00
|
|
|
import { useCallback, useMemo, useRef, useState } from 'react';
|
2024-06-04 10:57:52 +02:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
updatePluginStates: (settingValue: PluginSettings)=> void;
|
|
|
|
pluginSettings: PluginSettings;
|
|
|
|
repoApi: RepositoryApi;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type PluginCallback = (event: ItemEvent)=> void;
|
|
|
|
|
|
|
|
export interface PluginCallbacks {
|
|
|
|
onToggle: PluginCallback;
|
|
|
|
onUpdate: PluginCallback;
|
|
|
|
onInstall: PluginCallback;
|
|
|
|
onDelete: PluginCallback;
|
|
|
|
onShowPluginLog: PluginCallback;
|
|
|
|
}
|
|
|
|
|
|
|
|
const usePluginCallbacks = (props: Props) => {
|
|
|
|
const onPluginSettingsChange = useCallback((event: OnPluginSettingChangeEvent) => {
|
|
|
|
props.updatePluginStates(event.value);
|
|
|
|
}, [props.updatePluginStates]);
|
|
|
|
|
|
|
|
const updatePluginEnabled = useCallback((pluginId: string, enabled: boolean) => {
|
|
|
|
const newSettings = { ...props.pluginSettings };
|
2024-06-14 20:36:26 +02:00
|
|
|
newSettings[pluginId] = {
|
|
|
|
...defaultPluginSetting(),
|
|
|
|
...newSettings[pluginId],
|
|
|
|
enabled,
|
|
|
|
};
|
2024-06-04 10:57:52 +02:00
|
|
|
|
|
|
|
props.updatePluginStates(newSettings);
|
|
|
|
}, [props.pluginSettings, props.updatePluginStates]);
|
|
|
|
|
|
|
|
const onToggle = useCallback((event: ItemEvent) => {
|
|
|
|
const pluginId = event.item.manifest.id;
|
2024-06-14 20:36:26 +02:00
|
|
|
const settings = props.pluginSettings[pluginId] ?? defaultPluginSetting();
|
2024-06-04 10:57:52 +02:00
|
|
|
updatePluginEnabled(pluginId, !settings.enabled);
|
|
|
|
}, [props.pluginSettings, updatePluginEnabled]);
|
|
|
|
|
2024-06-14 20:36:44 +02:00
|
|
|
const pluginSettingsRef = useRef(props.pluginSettings);
|
|
|
|
pluginSettingsRef.current = props.pluginSettings;
|
|
|
|
|
|
|
|
const onDelete = useOnDeleteHandler(pluginSettingsRef, onPluginSettingsChange, true);
|
2024-06-04 10:57:52 +02:00
|
|
|
|
|
|
|
const [updatingPluginIds, setUpdatingPluginIds] = useState<Record<string, boolean>>({});
|
2024-06-14 20:36:44 +02:00
|
|
|
const onUpdate = useOnInstallHandler(setUpdatingPluginIds, pluginSettingsRef, props.repoApi, onPluginSettingsChange, true);
|
2024-06-04 10:57:52 +02:00
|
|
|
|
|
|
|
const [installingPluginIds, setInstallingPluginIds] = useState<Record<string, boolean>>({});
|
|
|
|
const onInstall = useOnInstallHandler(
|
2024-06-14 20:36:44 +02:00
|
|
|
setInstallingPluginIds, pluginSettingsRef, props.repoApi, onPluginSettingsChange, false,
|
2024-06-04 10:57:52 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
const onShowPluginLog = useCallback((event: ItemEvent) => {
|
|
|
|
const pluginId = event.item.manifest.id;
|
|
|
|
void NavService.go('Log', { defaultFilter: pluginId });
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
const callbacks = useMemo((): PluginCallbacks => {
|
|
|
|
return {
|
|
|
|
onToggle,
|
|
|
|
onDelete,
|
|
|
|
onUpdate,
|
|
|
|
onInstall,
|
|
|
|
onShowPluginLog,
|
|
|
|
};
|
|
|
|
}, [onToggle, onDelete, onUpdate, onInstall, onShowPluginLog]);
|
|
|
|
|
|
|
|
return {
|
|
|
|
callbacks,
|
|
|
|
updatingPluginIds,
|
|
|
|
installingPluginIds,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export default usePluginCallbacks;
|