mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-15 09:04:04 +02:00
53 lines
1.2 KiB
JavaScript
53 lines
1.2 KiB
JavaScript
const React = require('react'); const Component = React.Component;
|
|
const { connect } = require('react-redux');
|
|
const { app } = require('../app.js');
|
|
const { bridge } = require('electron').remote.require('./bridge');
|
|
|
|
class NavigatorComponent extends Component {
|
|
|
|
componentWillReceiveProps(newProps) {
|
|
if (newProps.route) {
|
|
const screenInfo = this.props.screens[newProps.route.routeName];
|
|
let windowTitle = ['Joplin'];
|
|
if (screenInfo.title) {
|
|
windowTitle.push(screenInfo.title());
|
|
}
|
|
this.updateWindowTitle(windowTitle.join(' - '));
|
|
}
|
|
}
|
|
|
|
updateWindowTitle(title) {
|
|
bridge().window().setTitle(title);
|
|
}
|
|
|
|
render() {
|
|
if (!this.props.route) throw new Error('Route must not be null');
|
|
|
|
const route = this.props.route;
|
|
const screenProps = route.props ? route.props : {};
|
|
const screenInfo = this.props.screens[route.routeName];
|
|
const Screen = screenInfo.screen;
|
|
|
|
const screenStyle = {
|
|
width: this.props.style.width,
|
|
height: this.props.style.height,
|
|
};
|
|
|
|
return (
|
|
<div style={this.props.style}>
|
|
<Screen style={screenStyle} {...screenProps}/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
}
|
|
|
|
const Navigator = connect(
|
|
(state) => {
|
|
return {
|
|
route: state.route,
|
|
};
|
|
}
|
|
)(NavigatorComponent)
|
|
|
|
module.exports = { Navigator }; |