Skip to content

Commit

Permalink
[EnhancedButton] Fix keyboard focus jumping issue
Browse files Browse the repository at this point in the history
It was possible to move keyboard focus using the mouse by keyboard focussing
on a button, clicking on another button, holding, and moving the mosue away.

Also fixes a state naming issue in RaisedButton, and some code style issues.
  • Loading branch information
mbrookes committed Apr 30, 2016
1 parent 273a769 commit 4e7e4b7
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 18 deletions.
3 changes: 0 additions & 3 deletions src/FlatButton/FlatButtonLabel.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,6 @@ function getStyles(props, context) {
class FlatButtonLabel extends Component {
static propTypes = {
label: PropTypes.node,
/**
* Override the inline-styles of the root element.
*/
style: PropTypes.object,
};

Expand Down
55 changes: 40 additions & 15 deletions src/RaisedButton/RaisedButton.js
Original file line number Diff line number Diff line change
Expand Up @@ -251,6 +251,7 @@ class RaisedButton extends Component {

state = {
hovered: false,
keyboardFocused: false,
touched: false,
initialZDepth: 0,
zDepth: 0,
Expand All @@ -275,48 +276,72 @@ class RaisedButton extends Component {
handleMouseDown = (event) => {
// only listen to left clicks
if (event.button === 0) {
this.setState({zDepth: this.state.initialZDepth + 1});
this.setState({
zDepth: this.state.initialZDepth + 1,
});
}
if (this.props.onMouseDown) {
this.props.onMouseDown(event);
}
if (this.props.onMouseDown) this.props.onMouseDown(event);
};

handleMouseUp = (event) => {
this.setState({zDepth: this.state.initialZDepth});
if (this.props.onMouseUp) this.props.onMouseUp(event);
this.setState({
zDepth: this.state.initialZDepth,
});
if (this.props.onMouseUp) {
this.props.onMouseUp(event);
}
};

handleMouseLeave = (event) => {
if (!this.refs.container.isKeyboardFocused()) this.setState({zDepth: this.state.initialZDepth, hovered: false});
if (this.props.onMouseLeave) this.props.onMouseLeave(event);
if (!this.state.keyboardFocused) {
this.setState({
zDepth: this.state.initialZDepth,
hovered: false,
});
}
if (this.props.onMouseLeave) {
this.props.onMouseLeave(event);
}
};

handleMouseEnter = (event) => {
if (!this.refs.container.isKeyboardFocused() && !this.state.touch) {
if (!this.state.keyboardFocused && !this.state.touched) {
this.setState({hovered: true});
}
if (this.props.onMouseEnter) this.props.onMouseEnter(event);
if (this.props.onMouseEnter) {
this.props.onMouseEnter(event);
}
};

handleTouchStart = (event) => {
this.setState({
touch: true,
touched: true,
zDepth: this.state.initialZDepth + 1,
});
if (this.props.onTouchStart) this.props.onTouchStart(event);

if (this.props.onTouchStart) {
this.props.onTouchStart(event);
}
};

handleTouchEnd = (event) => {
this.setState({zDepth: this.state.initialZDepth});
if (this.props.onTouchEnd) this.props.onTouchEnd(event);
this.setState({
zDepth: this.state.initialZDepth,
});

if (this.props.onTouchEnd) {
this.props.onTouchEnd(event);
}
};

handleKeyboardFocus = (event, keyboardFocused) => {
const zDepth = keyboardFocused && !this.props.disabled ?
this.state.initialZDepth + 1 : this.state.initialZDepth;
const zDepth = (keyboardFocused && !this.props.disabled) ? this.state.initialZDepth + 1 : this.state.initialZDepth;

this.setState({
zDepth: zDepth,
keyboardFocused,
keyboardFocused: keyboardFocused,
});
};

Expand Down
1 change: 1 addition & 0 deletions src/internal/EnhancedButton.js
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,7 @@ class EnhancedButton extends Component {
this.focusTimeout = setTimeout(() => {
if (tabPressed) {
this.setKeyboardFocus(event);
tabPressed = false;
}
}, 150);

Expand Down

0 comments on commit 4e7e4b7

Please sign in to comment.