Browse Source

Improve crash screen design and behaviour

master
meriadec 7 years ago
parent
commit
a9313ec197
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 73
      src/components/RenderError.js
  2. 6
      static/i18n/en/app.yml
  3. 1
      static/images/crash-screen.svg

73
src/components/RenderError.js

@ -1,20 +1,20 @@
// @flow // @flow
import React, { PureComponent } from 'react' import React, { PureComponent } from 'react'
import styled from 'styled-components'
import { shell, remote } from 'electron' import { shell, remote } from 'electron'
import qs from 'querystring' import qs from 'querystring'
import { translate } from 'react-i18next' import { translate } from 'react-i18next'
import { rgba } from 'styles/helpers' import { i } from 'helpers/staticPath'
import db from 'helpers/db' import hardReset from 'helpers/hardReset'
import type { T } from 'types/common' import type { T } from 'types/common'
import ExportLogsBtn from 'components/ExportLogsBtn' import ExportLogsBtn from 'components/ExportLogsBtn'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Space from 'components/base/Space'
import Button from 'components/base/Button' import Button from 'components/base/Button'
import TranslatedError from './TranslatedError' // import TranslatedError from './TranslatedError'
type Props = { type Props = {
error: Error, error: Error,
@ -23,25 +23,11 @@ type Props = {
children?: *, children?: *,
} }
const Container = styled(Box).attrs({ class RenderError extends PureComponent<Props, { isHardResetting: boolean }> {
grow: true, state = {
align: 'center', isHardResetting: false,
justify: 'center', }
bg: 'lightGraphite',
color: 'alertRed',
ff: 'Museo Sans|Bold',
flow: 2,
})``
const Inner = styled(Box).attrs({
p: 2,
bg: p => rgba(p.theme.colors.alertRed, 0.05),
borderRadius: 1,
})`
border: ${p => `1px solid ${rgba(p.theme.colors.alertRed, 0.1)}`};
`
class RenderError extends PureComponent<Props> {
handleCreateIssue = () => { handleCreateIssue = () => {
const { error } = this.props const { error } = this.props
if (!error) { if (!error) {
@ -60,27 +46,45 @@ ${error.stack}
} }
handleRestart = () => { handleRestart = () => {
remote.app.relaunch() remote.getCurrentWindow().webContents.reloadIgnoringCache()
remote.app.exit()
} }
handleReset = () => { handleHardReset = async () => {
db.resetAll() this.setState({ isHardResetting: true })
this.handleRestart() try {
await hardReset()
remote.getCurrentWindow().webContents.reloadIgnoringCache()
} catch (err) {
this.setState({ isHardResetting: false })
}
} }
render() { render() {
const { error, t, disableExport, children } = this.props const { t, disableExport, children } = this.props
const { isHardResetting } = this.state
return ( return (
<Container> <Box align="center" justify="center" grow>
<Inner> <img alt="" src={i('crash-screen.svg')} width={380} />
<TranslatedError error={error} /> <Space of={40} />
</Inner> <Box ff="Museo Sans|Regular" fontSize={7} color="dark">
{t('app:crash.oops')}
</Box>
<Space of={15} />
<Box
style={{ width: 500 }}
textAlign="center"
ff="Open Sans|Regular"
color="smoke"
fontSize={4}
>
{t('app:crash.uselessText')}
</Box>
<Space of={30} />
<Box horizontal flow={2}> <Box horizontal flow={2}>
<Button primary onClick={this.handleRestart}> <Button primary onClick={this.handleRestart}>
{t('app:crash.restart')} {t('app:crash.restart')}
</Button> </Button>
<Button danger onClick={this.handleReset}> <Button danger onClick={this.handleHardReset} isLoading={isHardResetting}>
{t('app:crash.reset')} {t('app:crash.reset')}
</Button> </Button>
{!disableExport ? <ExportLogsBtn /> : null} {!disableExport ? <ExportLogsBtn /> : null}
@ -89,9 +93,10 @@ ${error.stack}
</Button> </Button>
</Box> </Box>
{children} {children}
</Container> </Box>
) )
} }
} }
// <TranslatedError error={error} />
export default translate()(RenderError) export default translate()(RenderError)

6
static/i18n/en/app.yml

@ -368,6 +368,8 @@ update:
newVersionReady: A new update is available. newVersionReady: A new update is available.
relaunch: Update now relaunch: Update now
crash: crash:
oops: Oops, something went wrong.
uselessText: You may try again by restarting Ledger Live. Please export your logs and contact Ledger Support if the problem persists.
restart: Restart app restart: Restart app
reset: Reset app files reset: Hard reset
createTicket: Create ticket createTicket: Create issue

1
static/images/crash-screen.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 28 KiB

Loading…
Cancel
Save