Summary: I didn't update the render logic accordingly after figuring out how the internal update endpoint works. This closes that gap. Reviewed By: danielbuechele Differential Revision: D17316892 fbshipit-source-id: 1e6c4dd17b342b2a062cea90d763be01ed6fc1ec
118 lines
2.8 KiB
TypeScript
118 lines
2.8 KiB
TypeScript
/**
|
|
* Copyright 2018-present Facebook.
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
* @format
|
|
*/
|
|
|
|
import {LauncherMsg} from '../reducers/application';
|
|
import {colors, FlexRow, Glyph, styled} from 'flipper';
|
|
import Tooltip from '../ui/components/Tooltip';
|
|
import isProduction from '../utils/isProduction';
|
|
import {
|
|
checkForUpdate,
|
|
VersionCheckResult,
|
|
} from '../utils/publicVersionChecker';
|
|
import {reportPlatformFailures} from '../utils/metrics';
|
|
import React from 'react';
|
|
import {shell} from 'electron';
|
|
import config from '../utils/processConfig';
|
|
|
|
const Container = styled(FlexRow)({
|
|
alignItems: 'center',
|
|
marginLeft: 4,
|
|
});
|
|
|
|
type Props = {
|
|
launcherMsg: LauncherMsg;
|
|
version: string;
|
|
};
|
|
|
|
type State = {
|
|
versionCheckResult: VersionCheckResult;
|
|
};
|
|
|
|
function getSeverityColor(severity: 'warning' | 'error'): string {
|
|
switch (severity) {
|
|
case 'warning':
|
|
return colors.light30;
|
|
case 'error':
|
|
return colors.cherry;
|
|
}
|
|
}
|
|
|
|
export default class UpdateIndicator extends React.PureComponent<Props, State> {
|
|
state = {
|
|
versionCheckResult: {kind: 'up-to-date'} as VersionCheckResult,
|
|
};
|
|
|
|
renderMessage(): React.ReactNode {
|
|
if (this.props.launcherMsg.message.length == 0) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<Container>
|
|
<span title={this.props.launcherMsg.message}>
|
|
<Glyph
|
|
color={getSeverityColor(this.props.launcherMsg.severity)}
|
|
name="caution-triangle"
|
|
/>
|
|
</span>
|
|
</Container>
|
|
);
|
|
}
|
|
|
|
renderUpdateIndicator(): React.ReactNode {
|
|
const result = this.state.versionCheckResult;
|
|
if (result.kind !== 'update-available') {
|
|
return null;
|
|
}
|
|
|
|
const container = (
|
|
<Container>
|
|
<span onClick={() => shell.openExternal(result.url)}>
|
|
<Glyph
|
|
color={getSeverityColor(this.props.launcherMsg.severity)}
|
|
name="caution-triangle"
|
|
/>
|
|
</span>
|
|
</Container>
|
|
);
|
|
return (
|
|
<Tooltip
|
|
options={{position: 'toLeft'}}
|
|
title={`Update to Flipper v${
|
|
result.version
|
|
} available. Click to download.`}
|
|
children={container}
|
|
/>
|
|
);
|
|
}
|
|
|
|
componentDidMount() {
|
|
if (isProduction() && config().launcherEnabled) {
|
|
reportPlatformFailures(
|
|
checkForUpdate(this.props.version).then(res => {
|
|
if (res.kind === 'error') {
|
|
console.warn('Version check failure: ', res.msg);
|
|
throw new Error(res.msg);
|
|
}
|
|
|
|
this.setState({versionCheckResult: res});
|
|
}),
|
|
'publicVersionCheck',
|
|
);
|
|
}
|
|
}
|
|
|
|
render(): React.ReactNode {
|
|
return (
|
|
<>
|
|
{this.renderMessage()}
|
|
{this.renderUpdateIndicator()}
|
|
</>
|
|
);
|
|
}
|
|
}
|