Desktop: In config screen, click on a plugin name to open its home page

pull/4420/head
Laurent Cozic 2021-01-24 18:20:00 +00:00
parent a320e113ac
commit 351a05fb0d
2 changed files with 20 additions and 2 deletions

View File

@ -1,9 +1,11 @@
import * as React from 'react';
import { useCallback } from 'react';
import { _ } from '@joplin/lib/locale';
import styled from 'styled-components';
import ToggleButton from '../../../lib/ToggleButton/ToggleButton';
import Button, { ButtonLevel } from '../../../Button/Button';
import { PluginManifest } from '@joplin/lib/services/plugins/utils/types';
import bridge from '../../../../services/bridge';
export enum InstallState {
NotInstalled = 1,
@ -40,6 +42,7 @@ function manifestToItem(manifest: PluginManifest): PluginItem {
deleted: false,
devMode: false,
hasBeenUpdated: false,
homepage_url: manifest.homepage_url,
};
}
@ -52,6 +55,7 @@ export interface PluginItem {
deleted: boolean;
devMode: boolean;
hasBeenUpdated: boolean;
homepage_url: string;
}
const CellRoot = styled.div`
@ -95,7 +99,7 @@ const DevModeLabel = styled.div`
color: ${props => props.theme.color};
`;
const StyledName = styled.div`
const StyledNameAndVersion = styled.div`
font-family: ${props => props.theme.fontFamily};
color: ${props => props.theme.color};
font-size: ${props => props.theme.fontSize}px;
@ -104,6 +108,14 @@ const StyledName = styled.div`
flex: 1;
`;
const StyledName = styled.a`
color: ${props => props.theme.color};
&:hover {
text-decoration: underline;
}
`;
const StyledVersion = styled.span`
color: ${props => props.theme.colorFaded};
font-size: ${props => props.theme.fontSize * 0.9}px;
@ -119,6 +131,11 @@ const StyledDescription = styled.div`
export default function(props: Props) {
const item = props.item ? props.item : manifestToItem(props.manifest);
const onNameClick = useCallback(() => {
if (!props.item.homepage_url) return;
bridge().openExternal(props.item.homepage_url);
}, [props.item]);
// For plugins in dev mode things like enabling/disabling or
// uninstalling them doesn't make sense, as that should be done by
// adding/removing them from wherever they were loaded from.
@ -190,7 +207,7 @@ export default function(props: Props) {
return (
<CellRoot>
<CellTop>
<StyledName mb={'5px'}><span style={{ marginRight: 5 }}>{item.name} {item.deleted ? '(Deleted)' : ''}</span><StyledVersion>v{item.version}</StyledVersion></StyledName>
<StyledNameAndVersion mb={'5px'}><StyledName onClick={onNameClick} href="#" style={{ marginRight: 5 }}>{item.name} {item.deleted ? _('(%s)', 'Deleted') : ''}</StyledName><StyledVersion>v{item.version}</StyledVersion></StyledNameAndVersion>
{renderToggleButton()}
</CellTop>
<CellContent>

View File

@ -71,6 +71,7 @@ function usePluginItems(plugins: Plugins, settings: PluginSettings): PluginItem[
deleted: setting.deleted,
devMode: plugin.devMode,
hasBeenUpdated: setting.hasBeenUpdated,
homepage_url: plugin.manifest.homepage_url,
});
}