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
import React, { PureComponent } from 'react'
import styled from 'styled-components'
import { shell, remote } from 'electron'
import qs from 'querystring'
import { translate } from 'react-i18next'
import { rgba } from 'styles/helpers'
import db from 'helpers/db'
import { i } from 'helpers/staticPath'
import hardReset from 'helpers/hardReset'
import type { T } from 'types/common'
import ExportLogsBtn from 'components/ExportLogsBtn'
import Box from 'components/base/Box'
import Space from 'components/base/Space'
import Button from 'components/base/Button'
import TranslatedError from './TranslatedError'
// import TranslatedError from './TranslatedError'
type Props = {
error: Error,
@ -23,25 +23,11 @@ type Props = {
children?: *,
}
const Container = styled(Box).attrs({
grow: true,
align: 'center',
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, { isHardResetting: boolean }> {
state = {
isHardResetting: false,
}
class RenderError extends PureComponent<Props> {
handleCreateIssue = () => {
const { error } = this.props
if (!error) {
@ -60,27 +46,45 @@ ${error.stack}
}
handleRestart = () => {
remote.app.relaunch()
remote.app.exit()
remote.getCurrentWindow().webContents.reloadIgnoringCache()
}
handleReset = () => {
db.resetAll()
this.handleRestart()
handleHardReset = async () => {
this.setState({ isHardResetting: true })
try {
await hardReset()
remote.getCurrentWindow().webContents.reloadIgnoringCache()
} catch (err) {
this.setState({ isHardResetting: false })
}
}
render() {
const { error, t, disableExport, children } = this.props
const { t, disableExport, children } = this.props
const { isHardResetting } = this.state
return (
<Container>
<Inner>
<TranslatedError error={error} />
</Inner>
<Box align="center" justify="center" grow>
<img alt="" src={i('crash-screen.svg')} width={380} />
<Space of={40} />
<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}>
<Button primary onClick={this.handleRestart}>
{t('app:crash.restart')}
</Button>
<Button danger onClick={this.handleReset}>
<Button danger onClick={this.handleHardReset} isLoading={isHardResetting}>
{t('app:crash.reset')}
</Button>
{!disableExport ? <ExportLogsBtn /> : null}
@ -89,9 +93,10 @@ ${error.stack}
</Button>
</Box>
{children}
</Container>
</Box>
)
}
}
// <TranslatedError error={error} />
export default translate()(RenderError)

6
static/i18n/en/app.yml

@ -368,6 +368,8 @@ update:
newVersionReady: A new update is available.
relaunch: Update now
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
reset: Reset app files
createTicket: Create ticket
reset: Hard reset
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