From 7b45c7375569dfd67365db08f7d3b57a9531901f Mon Sep 17 00:00:00 2001
From: Eum SeungJu <109807198+sjsjmine129@users.noreply.github.com>
Date: Mon, 8 Apr 2024 10:41:29 +0900
Subject: [PATCH] [4/7] Add/ screen folders and navigation controls (#3)
* Fi/gitignore
* Add/NavigationSetting_1
* Add/navigation_2
* Add/react-native-svg
* Add/Navigator_done
---
.gitignore | 1 +
.vscode/settings.json | 3 +
App.js | 23 +-
android/app/build.gradle | 2 +
package.json | 12 +-
src/assets/UsePressAnimation.js | 28 +++
src/assets/color.js | 7 +
src/assets/svg.js | 52 +++++
src/components/AnimationButton.js | 41 ++++
src/navigation/BottomTabNavigator.js | 224 ++++++++++++++++++++
src/navigation/MainStackNavigator.js | 56 +++++
src/screens/home/HomeScreen.js | 62 ++++++
src/screens/list/ListDetailScreen.js | 50 +++++
src/screens/list/ListMainScreen.js | 50 +++++
src/screens/map/MapScreen.js | 50 +++++
src/screens/mypage/MypageScreen.js | 50 +++++
src/screens/signup/SignupScreen.js | 65 ++++++
yarn.lock | 302 ++++++++++++++++++++++++++-
18 files changed, 1053 insertions(+), 25 deletions(-)
create mode 100644 .vscode/settings.json
create mode 100644 src/assets/UsePressAnimation.js
create mode 100644 src/assets/color.js
create mode 100644 src/assets/svg.js
create mode 100644 src/components/AnimationButton.js
create mode 100644 src/navigation/BottomTabNavigator.js
create mode 100644 src/navigation/MainStackNavigator.js
create mode 100644 src/screens/home/HomeScreen.js
create mode 100644 src/screens/list/ListDetailScreen.js
create mode 100644 src/screens/list/ListMainScreen.js
create mode 100644 src/screens/map/MapScreen.js
create mode 100644 src/screens/mypage/MypageScreen.js
create mode 100644 src/screens/signup/SignupScreen.js
diff --git a/.gitignore b/.gitignore
index 0cab2ac..f7e209e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -64,3 +64,4 @@ yarn-error.log
# testing
/coverage
+node_modules
\ No newline at end of file
diff --git a/.vscode/settings.json b/.vscode/settings.json
new file mode 100644
index 0000000..385f27a
--- /dev/null
+++ b/.vscode/settings.json
@@ -0,0 +1,3 @@
+{
+ "java.configuration.updateBuildConfiguration": "interactive"
+}
diff --git a/App.js b/App.js
index 0721180..7f64754 100644
--- a/App.js
+++ b/App.js
@@ -6,21 +6,14 @@
*/
import React from 'react';
-import {SafeAreaView, ScrollView, Text, View} from 'react-native';
+import {SafeAreaView, ScrollView, Text, View, StyleSheet} from 'react-native';
+import MainStackNavigator from './src/navigation/MainStackNavigator';
+import 'react-native-gesture-handler';
-function App() {
- return (
-
-
-
- TEST!!!
-
-
-
- );
+export default function App() {
+ return ;
}
-export default App;
+const styles = StyleSheet.create({
+ entire: {},
+});
diff --git a/android/app/build.gradle b/android/app/build.gradle
index bcd447d..7347e53 100644
--- a/android/app/build.gradle
+++ b/android/app/build.gradle
@@ -108,6 +108,8 @@ dependencies {
// The version of react-native is set by the React Native Gradle Plugin
implementation("com.facebook.react:react-android")
implementation("com.facebook.react:flipper-integration")
+ // implementation("androidx.appcompat:appcompat:1.1.0-rc01")
+ // implementation("androidx.swiperefreshlayout:swiperefreshlayout:1.1.0-alpha02")
if (hermesEnabled.toBoolean()) {
implementation("com.facebook.react:hermes-android")
diff --git a/package.json b/package.json
index 55c53ee..e2b35d9 100644
--- a/package.json
+++ b/package.json
@@ -10,8 +10,18 @@
"test": "jest"
},
"dependencies": {
+ "@react-native-community/masked-view": "^0.1.11",
+ "@react-navigation/bottom-tabs": "^6.5.20",
+ "@react-navigation/native": "^6.1.17",
+ "@react-navigation/native-stack": "^6.9.26",
+ "@react-navigation/stack": "^6.3.29",
"react": "18.2.0",
- "react-native": "0.73.6"
+ "react-native": "0.73.6",
+ "react-native-gesture-handler": "^2.16.0",
+ "react-native-reanimated": "^3.8.1",
+ "react-native-safe-area-context": "^4.9.0",
+ "react-native-screens": "^3.30.1",
+ "react-native-svg": "^15.1.0"
},
"devDependencies": {
"@babel/core": "^7.20.0",
diff --git a/src/assets/UsePressAnimation.js b/src/assets/UsePressAnimation.js
new file mode 100644
index 0000000..07bdc77
--- /dev/null
+++ b/src/assets/UsePressAnimation.js
@@ -0,0 +1,28 @@
+import {useState} from 'react';
+import {Animated} from 'react-native';
+
+export const usePressAnimation = (initialValue = 1, toValue = 0.97) => {
+ const [scaleValue] = useState(new Animated.Value(initialValue));
+
+ const handlePressIn = () => {
+ Animated.spring(scaleValue, {
+ toValue: toValue,
+ friction: 3,
+ useNativeDriver: true,
+ }).start();
+ };
+
+ const handlePressOut = () => {
+ Animated.spring(scaleValue, {
+ toValue: initialValue,
+ friction: 3,
+ useNativeDriver: true,
+ }).start();
+ };
+
+ return {
+ scaleValue,
+ handlePressIn,
+ handlePressOut,
+ };
+};
diff --git a/src/assets/color.js b/src/assets/color.js
new file mode 100644
index 0000000..f6892ef
--- /dev/null
+++ b/src/assets/color.js
@@ -0,0 +1,7 @@
+export const COLOR_PRIMARY = '#003C71';
+export const COLOR_SECONDARY = '#A4D65E';
+export const COLOR_BACKGROUND = '#F5F5F5'; //FFFFFF
+export const COLOR_TEXT_BLACK = '#000000';
+export const COLOR_TEXT_DARKGRAY = '#535353';
+export const COLOR_GRAY = '#888888';
+export const COLOR_WHITE = '#FFFFFF';
diff --git a/src/assets/svg.js b/src/assets/svg.js
new file mode 100644
index 0000000..424b3f5
--- /dev/null
+++ b/src/assets/svg.js
@@ -0,0 +1,52 @@
+export const svgXml = {
+ baricon: {
+ home: `
+
+ `,
+ map: `
+
+ `,
+ list: `
+
+ `,
+ prifile: `
+
+ `,
+ homeColor: `
+
+ `,
+ mapColor: `
+
+ `,
+ listColor: `
+
+ `,
+ prifileColor: `
+
+ `,
+ },
+};
diff --git a/src/components/AnimationButton.js b/src/components/AnimationButton.js
new file mode 100644
index 0000000..99d348e
--- /dev/null
+++ b/src/components/AnimationButton.js
@@ -0,0 +1,41 @@
+import React from 'react';
+import {TouchableOpacity, Animated, StyleSheet} from 'react-native';
+import {usePressAnimation} from '../assets/UsePressAnimation';
+import {COLOR_GRAY} from '../assets/color';
+
+const AnimatedButton = ({
+ children,
+ onPress,
+ onLongPress,
+ style,
+ disabled = false,
+}) => {
+ const {scaleValue, handlePressIn, handlePressOut} = usePressAnimation();
+ const AnimatedTouchableOpacity =
+ Animated.createAnimatedComponent(TouchableOpacity);
+
+ return (
+
+ {children}
+
+ );
+};
+
+const styles = StyleSheet.create({
+ disabledButton: {
+ backgroundColor: COLOR_GRAY,
+ },
+});
+
+export default AnimatedButton;
diff --git a/src/navigation/BottomTabNavigator.js b/src/navigation/BottomTabNavigator.js
new file mode 100644
index 0000000..8507b52
--- /dev/null
+++ b/src/navigation/BottomTabNavigator.js
@@ -0,0 +1,224 @@
+/* eslint-disable react-native/no-inline-styles */
+/* eslint-disable react/no-unstable-nested-components */
+import React from 'react';
+import {
+ CardStyleInterpolators,
+ createStackNavigator,
+} from '@react-navigation/stack';
+import {SvgXml} from 'react-native-svg';
+import {svgXml} from '../assets/svg';
+import {DefaultTheme, NavigationContainer} from '@react-navigation/native';
+import {
+ Easing,
+ Linking,
+ Platform,
+ SafeAreaView,
+ StatusBar,
+ View,
+} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../assets/color';
+import {createBottomTabNavigator} from '@react-navigation/bottom-tabs';
+
+import HomeScreen from '../screens/home/HomeScreen';
+import ListMainScreen from '../screens/list/ListMainScreen';
+import ListDetailScreen from '../screens/list/ListDetailScreen';
+import MapScreen from '../screens/map/MapScreen';
+import MypageScreen from '../screens/mypage/MypageScreen';
+
+const BottomTab = createBottomTabNavigator();
+
+const customCardStyleInterpolator = ({current, next, layouts}) => {
+ return {
+ cardStyle: {
+ transform: [
+ {
+ translateX: current.progress.interpolate({
+ inputRange: [0, 1],
+ outputRange: [layouts.screen.width, 0], // transition from right to left
+ }),
+ },
+ {
+ scale: next
+ ? next.progress.interpolate({
+ inputRange: [0, 1],
+ outputRange: [1, 0.9],
+ })
+ : 1,
+ },
+ ],
+ },
+ overlayStyle: {
+ opacity: current.progress.interpolate({
+ inputRange: [0, 1],
+ outputRange: [0, 0.5],
+ }),
+ },
+ };
+};
+
+const HomeStack = createStackNavigator();
+function HomeNavigator() {
+ return (
+
+
+
+ );
+}
+
+const MapStack = createStackNavigator();
+function MapNavigator() {
+ return (
+
+
+
+ );
+}
+
+const ListStack = createStackNavigator();
+function ListNavigator() {
+ return (
+
+
+
+
+ );
+}
+
+const MypageStack = createStackNavigator();
+function MypageNavigator() {
+ return (
+
+
+
+ );
+}
+
+export default function BottomTabNavigator() {
+ return (
+
+ (
+
+ ),
+ }}
+ />
+ (
+
+ ),
+ }}
+ />
+ (
+
+ ),
+ }}
+ />
+ (
+
+ ),
+ }}
+ />
+
+ );
+}
diff --git a/src/navigation/MainStackNavigator.js b/src/navigation/MainStackNavigator.js
new file mode 100644
index 0000000..dfea396
--- /dev/null
+++ b/src/navigation/MainStackNavigator.js
@@ -0,0 +1,56 @@
+import React from 'react';
+import {
+ CardStyleInterpolators,
+ createStackNavigator,
+} from '@react-navigation/stack';
+
+import {DefaultTheme, NavigationContainer} from '@react-navigation/native';
+import {Easing, Linking, Platform, SafeAreaView, StatusBar} from 'react-native';
+import {COLOR_WHITE} from '../assets/color';
+import SignupScreen from '../screens/signup/SignupScreen';
+import BottomTabNavigator from './BottomTabNavigator';
+
+const MainStack = createStackNavigator();
+
+const MyTheme = {
+ ...DefaultTheme,
+ colors: {
+ ...DefaultTheme.colors,
+ background: COLOR_WHITE,
+ },
+};
+
+export const navigationRef = React.createRef();
+
+export function navigate(name, params) {
+ navigationRef.current?.navigate(name, params);
+}
+
+export function reset(routes) {
+ navigationRef.current?.reset(routes);
+}
+
+export default function MainStackNavigator() {
+ return (
+
+
+
+
+
+
+ );
+}
diff --git a/src/screens/home/HomeScreen.js b/src/screens/home/HomeScreen.js
new file mode 100644
index 0000000..7937b19
--- /dev/null
+++ b/src/screens/home/HomeScreen.js
@@ -0,0 +1,62 @@
+import React, {useState, useCallback, useEffect} from 'react';
+import {View, Text, SafeAreaView, ScrollView, StyleSheet} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../../assets/color';
+import AnimatedButton from '../../components/AnimationButton';
+import {useNavigation} from '@react-navigation/native';
+
+export default function HomeScreen() {
+ const navigation = useNavigation();
+
+ return (
+
+ HomeScreen
+ {
+ console.log('PRESSED~!!');
+ navigation.navigate('Signup');
+ }}
+ style={styles.buttonTest}>
+ Signup
+
+ {
+ console.log('PRESSED~!!');
+ navigation.navigate('ListNavigator');
+ }}
+ style={styles.buttonTest}>
+ ListNavigator
+
+
+ );
+}
+
+const styles = StyleSheet.create({
+ entire: {
+ flex: 1,
+ backgroundColor: COLOR_BACKGROUND,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ textMain: {
+ fontSize: 50,
+ color: COLOR_PRIMARY,
+ },
+ buttonTest: {
+ backgroundColor: COLOR_PRIMARY,
+ padding: 10,
+ borderRadius: 5,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ buttonText: {
+ fontSize: 20,
+ color: COLOR_WHITE,
+ fontWeight: 'bold',
+ alignSelf: 'center',
+ },
+});
diff --git a/src/screens/list/ListDetailScreen.js b/src/screens/list/ListDetailScreen.js
new file mode 100644
index 0000000..001e0a1
--- /dev/null
+++ b/src/screens/list/ListDetailScreen.js
@@ -0,0 +1,50 @@
+import React, {useState, useCallback, useEffect} from 'react';
+import {View, Text, SafeAreaView, ScrollView, StyleSheet} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../../assets/color';
+import AnimatedButton from '../../components/AnimationButton';
+
+export default function ListDetailScreen() {
+ return (
+
+ ListDetailScreen
+ {
+ console.log('PRESSED~!!');
+ }}
+ style={styles.buttonTest}>
+ Test Button
+
+
+ );
+}
+
+const styles = StyleSheet.create({
+ entire: {
+ flex: 1,
+ backgroundColor: COLOR_BACKGROUND,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ textMain: {
+ fontSize: 50,
+ color: COLOR_PRIMARY,
+ },
+ buttonTest: {
+ backgroundColor: COLOR_PRIMARY,
+ padding: 10,
+ borderRadius: 5,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ buttonText: {
+ fontSize: 20,
+ color: COLOR_WHITE,
+ fontWeight: 'bold',
+ alignSelf: 'center',
+ },
+});
diff --git a/src/screens/list/ListMainScreen.js b/src/screens/list/ListMainScreen.js
new file mode 100644
index 0000000..b1b7b09
--- /dev/null
+++ b/src/screens/list/ListMainScreen.js
@@ -0,0 +1,50 @@
+import React, {useState, useCallback, useEffect} from 'react';
+import {View, Text, SafeAreaView, ScrollView, StyleSheet} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../../assets/color';
+import AnimatedButton from '../../components/AnimationButton';
+
+export default function ListMainScreen() {
+ return (
+
+ ListMainScreen
+ {
+ console.log('PRESSED~!!');
+ }}
+ style={styles.buttonTest}>
+ Test Button
+
+
+ );
+}
+
+const styles = StyleSheet.create({
+ entire: {
+ flex: 1,
+ backgroundColor: COLOR_BACKGROUND,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ textMain: {
+ fontSize: 50,
+ color: COLOR_PRIMARY,
+ },
+ buttonTest: {
+ backgroundColor: COLOR_PRIMARY,
+ padding: 10,
+ borderRadius: 5,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ buttonText: {
+ fontSize: 20,
+ color: COLOR_WHITE,
+ fontWeight: 'bold',
+ alignSelf: 'center',
+ },
+});
diff --git a/src/screens/map/MapScreen.js b/src/screens/map/MapScreen.js
new file mode 100644
index 0000000..b0b35d0
--- /dev/null
+++ b/src/screens/map/MapScreen.js
@@ -0,0 +1,50 @@
+import React, {useState, useCallback, useEffect} from 'react';
+import {View, Text, SafeAreaView, ScrollView, StyleSheet} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../../assets/color';
+import AnimatedButton from '../../components/AnimationButton';
+
+export default function MapScreen() {
+ return (
+
+ MapScreen
+ {
+ console.log('PRESSED~!!');
+ }}
+ style={styles.buttonTest}>
+ Test Button
+
+
+ );
+}
+
+const styles = StyleSheet.create({
+ entire: {
+ flex: 1,
+ backgroundColor: COLOR_BACKGROUND,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ textMain: {
+ fontSize: 50,
+ color: COLOR_PRIMARY,
+ },
+ buttonTest: {
+ backgroundColor: COLOR_PRIMARY,
+ padding: 10,
+ borderRadius: 5,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ buttonText: {
+ fontSize: 20,
+ color: COLOR_WHITE,
+ fontWeight: 'bold',
+ alignSelf: 'center',
+ },
+});
diff --git a/src/screens/mypage/MypageScreen.js b/src/screens/mypage/MypageScreen.js
new file mode 100644
index 0000000..7339c9e
--- /dev/null
+++ b/src/screens/mypage/MypageScreen.js
@@ -0,0 +1,50 @@
+import React, {useState, useCallback, useEffect} from 'react';
+import {View, Text, SafeAreaView, ScrollView, StyleSheet} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../../assets/color';
+import AnimatedButton from '../../components/AnimationButton';
+
+export default function MypageScreen() {
+ return (
+
+ MypageScreen
+ {
+ console.log('PRESSED~!!');
+ }}
+ style={styles.buttonTest}>
+ Test Button
+
+
+ );
+}
+
+const styles = StyleSheet.create({
+ entire: {
+ flex: 1,
+ backgroundColor: COLOR_BACKGROUND,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ textMain: {
+ fontSize: 50,
+ color: COLOR_PRIMARY,
+ },
+ buttonTest: {
+ backgroundColor: COLOR_PRIMARY,
+ padding: 10,
+ borderRadius: 5,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ buttonText: {
+ fontSize: 20,
+ color: COLOR_WHITE,
+ fontWeight: 'bold',
+ alignSelf: 'center',
+ },
+});
diff --git a/src/screens/signup/SignupScreen.js b/src/screens/signup/SignupScreen.js
new file mode 100644
index 0000000..3f4631b
--- /dev/null
+++ b/src/screens/signup/SignupScreen.js
@@ -0,0 +1,65 @@
+import React, {useState, useCallback, useEffect} from 'react';
+import {View, Text, SafeAreaView, ScrollView, StyleSheet} from 'react-native';
+import {
+ COLOR_WHITE,
+ COLOR_BACKGROUND,
+ COLOR_GRAY,
+ COLOR_PRIMARY,
+} from '../../assets/color';
+import AnimatedButton from '../../components/AnimationButton';
+import {useNavigation} from '@react-navigation/native';
+
+export default function SignupScreen() {
+ const navigation = useNavigation();
+
+ return (
+
+ SignupScreen
+ {
+ console.log('PRESSED~!!');
+ navigation.navigate('BottomTab');
+ }}
+ style={styles.buttonTest}>
+ bottom tab
+
+ {
+ console.log('PRESSED~!!');
+ navigation.navigate('BottomTab', {
+ screen: 'ListNavigator',
+ params: {screen: 'ListDetail'},
+ });
+ }}
+ style={styles.buttonTest}>
+ List Detail
+
+
+ );
+}
+
+const styles = StyleSheet.create({
+ entire: {
+ flex: 1,
+ backgroundColor: COLOR_BACKGROUND,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ textMain: {
+ fontSize: 50,
+ color: COLOR_PRIMARY,
+ },
+ buttonTest: {
+ backgroundColor: COLOR_PRIMARY,
+ padding: 10,
+ borderRadius: 5,
+ justifyContent: 'center',
+ alignItems: 'center',
+ },
+ buttonText: {
+ fontSize: 20,
+ color: COLOR_WHITE,
+ fontWeight: 'bold',
+ alignSelf: 'center',
+ },
+});
diff --git a/yarn.lock b/yarn.lock
index 1349966..437bcd0 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -541,7 +541,7 @@
"@babel/helper-create-regexp-features-plugin" "^7.18.6"
"@babel/helper-plugin-utils" "^7.18.6"
-"@babel/plugin-transform-arrow-functions@^7.0.0", "@babel/plugin-transform-arrow-functions@^7.24.1":
+"@babel/plugin-transform-arrow-functions@^7.0.0", "@babel/plugin-transform-arrow-functions@^7.0.0-0", "@babel/plugin-transform-arrow-functions@^7.24.1":
version "7.24.1"
resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.24.1.tgz#2bf263617060c9cc45bcdbf492b8cc805082bf27"
integrity sha512-ngT/3NkRhsaep9ck9uj2Xhv9+xB1zShY3tM3g6om4xxCELwCDN4g4Aq5dRn48+0hasAql7s2hdBOysCfNpr4fw==
@@ -771,7 +771,7 @@
dependencies:
"@babel/helper-plugin-utils" "^7.24.0"
-"@babel/plugin-transform-nullish-coalescing-operator@^7.24.1":
+"@babel/plugin-transform-nullish-coalescing-operator@^7.0.0-0", "@babel/plugin-transform-nullish-coalescing-operator@^7.24.1":
version "7.24.1"
resolved "https://registry.yarnpkg.com/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.24.1.tgz#0cd494bb97cb07d428bd651632cb9d4140513988"
integrity sha512-iQ+caew8wRrhCikO5DrUYx0mrmdhkaELgFa+7baMcVuhxIkN7oxt06CZ51D65ugIb1UWRQ8oQe+HXAVM6qHFjw==
@@ -813,7 +813,7 @@
"@babel/helper-plugin-utils" "^7.24.0"
"@babel/plugin-syntax-optional-catch-binding" "^7.8.3"
-"@babel/plugin-transform-optional-chaining@^7.24.1":
+"@babel/plugin-transform-optional-chaining@^7.0.0-0", "@babel/plugin-transform-optional-chaining@^7.24.1":
version "7.24.1"
resolved "https://registry.yarnpkg.com/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.24.1.tgz#26e588acbedce1ab3519ac40cc748e380c5291e6"
integrity sha512-n03wmDt+987qXwAgcBlnUUivrZBPZ8z1plL0YvgQalLm+ZE5BMhGm94jhxXtA1wzv1Cu2aaOv1BM9vbVttrzSg==
@@ -913,7 +913,7 @@
babel-plugin-polyfill-regenerator "^0.6.1"
semver "^6.3.1"
-"@babel/plugin-transform-shorthand-properties@^7.0.0", "@babel/plugin-transform-shorthand-properties@^7.24.1":
+"@babel/plugin-transform-shorthand-properties@^7.0.0", "@babel/plugin-transform-shorthand-properties@^7.0.0-0", "@babel/plugin-transform-shorthand-properties@^7.24.1":
version "7.24.1"
resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.24.1.tgz#ba9a09144cf55d35ec6b93a32253becad8ee5b55"
integrity sha512-LyjVB1nsJ6gTTUKRjRWx9C1s9hE7dLfP/knKdrfeH9UPtAGjYGgxIbFfx7xyLIEWs7Xe1Gnf8EWiUqfjLhInZA==
@@ -935,7 +935,7 @@
dependencies:
"@babel/helper-plugin-utils" "^7.24.0"
-"@babel/plugin-transform-template-literals@^7.24.1":
+"@babel/plugin-transform-template-literals@^7.0.0-0", "@babel/plugin-transform-template-literals@^7.24.1":
version "7.24.1"
resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.24.1.tgz#15e2166873a30d8617e3e2ccadb86643d327aab7"
integrity sha512-WRkhROsNzriarqECASCNu/nojeXCDTE/F2HmRgOzi7NGvyfYGq1NEjKBK3ckLfRgGc6/lPAqP0vDOSw3YtG34g==
@@ -1095,7 +1095,7 @@
"@babel/types" "^7.4.4"
esutils "^2.0.2"
-"@babel/preset-typescript@^7.13.0":
+"@babel/preset-typescript@^7.13.0", "@babel/preset-typescript@^7.16.7":
version "7.24.1"
resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.24.1.tgz#89bdf13a3149a17b3b2a2c9c62547f06db8845ec"
integrity sha512-1DBaMmRDpuYQBPWD8Pf/WEwCrtgRHxsZnP4mIy9G/X+hFfbI47Q2G4t1Paakld84+qsk2fSsUPMKg71jkoOOaQ==
@@ -1168,6 +1168,13 @@
resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39"
integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==
+"@egjs/hammerjs@^2.0.17":
+ version "2.0.17"
+ resolved "https://registry.yarnpkg.com/@egjs/hammerjs/-/hammerjs-2.0.17.tgz#5dc02af75a6a06e4c2db0202cae38c9263895124"
+ integrity sha512-XQsZgjm2EcVUiZQf11UBJQfmZeEmOW8DpI1gsFeln6w0ae0ii4dMQEQ0kjl6DspdWX1aGY1/loyXnP0JS06e/A==
+ dependencies:
+ "@types/hammerjs" "^2.0.36"
+
"@eslint-community/eslint-utils@^4.2.0":
version "4.4.0"
resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59"
@@ -1681,6 +1688,11 @@
prompts "^2.4.2"
semver "^7.5.2"
+"@react-native-community/masked-view@^0.1.11":
+ version "0.1.11"
+ resolved "https://registry.yarnpkg.com/@react-native-community/masked-view/-/masked-view-0.1.11.tgz#2f4c6e10bee0786abff4604e39a37ded6f3980ce"
+ integrity sha512-rQfMIGSR/1r/SyN87+VD8xHHzDYeHaJq6elOSCAD+0iLagXkSI2pfA0LmSXP21uw5i3em7GkkRjfJ8wpqWXZNw==
+
"@react-native/assets-registry@0.73.1":
version "0.73.1"
resolved "https://registry.yarnpkg.com/@react-native/assets-registry/-/assets-registry-0.73.1.tgz#e2a6b73b16c183a270f338dc69c36039b3946e85"
@@ -1865,6 +1877,66 @@
invariant "^2.2.4"
nullthrows "^1.1.1"
+"@react-navigation/bottom-tabs@^6.5.20":
+ version "6.5.20"
+ resolved "https://registry.yarnpkg.com/@react-navigation/bottom-tabs/-/bottom-tabs-6.5.20.tgz#5335e75b02c527ef0569bd97d4f9185d65616e49"
+ integrity sha512-ow6Z06iS4VqBO8d7FP+HsGjJLWt2xTWIvuWjpoCvsM/uQXzCRDIjBv9HaKcXbF0yTW7IMir0oDAbU5PFzEDdgA==
+ dependencies:
+ "@react-navigation/elements" "^1.3.30"
+ color "^4.2.3"
+ warn-once "^0.1.0"
+
+"@react-navigation/core@^6.4.16":
+ version "6.4.16"
+ resolved "https://registry.yarnpkg.com/@react-navigation/core/-/core-6.4.16.tgz#f9369a134805174536b9aa0f0f483b930511caf9"
+ integrity sha512-UDTJBsHxnzgFETR3ZxhctP+RWr4SkyeZpbhpkQoIGOuwSCkt1SE0qjU48/u6r6w6XlX8OqVudn1Ab0QFXTHxuQ==
+ dependencies:
+ "@react-navigation/routers" "^6.1.9"
+ escape-string-regexp "^4.0.0"
+ nanoid "^3.1.23"
+ query-string "^7.1.3"
+ react-is "^16.13.0"
+ use-latest-callback "^0.1.9"
+
+"@react-navigation/elements@^1.3.30":
+ version "1.3.30"
+ resolved "https://registry.yarnpkg.com/@react-navigation/elements/-/elements-1.3.30.tgz#a81371f599af1070b12014f05d6c09b1a611fd9a"
+ integrity sha512-plhc8UvCZs0UkV+sI+3bisIyn78wz9O/BiWZXpounu72k/R/Sj5PuZYFJ1fi6psvriUveMCGh4LeZckAZu2qiQ==
+
+"@react-navigation/native-stack@^6.9.26":
+ version "6.9.26"
+ resolved "https://registry.yarnpkg.com/@react-navigation/native-stack/-/native-stack-6.9.26.tgz#90facf7783c9927f094bc9f01c613af75b6c241e"
+ integrity sha512-++dueQ+FDj2XkZ902DVrK79ub1vp19nSdAZWxKRgd6+Bc0Niiesua6rMCqymYOVaYh+dagwkA9r00bpt/U5WLw==
+ dependencies:
+ "@react-navigation/elements" "^1.3.30"
+ warn-once "^0.1.0"
+
+"@react-navigation/native@^6.1.17":
+ version "6.1.17"
+ resolved "https://registry.yarnpkg.com/@react-navigation/native/-/native-6.1.17.tgz#439f15a99809d26ea4682d2a3766081cf2ca31cf"
+ integrity sha512-mer3OvfwWOHoUSMJyLa4vnBH3zpFmCwuzrBPlw7feXklurr/ZDiLjLxUScOot6jLRMz/67GyilEYMmP99LL0RQ==
+ dependencies:
+ "@react-navigation/core" "^6.4.16"
+ escape-string-regexp "^4.0.0"
+ fast-deep-equal "^3.1.3"
+ nanoid "^3.1.23"
+
+"@react-navigation/routers@^6.1.9":
+ version "6.1.9"
+ resolved "https://registry.yarnpkg.com/@react-navigation/routers/-/routers-6.1.9.tgz#73f5481a15a38e36592a0afa13c3c064b9f90bed"
+ integrity sha512-lTM8gSFHSfkJvQkxacGM6VJtBt61ip2XO54aNfswD+KMw6eeZ4oehl7m0me3CR9hnDE4+60iAZR8sAhvCiI3NA==
+ dependencies:
+ nanoid "^3.1.23"
+
+"@react-navigation/stack@^6.3.29":
+ version "6.3.29"
+ resolved "https://registry.yarnpkg.com/@react-navigation/stack/-/stack-6.3.29.tgz#b03b2f2baa36c06e4c9e8c7da80d62f83ad0b835"
+ integrity sha512-tzlGkoRgB6P7vgw7rHuWo3TL7Gzu6xh5LMf+zSdCuEiKp/qASzxYfnTEr9tOLbVs/gf+qeukEDheCSAJKVpBXw==
+ dependencies:
+ "@react-navigation/elements" "^1.3.30"
+ color "^4.2.3"
+ warn-once "^0.1.0"
+
"@sideway/address@^4.1.5":
version "4.1.5"
resolved "https://registry.yarnpkg.com/@sideway/address/-/address-4.1.5.tgz#4bc149a0076623ced99ca8208ba780d65a99b9d5"
@@ -1941,6 +2013,11 @@
dependencies:
"@types/node" "*"
+"@types/hammerjs@^2.0.36":
+ version "2.0.45"
+ resolved "https://registry.yarnpkg.com/@types/hammerjs/-/hammerjs-2.0.45.tgz#ffa764bb68a66c08db6efb9c816eb7be850577b1"
+ integrity sha512-qkcUlZmX6c4J8q45taBKTL3p+LbITgyx7qhlPYOdOHZB7B31K0mXbP5YA7i7SgDeEGuI9MnumiKPEMrxg8j3KQ==
+
"@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0", "@types/istanbul-lib-coverage@^2.0.1":
version "2.0.6"
resolved "https://registry.yarnpkg.com/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz#7739c232a1fee9b4d3ce8985f314c0c6d33549d7"
@@ -2456,6 +2533,11 @@ bl@^4.1.0:
inherits "^2.0.4"
readable-stream "^3.4.0"
+boolbase@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e"
+ integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==
+
brace-expansion@^1.1.7:
version "1.1.11"
resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd"
@@ -2688,11 +2770,27 @@ color-name@1.1.3:
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25"
integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==
-color-name@~1.1.4:
+color-name@^1.0.0, color-name@~1.1.4:
version "1.1.4"
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2"
integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
+color-string@^1.9.0:
+ version "1.9.1"
+ resolved "https://registry.yarnpkg.com/color-string/-/color-string-1.9.1.tgz#4467f9146f036f855b764dfb5bf8582bf342c7a4"
+ integrity sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg==
+ dependencies:
+ color-name "^1.0.0"
+ simple-swizzle "^0.2.2"
+
+color@^4.2.3:
+ version "4.2.3"
+ resolved "https://registry.yarnpkg.com/color/-/color-4.2.3.tgz#d781ecb5e57224ee43ea9627560107c0e0c6463a"
+ integrity sha512-1rXeuUUiGGrykh+CeBdu5Ie7OJwinCgQY0bc7GCRxy5xVHy+moaqkpL/jqQq0MtQOeYcrqEz4abc5f0KtU7W4A==
+ dependencies:
+ color-convert "^2.0.1"
+ color-string "^1.9.0"
+
colorette@^1.0.7:
version "1.4.0"
resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.4.0.tgz#5190fbb87276259a86ad700bff2c6d6faa3fca40"
@@ -2802,6 +2900,30 @@ cross-spawn@^7.0.2, cross-spawn@^7.0.3:
shebang-command "^2.0.0"
which "^2.0.1"
+css-select@^5.1.0:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/css-select/-/css-select-5.1.0.tgz#b8ebd6554c3637ccc76688804ad3f6a6fdaea8a6"
+ integrity sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==
+ dependencies:
+ boolbase "^1.0.0"
+ css-what "^6.1.0"
+ domhandler "^5.0.2"
+ domutils "^3.0.1"
+ nth-check "^2.0.1"
+
+css-tree@^1.1.3:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.3.tgz#eb4870fb6fd7707327ec95c2ff2ab09b5e8db91d"
+ integrity sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==
+ dependencies:
+ mdn-data "2.0.14"
+ source-map "^0.6.1"
+
+css-what@^6.1.0:
+ version "6.1.0"
+ resolved "https://registry.yarnpkg.com/css-what/-/css-what-6.1.0.tgz#fb5effcf76f1ddea2c81bdfaa4de44e79bac70f4"
+ integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==
+
csstype@^3.0.2:
version "3.1.3"
resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.1.3.tgz#d80ff294d114fb0e6ac500fbf85b60137d7eff81"
@@ -2858,6 +2980,11 @@ decamelize@^1.2.0:
resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290"
integrity sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==
+decode-uri-component@^0.2.2:
+ version "0.2.2"
+ resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz#e69dbe25d37941171dd540e024c444cd5188e1e9"
+ integrity sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ==
+
dedent@^1.0.0:
version "1.5.1"
resolved "https://registry.yarnpkg.com/dedent/-/dedent-1.5.1.tgz#4f3fc94c8b711e9bb2800d185cd6ad20f2a90aff"
@@ -2953,6 +3080,36 @@ doctrine@^3.0.0:
dependencies:
esutils "^2.0.2"
+dom-serializer@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-2.0.0.tgz#e41b802e1eedf9f6cae183ce5e622d789d7d8e53"
+ integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==
+ dependencies:
+ domelementtype "^2.3.0"
+ domhandler "^5.0.2"
+ entities "^4.2.0"
+
+domelementtype@^2.3.0:
+ version "2.3.0"
+ resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d"
+ integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==
+
+domhandler@^5.0.2, domhandler@^5.0.3:
+ version "5.0.3"
+ resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-5.0.3.tgz#cc385f7f751f1d1fc650c21374804254538c7d31"
+ integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==
+ dependencies:
+ domelementtype "^2.3.0"
+
+domutils@^3.0.1:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/domutils/-/domutils-3.1.0.tgz#c47f551278d3dc4b0b1ab8cbb42d751a6f0d824e"
+ integrity sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA==
+ dependencies:
+ dom-serializer "^2.0.0"
+ domelementtype "^2.3.0"
+ domhandler "^5.0.3"
+
ee-first@1.1.1:
version "1.1.1"
resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d"
@@ -2978,6 +3135,11 @@ encodeurl@~1.0.2:
resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59"
integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==
+entities@^4.2.0:
+ version "4.5.0"
+ resolved "https://registry.yarnpkg.com/entities/-/entities-4.5.0.tgz#5d268ea5e7113ec74c4d033b79ea5a35a488fb48"
+ integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==
+
envinfo@^7.10.0:
version "7.11.1"
resolved "https://registry.yarnpkg.com/envinfo/-/envinfo-7.11.1.tgz#2ffef77591057081b0129a8fd8cf6118da1b94e1"
@@ -3442,6 +3604,11 @@ fill-range@^7.0.1:
dependencies:
to-regex-range "^5.0.1"
+filter-obj@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/filter-obj/-/filter-obj-1.1.0.tgz#9b311112bc6c6127a16e016c6c5d7f19e0805c5b"
+ integrity sha512-8rXg1ZnX7xzy2NGDVkBVaAy+lSlPNwad13BtgSlLuxfIslyt5Vg64U7tFcCt4WS1R0hvtnQybT/IyCkGZ3DpXQ==
+
finalhandler@1.1.2:
version "1.1.2"
resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.2.tgz#b7e7d000ffd11938d0fdb053506f6ebabe9f587d"
@@ -3758,6 +3925,13 @@ hermes-profile-transformer@^0.0.6:
dependencies:
source-map "^0.7.3"
+hoist-non-react-statics@^3.3.0:
+ version "3.3.2"
+ resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45"
+ integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==
+ dependencies:
+ react-is "^16.7.0"
+
html-escaper@^2.0.0:
version "2.0.2"
resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453"
@@ -3867,6 +4041,11 @@ is-arrayish@^0.2.1:
resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d"
integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==
+is-arrayish@^0.3.1:
+ version "0.3.2"
+ resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.3.2.tgz#4574a2ae56f7ab206896fb431eaeed066fdf8f03"
+ integrity sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==
+
is-async-function@^2.0.0:
version "2.0.0"
resolved "https://registry.yarnpkg.com/is-async-function/-/is-async-function-2.0.0.tgz#8e4418efd3e5d3a6ebb0164c05ef5afb69aa9646"
@@ -4803,6 +4982,11 @@ marky@^1.2.2:
resolved "https://registry.yarnpkg.com/marky/-/marky-1.2.5.tgz#55796b688cbd72390d2d399eaaf1832c9413e3c0"
integrity sha512-q9JtQJKjpsVxCRVgQ+WapguSbKC3SQ5HEzFGPAJMStgh3QjCawp00UKv3MTTAArTmGmmPUvllHZoNbZ3gs0I+Q==
+mdn-data@2.0.14:
+ version "2.0.14"
+ resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50"
+ integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==
+
memoize-one@^5.0.0:
version "5.2.1"
resolved "https://registry.yarnpkg.com/memoize-one/-/memoize-one-5.2.1.tgz#8337aa3c4335581839ec01c3d594090cebe8f00e"
@@ -5076,6 +5260,11 @@ ms@2.1.3:
resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2"
integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==
+nanoid@^3.1.23:
+ version "3.3.7"
+ resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.7.tgz#d0c301a691bc8d54efa0a2226ccf3fe2fd656bd8"
+ integrity sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==
+
natural-compare-lite@^1.4.0:
version "1.4.0"
resolved "https://registry.yarnpkg.com/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz#17b09581988979fddafe0201e931ba933c96cbb4"
@@ -5147,6 +5336,13 @@ npm-run-path@^4.0.1:
dependencies:
path-key "^3.0.0"
+nth-check@^2.0.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d"
+ integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==
+ dependencies:
+ boolbase "^1.0.0"
+
nullthrows@^1.1.1:
version "1.1.1"
resolved "https://registry.yarnpkg.com/nullthrows/-/nullthrows-1.1.1.tgz#7818258843856ae971eae4208ad7d7eb19a431b1"
@@ -5489,7 +5685,7 @@ prompts@^2.0.1, prompts@^2.4.2:
kleur "^3.0.3"
sisteransi "^1.0.5"
-prop-types@^15.8.1:
+prop-types@^15.7.2, prop-types@^15.8.1:
version "15.8.1"
resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.8.1.tgz#67d87bf1a694f48435cf332c24af10214a3140b5"
integrity sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==
@@ -5508,6 +5704,16 @@ pure-rand@^6.0.0:
resolved "https://registry.yarnpkg.com/pure-rand/-/pure-rand-6.1.0.tgz#d173cf23258231976ccbdb05247c9787957604f2"
integrity sha512-bVWawvoZoBYpp6yIoQtQXHZjmz35RSVHnUOTefl8Vcjr8snTPY1wnpSPMWekcFwbxI6gtmT7rSYPFvz71ldiOA==
+query-string@^7.1.3:
+ version "7.1.3"
+ resolved "https://registry.yarnpkg.com/query-string/-/query-string-7.1.3.tgz#a1cf90e994abb113a325804a972d98276fe02328"
+ integrity sha512-hh2WYhq4fi8+b+/2Kg9CEge4fDPvHS534aOOvOZeQ3+Vf2mCFsaFBYj0i+iXcAq6I9Vzp5fjMFBlONvayDC1qg==
+ dependencies:
+ decode-uri-component "^0.2.2"
+ filter-obj "^1.1.0"
+ split-on-first "^1.0.0"
+ strict-uri-encode "^2.0.0"
+
queue-microtask@^1.2.2:
version "1.2.3"
resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243"
@@ -5533,12 +5739,17 @@ react-devtools-core@^4.27.7:
shell-quote "^1.6.1"
ws "^7"
+react-freeze@^1.0.0:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/react-freeze/-/react-freeze-1.0.4.tgz#cbbea2762b0368b05cbe407ddc9d518c57c6f3ad"
+ integrity sha512-r4F0Sec0BLxWicc7HEyo2x3/2icUTrRmDjaaRyzzn+7aDyFZliszMDOgLVwSnQnYENOlL1o569Ze2HZefk8clA==
+
"react-is@^16.12.0 || ^17.0.0 || ^18.0.0", react-is@^18.0.0, react-is@^18.2.0:
version "18.2.0"
resolved "https://registry.yarnpkg.com/react-is/-/react-is-18.2.0.tgz#199431eeaaa2e09f86427efbb4f1473edb47609b"
integrity sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==
-react-is@^16.13.1:
+react-is@^16.13.0, react-is@^16.13.1, react-is@^16.7.0:
version "16.13.1"
resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4"
integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==
@@ -5548,6 +5759,52 @@ react-is@^17.0.1:
resolved "https://registry.yarnpkg.com/react-is/-/react-is-17.0.2.tgz#e691d4a8e9c789365655539ab372762b0efb54f0"
integrity sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==
+react-native-gesture-handler@^2.16.0:
+ version "2.16.0"
+ resolved "https://registry.yarnpkg.com/react-native-gesture-handler/-/react-native-gesture-handler-2.16.0.tgz#45a00b5988e74ebc58f130c8d1443319c8e678db"
+ integrity sha512-1hFkx7RIfeJSyTQQ0Nkv4icFVZ5+XjQkd47OgZMBFzoB7ecL+nFSz8KLi3OCWOhq+nbHpSPlSG5VF3CQNCJpWA==
+ dependencies:
+ "@egjs/hammerjs" "^2.0.17"
+ hoist-non-react-statics "^3.3.0"
+ invariant "^2.2.4"
+ lodash "^4.17.21"
+ prop-types "^15.7.2"
+
+react-native-reanimated@^3.8.1:
+ version "3.8.1"
+ resolved "https://registry.yarnpkg.com/react-native-reanimated/-/react-native-reanimated-3.8.1.tgz#45c13d4bedebef8df3d5a8756f25072de65960d7"
+ integrity sha512-EdM0vr3JEaNtqvstqESaPfOBy0gjYBkr1iEolWJ82Ax7io8y9OVUIphgsLKTB36CtR1XtmBw0RZVj7KArc7ZVA==
+ dependencies:
+ "@babel/plugin-transform-arrow-functions" "^7.0.0-0"
+ "@babel/plugin-transform-nullish-coalescing-operator" "^7.0.0-0"
+ "@babel/plugin-transform-optional-chaining" "^7.0.0-0"
+ "@babel/plugin-transform-shorthand-properties" "^7.0.0-0"
+ "@babel/plugin-transform-template-literals" "^7.0.0-0"
+ "@babel/preset-typescript" "^7.16.7"
+ convert-source-map "^2.0.0"
+ invariant "^2.2.4"
+
+react-native-safe-area-context@^4.9.0:
+ version "4.9.0"
+ resolved "https://registry.yarnpkg.com/react-native-safe-area-context/-/react-native-safe-area-context-4.9.0.tgz#21a570ca3594cb4259ba65f93befaa60d91bcbd0"
+ integrity sha512-/OJD9Pb8IURyvn+1tWTszWPJqsbZ4hyHBU9P0xhOmk7h5owSuqL0zkfagU0pg7Vh0G2NKQkaPpUKUMMCUMDh/w==
+
+react-native-screens@^3.30.1:
+ version "3.30.1"
+ resolved "https://registry.yarnpkg.com/react-native-screens/-/react-native-screens-3.30.1.tgz#254f5cbbeed649492da112756f85ecae3ccf313e"
+ integrity sha512-/muEvjocCtFb+j5J3YmLvB25+f4rIU8hnnxgGTkXcAf2omPBY8uhPjJaaFUlvj64VEoEzJcRpugbXWsjfPPIFg==
+ dependencies:
+ react-freeze "^1.0.0"
+ warn-once "^0.1.0"
+
+react-native-svg@^15.1.0:
+ version "15.1.0"
+ resolved "https://registry.yarnpkg.com/react-native-svg/-/react-native-svg-15.1.0.tgz#07c75f29b1d641faba50144c7ccd21604b368420"
+ integrity sha512-p0Sx0EpQNk1nu6UcMEiB8K9P04n3J7s+pNYUwf1d/Yz+v4hk961VjuVqjyndgiEbHZyWiKWLZRVNuvLpwjPY2A==
+ dependencies:
+ css-select "^5.1.0"
+ css-tree "^1.1.3"
+
react-native@0.73.6:
version "0.73.6"
resolved "https://registry.yarnpkg.com/react-native/-/react-native-0.73.6.tgz#ed4c675e205a34bd62c4ce8b9bd1ca5c85126d5b"
@@ -5983,6 +6240,13 @@ signal-exit@^3.0.2, signal-exit@^3.0.3, signal-exit@^3.0.7:
resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9"
integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==
+simple-swizzle@^0.2.2:
+ version "0.2.2"
+ resolved "https://registry.yarnpkg.com/simple-swizzle/-/simple-swizzle-0.2.2.tgz#a4da6b635ffcccca33f70d17cb92592de95e557a"
+ integrity sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==
+ dependencies:
+ is-arrayish "^0.3.1"
+
sisteransi@^1.0.5:
version "1.0.5"
resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed"
@@ -6033,6 +6297,11 @@ source-map@^0.7.3:
resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.4.tgz#a9bbe705c9d8846f4e08ff6765acf0f1b0898656"
integrity sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==
+split-on-first@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/split-on-first/-/split-on-first-1.1.0.tgz#f610afeee3b12bce1d0c30425e76398b78249a5f"
+ integrity sha512-43ZssAJaMusuKWL8sKUBQXHWOpq8d6CfN/u1p4gUzfJkM05C8rxTmYrkIPTXapZpORA6LkkzcUulJ8FqA7Uudw==
+
sprintf-js@~1.0.2:
version "1.0.3"
resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c"
@@ -6067,6 +6336,11 @@ statuses@~1.5.0:
resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c"
integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==
+strict-uri-encode@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/strict-uri-encode/-/strict-uri-encode-2.0.0.tgz#b9c7330c7042862f6b142dc274bbcc5866ce3546"
+ integrity sha512-QwiXZgpRcKkhTj2Scnn++4PKtWsH0kpzZ62L2R6c/LUVYv7hVnZqcg2+sMuT6R7Jusu1vviK/MFsu6kNJfWlEQ==
+
string-length@^4.0.1:
version "4.0.2"
resolved "https://registry.yarnpkg.com/string-length/-/string-length-4.0.2.tgz#a8a8dc7bd5c1a82b9b3c8b87e125f66871b6e57a"
@@ -6446,6 +6720,11 @@ uri-js@^4.2.2:
dependencies:
punycode "^2.1.0"
+use-latest-callback@^0.1.9:
+ version "0.1.9"
+ resolved "https://registry.yarnpkg.com/use-latest-callback/-/use-latest-callback-0.1.9.tgz#10191dc54257e65a8e52322127643a8940271e2a"
+ integrity sha512-CL/29uS74AwreI/f2oz2hLTW7ZqVeV5+gxFeGudzQrgkCytrHw33G4KbnQOrRlAEzzAFXi7dDLMC9zhWcVpzmw==
+
util-deprecate@^1.0.1, util-deprecate@~1.0.1:
version "1.0.2"
resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf"
@@ -6482,6 +6761,11 @@ walker@^1.0.7, walker@^1.0.8:
dependencies:
makeerror "1.0.12"
+warn-once@^0.1.0:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/warn-once/-/warn-once-0.1.1.tgz#952088f4fb56896e73fd4e6a3767272a3fccce43"
+ integrity sha512-VkQZJbO8zVImzYFteBXvBOZEl1qL175WH8VmZcxF2fZAoudNhNDvHi+doCaAEdU2l2vtcIwa2zn0QK5+I1HQ3Q==
+
wcwidth@^1.0.1:
version "1.0.1"
resolved "https://registry.yarnpkg.com/wcwidth/-/wcwidth-1.0.1.tgz#f0b0dcf915bc5ff1528afadb2c0e17b532da2fe8"