mirror of
https://github.com/status-im/react-native.git
synced 2025-01-18 05:23:26 +00:00
6ad41a81bc
Summary: After taking a look at the existing animation docs, I found that most of the documentation on using `Animated` was spread out throughout the Animations guide and the `Animated` API reference, without any particular structure in place. This PR aims to clean up the API reference, focusing on documenting all the provided methods exhaustively, and deferring to the Animations guide for long form examples and supporting content. The `Easing` module is referred to at various points in the API reference, so I decided to clean up this doc as well. easings.net provides some handy visualizations that should make it easier for the reader to understand what sort of easing curve each method provides. The site was built locally, and I verified all three documents render correctly. ![screencapture-localhost-8079-react-native-docs-animations-html-1487212173651](https://cloud.githubusercontent.com/assets/165856/23004694/d3db1670-f3ac-11e6-9d4e-0dd6079b7c5c.png) Closes https://github.com/facebook/react-native/pull/12410 Differential Revision: D4581314 Pulled By: hramos fbshipit-source-id: 27c0bce2afac8f084311b9d6113a2641133b42e5
164 lines
4.7 KiB
JavaScript
164 lines
4.7 KiB
JavaScript
/**
|
|
* Copyright (c) 2013-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* The examples provided by Facebook are for non-commercial testing and
|
|
* evaluation purposes only.
|
|
*
|
|
* Facebook reserves all rights not expressly granted.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL
|
|
* FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
* AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
* @providesModule AnExSet
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
var React = require('react');
|
|
var ReactNative = require('react-native');
|
|
var {
|
|
Animated,
|
|
PanResponder,
|
|
StyleSheet,
|
|
Text,
|
|
View,
|
|
} = ReactNative;
|
|
|
|
var AnExBobble = require('./AnExBobble');
|
|
var AnExChained = require('./AnExChained');
|
|
var AnExScroll = require('./AnExScroll');
|
|
var AnExTilt = require('./AnExTilt');
|
|
|
|
class AnExSet extends React.Component {
|
|
state: any;
|
|
|
|
constructor(props: Object) {
|
|
super(props);
|
|
function randColor() {
|
|
var colors = [0,1,2].map(() => Math.floor(Math.random() * 150 + 100));
|
|
return 'rgb(' + colors.join(',') + ')';
|
|
}
|
|
this.state = {
|
|
closeColor: randColor(),
|
|
openColor: randColor(),
|
|
};
|
|
}
|
|
render(): React.Element<any> {
|
|
var backgroundColor = this.props.openVal ?
|
|
this.props.openVal.interpolate({
|
|
inputRange: [0, 1],
|
|
outputRange: [
|
|
this.state.closeColor, // interpolates color strings
|
|
this.state.openColor
|
|
],
|
|
}) :
|
|
this.state.closeColor;
|
|
var panelWidth = this.props.containerLayout && this.props.containerLayout.width || 320;
|
|
return (
|
|
<View style={styles.container}>
|
|
<Animated.View
|
|
style={[styles.header, { backgroundColor }]}
|
|
{...this.state.dismissResponder.panHandlers}>
|
|
<Text style={[styles.text, styles.headerText]}>
|
|
{this.props.id}
|
|
</Text>
|
|
</Animated.View>
|
|
{this.props.isActive &&
|
|
<View style={styles.stream}>
|
|
<View style={styles.card}>
|
|
<Text style={styles.text}>
|
|
July 2nd
|
|
</Text>
|
|
<AnExTilt isActive={this.props.isActive} />
|
|
<AnExBobble />
|
|
</View>
|
|
<AnExScroll panelWidth={panelWidth}/>
|
|
<AnExChained />
|
|
</View>
|
|
}
|
|
</View>
|
|
);
|
|
}
|
|
|
|
componentWillMount() {
|
|
this.state.dismissY = new Animated.Value(0);
|
|
this.state.dismissResponder = PanResponder.create({
|
|
onStartShouldSetPanResponder: () => this.props.isActive,
|
|
onPanResponderGrant: () => {
|
|
Animated.spring(this.props.openVal, { // Animated value passed in.
|
|
toValue: this.state.dismissY.interpolate({ // Track dismiss gesture
|
|
inputRange: [0, 300], // and interpolate pixel distance
|
|
outputRange: [1, 0], // to a fraction.
|
|
}),
|
|
useNativeDriver: true,
|
|
}).start();
|
|
},
|
|
onPanResponderMove: Animated.event(
|
|
[null, {dy: this.state.dismissY}], // track pan gesture
|
|
{useNativeDriver: true}
|
|
),
|
|
onPanResponderRelease: (e, gestureState) => {
|
|
if (gestureState.dy > 100) {
|
|
this.props.onDismiss(gestureState.vy); // delegates dismiss action to parent
|
|
} else {
|
|
Animated.spring(this.props.openVal, {
|
|
toValue: 1, // animate back open if released early
|
|
useNativeDriver: true,
|
|
}).start();
|
|
}
|
|
},
|
|
});
|
|
}
|
|
}
|
|
|
|
var styles = StyleSheet.create({
|
|
container: {
|
|
flex: 1,
|
|
},
|
|
header: {
|
|
alignItems: 'center',
|
|
paddingTop: 18,
|
|
height: 90,
|
|
},
|
|
stream: {
|
|
flex: 1,
|
|
backgroundColor: 'rgb(230, 230, 230)',
|
|
},
|
|
card: {
|
|
margin: 8,
|
|
padding: 8,
|
|
borderRadius: 6,
|
|
backgroundColor: 'white',
|
|
shadowRadius: 2,
|
|
shadowColor: 'black',
|
|
shadowOpacity: 0.2,
|
|
shadowOffset: {height: 0.5},
|
|
},
|
|
text: {
|
|
padding: 4,
|
|
paddingBottom: 10,
|
|
fontWeight: 'bold',
|
|
fontSize: 18,
|
|
backgroundColor: 'transparent',
|
|
},
|
|
headerText: {
|
|
fontSize: 25,
|
|
color: 'white',
|
|
shadowRadius: 3,
|
|
shadowColor: 'black',
|
|
shadowOpacity: 1,
|
|
shadowOffset: {height: 1},
|
|
},
|
|
});
|
|
|
|
module.exports = AnExSet;
|