mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-12 08:54:00 +02:00
34f0a2951a
* Moved button row to separate component file and started Sharing dialog * Adding Sharing dialog * Applied "npx react-codemod rename-unsafe-lifecycles" * More UI * Tools: Improved TypeScript integration * Improved share dialog * Tools Added support for translation validation in CI, and added support for plural translations * Improved UI and sharing workflow * Share workflow * Cleaned up and improved sharing config error handling * Fixed build scripts and doc for TypeScript * Run linter
46 lines
1.1 KiB
JavaScript
46 lines
1.1 KiB
JavaScript
const React = require('react');
|
|
const { _ } = require('lib/locale.js');
|
|
const { themeStyle } = require('../theme.js');
|
|
|
|
function DialogButtonRow(props) {
|
|
const theme = themeStyle(props.theme);
|
|
|
|
const okButton_click = () => {
|
|
if (props.onClick) props.onClick({ buttonName: 'ok' });
|
|
};
|
|
|
|
const cancelButton_click = () => {
|
|
if (props.onClick) props.onClick({ buttonName: 'cancel' });
|
|
};
|
|
|
|
const onKeyDown = (event) => {
|
|
if (event.keyCode === 13) {
|
|
okButton_click();
|
|
} else if (event.keyCode === 27) {
|
|
cancelButton_click();
|
|
}
|
|
};
|
|
|
|
const buttonComps = [];
|
|
|
|
if (props.okButtonShow !== false) {
|
|
buttonComps.push(
|
|
<button key="ok" style={theme.buttonStyle} onClick={okButton_click} ref={props.okButtonRef} onKeyDown={onKeyDown}>
|
|
{_('OK')}
|
|
</button>
|
|
);
|
|
}
|
|
|
|
if (props.cancelButtonShow !== false) {
|
|
buttonComps.push(
|
|
<button key="cancel" style={Object.assign({}, theme.buttonStyle, { marginLeft: 10 })} onClick={cancelButton_click}>
|
|
{props.cancelButtonLabel ? props.cancelButtonLabel : _('Cancel')}
|
|
</button>
|
|
);
|
|
}
|
|
|
|
return <div style={{ textAlign: 'right', marginTop: 10 }}>{buttonComps}</div>;
|
|
}
|
|
|
|
module.exports = DialogButtonRow;
|