From 7c539976dd72d0c1dfaeb465862340b3f8fbfa10 Mon Sep 17 00:00:00 2001 From: Henry Heino <46334387+personalizedrefrigerator@users.noreply.github.com> Date: Fri, 2 Feb 2024 09:51:26 -0800 Subject: [PATCH] Mobile: Fixes #7974: Andoid: Fix crash on opening settings on some devices (#9806) --- ...ommunity-slider-npm-4.4.4-d78e472f48.patch | 62 +++++++++++++++++++ package.json | 3 +- yarn.lock | 7 +++ 3 files changed, 71 insertions(+), 1 deletion(-) create mode 100644 .yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch diff --git a/.yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch b/.yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch new file mode 100644 index 000000000..13886e9be --- /dev/null +++ b/.yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch @@ -0,0 +1,62 @@ +diff --git a/android/src/newarch/java/com/reactnativecommunity/slider/ReactSliderManager.java b/android/src/newarch/java/com/reactnativecommunity/slider/ReactSliderManager.java +index a5bb95eec3337b93a2338a2869a2bda176c91cae..87817688eb280c2f702c26dc35558c6a0a4db1ea 100644 +--- a/android/src/newarch/java/com/reactnativecommunity/slider/ReactSliderManager.java ++++ b/android/src/newarch/java/com/reactnativecommunity/slider/ReactSliderManager.java +@@ -42,12 +42,20 @@ public class ReactSliderManager extends SimpleViewManager implement + public void onProgressChanged(SeekBar seekbar, int progress, boolean fromUser) { + ReactSlider slider = (ReactSlider)seekbar; + +- if(progress < slider.getLowerLimit()) { +- progress = slider.getLowerLimit(); +- seekbar.setProgress(progress); +- } else if (progress > slider.getUpperLimit()) { +- progress = slider.getUpperLimit(); +- seekbar.setProgress(progress); ++ // During initialization, lowerLimit can be greater than upperLimit. ++ // ++ // If a change event is received during this, we need a check to prevent ++ // infinite recursion. ++ // ++ // Issue: https://github.com/callstack/react-native-slider/issues/571 ++ if (slider.getLowerLimit() <= slider.getUpperLimit()) { ++ if(progress < slider.getLowerLimit()) { ++ progress = slider.getLowerLimit(); ++ seekbar.setProgress(progress); ++ } else if (progress > slider.getUpperLimit()) { ++ progress = slider.getUpperLimit(); ++ seekbar.setProgress(progress); ++ } + } + + ReactContext reactContext = (ReactContext) seekbar.getContext(); +diff --git a/android/src/oldarch/java/com/reactnativecommunity/slider/ReactSliderManager.java b/android/src/oldarch/java/com/reactnativecommunity/slider/ReactSliderManager.java +index 3ff5930f85a3cd92c2549925f41058abb188a57e..ab3681fdfe0b736c97020e1434e450c8183e6f18 100644 +--- a/android/src/oldarch/java/com/reactnativecommunity/slider/ReactSliderManager.java ++++ b/android/src/oldarch/java/com/reactnativecommunity/slider/ReactSliderManager.java +@@ -30,12 +30,20 @@ public class ReactSliderManager extends SimpleViewManager { + public void onProgressChanged(SeekBar seekbar, int progress, boolean fromUser) { + ReactSlider slider = (ReactSlider)seekbar; + +- if(progress < slider.getLowerLimit()) { +- progress = slider.getLowerLimit(); +- seekbar.setProgress(progress); +- } else if(progress > slider.getUpperLimit()) { +- progress = slider.getUpperLimit(); +- seekbar.setProgress(progress); ++ // During initialization, lowerLimit can be greater than upperLimit. ++ // ++ // If a change event is received during this, we need a check to prevent ++ // infinite recursion. ++ // ++ // Issue: https://github.com/callstack/react-native-slider/issues/571 ++ if (slider.getLowerLimit() <= slider.getUpperLimit()) { ++ if(progress < slider.getLowerLimit()) { ++ progress = slider.getLowerLimit(); ++ seekbar.setProgress(progress); ++ } else if (progress > slider.getUpperLimit()) { ++ progress = slider.getUpperLimit(); ++ seekbar.setProgress(progress); ++ } + } + + ReactContext reactContext = (ReactContext) seekbar.getContext(); diff --git a/package.json b/package.json index 8b6042083..f19576474 100644 --- a/package.json +++ b/package.json @@ -107,6 +107,7 @@ "app-builder-lib@24.4.0": "patch:app-builder-lib@npm%3A24.4.0#./.yarn/patches/app-builder-lib-npm-24.4.0-05322ff057.patch", "react-native@0.71.10": "patch:react-native@npm%3A0.71.10#./.yarn/patches/react-native-animation-fix/react-native-npm-0.71.10-f9c32562d8.patch", "nanoid": "patch:nanoid@npm%3A3.3.7#./.yarn/patches/nanoid-npm-3.3.7-98824ba130.patch", - "pdfjs-dist": "patch:pdfjs-dist@npm%3A3.11.174#./.yarn/patches/pdfjs-dist-npm-3.11.174-67f2fee6d6.patch" + "pdfjs-dist": "patch:pdfjs-dist@npm%3A3.11.174#./.yarn/patches/pdfjs-dist-npm-3.11.174-67f2fee6d6.patch", + "@react-native-community/slider@4.4.4": "patch:@react-native-community/slider@npm%3A4.4.4#./.yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch" } } diff --git a/yarn.lock b/yarn.lock index b1ab74a94..466f04516 100644 --- a/yarn.lock +++ b/yarn.lock @@ -9367,6 +9367,13 @@ __metadata: languageName: node linkType: hard +"@react-native-community/slider@patch:@react-native-community/slider@npm%3A4.4.4#./.yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch::locator=root%40workspace%3A.": + version: 4.4.4 + resolution: "@react-native-community/slider@patch:@react-native-community/slider@npm%3A4.4.4#./.yarn/patches/@react-native-community-slider-npm-4.4.4-d78e472f48.patch::version=4.4.4&hash=1120f2&locator=root%40workspace%3A." + checksum: c4397dd2e914f52e3d9b4058d3cf850e67d99c85a59492835647513af85ba62ba182c5c7655fd35d6f768155d45c0c8b5eb0adaad803165d9fec508b77b19a2b + languageName: node + linkType: hard + "@react-native/assets@npm:1.0.0": version: 1.0.0 resolution: "@react-native/assets@npm:1.0.0"