/** * Copyright (c) 2015-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. * * @providesModule LayoutAnimation */ 'use strict'; var PropTypes = require('ReactPropTypes'); var RCTUIManager = require('NativeModules').UIManager; var createStrictShapeTypeChecker = require('createStrictShapeTypeChecker'); var keyMirror = require('keyMirror'); var Types = keyMirror({ spring: true, linear: true, easeInEaseOut: true, easeIn: true, easeOut: true, }); var Properties = keyMirror({ opacity: true, scaleXY: true, }); var animChecker = createStrictShapeTypeChecker({ duration: PropTypes.number, delay: PropTypes.number, springDamping: PropTypes.number, initialVelocity: PropTypes.number, type: PropTypes.oneOf( Object.keys(Types) ), property: PropTypes.oneOf( // Only applies to create/delete Object.keys(Properties) ), }); var configChecker = createStrictShapeTypeChecker({ duration: PropTypes.number.isRequired, create: animChecker, update: animChecker, delete: animChecker, }); var LayoutAnimation = { configureNext(config, onAnimationDidEnd, onError) { configChecker({config}, 'config', 'LayoutAnimation.configureNext'); RCTUIManager.configureNextLayoutAnimation(config, onAnimationDidEnd, onError); }, create(duration, type, creationProp) { return { duration, create: { type, property: creationProp, }, update: { type, }, }; }, Types: Types, Properties: Properties, configChecker: configChecker, }; LayoutAnimation.Presets = { easeInEaseOut: LayoutAnimation.create( 0.3, Types.easeInEaseOut, Properties.opacity ), linear: LayoutAnimation.create( 0.5, Types.linear, Properties.opacity ), spring: { duration: 0.7, create: { type: Types.linear, property: Properties.opacity, }, update: { type: Types.spring, springDamping: 0.4, }, }, }; module.exports = LayoutAnimation;