fix(swipe): Don't allow touch-up to re-settle already settled swipe gestures

This commit is contained in:
Ben Gotow 2016-02-24 16:08:19 -08:00
parent 17ea99d2ff
commit 09f0c12f0d

View file

@ -1,4 +1,5 @@
import React, {Component, PropTypes} from 'react'; import React, {Component, PropTypes} from 'react';
import DOMUtils from '../dom-utils';
import _ from 'underscore'; import _ from 'underscore';
import {exec} from 'child_process'; import {exec} from 'child_process';
@ -59,6 +60,7 @@ export default class SwipeContainer extends Component {
onSwipeLeftClass: React.PropTypes.string, onSwipeLeftClass: React.PropTypes.string,
onSwipeRight: React.PropTypes.func, onSwipeRight: React.PropTypes.func,
onSwipeRightClass: React.PropTypes.string, onSwipeRightClass: React.PropTypes.string,
onSwipeCenter: React.PropTypes.func,
}; };
constructor(props) { constructor(props) {
@ -155,7 +157,7 @@ export default class SwipeContainer extends Component {
_onScrollTouchEnd = ()=> { _onScrollTouchEnd = ()=> {
this.tracking = false; this.tracking = false;
if (this.phase !== Phase.None) { if ((this.phase !== Phase.None) && (this.phase !== Phase.Settling)) {
this.phase = Phase.Settling; this.phase = Phase.Settling;
this.fired = false; this.fired = false;
this.setState({ this.setState({
@ -244,15 +246,16 @@ export default class SwipeContainer extends Component {
const shouldFinish = (f >= 1.0); const shouldFinish = (f >= 1.0);
const mostlyFinished = ((Math.abs(currentX) / Math.abs(targetX)) > 0.8); const mostlyFinished = ((Math.abs(currentX) / Math.abs(targetX)) > 0.8);
const shouldFire = (targetX !== 0) && mostlyFinished && (this.fired === false); const shouldFire = mostlyFinished && (this.fired === false);
if (shouldFire) { if (shouldFire) {
this.fired = true; this.fired = true;
if (targetX > 0) { if ((targetX > 0) && this.props.onSwipeRight) {
this.props.onSwipeRight(this._onSwipeActionCompleted); this.props.onSwipeRight(this._onSwipeActionCompleted);
} } else if ((targetX < 0) && this.props.onSwipeLeft) {
if (targetX < 0) {
this.props.onSwipeLeft(this._onSwipeActionCompleted); this.props.onSwipeLeft(this._onSwipeActionCompleted);
} else if ((targetX == 0) && this.props.onSwipeCenter) {
this.props.onSwipeCenter();
} }
} }