From 26e8c5af722ce810f7159401bdd8c0d195ae0fc3 Mon Sep 17 00:00:00 2001 From: Janic Duplessis Date: Mon, 5 Dec 2016 22:45:13 -0500 Subject: [PATCH] Fixes --- Libraries/Components/ScrollView/ScrollView.js | 16 +++++++++++++--- .../ScrollView/ScrollViewStickyHeader.js | 7 ++----- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/Libraries/Components/ScrollView/ScrollView.js b/Libraries/Components/ScrollView/ScrollView.js index 00aa00ac6790e5..9ab25a23f33b72 100644 --- a/Libraries/Components/ScrollView/ScrollView.js +++ b/Libraries/Components/ScrollView/ScrollView.js @@ -355,14 +355,18 @@ const ScrollView = React.createClass({ mixins: [ScrollResponder.Mixin], - _scrollAnimatedValue: new Animated.Value(0), - _scrollAnimatedValueAttachment: null, - _stickyHeaderRefs: new Map(), + _scrollAnimatedValue: (null: ?Animated.Value), + _scrollAnimatedValueAttachment: (null: ?{detach: () => void}), + _stickyHeaderRefs: (new Map(): Map), getInitialState: function() { return this.scrollResponderMixinGetInitialState(); }, + componentWillMount: function() { + this._scrollAnimatedValue = new Animated.Value(0); + }, + componentDidMount: function() { this._updateAnimatedNodeAttachment(); }, @@ -371,6 +375,12 @@ const ScrollView = React.createClass({ this._updateAnimatedNodeAttachment(); }, + componentWillUnmount: function() { + if (this._scrollAnimatedValueAttachment) { + this._scrollAnimatedValueAttachment.detach(); + } + }, + setNativeProps: function(props: Object) { this._scrollViewRef && this._scrollViewRef.setNativeProps(props); }, diff --git a/Libraries/Components/ScrollView/ScrollViewStickyHeader.js b/Libraries/Components/ScrollView/ScrollViewStickyHeader.js index 24596e2e99a2cf..799061769d2d1f 100644 --- a/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +++ b/Libraries/Components/ScrollView/ScrollViewStickyHeader.js @@ -13,11 +13,8 @@ const Animated = require('Animated'); const React = require('React'); -const UIManager = require('UIManager'); const StyleSheet = require('StyleSheet'); -const findNodeHandle = require('findNodeHandle'); - type Props = { children?: React.Element<*>, scrollAnimatedValue: Animated.Value, @@ -50,8 +47,8 @@ class ScrollViewStickyHeader extends React.Component { let translateY; if (measured) { - const inputRange = [-1, layoutY]; - const outputRange: Array = [0, 0]; + const inputRange = [-1, 0, layoutY]; + const outputRange: Array = [-1, 0, 0]; if (nextHeaderLayoutY != null) { inputRange.push(nextHeaderLayoutY, nextHeaderLayoutY + 1); outputRange.push(nextHeaderLayoutY - layoutY, nextHeaderLayoutY - layoutY);