Browse Source

Merge pull request #308 from NastiaS/lockScreenBranch

lock screen design implementation
master
Gaëtan Renaudeau 7 years ago
committed by GitHub
parent
commit
6eb21d5505
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 60
      src/components/IsUnlocked.js
  2. 42
      src/icons/LockScreen.js
  3. 5
      static/i18n/en/common.yml

60
src/components/IsUnlocked.js

@ -4,10 +4,14 @@ import bcrypt from 'bcryptjs'
import React, { Component } from 'react' import React, { Component } from 'react'
import { connect } from 'react-redux' import { connect } from 'react-redux'
import { compose } from 'redux' import { compose } from 'redux'
import styled from 'styled-components'
import { translate } from 'react-i18next' import { translate } from 'react-i18next'
import type { Account } from '@ledgerhq/wallet-common/lib/types' import type { Account } from '@ledgerhq/wallet-common/lib/types'
import type { Settings, T } from 'types/common' import type { Settings, T } from 'types/common'
import IconLockScreen from 'icons/LockScreen'
import { ErrorMessageInput } from 'components/base/Input'
import get from 'lodash/get' import get from 'lodash/get'
@ -43,6 +47,7 @@ type Props = {
} }
type State = { type State = {
inputValue: InputValue, inputValue: InputValue,
incorrectPassword: boolean,
} }
const mapStateToProps = state => ({ const mapStateToProps = state => ({
@ -61,8 +66,27 @@ const defaultState = {
inputValue: { inputValue: {
password: '', password: '',
}, },
incorrectPassword: false,
} }
export const PageTitle = styled(Box).attrs({
width: 152,
height: 27,
ff: 'Museo Sans|Regular',
fontSize: 7,
color: 'dark',
})``
export const LockScreenDesc = styled(Box).attrs({
width: 340,
height: 36,
ff: 'Open Sans|Regular',
fontSize: 4,
textAlign: 'center',
color: 'smoke',
})`
margin: 10px auto 25px;
`
class IsUnlocked extends Component<Props, State> { class IsUnlocked extends Component<Props, State> {
state = { state = {
...defaultState, ...defaultState,
@ -121,6 +145,8 @@ class IsUnlocked extends Component<Props, State> {
this.setState({ this.setState({
...defaultState, ...defaultState,
}) })
} else {
this.setState({ incorrectPassword: true })
} }
} }
@ -133,22 +159,36 @@ class IsUnlocked extends Component<Props, State> {
_input: ?HTMLInputElement _input: ?HTMLInputElement
render() { render() {
const { inputValue } = this.state const { inputValue, incorrectPassword } = this.state
const { isLocked, t } = this.props const { isLocked, t } = this.props
if (isLocked) { if (isLocked) {
return ( return (
<Box sticky alignItems="center" justifyContent="center" onClick={this.handleFocusInput}> <Box sticky alignItems="center" justifyContent="center" onClick={this.handleFocusInput}>
<form onSubmit={this.handleSubmit}> <form onSubmit={this.handleSubmit}>
<Box> <Box align="center">
<InputPassword <IconLockScreen size={136} />
autoFocus <PageTitle>{t('common:lockScreen.title')}</PageTitle>
innerRef={(n: any) => (this._input = n)} <LockScreenDesc>
placeholder={t('common:password')} {t('common:lockScreen.subTitle')}
type="password" <br />
onChange={this.handleChangeInput('password')} {t('common:lockScreen.description')}
value={inputValue.password} </LockScreenDesc>
/> <Box style={{ minWidth: 230 }}>
<InputPassword
autoFocus
innerRef={(n: any) => (this._input = n)}
placeholder={t('common:lockScreen.inputPlaceholder')}
type="password"
onChange={this.handleChangeInput('password')}
value={inputValue.password}
/>
{incorrectPassword && (
<ErrorMessageInput>
{t('password:errorMessageIncorrectPassword')}
</ErrorMessageInput>
)}
</Box>
</Box> </Box>
</form> </form>
</Box> </Box>

42
src/icons/LockScreen.js

@ -0,0 +1,42 @@
// @flow
/* this icon is a placeholder for now */
import React from 'react'
export default ({ size, ...p }: { size: number }) => (
<svg width={size} height={size} {...p}>
<defs>
<filter
id="a"
width="178.9%"
height="178.9%"
x="-39.4%"
y="-37.2%"
filterUnits="objectBoundingBox"
>
<feOffset dy="2" in="SourceAlpha" result="shadowOffsetOuter1" />
<feGaussianBlur in="shadowOffsetOuter1" result="shadowBlurOuter1" stdDeviation="11.5" />
<feColorMatrix
in="shadowBlurOuter1"
result="shadowMatrixOuter1"
values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.0787760417 0"
/>
<feMerge>
<feMergeNode in="shadowMatrixOuter1" />
<feMergeNode in="SourceGraphic" />
</feMerge>
</filter>
</defs>
<g fill="none" fillRule="evenodd" filter="url(#a)" transform="translate(23 21)">
<rect width="90" height="90" fill="#FFF" rx="20" />
<path fill="#6490F1" d="M45 13.36c-17.475 0-31.64 14.165-31.64 31.64S27.524 76.64 45 76.64" />
<path fill="#142533" fillOpacity=".1" d="M13.36 45c0 17.475 14.165 31.64 31.64 31.64V45" />
<path
fill="#142533"
fillOpacity=".1"
d="M22.845 67.59c5.708 5.598 13.528 9.05 22.155 9.05V45"
/>
</g>
</svg>
)

5
static/i18n/en/common.yml

@ -18,3 +18,8 @@ retry: Retry
close: Close close: Close
eastern: Eastern eastern: Eastern
western: Western western: Western
lockScreen:
title: Welcome Back
subTitle: Your application is locked
description: Please enter your password to continue
inputPlaceholder: Type your password

Loading…
Cancel
Save