2024-04-08 13:36:40 +02:00
|
|
|
import * as React from 'react';
|
|
|
|
import { useCallback } from 'react';
|
2024-06-04 10:57:52 +02:00
|
|
|
import { PluginItem } from '@joplin/lib/components/shared/config/plugins/types';
|
|
|
|
import TextButton, { TextButtonProps, ButtonType } from '../../../../buttons/TextButton';
|
|
|
|
import { PluginCallback } from '../utils/usePluginCallbacks';
|
2024-04-08 13:36:40 +02:00
|
|
|
|
|
|
|
|
2024-06-04 10:57:52 +02:00
|
|
|
interface Props extends Omit<TextButtonProps, 'type'|'item'|'onPress'|'children'> {
|
2024-04-08 13:36:40 +02:00
|
|
|
item: PluginItem;
|
2024-06-04 10:57:52 +02:00
|
|
|
type?: ButtonType;
|
2024-04-08 13:36:40 +02:00
|
|
|
onPress?: PluginCallback;
|
|
|
|
title: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const ActionButton: React.FC<Props> = props => {
|
|
|
|
const onPress = useCallback(() => {
|
|
|
|
props.onPress?.({ item: props.item });
|
|
|
|
}, [props.onPress, props.item]);
|
|
|
|
|
|
|
|
// Include additional information about the button when using a screen
|
|
|
|
// reader (helps make it clear which plugin a delete/enable button).
|
|
|
|
//
|
|
|
|
// Because this is being read by a screen reader and to reduce load on
|
|
|
|
// translators, the method of joining the title and manifest name is not
|
|
|
|
// marked as translatable.
|
|
|
|
const accessibilityLabel = `${props.title} ${props.item.manifest.name}`;
|
|
|
|
return (
|
2024-06-04 10:57:52 +02:00
|
|
|
<TextButton
|
|
|
|
type={ButtonType.Primary}
|
2024-04-08 13:36:40 +02:00
|
|
|
{...props}
|
|
|
|
onPress={onPress}
|
|
|
|
accessibilityLabel={accessibilityLabel}
|
2024-06-04 10:57:52 +02:00
|
|
|
>{props.title}</TextButton>
|
2024-04-08 13:36:40 +02:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ActionButton;
|