Skip to content

Commit

Permalink
[TextField] add floatingLabelFocusStyle prop
Browse files Browse the repository at this point in the history
  • Loading branch information
Evan Henley committed Apr 24, 2016
1 parent 713dc4c commit 8904c37
Show file tree
Hide file tree
Showing 4 changed files with 71 additions and 22 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import React from 'react';
import TextField from 'material-ui/TextField';
import {orange500} from 'material-ui/styles/colors';
import {orange500, blue500} from 'material-ui/styles/colors';

const styles = {
errorStyle: {
Expand All @@ -9,6 +9,12 @@ const styles = {
underlineStyle: {
borderColor: orange500,
},
floatingLabelStyle: {
color: orange500,
},
floatingLabelFocusStyle: {
color: blue500,
},
};

const TextFieldExampleCustomize = () => (
Expand All @@ -29,6 +35,11 @@ const TextFieldExampleCustomize = () => (
<TextField
hintText="Custom Underline Focus Color"
underlineFocusStyle={styles.underlineStyle}
/><br />
<TextField
floatingLabelText="Styled Floating Label Text"
floatingLabelStyle={styles.floatingLabelStyle}
floatingLabelFocusStyle={styles.floatingLabelFocusStyle}
/>
</div>
);
Expand Down
7 changes: 7 additions & 0 deletions src/TextField/TextField.js
Original file line number Diff line number Diff line change
Expand Up @@ -139,10 +139,16 @@ class TextField extends Component {
* If true, the floating label will float even when there is no value.
*/
floatingLabelFixed: PropTypes.bool,
/**
* The style object to use to override floating label styles when focused.
*/
floatingLabelFocusStyle: PropTypes.object,

/**
* The style object to use to override floating label styles.
*/
floatingLabelStyle: PropTypes.object,

/**
* The content to use for the floating label element.
*/
Expand Down Expand Up @@ -419,6 +425,7 @@ class TextField extends Component {
<TextFieldLabel
muiTheme={this.context.muiTheme}
style={Object.assign(styles.floatingLabel, this.props.floatingLabelStyle)}
shrinkStyle={this.props.floatingLabelFocusStyle}
htmlFor={inputId}
shrink={this.state.hasValue || this.state.isFocused || floatingLabelFixed}
disabled={disabled}
Expand Down
48 changes: 27 additions & 21 deletions src/TextField/TextFieldLabel.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,26 @@
import React, {PropTypes} from 'react';
import transitions from '../styles/transitions';

function getStyles(props) {
const shrinkStyles = props.shrink ? Object.assign({
transform: 'perspective(1px) scale(0.75) translate3d(0, -28px, 0)',
pointerEvents: 'none',
}, props.shrinkStyle) : null;

return Object.assign({
position: 'absolute',
lineHeight: '22px',
top: 38,
transition: transitions.easeOut(),
zIndex: 1, // Needed to display label above Chrome's autocomplete field background
cursor: props.disabled ? 'default' : 'text',
transform: 'scale(1) translate3d(0, 0, 0)',
transformOrigin: 'left top',
pointerEvents: 'auto',
userSelect: 'none',
}, props.style, shrinkStyles);
}

const propTypes = {
/**
* @ignore
Expand Down Expand Up @@ -35,6 +55,11 @@ const propTypes = {
* Override the inline-styles of the root element.
*/
style: PropTypes.object,

/**
* Override the inline-styles of the root element when focused.
*/
shrinkStyle: PropTypes.object,
};

const defaultProps = {
Expand All @@ -47,36 +72,17 @@ const TextFieldLabel = (props) => {
muiTheme,
className,
children,
disabled,
shrink,
htmlFor,
style,
onTouchTap,
} = props;

const styles = {
root: {
position: 'absolute',
lineHeight: '22px',
top: 38,
transition: transitions.easeOut(),
zIndex: 1, // Needed to display label above Chrome's autocomplete field background
cursor: disabled ? 'default' : 'text',
transform: shrink ?
'perspective(1px) scale(0.75) translate3d(0, -28px, 0)' :
'scale(1) translate3d(0, 0, 0)',
transformOrigin: 'left top',
pointerEvents: shrink ? 'none' : 'auto',
userSelect: 'none',
},
};

const {prepareStyles} = muiTheme;
const styles = getStyles(props);

return (
<label
className={className}
style={prepareStyles(Object.assign({}, styles.root, style))}
style={prepareStyles(styles)}
htmlFor={htmlFor}
onTouchTap={onTouchTap}
>
Expand Down
25 changes: 25 additions & 0 deletions src/TextField/TextFieldLabel.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
/* eslint-env mocha */
import React from 'react';
import {shallow} from 'enzyme';
import {expect} from 'chai';
import TextFieldLabel from './TextFieldLabel';
import getMuiTheme from '../styles/getMuiTheme';

describe('<TextFieldLabel>', () => {
it('uses focus styles', () => {
const wrapper = shallow(
<TextFieldLabel
muiTheme={getMuiTheme()}
shrink={false}
style={{color: 'regularcolor'}}
shrinkStyle={{color: 'focuscolor'}}
/>
);

expect(wrapper.type()).to.equal('label');
expect(wrapper.prop('style').color).to.equal('regularcolor');

wrapper.setProps({shrink: true});
expect(wrapper.prop('style').color).to.equal('focuscolor');
});
});

0 comments on commit 8904c37

Please sign in to comment.