1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-07-06 23:56:13 +02:00

Chore: Refactor mobile plugin logic into locations more consistent with other parts of the app (#10636)

This commit is contained in:
Henry Heino
2024-06-25 05:59:59 -07:00
committed by GitHub
parent 801d36c41f
commit c7116b135f
34 changed files with 155 additions and 91 deletions

View File

@ -0,0 +1,62 @@
import * as React from 'react';
import { ReactElement } from 'react';
import { PluginHtmlContents, PluginStates, ViewInfo } from '@joplin/lib/services/plugins/reducer';
import PluginDialogWebView from './PluginDialogWebView';
import { Modal, Portal } from 'react-native-paper';
import PluginService from '@joplin/lib/services/plugins/PluginService';
import WebviewController, { ContainerType } from '@joplin/lib/services/plugins/WebviewController';
import useViewInfos from './hooks/useViewInfos';
import PluginPanelViewer from './PluginPanelViewer';
interface Props {
themeId: number;
pluginHtmlContents: PluginHtmlContents;
pluginStates: PluginStates;
}
const dismissDialog = (viewInfo: ViewInfo) => {
if (!viewInfo.view.opened) return;
const plugin = PluginService.instance().pluginById(viewInfo.plugin.id);
const viewController = plugin.viewController(viewInfo.view.id) as WebviewController;
viewController.closeWithResponse(null);
};
const PluginDialogManager: React.FC<Props> = props => {
const viewInfos = useViewInfos(props.pluginStates);
const dialogs: ReactElement[] = [];
for (const viewInfo of viewInfos) {
if (viewInfo.view.containerType === ContainerType.Panel || !viewInfo.view.opened) {
continue;
}
dialogs.push(
<Portal
key={`${viewInfo.plugin.id}-${viewInfo.view.id}`}
>
<Modal
visible={true}
onDismiss={() => dismissDialog(viewInfo)}
>
<PluginDialogWebView
viewInfo={viewInfo}
themeId={props.themeId}
pluginStates={props.pluginStates}
pluginHtmlContents={props.pluginHtmlContents}
/>
</Modal>
</Portal>,
);
}
return (
<>
{dialogs}
<PluginPanelViewer/>
</>
);
};
export default PluginDialogManager;