/** * Copyright (c) 2015, Facebook, Inc. All rights reserved. * * Facebook, Inc. ("Facebook") owns all right, title and interest, including * all intellectual property and other proprietary rights, in and to the React * Native CustomComponents software (the "Software"). Subject to your * compliance with these terms, you are hereby granted a non-exclusive, * worldwide, royalty-free copyright license to (1) use and copy the Software; * and (2) reproduce and distribute the Software as part of your own software * ("Your Software"). Facebook reserves all rights not expressly granted to * you in this license agreement. * * THE SOFTWARE AND DOCUMENTATION, IF ANY, ARE PROVIDED "AS IS" AND ANY EXPRESS * OR IMPLIED WARRANTIES (INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE) ARE DISCLAIMED. * IN NO EVENT SHALL FACEBOOK OR ITS AFFILIATES, OFFICERS, DIRECTORS OR * EMPLOYEES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THE SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * @providesModule NavigationCardStack * @flow */ 'use strict'; const Animated = require('Animated'); const NavigationAnimatedView = require('NavigationAnimatedView'); const NavigationCardStackItem = require('NavigationCardStackItem'); const NavigationContainer = require('NavigationContainer'); const React = require('React'); const ReactComponentWithPureRenderMixin = require('ReactComponentWithPureRenderMixin'); const StyleSheet = require('StyleSheet'); const emptyFunction = require('emptyFunction'); const {PropTypes} = React; const {Directions} = NavigationCardStackItem; import type { NavigationParentState, } from 'NavigationStateUtils'; import type { Layout, NavigationStateRenderer, NavigationStateRendererProps, Position, TimingSetter, } from 'NavigationAnimatedView'; type Props = { direction: string, navigationState: NavigationParentState, renderOverlay: NavigationStateRenderer, renderScene: NavigationStateRenderer, }; /** * A controlled navigation view that renders a list of cards. */ class NavigationCardStack extends React.Component { _renderScene : NavigationStateRenderer; _setTiming: TimingSetter; constructor(props: Props, context: any) { super(props, context); this._renderScene = this._renderScene.bind(this); this._setTiming = this._setTiming.bind(this); } shouldComponentUpdate(nextProps: Object, nextState: Object): boolean { return ReactComponentWithPureRenderMixin.shouldComponentUpdate.call( this, nextProps, nextState ); } render(): ReactElement { return ( ); } _renderScene(props: NavigationStateRendererProps): ReactElement { const { index, layout, navigationState, position, } = props; return ( ); } _setTiming(position: Position, navigationState: NavigationParentState): void { Animated.timing( position, { duration: 500, toValue: navigationState.index, } ).start(); } } NavigationCardStack.propTypes = { direction: PropTypes.oneOf([Directions.HORIZONTAL, Directions.VERTICAL]), navigationState: PropTypes.object.isRequired, renderOverlay: PropTypes.func, renderScene: PropTypes.func.isRequired, }; NavigationCardStack.defaultProps = { direction: Directions.HORIZONTAL, renderOverlay: emptyFunction.thatReturnsNull, }; NavigationCardStack.Directions = Directions; const styles = StyleSheet.create({ animatedView: { flex: 1, }, }); module.exports = NavigationContainer.create(NavigationCardStack);