mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-08 13:06:15 +02:00
56 lines
1.4 KiB
TypeScript
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>
|
|
);
|
|
}
|