mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 20:14:12 +00:00
bf6a122e38
* 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%
76 lines
1.7 KiB
TypeScript
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');
|
|
}
|
|
}
|