2024-06-15 11:00:21 +02:00
|
|
|
import { _ } from '@joplin/lib/locale';
|
|
|
|
import { PluginManifest } from '@joplin/lib/services/plugins/utils/types';
|
|
|
|
import * as React from 'react';
|
|
|
|
import IconButton from '../../../../IconButton';
|
2024-08-02 15:51:49 +02:00
|
|
|
import { Linking, StyleSheet } from 'react-native';
|
2024-06-15 11:00:21 +02:00
|
|
|
import { themeStyle } from '../../../../global-style';
|
2024-08-02 15:51:49 +02:00
|
|
|
import { useCallback, useContext, useMemo } from 'react';
|
|
|
|
import { DialogContext } from '../../../../DialogManager';
|
2024-06-15 11:00:21 +02:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
themeId: number;
|
|
|
|
manifest: PluginManifest;
|
|
|
|
isCompatible: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
const useStyles = (themeId: number) => {
|
|
|
|
return useMemo(() => {
|
|
|
|
const theme = themeStyle(themeId);
|
|
|
|
return StyleSheet.create({
|
|
|
|
container: {
|
|
|
|
opacity: 0.8,
|
|
|
|
},
|
|
|
|
wrapper: {
|
|
|
|
borderColor: theme.colorWarn,
|
|
|
|
borderWidth: 1,
|
|
|
|
borderRadius: 20,
|
|
|
|
justifyContent: 'center',
|
|
|
|
height: 32,
|
|
|
|
width: 32,
|
|
|
|
textAlign: 'center',
|
|
|
|
},
|
|
|
|
icon: {
|
|
|
|
fontSize: 14,
|
|
|
|
color: theme.colorWarn,
|
|
|
|
marginLeft: 'auto',
|
|
|
|
marginRight: 'auto',
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}, [themeId]);
|
|
|
|
};
|
|
|
|
|
|
|
|
const RecommendedBadge: React.FC<Props> = props => {
|
|
|
|
const styles = useStyles(props.themeId);
|
|
|
|
|
2024-08-02 15:51:49 +02:00
|
|
|
const dialogs = useContext(DialogContext);
|
|
|
|
const onRecommendedPress = useCallback(() => {
|
|
|
|
dialogs.prompt(
|
|
|
|
'',
|
|
|
|
_('The Joplin team has vetted this plugin and it meets our standards for security and performance.'),
|
|
|
|
[
|
|
|
|
{
|
|
|
|
text: _('Learn more'),
|
|
|
|
onPress: () => Linking.openURL('https://github.com/joplin/plugins/blob/master/readme/recommended.md'),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: _('OK'),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
{ cancelable: true },
|
|
|
|
);
|
|
|
|
}, [dialogs]);
|
|
|
|
|
2024-06-15 11:00:21 +02:00
|
|
|
if (!props.manifest._recommended || !props.isCompatible) return null;
|
|
|
|
|
|
|
|
return <IconButton
|
|
|
|
onPress={onRecommendedPress}
|
|
|
|
iconName='fas fa-crown'
|
|
|
|
containerStyle={styles.container}
|
|
|
|
contentWrapperStyle={styles.wrapper}
|
|
|
|
iconStyle={styles.icon}
|
|
|
|
themeId={props.themeId}
|
|
|
|
description={_('Recommended')}
|
|
|
|
/>;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default RecommendedBadge;
|