Skip to content

Commit

Permalink
Migrate MultiplicationAnimatedNode to Kotlin (facebook#45756)
Browse files Browse the repository at this point in the history
Summary:
Pull Request resolved: facebook#45756

# Changelog:
[Internal] -
As in the title.

Reviewed By: cortinico

Differential Revision: D60340884
  • Loading branch information
rshest authored and facebook-github-bot committed Jul 30, 2024
1 parent 9e8804a commit e4cce79
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 56 deletions.

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/*
* 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 a product of their
* values
*/
internal class MultiplicationAnimatedNode(
config: ReadableMap,
private val nativeAnimatedNodesManager: NativeAnimatedNodesManager
) : ValueAnimatedNode() {
private var inputNodes: IntArray

init {
val input = config.getArray("input")
inputNodes =
if (input == null) {
IntArray(0)
} else {
IntArray(input.size()) { i -> input.getInt(i) }
}
}

override fun update() {
nodeValue = 1.0
for (i in inputNodes.indices) {
val animatedNode = nativeAnimatedNodesManager.getNodeById(inputNodes[i])
val multiplier =
if (animatedNode != null && animatedNode is ValueAnimatedNode) {
animatedNode.getValue()
} else {
throw JSApplicationCausedNativeException(
"Illegal node ID set as an input for Animated.multiply node")
}
nodeValue *= multiplier
}
}

override fun prettyPrint(): String =
"MultiplicationAnimatedNode[$tag]: input nodes: $inputNodes - super: ${super.prettyPrint()}"
}

0 comments on commit e4cce79

Please sign in to comment.