|
@ -1,6 +1,7 @@ |
|
|
// @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' |
|
@ -21,7 +22,7 @@ import { IconWrapperCircle } from './SettingsPage/sections/Profile' |
|
|
type Props = { |
|
|
type Props = { |
|
|
error: Error, |
|
|
error: Error, |
|
|
t: T, |
|
|
t: T, |
|
|
disableExport?: boolean, |
|
|
withoutAppData?: boolean, |
|
|
children?: *, |
|
|
children?: *, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -75,7 +76,7 @@ ${error.stack} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { error, t, disableExport, children } = this.props |
|
|
const { error, t, withoutAppData, children } = this.props |
|
|
const { isHardResetting, isHardResetModalOpened } = this.state |
|
|
const { isHardResetting, isHardResetModalOpened } = this.state |
|
|
return ( |
|
|
return ( |
|
|
<Box align="center" grow> |
|
|
<Box align="center" grow> |
|
@ -100,7 +101,7 @@ ${error.stack} |
|
|
<Button primary onClick={this.handleRestart}> |
|
|
<Button primary onClick={this.handleRestart}> |
|
|
{t('app:crash.restart')} |
|
|
{t('app:crash.restart')} |
|
|
</Button> |
|
|
</Button> |
|
|
{!disableExport ? <ExportLogsBtn /> : null} |
|
|
<ExportLogsBtn withoutAppData={withoutAppData} /> |
|
|
<Button primary onClick={this.handleCreateIssue}> |
|
|
<Button primary onClick={this.handleCreateIssue}> |
|
|
{t('app:crash.createTicket')} |
|
|
{t('app:crash.createTicket')} |
|
|
</Button> |
|
|
</Button> |
|
@ -120,10 +121,8 @@ ${error.stack} |
|
|
renderIcon={this.hardResetIconRender} |
|
|
renderIcon={this.hardResetIconRender} |
|
|
/> |
|
|
/> |
|
|
<Box my={6}> |
|
|
<Box my={6}> |
|
|
<ErrContainer> |
|
|
<ErrContainer>{`${String(error)} |
|
|
<strong>{String(error)}</strong> |
|
|
${error.stack || 'no stacktrace'}`}</ErrContainer>
|
|
|
<div>{error.stack || 'no stacktrace'}</div> |
|
|
|
|
|
</ErrContainer> |
|
|
|
|
|
</Box> |
|
|
</Box> |
|
|
<pre |
|
|
<pre |
|
|
style={{ |
|
|
style={{ |
|
@ -142,21 +141,15 @@ ${error.stack} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const ErrContainer = ({ children }: { children: any }) => ( |
|
|
const ErrContainer = styled.pre` |
|
|
<pre |
|
|
margin: auto; |
|
|
style={{ |
|
|
max-width: 80vw; |
|
|
margin: 'auto', |
|
|
overflow: auto; |
|
|
maxWidth: '80vw', |
|
|
font-size: 10px; |
|
|
overflow: 'auto', |
|
|
font-family: monospace; |
|
|
fontSize: 10, |
|
|
cursor: text; |
|
|
fontFamily: 'monospace', |
|
|
user-select: text; |
|
|
cursor: 'text', |
|
|
opacity: 0.3; |
|
|
userSelect: 'text', |
|
|
` |
|
|
opacity: 0.3, |
|
|
|
|
|
}} |
|
|
|
|
|
> |
|
|
|
|
|
{children} |
|
|
|
|
|
</pre> |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
export default translate()(RenderError) |
|
|
export default translate()(RenderError) |
|
|