|
@ -3,7 +3,6 @@ |
|
|
import React, { PureComponent } from 'react' |
|
|
import React, { PureComponent } from 'react' |
|
|
import { translate } from 'react-i18next' |
|
|
import { translate } from 'react-i18next' |
|
|
import { compose } from 'redux' |
|
|
import { compose } from 'redux' |
|
|
import { Motion, spring } from 'react-motion' |
|
|
|
|
|
import { connect } from 'react-redux' |
|
|
import { connect } from 'react-redux' |
|
|
import styled from 'styled-components' |
|
|
import styled from 'styled-components' |
|
|
|
|
|
|
|
@ -12,6 +11,8 @@ import { sendEvent } from 'renderer/events' |
|
|
import type { State } from 'reducers' |
|
|
import type { State } from 'reducers' |
|
|
import type { UpdateStatus } from 'reducers/update' |
|
|
import type { UpdateStatus } from 'reducers/update' |
|
|
|
|
|
|
|
|
|
|
|
import { radii } from 'styles/theme' |
|
|
|
|
|
|
|
|
import Box from 'components/base/Box' |
|
|
import Box from 'components/base/Box' |
|
|
import Text from 'components/base/Text' |
|
|
import Text from 'components/base/Text' |
|
|
|
|
|
|
|
@ -28,18 +29,15 @@ const mapStateToProps = (state: State) => ({ |
|
|
}) |
|
|
}) |
|
|
|
|
|
|
|
|
const Container = styled(Box).attrs({ |
|
|
const Container = styled(Box).attrs({ |
|
|
p: 1, |
|
|
py: 1, |
|
|
|
|
|
px: 3, |
|
|
bg: 'wallet', |
|
|
bg: 'wallet', |
|
|
color: 'white', |
|
|
color: 'white', |
|
|
style: p => ({ |
|
|
style: p => ({ |
|
|
transform: `translate3d(0, ${p.offset}%, 0)`, |
|
|
transform: `translate3d(0, ${p.offset}%, 0)`, |
|
|
}), |
|
|
}), |
|
|
})` |
|
|
})` |
|
|
position: absolute; |
|
|
border-radius: ${radii[1]}px; |
|
|
top: 0; |
|
|
|
|
|
left: 0; |
|
|
|
|
|
right: 0; |
|
|
|
|
|
z-index: 10; |
|
|
|
|
|
` |
|
|
` |
|
|
|
|
|
|
|
|
class UpdateNotifier extends PureComponent<Props> { |
|
|
class UpdateNotifier extends PureComponent<Props> { |
|
@ -57,13 +55,15 @@ class UpdateNotifier extends PureComponent<Props> { |
|
|
return ( |
|
|
return ( |
|
|
<Box horizontal flow={2}> |
|
|
<Box horizontal flow={2}> |
|
|
<Text fontWeight="bold">{t('update:newVersionReady')}</Text> |
|
|
<Text fontWeight="bold">{t('update:newVersionReady')}</Text> |
|
|
|
|
|
<Box ml="auto"> |
|
|
<Text |
|
|
<Text |
|
|
style={{ cursor: 'pointer' }} |
|
|
style={{ cursor: 'pointer', textDecoration: 'underline' }} |
|
|
onClick={() => sendEvent('msg', 'updater:quitAndInstall')} |
|
|
onClick={() => sendEvent('msg', 'updater:quitAndInstall')} |
|
|
> |
|
|
> |
|
|
{t('update:relaunch')} |
|
|
{t('update:relaunch')} |
|
|
</Text> |
|
|
</Text> |
|
|
</Box> |
|
|
</Box> |
|
|
|
|
|
</Box> |
|
|
) |
|
|
) |
|
|
default: |
|
|
default: |
|
|
return null |
|
|
return null |
|
@ -71,18 +71,14 @@ class UpdateNotifier extends PureComponent<Props> { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { updateStatus } = this.props |
|
|
const { updateStatus, ...props } = this.props |
|
|
|
|
|
|
|
|
const isToggled = updateStatus === 'downloaded' |
|
|
const isToggled = updateStatus === 'downloaded' |
|
|
return ( |
|
|
|
|
|
<Motion |
|
|
if (!isToggled) { |
|
|
style={{ |
|
|
return null |
|
|
offset: spring(isToggled ? 0 : -100), |
|
|
} |
|
|
}} |
|
|
return <Container {...props}>{this.renderStatus()}</Container> |
|
|
> |
|
|
|
|
|
{m => <Container offset={m.offset}>{this.renderStatus()}</Container>} |
|
|
|
|
|
</Motion> |
|
|
|
|
|
) |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|