import { PluginItem } from '@joplin/lib/components/shared/config/plugins/types'; import PluginService from '@joplin/lib/services/plugins/PluginService'; import shim from '@joplin/lib/shim'; import * as React from 'react'; import { Alert, Linking, View, ViewStyle } from 'react-native'; import { _ } from '@joplin/lib/locale'; import { PluginCallback } from '../utils/usePluginCallbacks'; import StyledChip from './StyledChip'; import { themeStyle } from '../../../../global-style'; interface Props { themeId: number; item: PluginItem; hasErrors: boolean; isCompatible: boolean; canUpdate: boolean; showInstalledChip: boolean; onShowPluginLog?: PluginCallback; } const onRecommendedPress = () => { Alert.alert( '', _('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 }, ); }; const containerStyle: ViewStyle = { flexDirection: 'row', gap: 4, // Smaller than default chip size transform: [{ scale: 0.84 }], transformOrigin: 'left', }; const PluginChips: React.FC = props => { const item = props.item; const theme = themeStyle(props.themeId); const renderErrorsChip = () => { if (!props.hasErrors) return null; return ( props.onShowPluginLog({ item })} > {_('Error')} ); }; const renderRecommendedChip = () => { if (!props.item.manifest._recommended || !props.isCompatible) { return null; } return {_('Recommended')}; }; const renderBuiltInChip = () => { if (!props.item.builtIn) { return null; } return {_('Built-in')}; }; const renderIncompatibleChip = () => { if (props.isCompatible) return null; return ( { void shim.showMessageBox( PluginService.instance().describeIncompatibility(props.item.manifest), { buttons: [_('OK')] }, ); }} >{_('Incompatible')} ); }; const renderUpdatableChip = () => { if (!props.isCompatible || !props.canUpdate) return null; return ( {_('Update available')} ); }; const renderDisabledChip = () => { if (props.item.enabled || !props.item.installed) { return null; } return {_('Disabled')}; }; const renderInstalledChip = () => { if (!props.showInstalledChip) { return null; } return {_('Installed')}; }; return {renderIncompatibleChip()} {renderInstalledChip()} {renderErrorsChip()} {renderRecommendedChip()} {renderBuiltInChip()} {renderUpdatableChip()} {renderDisabledChip()} ; }; export default PluginChips;