1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Fix text field labels of first time flow. Add text fields to storybook (#4389)

This commit is contained in:
Alexander Tseung 2018-05-29 09:35:18 -05:00 committed by GitHub
parent c665fe191d
commit d1f5d8ccc6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 84 additions and 44 deletions

View File

@ -143,6 +143,7 @@ class CreatePasswordScreen extends Component {
autoComplete="new-password" autoComplete="new-password"
margin="normal" margin="normal"
fullWidth fullWidth
largeLabel
/> />
<TextField <TextField
id="confirm-password" id="confirm-password"
@ -155,6 +156,7 @@ class CreatePasswordScreen extends Component {
autoComplete="confirm-password" autoComplete="confirm-password"
margin="normal" margin="normal"
fullWidth fullWidth
largeLabel
/> />
<button <button
className="first-time-flow__button" className="first-time-flow__button"

View File

@ -146,6 +146,7 @@ class ImportSeedPhraseScreen extends Component {
error={passwordError} error={passwordError}
autoComplete="new-password" autoComplete="new-password"
margin="normal" margin="normal"
largeLabel
/> />
<TextField <TextField
id="confirm-password" id="confirm-password"
@ -157,6 +158,7 @@ class ImportSeedPhraseScreen extends Component {
error={confirmPasswordError} error={confirmPasswordError}
autoComplete="confirm-password" autoComplete="confirm-password"
margin="normal" margin="normal"
largeLabel
/> />
<button <button
className="first-time-flow__button" className="first-time-flow__button"

View File

@ -1,8 +1,15 @@
import React, { Component } from 'react' import React from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import { withStyles } from '@material-ui/core/styles' import { withStyles } from '@material-ui/core/styles'
import { default as MaterialTextField } from '@material-ui/core/TextField' import { default as MaterialTextField } from '@material-ui/core/TextField'
const inputLabelBase = {
transform: 'none',
transition: 'none',
position: 'initial',
color: '#5b5b5b',
}
const styles = { const styles = {
materialLabel: { materialLabel: {
'&$materialFocused': { '&$materialFocused': {
@ -46,57 +53,57 @@ const styles = {
border: '1px solid #2f9ae0', border: '1px solid #2f9ae0',
}, },
}, },
largeInputLabel: {
...inputLabelBase,
fontSize: '1rem',
},
inputLabel: { inputLabel: {
...inputLabelBase,
fontSize: '.75rem', fontSize: '.75rem',
transform: 'none',
transition: 'none',
position: 'initial',
color: '#5b5b5b',
}, },
} }
class TextField extends Component { const TextField = props => {
static defaultProps = { const { error, classes, material, startAdornment, largeLabel, ...textFieldProps } = props
error: null,
}
static propTypes = { return (
error: PropTypes.string, <MaterialTextField
classes: PropTypes.object, error={Boolean(error)}
material: PropTypes.bool, helperText={error}
startAdornment: PropTypes.element, InputLabelProps={{
} shrink: material ? undefined : true,
className: material ? '' : (largeLabel ? classes.largeInputLabel : classes.inputLabel),
FormLabelClasses: {
root: material ? classes.materialLabel : classes.formLabel,
focused: material ? classes.materialFocused : classes.formLabelFocused,
error: classes.materialError,
},
}}
InputProps={{
startAdornment: startAdornment || undefined,
disableUnderline: !material,
classes: {
root: material ? '' : classes.inputRoot,
input: material ? '' : classes.input,
underline: material ? classes.materialUnderline : '',
focused: material ? '' : classes.inputFocused,
},
}}
{...textFieldProps}
/>
)
}
render () { TextField.defaultProps = {
const { error, classes, material, startAdornment, ...textFieldProps } = this.props error: null,
}
return ( TextField.propTypes = {
<MaterialTextField error: PropTypes.string,
error={Boolean(error)} classes: PropTypes.object,
helperText={error} material: PropTypes.bool,
InputLabelProps={{ startAdornment: PropTypes.element,
shrink: material ? undefined : true, largeLabel: PropTypes.bool,
className: material ? '' : classes.inputLabel,
FormLabelClasses: {
root: material ? classes.materialLabel : classes.formLabel,
focused: material ? classes.materialFocused : classes.formLabelFocused,
error: classes.materialError,
},
}}
InputProps={{
startAdornment: startAdornment || undefined,
disableUnderline: !material,
classes: {
root: material ? '' : classes.inputRoot,
input: material ? '' : classes.input,
underline: material ? classes.materialUnderline : '',
focused: material ? '' : classes.inputFocused,
},
}}
{...textFieldProps}
/>
)
}
} }
export default withStyles(styles)(TextField) export default withStyles(styles)(TextField)

View File

@ -22,3 +22,32 @@ storiesOf('TextField', module)
error="Invalid value" error="Invalid value"
/> />
) )
.add('Mascara text', () =>
<TextField
label="Text"
type="text"
largeLabel
/>
)
.add('Material text', () =>
<TextField
label="Text"
type="text"
material
/>
)
.add('Material password', () =>
<TextField
label="Password"
type="password"
material
/>
)
.add('Material error', () =>
<TextField
type="text"
label="Name"
error="Invalid value"
material
/>
)