mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-24 10:27:10 +02:00
116 lines
3.1 KiB
TypeScript
116 lines
3.1 KiB
TypeScript
import { PluginItem } from '@joplin/lib/components/shared/config/plugins/types';
|
|
import * as React from 'react';
|
|
import { _ } from '@joplin/lib/locale';
|
|
import { useCallback, useMemo, useState } from 'react';
|
|
import { Button, IconButton, List, Portal, Text } from 'react-native-paper';
|
|
import getPluginIssueReportUrl from '@joplin/lib/services/plugins/utils/getPluginIssueReportUrl';
|
|
import { Linking, ScrollView, StyleSheet, View } from 'react-native';
|
|
import DismissibleDialog from '../../../../DismissibleDialog';
|
|
import openWebsiteForPlugin from '../utils/openWebsiteForPlugin';
|
|
|
|
interface Props {
|
|
themeId: number;
|
|
size: number;
|
|
item: PluginItem;
|
|
onModalDismiss?: ()=> void;
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
aboutPluginContainer: {
|
|
paddingLeft: 10,
|
|
paddingRight: 10,
|
|
paddingBottom: 10,
|
|
},
|
|
descriptionText: {
|
|
marginTop: 5,
|
|
marginBottom: 5,
|
|
},
|
|
fraudulentPluginButton: {
|
|
opacity: 0.6,
|
|
},
|
|
});
|
|
|
|
const PluginInfoModal: React.FC<Props> = props => {
|
|
const aboutPlugin = (
|
|
<View style={styles.aboutPluginContainer}>
|
|
<Text variant='titleLarge'>{props.item.manifest.name}</Text>
|
|
<Text variant='bodyLarge'>{props.item.manifest.author ? _('by %s', props.item.manifest.author) : ''}</Text>
|
|
<Text style={styles.descriptionText}>{props.item.manifest.description ?? _('No description')}</Text>
|
|
</View>
|
|
);
|
|
|
|
const onAboutPress = useCallback(() => {
|
|
void openWebsiteForPlugin({ item: props.item });
|
|
}, [props.item]);
|
|
|
|
const reportIssueUrl = useMemo(() => {
|
|
return getPluginIssueReportUrl(props.item.manifest);
|
|
}, [props.item]);
|
|
|
|
const onReportIssuePress = useCallback(() => {
|
|
void Linking.openURL(reportIssueUrl);
|
|
}, [reportIssueUrl]);
|
|
|
|
const reportIssueButton = (
|
|
<List.Item
|
|
left={props => <List.Icon {...props} icon='bug'/>}
|
|
title={_('Report an issue')}
|
|
onPress={onReportIssuePress}
|
|
/>
|
|
);
|
|
|
|
const onReportFraudulentPress = useCallback(() => {
|
|
void Linking.openURL('https://github.com/laurent22/joplin/security/advisories/new');
|
|
}, []);
|
|
|
|
return (
|
|
<Portal>
|
|
<DismissibleDialog
|
|
themeId={props.themeId}
|
|
visible={true}
|
|
onDismiss={props.onModalDismiss}
|
|
>
|
|
<ScrollView>
|
|
{aboutPlugin}
|
|
<List.Item
|
|
left={props => <List.Icon {...props} icon='web'/>}
|
|
title={_('About')}
|
|
onPress={onAboutPress}
|
|
/>
|
|
{ reportIssueUrl ? reportIssueButton : null }
|
|
</ScrollView>
|
|
<Button
|
|
icon='shield-bug'
|
|
style={styles.fraudulentPluginButton}
|
|
onPress={onReportFraudulentPress}
|
|
>{_('Report fraudulent plugin')}</Button>
|
|
</DismissibleDialog>
|
|
</Portal>
|
|
);
|
|
};
|
|
|
|
const PluginInfoButton: React.FC<Props> = props => {
|
|
const [showInfoModal, setShowInfoModal] = useState(false);
|
|
const onInfoButtonPress = useCallback(() => {
|
|
setShowInfoModal(true);
|
|
}, []);
|
|
|
|
const onModalDismiss = useCallback(() => {
|
|
setShowInfoModal(false);
|
|
props.onModalDismiss?.();
|
|
}, [props.onModalDismiss]);
|
|
|
|
return (
|
|
<>
|
|
{showInfoModal ? <PluginInfoModal {...props} onModalDismiss={onModalDismiss} /> : null}
|
|
<IconButton
|
|
size={props.size}
|
|
icon='information'
|
|
onPress={onInfoButtonPress}
|
|
/>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default PluginInfoButton;
|