Browse Source

add confirm to hard reset on the crash screen

master
Anastasia Poupeney 7 years ago
parent
commit
254c07a704
  1. 42
      src/components/RenderError.js
  2. 2
      src/components/SettingsPage/sections/Profile.js
  3. 2
      src/icons/TriangleWarning.js

42
src/components/RenderError.js

@ -14,6 +14,9 @@ import ExportLogsBtn from 'components/ExportLogsBtn'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Space from 'components/base/Space' import Space from 'components/base/Space'
import Button from 'components/base/Button' import Button from 'components/base/Button'
import IconTriangleWarning from 'icons/TriangleWarning'
import ConfirmModal from './base/Modal/ConfirmModal'
import { IconWrapperCircle } from './SettingsPage/sections/Profile'
type Props = { type Props = {
error: Error, error: Error,
@ -22,11 +25,33 @@ type Props = {
children?: *, children?: *,
} }
class RenderError extends PureComponent<Props, { isHardResetting: boolean }> { class RenderError extends PureComponent<
Props,
{ isHardResetting: boolean, isHardResetModalOpened: boolean },
> {
state = { state = {
isHardResetting: false, isHardResetting: false,
isHardResetModalOpened: false,
} }
handleOpenHardResetModal = () => this.setState({ isHardResetModalOpened: true })
handleCloseHardResetModal = () => this.setState({ isHardResetModalOpened: false })
handleHardReset = async () => {
this.setState({ isHardResetting: true })
try {
await hardReset()
remote.getCurrentWindow().webContents.reloadIgnoringCache()
} catch (err) {
this.setState({ isHardResetting: false })
}
}
hardResetIconRender = () => (
<IconWrapperCircle color="alertRed">
<IconTriangleWarning width={23} height={21} />
</IconWrapperCircle>
)
handleCreateIssue = () => { handleCreateIssue = () => {
const { error } = this.props const { error } = this.props
if (!error) { if (!error) {
@ -60,7 +85,7 @@ ${error.stack}
render() { render() {
const { error, t, disableExport, children } = this.props const { error, t, disableExport, children } = this.props
const { isHardResetting } = this.state const { isHardResetting, isHardResetModalOpened } = this.state
return ( return (
<Box align="center" grow> <Box align="center" grow>
<Space of={100} /> <Space of={100} />
@ -88,10 +113,21 @@ ${error.stack}
<Button primary onClick={this.handleCreateIssue}> <Button primary onClick={this.handleCreateIssue}>
{t('app:crash.createTicket')} {t('app:crash.createTicket')}
</Button> </Button>
<Button danger onClick={this.handleHardReset} isLoading={isHardResetting}> <Button danger onClick={this.handleOpenHardResetModal}>
{t('app:crash.reset')} {t('app:crash.reset')}
</Button> </Button>
</Box> </Box>
<ConfirmModal
isDanger
isLoading={isHardResetting}
isOpened={isHardResetModalOpened}
onClose={this.handleCloseHardResetModal}
onReject={this.handleCloseHardResetModal}
onConfirm={this.handleHardReset}
title={t('app:settings.hardResetModal.title')}
desc={t('app:settings.hardResetModal.desc')}
renderIcon={this.hardResetIconRender}
/>
<Box my={6}> <Box my={6}>
<ErrContainer> <ErrContainer>
<strong>{String(error)}</strong> <strong>{String(error)}</strong>

2
src/components/SettingsPage/sections/Profile.js

@ -263,7 +263,7 @@ export default connect(
)(TabProfile) )(TabProfile)
// TODO: need a helper file for common styles across the app // TODO: need a helper file for common styles across the app
const IconWrapperCircle = styled(Box).attrs({})` export const IconWrapperCircle = styled(Box).attrs({})`
width: 50px; width: 50px;
height: 50px; height: 50px;
border-radius: 50%; border-radius: 50%;

2
src/icons/TriangleWarning.js

@ -10,7 +10,7 @@ const path = (
) )
export default ({ height, width, ...p }: { height: number, width: number }) => ( export default ({ height, width, ...p }: { height: number, width: number }) => (
<svg viewBox="0 0 19 17" height={height} width={width} {...p}> <svg viewBox="0 0 17 17" height={height} width={width} {...p}>
{path} {path}
</svg> </svg>
) )

Loading…
Cancel
Save