From 4e7e4b722f2e718f7ff12118acc63a1c53de2799 Mon Sep 17 00:00:00 2001 From: mbrookes Date: Sat, 30 Apr 2016 18:02:51 +0100 Subject: [PATCH] [EnhancedButton] Fix keyboard focus jumping issue 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. --- src/FlatButton/FlatButtonLabel.js | 3 -- src/RaisedButton/RaisedButton.js | 55 ++++++++++++++++++++++--------- src/internal/EnhancedButton.js | 1 + 3 files changed, 41 insertions(+), 18 deletions(-) diff --git a/src/FlatButton/FlatButtonLabel.js b/src/FlatButton/FlatButtonLabel.js index d97f3966c5bab1..baa3b9916a5a2d 100644 --- a/src/FlatButton/FlatButtonLabel.js +++ b/src/FlatButton/FlatButtonLabel.js @@ -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, }; diff --git a/src/RaisedButton/RaisedButton.js b/src/RaisedButton/RaisedButton.js index 524b643b4c45cb..e24dbc43d1862a 100644 --- a/src/RaisedButton/RaisedButton.js +++ b/src/RaisedButton/RaisedButton.js @@ -251,6 +251,7 @@ class RaisedButton extends Component { state = { hovered: false, + keyboardFocused: false, touched: false, initialZDepth: 0, zDepth: 0, @@ -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, }); }; diff --git a/src/internal/EnhancedButton.js b/src/internal/EnhancedButton.js index 6c277693dbfade..3219634384481b 100644 --- a/src/internal/EnhancedButton.js +++ b/src/internal/EnhancedButton.js @@ -210,6 +210,7 @@ class EnhancedButton extends Component { this.focusTimeout = setTimeout(() => { if (tabPressed) { this.setKeyboardFocus(event); + tabPressed = false; } }, 150);