aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components/text-field/text-field.component.js
diff options
context:
space:
mode:
authorBruno <brunobar79@gmail.com>2018-05-31 10:27:33 +0800
committerBruno <brunobar79@gmail.com>2018-05-31 10:27:33 +0800
commitde9672726833e26ea96d198c0d9f1464015614f5 (patch)
tree5a213d4ff8269fe52c9e561fe8da6fefb4e03d09 /ui/app/components/text-field/text-field.component.js
parent3dd58463caef98c2cc1f068931624795a43912db (diff)
parent39d22a4ddb4ba0f4ad456009c86486a433c6724e (diff)
downloadtangerine-wallet-browser-de9672726833e26ea96d198c0d9f1464015614f5.tar.gz
tangerine-wallet-browser-de9672726833e26ea96d198c0d9f1464015614f5.tar.zst
tangerine-wallet-browser-de9672726833e26ea96d198c0d9f1464015614f5.zip
Merge remote-tracking branch 'upstream/develop' into develop
Diffstat (limited to 'ui/app/components/text-field/text-field.component.js')
-rw-r--r--ui/app/components/text-field/text-field.component.js78
1 files changed, 64 insertions, 14 deletions
diff --git a/ui/app/components/text-field/text-field.component.js b/ui/app/components/text-field/text-field.component.js
index 6fd3b82b4..2c72d8124 100644
--- a/ui/app/components/text-field/text-field.component.js
+++ b/ui/app/components/text-field/text-field.component.js
@@ -1,45 +1,92 @@
import React from 'react'
import PropTypes from 'prop-types'
-import { withStyles } from 'material-ui/styles'
-import { default as MaterialTextField } from 'material-ui/TextField'
+import { withStyles } from '@material-ui/core/styles'
+import { default as MaterialTextField } from '@material-ui/core/TextField'
+
+const inputLabelBase = {
+ transform: 'none',
+ transition: 'none',
+ position: 'initial',
+ color: '#5b5b5b',
+}
const styles = {
- cssLabel: {
- '&$cssFocused': {
+ materialLabel: {
+ '&$materialFocused': {
color: '#aeaeae',
},
- '&$cssError': {
+ '&$materialError': {
color: '#aeaeae',
},
fontWeight: '400',
color: '#aeaeae',
},
- cssFocused: {},
- cssUnderline: {
+ materialFocused: {},
+ materialUnderline: {
'&:after': {
- backgroundColor: '#f7861c',
+ borderBottom: '2px solid #f7861c',
+ },
+ },
+ materialError: {},
+ // Non-material styles
+ formLabel: {
+ '&$formLabelFocused': {
+ color: '#5b5b5b',
+ },
+ '&$materialError': {
+ color: '#5b5b5b',
},
},
- cssError: {},
+ formLabelFocused: {},
+ inputFocused: {},
+ inputRoot: {
+ 'label + &': {
+ marginTop: '8px',
+ },
+ border: '1px solid #d2d8dd',
+ height: '48px',
+ borderRadius: '4px',
+ padding: '0 16px',
+ display: 'flex',
+ alignItems: 'center',
+ '&$inputFocused': {
+ border: '1px solid #2f9ae0',
+ },
+ },
+ largeInputLabel: {
+ ...inputLabelBase,
+ fontSize: '1rem',
+ },
+ inputLabel: {
+ ...inputLabelBase,
+ fontSize: '.75rem',
+ },
}
const TextField = props => {
- const { error, classes, ...textFieldProps } = props
+ const { error, classes, material, startAdornment, largeLabel, ...textFieldProps } = props
return (
<MaterialTextField
error={Boolean(error)}
helperText={error}
InputLabelProps={{
+ shrink: material ? undefined : true,
+ className: material ? '' : (largeLabel ? classes.largeInputLabel : classes.inputLabel),
FormLabelClasses: {
- root: classes.cssLabel,
- focused: classes.cssFocused,
- error: classes.cssError,
+ root: material ? classes.materialLabel : classes.formLabel,
+ focused: material ? classes.materialFocused : classes.formLabelFocused,
+ error: classes.materialError,
},
}}
InputProps={{
+ startAdornment: startAdornment || undefined,
+ disableUnderline: !material,
classes: {
- underline: classes.cssUnderline,
+ root: material ? '' : classes.inputRoot,
+ input: material ? '' : classes.input,
+ underline: material ? classes.materialUnderline : '',
+ focused: material ? '' : classes.inputFocused,
},
}}
{...textFieldProps}
@@ -54,6 +101,9 @@ TextField.defaultProps = {
TextField.propTypes = {
error: PropTypes.string,
classes: PropTypes.object,
+ material: PropTypes.bool,
+ startAdornment: PropTypes.element,
+ largeLabel: PropTypes.bool,
}
export default withStyles(styles)(TextField)