1
0
mirror of https://github.com/laurent22/joplin.git synced 2024-12-30 10:36:35 +02:00
joplin/packages/app-desktop/services/plugins/UserWebviewDialogButtonBar.tsx

56 lines
1.4 KiB
TypeScript

import * as React from 'react';
import Button from '../../gui/Button/Button';
import { _ } from '@joplin/lib/locale';
import { ButtonSpec } from '@joplin/lib/services/plugins/api/types';
const styled = require('styled-components').default;
const { space } = require('styled-system');
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
type StyleProps = any;
interface Props {
buttons: ButtonSpec[];
}
const StyledRoot = styled.div`
display: flex;
width: 100%;
box-sizing: border-box;
justify-content: flex-end;
padding-top: ${(props: StyleProps) => props.theme.mainPadding}px;
`;
const StyledButton = styled(Button)`${space}`;
function buttonTitle(b: ButtonSpec) {
if (b.title) return b.title;
const defaultTitles: Record<string, string> = {
'ok': _('OK'),
'cancel': _('Cancel'),
'yes': _('Yes'),
'no': _('No'),
'close': _('Close'),
};
return defaultTitles[b.id] ? defaultTitles[b.id] : b.id;
}
export default function UserWebviewDialogButtonBar(props: Props) {
function renderButtons() {
const output = [];
for (let i = 0; i < props.buttons.length; i++) {
const b = props.buttons[i];
const marginRight = i !== props.buttons.length - 1 ? '6px' : '0px';
output.push(<StyledButton key={b.id} onClick={b.onClick} title={buttonTitle(b)} mr={marginRight}/>);
}
return output;
}
return (
<StyledRoot>
{renderButtons()}
</StyledRoot>
);
}