MyCrypto/common/components/NewAppReleaseModal.tsx
William O'Beirne bf6a122e38 Night Mode Theme (#1896)
* Initial changes to define theme maps, color function, and convert all global styles.

* More global styles.

* All styles converted, colors uncertain.

* Fix tabs, temporary theme toggle button.

* Color refinements

* Color network selector, introduce shade function

* Make palette page

* Add theme button and minor styling to nav

* Blueify dark theme

* A bunch of color adjustments to work better with dark theme

* Fix tables

* Fix wallet decrypt colors

* More misc fixes

* Fix up electron colors

* Convert web theme to redux state / action

* Theme toggle in app, prevent rerenders

* Get rid of all variables, fix selects

* Fix conf modal, modal close styles

* Fix test

* Adjust swap colors

* Check in breaking out component, changing icons

* Check in progress

* Theme toggle in footer. New icons

* Prevent rerender on theme change

* Fix up outstanding merge conflicts

* Fix generate colors to be dark mode friendly

* Reduce swap color intensity

* Make disabled buttons darker in dark mode

* Reduce button size by 25%
2018-06-26 23:51:42 -05:00

76 lines
1.7 KiB
TypeScript

import React from 'react';
import translate, { translateRaw } from 'translations';
import Modal, { IButton } from 'components/ui/Modal';
import { getLatestElectronRelease } from 'utils/versioning';
import { VERSION } from 'config/data';
interface State {
isOpen: boolean;
newRelease?: string;
}
export default class NewAppReleaseModal extends React.PureComponent<{}, State> {
public state: State = {
isOpen: false
};
public async componentDidMount() {
try {
const newRelease = await getLatestElectronRelease();
if (newRelease) {
this.setState({ isOpen: true, newRelease });
}
} catch (err) {
console.error('Failed to fetch latest release from GitHub:', err);
}
}
public render() {
const { isOpen } = this.state;
const buttons: IButton[] = [
{
text: translate('APP_UPDATE_CONFIRM'),
type: 'primary',
onClick: this.openRelease
},
{
text: translate('APP_UPDATE_CANCEL'),
type: 'default',
onClick: this.close
}
];
return (
<Modal
title={translateRaw('APP_UPDATE_TITLE')}
isOpen={isOpen}
buttons={buttons}
handleClose={this.close}
maxWidth={520}
>
<h4>
{translateRaw('APP_UPDATE_BODY')} {this.versionCompareStr()}
</h4>
</Modal>
);
}
private versionCompareStr() {
return (
<>
<h5>Current Version: {VERSION}</h5>
<h5>New Version: {this.state.newRelease}</h5>
</>
);
}
private close = () => {
this.setState({ isOpen: false });
};
private openRelease() {
window.open('https://github.com/MyCryptoHQ/MyCrypto/releases/latest');
}
}