1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-17 18:44:45 +02:00
joplin/packages/app-desktop/gui/ConfigScreen/ButtonBar.tsx

59 lines
2.0 KiB
TypeScript
Raw Normal View History

2020-09-15 15:01:07 +02:00
import * as React from 'react';
import Button, { ButtonLevel } from '../Button/Button';
import { _ } from '@joplin/lib/locale';
2020-09-15 15:01:07 +02:00
const styled = require('styled-components').default;
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied;
type StyleProps = any;
2020-09-15 15:01:07 +02:00
interface Props {
backButtonTitle?: string;
hasChanges?: boolean;
// eslint-disable-next-line @typescript-eslint/ban-types -- Old code before rule was applied
onCancelClick: Function;
// eslint-disable-next-line @typescript-eslint/ban-types -- Old code before rule was applied
onSaveClick?: Function;
// eslint-disable-next-line @typescript-eslint/ban-types -- Old code before rule was applied
onApplyClick?: Function;
2020-09-15 15:01:07 +02:00
}
export const StyledRoot = styled.div`
display: flex;
align-items: center;
padding: 10px;
background-color: ${(props: StyleProps) => props.theme.backgroundColor3};
padding-left: ${(props: StyleProps) => props.theme.configScreenPadding}px;
2020-09-15 15:01:07 +02:00
border-top-width: 1px;
border-top-style: solid;
border-top-color: ${(props: StyleProps) => props.theme.dividerColor};
2020-09-15 15:01:07 +02:00
`;
export default function ButtonBar(props: Props) {
2020-09-15 15:01:07 +02:00
function renderOkButton() {
if (!props.onSaveClick) return null;
return <Button style={{ marginRight: 10 }} level={ButtonLevel.Primary} disabled={!props.hasChanges} onClick={props.onSaveClick} title={_('OK')}/>;
}
function renderApplyButton() {
if (!props.onApplyClick) return null;
return <Button level={ButtonLevel.Primary} disabled={!props.hasChanges} onClick={props.onApplyClick} title={_('Apply')}/>;
}
return (
<StyledRoot>
<Button
onClick={props.onCancelClick}
level={ButtonLevel.Secondary}
iconName="fa fa-chevron-left"
title={props.backButtonTitle ? props.backButtonTitle : _('Back')}
/>
{ (props.onApplyClick || props.onSaveClick) && (
<div style={{ display: 'flex', flexDirection: 'row', marginLeft: 30 }}>
{renderOkButton()}
{renderApplyButton()}
</div>
)}
</StyledRoot>
);
}