2019-07-29 14:13:23 +02:00
|
|
|
const React = require('react');
|
2017-11-06 18:35:04 +00:00
|
|
|
const { connect } = require('react-redux');
|
2023-01-19 17:19:06 +00:00
|
|
|
import Setting from '@joplin/lib/models/Setting';
|
|
|
|
import { AppState } from '../app.reducer';
|
2021-10-01 19:35:27 +01:00
|
|
|
const bridge = require('@electron/remote').require('./bridge').default;
|
2017-11-06 18:35:04 +00:00
|
|
|
|
2023-01-19 17:19:06 +00:00
|
|
|
interface Props {
|
|
|
|
route: any;
|
|
|
|
}
|
|
|
|
|
|
|
|
class NavigatorComponent extends React.Component<Props> {
|
2023-03-06 14:22:01 +00:00
|
|
|
public UNSAFE_componentWillReceiveProps(newProps: Props) {
|
2017-11-12 16:47:33 +00:00
|
|
|
if (newProps.route) {
|
2021-05-04 10:34:18 +02:00
|
|
|
const screenInfo = this.props.screens[newProps.route.routeName];
|
2021-08-12 16:54:10 +01:00
|
|
|
const devMarker = Setting.value('env') === 'dev' ? ` (DEV - ${Setting.value('profileDir')})` : '';
|
2021-05-04 10:34:18 +02:00
|
|
|
const windowTitle = [`Joplin${devMarker}`];
|
|
|
|
if (screenInfo.title) {
|
|
|
|
windowTitle.push(screenInfo.title());
|
|
|
|
}
|
|
|
|
this.updateWindowTitle(windowTitle.join(' - '));
|
2017-11-12 16:47:33 +00:00
|
|
|
}
|
|
|
|
}
|
2021-05-04 10:34:18 +02:00
|
|
|
|
2023-03-06 14:22:01 +00:00
|
|
|
public updateWindowTitle(title: string) {
|
2019-03-03 00:31:41 +00:00
|
|
|
try {
|
2019-09-10 23:53:01 +00:00
|
|
|
if (bridge().window()) bridge().window().setTitle(title);
|
2019-03-03 00:31:41 +00:00
|
|
|
} catch (error) {
|
|
|
|
console.warn('updateWindowTitle', error);
|
|
|
|
}
|
2017-11-12 16:47:33 +00:00
|
|
|
}
|
|
|
|
|
2023-03-06 14:22:01 +00:00
|
|
|
public render() {
|
2017-11-06 18:35:04 +00:00
|
|
|
if (!this.props.route) throw new Error('Route must not be null');
|
|
|
|
|
|
|
|
const route = this.props.route;
|
2017-11-11 17:36:47 +00:00
|
|
|
const screenProps = route.props ? route.props : {};
|
2017-11-12 16:47:33 +00:00
|
|
|
const screenInfo = this.props.screens[route.routeName];
|
|
|
|
const Screen = screenInfo.screen;
|
2017-11-06 18:35:04 +00:00
|
|
|
|
|
|
|
const screenStyle = {
|
|
|
|
width: this.props.style.width,
|
|
|
|
height: this.props.style.height,
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
2022-04-16 15:13:17 +01:00
|
|
|
<div style={this.props.style} className={this.props.className}>
|
2019-07-29 14:13:23 +02:00
|
|
|
<Screen style={screenStyle} {...screenProps} />
|
2017-11-06 18:35:04 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-19 17:19:06 +00:00
|
|
|
const Navigator = connect((state: AppState) => {
|
2019-07-29 14:13:23 +02:00
|
|
|
return {
|
|
|
|
route: state.route,
|
|
|
|
};
|
|
|
|
})(NavigatorComponent);
|
2017-11-06 18:35:04 +00:00
|
|
|
|
2023-01-19 17:19:06 +00:00
|
|
|
export default Navigator;
|