2020-05-28 17:47:18 +08:00
|
|
|
// @flow
|
|
|
|
import React from 'react';
|
|
|
|
import { ipcRenderer } from 'electron';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
|
|
|
|
type Props = {};
|
|
|
|
|
|
|
|
type State = {
|
|
|
|
hoverUrl: string,
|
|
|
|
show: boolean,
|
|
|
|
};
|
|
|
|
|
|
|
|
class StatusBar extends React.PureComponent<Props, State> {
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
this.state = {
|
|
|
|
hoverUrl: '',
|
|
|
|
show: false,
|
|
|
|
};
|
|
|
|
(this: any).handleUrlChange = this.handleUrlChange.bind(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
ipcRenderer.on('update-target-url', this.handleUrlChange);
|
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
ipcRenderer.removeListener('update-target-url', this.handleUrlChange);
|
|
|
|
}
|
|
|
|
|
|
|
|
handleUrlChange(event: any, url: string) {
|
|
|
|
// We want to retain the previous URL so that it can fade out
|
|
|
|
// without the component collapsing.
|
|
|
|
if (url === '') {
|
|
|
|
this.setState({ show: false });
|
|
|
|
} else {
|
|
|
|
this.setState({ show: true });
|
|
|
|
this.setState({ hoverUrl: url });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { hoverUrl, show } = this.state;
|
2021-03-09 23:38:27 +08:00
|
|
|
return <div className={classnames('status-bar', { visible: show })}>{decodeURI(hoverUrl)}</div>;
|
2020-05-28 17:47:18 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default StatusBar;
|