Skip to content

Commit

Permalink
Kotlinify EventAnimationDriver (facebook#45766)
Browse files Browse the repository at this point in the history
Summary:
Pull Request resolved: facebook#45766

# Changelog:
[Internal] -

As in the title.

Differential Revision: D60348157
  • Loading branch information
rshest authored and facebook-github-bot committed Jul 29, 2024
1 parent ae6fd1a commit 78699ea
Show file tree
Hide file tree
Showing 3 changed files with 112 additions and 126 deletions.

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
/*
* 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.ReadableArray
import com.facebook.react.bridge.ReadableMap
import com.facebook.react.bridge.ReadableType
import com.facebook.react.bridge.UnexpectedNativeTypeException
import com.facebook.react.bridge.WritableArray
import com.facebook.react.bridge.WritableMap
import com.facebook.react.uimanager.events.EventCategoryDef
import com.facebook.react.uimanager.events.RCTModernEventEmitter
import com.facebook.react.uimanager.events.TouchEvent

/** Handles updating a [ValueAnimatedNode] when an event gets dispatched. */
internal class EventAnimationDriver(
@JvmField var eventName: String,
@JvmField internal var viewTag: Int,
private val eventPath: List<String>,
@JvmField internal var valueNode: ValueAnimatedNode
) : RCTModernEventEmitter {
override fun receiveEvent(targetReactTag: Int, eventName: String, event: WritableMap?) {
receiveEvent(-1, targetReactTag, eventName, event)
}

override fun receiveEvent(
surfaceId: Int,
targetTag: Int,
eventName: String,
event: WritableMap?
) {
// We assume this event can't be coalesced. `customCoalesceKey` has no meaning in Fabric.
receiveEvent(surfaceId, targetTag, eventName, false, 0, event, EventCategoryDef.UNSPECIFIED)
}

override fun receiveTouches(
eventName: String,
touches: WritableArray,
changedIndices: WritableArray
) {
throw UnsupportedOperationException("receiveTouches is not support by native animated events")
}

override fun receiveTouches(touchEvent: TouchEvent) {
throw UnsupportedOperationException("receiveTouches is not support by native animated events")
}

override fun receiveEvent(
surfaceId: Int,
targetTag: Int,
eventName: String,
canCoalesceEvent: Boolean,
customCoalesceKey: Int,
event: WritableMap?,
@EventCategoryDef category: Int
) {
requireNotNull(event) { "Native animated events must have event data." }

// Get the new value for the node by looking into the event map using the provided event path.
var currMap: ReadableMap? = event
var currArray: ReadableArray? = null
for (i in 0 until eventPath.size - 1) {
if (currMap != null) {
val key = eventPath[i]
val keyType = currMap.getType(key)
if (keyType == ReadableType.Map) {
currMap = currMap.getMap(key)
currArray = null
} else if (keyType == ReadableType.Array) {
currArray = currMap.getArray(key)
currMap = null
} else {
throw UnexpectedNativeTypeException("Unexpected type $keyType for key '$key'")
}
} else {
val index = eventPath[i].toInt()
val keyType = currArray?.getType(index)
if (keyType == ReadableType.Map) {
currMap = currArray?.getMap(index)
currArray = null
} else if (keyType == ReadableType.Array) {
currArray = currArray?.getArray(index)
currMap = null
} else {
throw UnexpectedNativeTypeException("Unexpected type $keyType for index '$index'")
}
}
}
val lastKey = eventPath[eventPath.size - 1]
if (currMap != null) {
valueNode.nodeValue = currMap.getDouble(lastKey)
} else {
val lastIndex = lastKey.toInt()
valueNode.nodeValue = currArray?.getDouble(lastIndex) ?: 0.0
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -563,9 +563,9 @@ public void removeAnimatedEventFromView(
ListIterator<EventAnimationDriver> it = mEventDrivers.listIterator();
while (it.hasNext()) {
EventAnimationDriver driver = it.next();
if (eventName.equals(driver.mEventName)
&& viewTag == driver.mViewTag
&& animatedValueTag == driver.mValueNode.tag) {
if (eventName.equals(driver.eventName)
&& viewTag == driver.viewTag
&& animatedValueTag == driver.valueNode.tag) {
it.remove();
break;
}
Expand Down Expand Up @@ -609,11 +609,11 @@ private void handleEvent(Event event) {
boolean foundAtLeastOneDriver = false;
Event.EventAnimationDriverMatchSpec matchSpec = event.getEventAnimationDriverMatchSpec();
for (EventAnimationDriver driver : mEventDrivers) {
if (matchSpec.match(driver.mViewTag, driver.mEventName)) {
if (matchSpec.match(driver.viewTag, driver.eventName)) {
foundAtLeastOneDriver = true;
stopAnimationsForNode(driver.mValueNode);
stopAnimationsForNode(driver.valueNode);
event.dispatchModern(driver);
mRunUpdateNodeList.add(driver.mValueNode);
mRunUpdateNodeList.add(driver.valueNode);
}
}

Expand Down Expand Up @@ -704,10 +704,10 @@ Set<Integer> getTagsOfConnectedNodes(int tag, String eventName) {
while (it.hasNext()) {
EventAnimationDriver driver = it.next();
if (driver != null) {
if (eventName.equals(driver.mEventName) && tag == driver.mViewTag) {
tags.add(driver.mViewTag);
if (driver.mValueNode != null && driver.mValueNode.children != null) {
for (AnimatedNode node : driver.mValueNode.children) {
if (eventName.equals(driver.eventName) && tag == driver.viewTag) {
tags.add(driver.viewTag);
if (driver.valueNode != null && driver.valueNode.children != null) {
for (AnimatedNode node : driver.valueNode.children) {
tags.add(node.tag);
}
}
Expand Down

0 comments on commit 78699ea

Please sign in to comment.