-
-
Notifications
You must be signed in to change notification settings - Fork 645
Expand file tree
/
Copy pathScreenAnimationDelegate.kt
More file actions
90 lines (73 loc) · 2.93 KB
/
ScreenAnimationDelegate.kt
File metadata and controls
90 lines (73 loc) · 2.93 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
package com.swmansion.rnscreens.events
import android.animation.Animator
import android.util.Log
import com.swmansion.rnscreens.ScreenStackFragmentWrapper
// The goal is to make this universal delegate for handling animation progress related logic.
// At this moment this class works only with form sheet presentation.
class ScreenAnimationDelegate(
private val wrapper: ScreenStackFragmentWrapper,
private val eventEmitter: ScreenEventEmitter?,
private val animationType: AnimationType,
) : Animator.AnimatorListener {
enum class AnimationType {
ENTER,
EXIT
}
private var currentState: LifecycleState = LifecycleState.INITIALIZED
private fun progressState() {
currentState =
when (currentState) {
LifecycleState.INITIALIZED -> LifecycleState.START_DISPATCHED
LifecycleState.START_DISPATCHED -> LifecycleState.END_DISPATCHED
LifecycleState.END_DISPATCHED -> LifecycleState.END_DISPATCHED
}
}
override fun onAnimationStart(animation: Animator) {
if (currentState === LifecycleState.INITIALIZED) {
progressState()
Log.i("HT", "AnimationDelegate onAnimationStart")
// These callbacks do not work as expected from this call site, TODO: investigate it.
// To fix it quickly we emit required events manually
// wrapper.onViewAnimationStart()
when (animationType) {
AnimationType.ENTER -> eventEmitter?.dispatchOnWillAppear()
AnimationType.EXIT -> eventEmitter?.dispatchOnWillDisappear()
}
val isExitAnimation = animationType === AnimationType.EXIT
eventEmitter?.dispatchTransitionProgress(
0.0f,
isExitAnimation,
isExitAnimation,
)
}
}
override fun onAnimationEnd(animation: Animator) {
if (currentState === LifecycleState.START_DISPATCHED) {
progressState()
animation.removeListener(this)
Log.i("HT", "AnimationDelegate onAnimationEnd")
// wrapper.onViewAnimationEnd()
when (animationType) {
AnimationType.ENTER -> eventEmitter?.dispatchOnAppear()
AnimationType.EXIT -> eventEmitter?.dispatchOnDisappear()
}
val isExitAnimation = animationType === AnimationType.EXIT
eventEmitter?.dispatchTransitionProgress(
1.0f,
isExitAnimation,
isExitAnimation,
)
wrapper.screen.endRemovalTransition()
}
}
override fun onAnimationCancel(animation: Animator) = Unit
override fun onAnimationRepeat(animation: Animator) = Unit
private enum class LifecycleState {
INITIALIZED,
START_DISPATCHED,
END_DISPATCHED,
}
companion object {
const val TAG = "ScreenEventDelegate"
}
}