joplin/ElectronClient/app/gui/ClipperConfigScreen.jsx

101 lines
15 KiB
React
Raw Normal View History

const React = require('react');
const { connect } = require('react-redux');
const { reg } = require('lib/registry.js');
const { bridge } = require('electron').remote.require('./bridge');
const { Header } = require('./Header.min.js');
const { themeStyle } = require('../theme.js');
const { _ } = require('lib/locale.js');
const ClipperServer = require('lib/ClipperServer');
const Setting = require('lib/models/Setting');
class ClipperConfigScreenComponent extends React.Component {
disableClipperServer_click() {
Setting.setValue('clipperServer.autoStart', false);
ClipperServer.instance().stop();
}
enableClipperServer_click() {
Setting.setValue('clipperServer.autoStart', true);
ClipperServer.instance().start();
}
chromeButton_click() {
bridge().openExternal("https://chrome.google.com/webstore/detail/joplin-web-clipper/alofnhikmmkdbbbgpnglcpdollgjjfek")
}
firefoxButton_click() {
bridge().openExternal("https://addons.mozilla.org/en-US/firefox/addon/joplin-web-clipper/");
}
render() {
const style = this.props.style;
const theme = themeStyle(this.props.theme);
const headerStyle = {
width: style.width,
};
const stepBoxStyle = {
border: "1px solid #ccc",
padding: 15,
paddingTop: 0,
marginBottom: 15,
};
let webClipperStatusComps = [];
if (this.props.clipperServerAutoStart) {
2018-05-26 16:25:11 +00:00
webClipperStatusComps.push(<p key="text_1" style={theme.textStyle}><b>{_('The web clipper service is enabled and set to auto-start.')}</b></p>)
if (this.props.clipperServer.startState === 'started') {
webClipperStatusComps.push(<p key="text_2" style={theme.textStyle}>{_('Status: Started on port %d', this.props.clipperServer.port)}</p>)
} else {
webClipperStatusComps.push(<p key="text_3" style={theme.textStyle}>{_('Status: %s', this.props.clipperServer.startState)}</p>)
}
webClipperStatusComps.push(<button key="disable_button" onClick={this.disableClipperServer_click}>{_('Disable Web Clipper Service')}</button>)
} else {
webClipperStatusComps.push(<p key="text_4" style={theme.textStyle}>{_('The web clipper service is not enabled.')}</p>)
webClipperStatusComps.push(<button key="enable_button" onClick={this.enableClipperServer_click}>{_('Enable Web Clipper Service')}</button>)
}
return (
<div>
<Header style={headerStyle} />
<div style={{padding: theme.margin}}>
<p style={theme.textStyle}>{_('Joplin Web Clipper allows saving web pages and screenshots from your browser to Joplin.')}</p>
<p style={theme.textStyle}>{_('In order to use the web clipper, you need to do the following:')}</p>
<div style={stepBoxStyle}>
<p style={theme.h1Style}>{_('Step 1: Enable the clipper service')}</p>
<p style={theme.textStyle}>{_('This service allows the browser extension to communicate with Joplin. When enabling it your firewall may ask you to give permission to Joplin to listen to a particular port.')}</p>
<div>
{webClipperStatusComps}
</div>
</div>
<div style={stepBoxStyle}>
<p style={theme.h1Style}>{_('Step 2: Install the extension')}</p>
<p style={theme.textStyle}>{_('Download and install the relevant extension for your browser:')}</p>
<div>
<p><a href='#' onClick={this.chromeButton_click}><img src="
<p><a href='#' onClick={this.firefoxButton_click}><img src="
</div>
</div>
</div>
</div>
);
}
}
const mapStateToProps = (state) => {
return {
theme: state.settings.theme,
clipperServer: state.clipperServer,
clipperServerAutoStart: state.settings['clipperServer.autoStart'],
};
};
const ClipperConfigScreen = connect(mapStateToProps)(ClipperConfigScreenComponent);
module.exports = { ClipperConfigScreen };