2024-04-12 00:20:38 +02:00
|
|
|
diff --git a/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.h b/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.h
|
|
|
|
index e9b330f..1ecdf0a 100644
|
|
|
|
--- a/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.h
|
|
|
|
+++ b/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.h
|
|
|
|
@@ -16,4 +16,6 @@
|
|
|
|
@property (nonatomic, copy) RCTDirectEventBlock onRefresh;
|
|
|
|
@property (nonatomic, weak) UIScrollView *scrollView;
|
|
|
|
|
|
|
|
+- (void)forwarderBeginRefreshing;
|
|
|
|
+
|
|
|
|
@end
|
2024-03-19 20:05:28 +01:00
|
|
|
diff --git a/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.m b/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.m
|
2024-04-12 00:20:38 +02:00
|
|
|
index b09e653..4c32b31 100644
|
2024-03-19 20:05:28 +01:00
|
|
|
--- a/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.m
|
|
|
|
+++ b/node_modules/react-native/React/Views/RefreshControl/RCTRefreshControl.m
|
2024-04-12 00:20:38 +02:00
|
|
|
@@ -198,9 +198,53 @@ - (void)refreshControlValueChanged
|
2024-03-19 20:05:28 +01:00
|
|
|
[self setCurrentRefreshingState:super.refreshing];
|
|
|
|
_refreshingProgrammatically = NO;
|
2024-04-12 00:20:38 +02:00
|
|
|
|
2024-03-19 20:05:28 +01:00
|
|
|
+ if (@available(iOS 17.4, *)) {
|
|
|
|
+ if (_currentRefreshingState) {
|
|
|
|
+ UIImpactFeedbackGenerator *feedbackGenerator = [[UIImpactFeedbackGenerator alloc] initWithStyle:UIImpactFeedbackStyleLight];
|
|
|
|
+ [feedbackGenerator prepare];
|
|
|
|
+ [feedbackGenerator impactOccurred];
|
2024-02-06 23:45:41 +01:00
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
2024-03-19 20:05:28 +01:00
|
|
|
if (_onRefresh) {
|
|
|
|
_onRefresh(nil);
|
2024-04-12 00:20:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
+/*
|
|
|
|
+ This method is used by Bluesky's ExpoScrollForwarder. This allows other React Native
|
|
|
|
+ libraries to perform a refresh of a scrollview and access the refresh control's onRefresh
|
|
|
|
+ function.
|
|
|
|
+ */
|
|
|
|
+- (void)forwarderBeginRefreshing
|
|
|
|
+{
|
|
|
|
+ _refreshingProgrammatically = NO;
|
|
|
|
+
|
|
|
|
+ [self sizeToFit];
|
|
|
|
+
|
|
|
|
+ if (!self.scrollView) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ UIScrollView *scrollView = (UIScrollView *)self.scrollView;
|
|
|
|
+
|
|
|
|
+ [UIView animateWithDuration:0.3
|
|
|
|
+ delay:0
|
|
|
|
+ options:UIViewAnimationOptionBeginFromCurrentState
|
|
|
|
+ animations:^(void) {
|
|
|
|
+ // Whenever we call this method, the scrollview will always be at a position of
|
|
|
|
+ // -130 or less. Scrolling back to -65 simulates the default behavior of RCTRefreshControl
|
|
|
|
+ [scrollView setContentOffset:CGPointMake(0, -65)];
|
|
|
|
+ }
|
|
|
|
+ completion:^(__unused BOOL finished) {
|
|
|
|
+ [super beginRefreshing];
|
|
|
|
+ [self setCurrentRefreshingState:super.refreshing];
|
|
|
|
+
|
|
|
|
+ if (self->_onRefresh) {
|
|
|
|
+ self->_onRefresh(nil);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ ];
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
@end
|
2024-06-08 10:55:57 +02:00
|
|
|
diff --git a/node_modules/react-native/ReactAndroid/src/main/java/com/facebook/react/modules/core/JavaTimerManager.java b/node_modules/react-native/ReactAndroid/src/main/java/com/facebook/react/modules/core/JavaTimerManager.java
|
|
|
|
index 5f5e1ab..aac00b6 100644
|
|
|
|
--- a/node_modules/react-native/ReactAndroid/src/main/java/com/facebook/react/modules/core/JavaTimerManager.java
|
|
|
|
+++ b/node_modules/react-native/ReactAndroid/src/main/java/com/facebook/react/modules/core/JavaTimerManager.java
|
|
|
|
@@ -99,8 +99,9 @@ public class JavaTimerManager {
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the JS thread is busy for multiple frames we cancel any other pending runnable.
|
|
|
|
- if (mCurrentIdleCallbackRunnable != null) {
|
|
|
|
- mCurrentIdleCallbackRunnable.cancel();
|
|
|
|
+ IdleCallbackRunnable currentRunnable = mCurrentIdleCallbackRunnable;
|
|
|
|
+ if (currentRunnable != null) {
|
|
|
|
+ currentRunnable.cancel();
|
|
|
|
}
|
|
|
|
|
|
|
|
mCurrentIdleCallbackRunnable = new IdleCallbackRunnable(frameTimeNanos);
|