forked from facebook/react-native
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Migrate DivisionAnimatedNode, Java->Kotlin (facebook#45762)
Summary: Pull Request resolved: facebook#45762 # Changelog: [Internal] - As in the title. Differential Revision: D60341635
- Loading branch information
1 parent
d3746b2
commit feda5e5
Showing
2 changed files
with
57 additions
and
64 deletions.
There are no files selected for viewing
64 changes: 0 additions & 64 deletions
64
...t-native/ReactAndroid/src/main/java/com/facebook/react/animated/DivisionAnimatedNode.java
This file was deleted.
Oops, something went wrong.
57 changes: 57 additions & 0 deletions
57
...act-native/ReactAndroid/src/main/java/com/facebook/react/animated/DivisionAnimatedNode.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
/* | ||
* Copyright (c) Meta Platforms, Inc. and affiliates. | ||
* | ||
* This source code is licensed under the MIT license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
|
||
package com.facebook.react.animated | ||
|
||
import com.facebook.react.bridge.JSApplicationCausedNativeException | ||
import com.facebook.react.bridge.ReadableMap | ||
|
||
/** | ||
* Animated node which takes two or more value node as an input and outputs an in-order division of | ||
* their values. | ||
*/ | ||
internal class DivisionAnimatedNode( | ||
config: ReadableMap, | ||
private val nativeAnimatedNodesManager: NativeAnimatedNodesManager | ||
) : ValueAnimatedNode() { | ||
private val inputNodes: IntArray | ||
|
||
init { | ||
val nodes = config.getArray("input") | ||
val size = nodes?.size() ?: 0 | ||
inputNodes = IntArray(size) | ||
if (nodes != null) { | ||
for (i in inputNodes.indices) { | ||
inputNodes[i] = nodes.getInt(i) | ||
} | ||
} | ||
} | ||
|
||
override fun update() { | ||
for (i in inputNodes.indices) { | ||
val animatedNode = nativeAnimatedNodesManager.getNodeById(inputNodes[i]) | ||
if (animatedNode != null && animatedNode is ValueAnimatedNode) { | ||
val value = animatedNode.nodeValue | ||
if (i == 0) { | ||
nodeValue = value | ||
continue | ||
} | ||
if (value == 0.0) { | ||
throw JSApplicationCausedNativeException( | ||
"Detected a division by zero in Animated.divide node with Animated ID $tag") | ||
} | ||
nodeValue /= value | ||
} else { | ||
throw JSApplicationCausedNativeException( | ||
"Illegal node ID set as an input for Animated.divide node with Animated ID $tag") | ||
} | ||
} | ||
} | ||
|
||
override fun prettyPrint(): String = | ||
"DivisionAnimatedNode[$tag]: input nodes: $inputNodes - super: ${super.prettyPrint()}" | ||
} |