2015-03-10 19:11:28 -07:00
|
|
|
/**
|
2015-03-23 15:07:33 -07:00
|
|
|
* 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.
|
2015-03-10 19:11:28 -07:00
|
|
|
*
|
2015-04-06 08:38:56 -07:00
|
|
|
* @providesModule AnimationExperimental
|
2015-03-10 19:11:28 -07:00
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
2015-04-06 08:38:56 -07:00
|
|
|
var RCTAnimationManager = require('NativeModules').AnimationExperimentalManager;
|
2015-07-07 16:19:40 -07:00
|
|
|
if (!RCTAnimationManager) {
|
|
|
|
// AnimationExperimental isn't available internally - this is a temporary
|
|
|
|
// workaround to enable its availability to be determined at runtime.
|
|
|
|
// For Flow let's pretend like we always export AnimationExperimental
|
|
|
|
// so all our users don't need to do null checks
|
|
|
|
module.exports = null;
|
|
|
|
} else {
|
|
|
|
|
2015-05-12 18:55:13 -07:00
|
|
|
var React = require('React');
|
2015-03-10 19:11:28 -07:00
|
|
|
var AnimationUtils = require('AnimationUtils');
|
|
|
|
|
|
|
|
type EasingFunction = (t: number) => number;
|
|
|
|
|
2015-04-09 08:46:53 -07:00
|
|
|
var Properties = {
|
|
|
|
opacity: true,
|
|
|
|
position: true,
|
|
|
|
positionX: true,
|
|
|
|
positionY: true,
|
|
|
|
rotation: true,
|
|
|
|
scaleXY: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
type ValueType = number | Array<number> | {[key: string]: number};
|
|
|
|
|
2015-04-06 08:38:56 -07:00
|
|
|
/**
|
|
|
|
* This is an experimental module that is under development, incomplete,
|
|
|
|
* potentially buggy, not used in any production apps, and will probably change
|
|
|
|
* in non-backward compatible ways.
|
|
|
|
*
|
|
|
|
* Use at your own risk.
|
|
|
|
*/
|
|
|
|
var AnimationExperimental = {
|
2015-03-10 19:11:28 -07:00
|
|
|
startAnimation: function(
|
2015-04-09 08:46:53 -07:00
|
|
|
anim: {
|
|
|
|
node: any;
|
|
|
|
duration: number;
|
|
|
|
easing: ($Enum<typeof AnimationUtils.Defaults> | EasingFunction);
|
|
|
|
property: $Enum<typeof Properties>;
|
|
|
|
toValue: ValueType;
|
|
|
|
fromValue?: ValueType;
|
|
|
|
delay?: number;
|
|
|
|
},
|
|
|
|
callback?: ?(finished: bool) => void
|
2015-03-10 19:11:28 -07:00
|
|
|
): number {
|
2015-05-12 18:55:13 -07:00
|
|
|
var nodeHandle = React.findNodeHandle(anim.node);
|
2015-04-09 08:46:53 -07:00
|
|
|
var easingSample = AnimationUtils.evaluateEasingFunction(
|
|
|
|
anim.duration,
|
|
|
|
anim.easing
|
|
|
|
);
|
|
|
|
var tag: number = AnimationUtils.allocateTag();
|
|
|
|
var props = {};
|
|
|
|
props[anim.property] = {to: anim.toValue};
|
|
|
|
RCTAnimationManager.startAnimation(
|
2015-04-06 08:38:56 -07:00
|
|
|
nodeHandle,
|
2015-04-09 08:46:53 -07:00
|
|
|
tag,
|
|
|
|
anim.duration,
|
|
|
|
anim.delay,
|
2015-04-06 08:38:56 -07:00
|
|
|
easingSample,
|
2015-04-09 08:46:53 -07:00
|
|
|
props,
|
|
|
|
callback
|
2015-04-06 08:38:56 -07:00
|
|
|
);
|
2015-03-14 10:52:40 -07:00
|
|
|
return tag;
|
2015-03-10 19:11:28 -07:00
|
|
|
},
|
|
|
|
|
2015-03-14 10:52:40 -07:00
|
|
|
stopAnimation: function(tag: number) {
|
2015-03-10 19:11:28 -07:00
|
|
|
RCTAnimationManager.stopAnimation(tag);
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2015-04-09 08:46:53 -07:00
|
|
|
if (__DEV__) {
|
|
|
|
if (RCTAnimationManager && RCTAnimationManager.Properties) {
|
|
|
|
var a = Object.keys(Properties);
|
|
|
|
var b = RCTAnimationManager.Properties;
|
|
|
|
var diff = a.filter((i) => b.indexOf(i) < 0).concat(
|
|
|
|
b.filter((i) => a.indexOf(i) < 0)
|
|
|
|
);
|
|
|
|
if (diff.length > 0) {
|
|
|
|
throw new Error('JS animation properties don\'t match native properties.' +
|
|
|
|
JSON.stringify(diff, null, ' '));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-06 08:38:56 -07:00
|
|
|
module.exports = AnimationExperimental;
|
2015-07-07 16:19:40 -07:00
|
|
|
|
|
|
|
}
|