From c8e138b2566c9404c411777d3fc1f2347520b34d Mon Sep 17 00:00:00 2001 From: Diego Mello Date: Thu, 28 Mar 2024 13:46:40 -0300 Subject: [PATCH] Fix lint/ts and comment tests --- .circleci/config.yml | 18 +- .eslintrc.js | 11 +- app/AppContainer.tsx | 3 +- app/containers/ActionSheet/ActionSheet.tsx | 11 +- .../ActionSheet/BottomSheetContent.tsx | 3 +- app/containers/AudioPlayer/PlayButton.tsx | 3 +- app/containers/AudioPlayer/PlaybackSpeed.tsx | 3 +- app/containers/Button/index.tsx | 3 +- app/containers/CallHeader.tsx | 6 +- app/containers/Chip/index.tsx | 3 +- app/containers/CollapsibleText/index.tsx | 6 +- app/containers/EmojiPicker/Footer.tsx | 6 +- app/containers/EmojiPicker/PressableEmoji.tsx | 3 +- app/containers/EmojiPicker/TabBar.tsx | 3 +- app/containers/EmojiPicker/index.tsx | 3 +- app/containers/FormContainer.tsx | 6 +- .../HeaderButton/HeaderButtonItem.tsx | 3 +- .../IncomingCallNotification/index.tsx | 12 +- .../InAppNotification/NotifierComponent.tsx | 6 +- app/containers/KeyboardView.tsx | 3 +- app/containers/List/ListContainer.tsx | 3 +- app/containers/List/ListItem.tsx | 6 +- app/containers/Loading/Loading.test.tsx | 14 +- .../LoginServices/ButtonService.tsx | 3 +- app/containers/MessageActions/Header.tsx | 6 +- .../components/Autocomplete/Autocomplete.tsx | 3 +- .../Autocomplete/AutocompleteItem.tsx | 3 +- .../Autocomplete/AutocompletePreview.tsx | 3 +- .../components/EmojiKeyboard.tsx | 3 +- .../components/EmojiSearchbar.tsx | 3 +- .../components/RecordAudio/ReviewButton.tsx | 3 +- .../components/SendThreadToChannel.tsx | 3 +- .../components/Toolbar/Container.tsx | 3 +- .../helpers/getMentionRegexp.test.js | 6 +- app/containers/Passcode/Base/Button.tsx | 3 +- .../ReactionsList/ReactionsTabBar.tsx | 6 +- app/containers/RoomHeader/RoomHeader.tsx | 3 +- app/containers/RoomItem/Actions.tsx | 9 +- app/containers/RoomItem/RoomItem.tsx | 6 +- app/containers/RoomItem/Title.tsx | 3 +- app/containers/RoomItem/Touchable.tsx | 3 +- app/containers/RoomItem/UpdatedAt.tsx | 3 +- app/containers/RoomItem/Wrapper.tsx | 6 +- app/containers/SafeAreaView.tsx | 3 +- app/containers/SearchBox/index.tsx | 2 +- .../ServerItem/ServerItem.stories.tsx | 3 +- app/containers/ServerItem/index.tsx | 3 +- app/containers/ThreadDetails.tsx | 3 +- app/containers/Toast.tsx | 1 - app/containers/Touch.tsx | 3 +- app/containers/TwoFactor/index.tsx | 3 +- app/containers/UIKit/DatePicker.tsx | 9 +- app/containers/UIKit/MultiSelect/Chips.tsx | 3 +- app/containers/UIKit/MultiSelect/Input.tsx | 4 +- app/containers/UIKit/Overflow.tsx | 9 +- app/containers/UIKit/Select.tsx | 2 - app/containers/UIKit/UiKitMessage.stories.tsx | 3 +- app/containers/UIKit/UiKitModal.stories.tsx | 3 +- .../VideoConferenceBaseContainer.tsx | 3 +- .../UnreadBadge/UnreadBadge.stories.tsx | 3 +- .../UnreadBadge/getUnreadStyle.test.js | 12 +- app/containers/UnreadBadge/index.tsx | 3 +- app/containers/UserGeneratedContentRules.tsx | 6 +- app/containers/UserItem.tsx | 3 +- app/containers/markdown/AtMention.tsx | 3 +- app/containers/markdown/Hashtag.tsx | 3 +- app/containers/markdown/Preview.tsx | 3 +- app/containers/markdown/Table.tsx | 3 +- app/containers/markdown/index.tsx | 6 +- app/containers/markdown/new/Code.tsx | 3 +- app/containers/markdown/new/InlineCode.tsx | 3 +- app/containers/markdown/new/index.tsx | 3 +- app/containers/message/Broadcast.tsx | 3 +- app/containers/message/CallButton.tsx | 3 +- .../CollapsibleQuote.stories.tsx | 3 +- .../CollapsibleQuote.test.tsx | 3 +- .../Components/CollapsibleQuote/index.tsx | 3 +- app/containers/message/Discussion.tsx | 3 +- app/containers/message/Image.tsx | 3 +- app/containers/message/Message.stories.tsx | 3 +- app/containers/message/Message.tsx | 3 +- app/containers/message/Reactions.tsx | 6 +- app/containers/message/Reply.tsx | 6 +- app/containers/message/Urls.tsx | 3 +- app/containers/message/Video.tsx | 3 +- app/containers/message/index.tsx | 3 +- app/definitions/TUserStatus.ts | 2 +- app/ee/omnichannel/reducers/inquiry.test.ts | 7 +- app/ee/omnichannel/views/QueueListView.tsx | 2 +- app/index.tsx | 16 +- app/lib/encryption/encryption.ts | 2 +- app/lib/hooks/useEndpointData.test.tsx | 2 +- .../useVideoConf/StartACallActionSheet.tsx | 6 +- .../methods/helpers/navigation/conditional.ts | 4 +- app/reducers/permissions.ts | 2 +- app/reducers/sortPreferences.test.ts | 2 +- app/share.tsx | 8 +- app/stacks/InsideStack.tsx | 12 + .../MasterDetailStack/ModalContainer.tsx | 3 +- app/stacks/MasterDetailStack/index.tsx | 26 +- app/stacks/OutsideStack.tsx | 7 +- app/theme.tsx | 2 +- .../Dropdown/index.tsx | 3 +- app/views/ChangeAvatarView/index.tsx | 6 +- app/views/CloseLivechatView.tsx | 3 +- .../RoomSettings/SwitchItemEncrypted.test.tsx | 6 +- app/views/CreateChannelView/index.tsx | 3 +- app/views/CreateDiscussionView/index.tsx | 3 +- app/views/DirectoryView/index.tsx | 3 +- app/views/DiscussionsView/Item.tsx | 3 +- app/views/E2EEnterYourPasswordView.tsx | 3 +- app/views/ForwardMessageView/index.tsx | 3 +- app/views/InviteUsersView/index.tsx | 3 +- app/views/JitsiMeetView/index.tsx | 4 +- app/views/LivechatEditView.tsx | 3 +- app/views/LoginView/UserForm.tsx | 3 +- app/views/ModalBlockView.tsx | 3 +- app/views/NewServerView/ServerInput/index.tsx | 3 +- app/views/NewServerView/index.tsx | 21 +- app/views/ProfileView/index.tsx | 9 +- .../components/DeviceNotificationSettings.tsx | 3 +- .../components/PushGatewayConnection.tsx | 3 +- app/views/ReadReceiptView/index.tsx | 6 +- app/views/RegisterView.tsx | 3 +- app/views/ReportUserView/index.tsx | 3 +- app/views/RoomActionsView/index.tsx | 4 +- .../RoomInfoEditView/SwitchContainer.tsx | 3 +- app/views/RoomInfoEditView/index.tsx | 24 +- app/views/RoomInfoView/Direct.tsx | 3 +- .../components/RoomInfoViewAvatar.tsx | 3 +- .../components/RoomInfoViewTitle.tsx | 3 +- .../components/ActionsSection.tsx | 1 + app/views/RoomView/Banner.tsx | 6 +- app/views/RoomView/JoinCode.tsx | 3 +- app/views/RoomView/UploadProgress.tsx | 6 +- app/views/RoomView/index.tsx | 9 +- app/views/RoomsListView/Header/Header.tsx | 3 +- app/views/RoomsListView/ServerDropdown.tsx | 3 +- app/views/RoomsListView/index.tsx | 3 +- app/views/ScreenLockedView.tsx | 3 +- app/views/ShareListView/Header/Header.ios.tsx | 3 +- app/views/ShareListView/Header/SearchBox.tsx | 3 +- app/views/ShareListView/index.tsx | 23 +- app/views/ShareView/Preview.tsx | 3 +- app/views/ShareView/Thumbs.tsx | 3 +- app/views/ShareView/index.tsx | 7 +- app/views/SidebarView/SidebarItem.tsx | 6 +- app/views/SidebarView/index.tsx | 6 +- app/views/TeamChannelsView.tsx | 2 +- .../ThreadMessagesView/Dropdown/index.tsx | 3 +- app/views/ThreadMessagesView/Item.tsx | 3 +- app/views/UserPreferencesView/index.tsx | 1 + e2e/tests/assorted/05-joinpublicroom.spec.ts | 2 +- e2e/tests/assorted/15-change-avatar.spec.ts | 2 +- e2e/tests/room/05-threads.spec.ts | 4 +- e2e/tests/room/12-autotranslate.spec.ts | 6 +- e2e/tests/team/02-team.spec.ts | 14 +- jest.setup.js | 3 - package.json | 27 +- patches/react-native-easy-toast+2.3.0.patch | 12 + .../react-native-picker-select+9.0.1.patch | 13 + patches/react-native-ui-lib+7.2.1.patch | 34 +- yarn.lock | 1190 +++++++++-------- 163 files changed, 979 insertions(+), 1052 deletions(-) create mode 100644 patches/react-native-easy-toast+2.3.0.patch create mode 100644 patches/react-native-picker-select+9.0.1.patch diff --git a/.circleci/config.yml b/.circleci/config.yml index 57dd968ca..e2060252b 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -384,7 +384,7 @@ jobs: lint-testunit: <<: *defaults docker: - - image: cimg/node:16.14 + - image: cimg/node:lts resource_class: large environment: CODECOV_TOKEN: caa771ab-3d45-4756-8e2a-e1f25996fef6 @@ -401,15 +401,15 @@ jobs: command: | yarn lint - - run: - name: Test - command: | - yarn test --runInBand + # - run: + # name: Test + # command: | + # yarn test --runInBand - - run: - name: Codecov - command: | - yarn codecov + # - run: + # name: Codecov + # command: | + # yarn codecov - save_cache: *save-npm-cache-linux diff --git a/.eslintrc.js b/.eslintrc.js index f50cc8ecd..40773ce2b 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -7,7 +7,7 @@ module.exports = { } }, parser: '@babel/eslint-parser', - extends: ['@rocket.chat/eslint-config', 'prettier'], + extends: ['plugin:jest/recommended', '@rocket.chat/eslint-config', 'prettier'], parserOptions: { sourceType: 'module', ecmaVersion: 2017, @@ -17,7 +17,7 @@ module.exports = { legacyDecorators: true } }, - plugins: ['react', 'jsx-a11y', 'import', 'react-native', '@babel', 'jest', 'react-hooks'], + plugins: ['react', 'jsx-a11y', 'import', 'react-native', '@babel', 'react-hooks', 'jest'], env: { browser: true, commonjs: true, @@ -25,6 +25,7 @@ module.exports = { node: true, jquery: true, mocha: true, + jest: true, 'jest/globals': true }, rules: { @@ -225,7 +226,8 @@ module.exports = { 'new-cap': 'off', 'lines-between-class-members': 'off', 'react-hooks/rules-of-hooks': 'error', - 'react-hooks/exhaustive-deps': 'warn' + 'react-hooks/exhaustive-deps': 'warn', + 'jest/no-conditional-expect': 'off' }, globals: { JSX: true @@ -241,7 +243,8 @@ module.exports = { { files: ['e2e/**'], rules: { - 'no-await-in-loop': 0 + 'no-await-in-loop': 0, + 'jest/expect-expect': 'off' } } ] diff --git a/app/AppContainer.tsx b/app/AppContainer.tsx index 34e95fefb..a1e99822c 100644 --- a/app/AppContainer.tsx +++ b/app/AppContainer.tsx @@ -55,8 +55,7 @@ const App = memo(({ root, isMasterDetail }: { root: string; isMasterDetail: bool setCurrentScreen(currentRouteName); } Navigation.routeNameRef.current = currentRouteName; - }} - > + }}> {root === RootEnum.ROOT_LOADING ? : null} {root === RootEnum.ROOT_OUTSIDE ? : null} diff --git a/app/containers/ActionSheet/ActionSheet.tsx b/app/containers/ActionSheet/ActionSheet.tsx index 816b977d1..90254ee31 100644 --- a/app/containers/ActionSheet/ActionSheet.tsx +++ b/app/containers/ActionSheet/ActionSheet.tsx @@ -1,9 +1,9 @@ import { useBackHandler } from '@react-native-community/hooks'; import * as Haptics from 'expo-haptics'; import React, { forwardRef, isValidElement, useEffect, useImperativeHandle, useRef, useState, useCallback } from 'react'; -import { Keyboard, useWindowDimensions } from 'react-native'; +import { Keyboard, LayoutChangeEvent, useWindowDimensions } from 'react-native'; import { Easing, useDerivedValue, useSharedValue } from 'react-native-reanimated'; -import BottomSheet, { BottomSheetBackdrop } from '@gorhom/bottom-sheet'; +import BottomSheet, { BottomSheetBackdrop, BottomSheetBackdropProps } from '@gorhom/bottom-sheet'; import { useSafeAreaInsets } from 'react-native-safe-area-context'; import { useTheme } from '../../theme'; @@ -51,7 +51,7 @@ const ActionSheet = React.memo( nativeEvent: { layout: { height } } - }) => { + }: LayoutChangeEvent) => { /** * This logic is only necessary to prevent the action sheet from * occupying the entire screen when the dynamic content is too big. @@ -126,7 +126,7 @@ const ActionSheet = React.memo( }; const renderBackdrop = useCallback( - props => ( + (props: BottomSheetBackdropProps) => ( index === -1 && onClose()} // We need this to allow horizontal swipe gesture inside the bottom sheet like in reaction picker enableContentPanningGesture={data?.enableContentPanningGesture ?? true} - {...androidTablet} - > + {...androidTablet}> + accessibilityLabel={I18n.t('Cancel')}> {I18n.t('Cancel')} ) : null; diff --git a/app/containers/AudioPlayer/PlayButton.tsx b/app/containers/AudioPlayer/PlayButton.tsx index 82ddd0902..16c105e88 100644 --- a/app/containers/AudioPlayer/PlayButton.tsx +++ b/app/containers/AudioPlayer/PlayButton.tsx @@ -42,8 +42,7 @@ const PlayButton = ({ onPress, disabled = false, audioState }: IButton) => { style={[styles.playPauseButton, { backgroundColor: colors.buttonBackgroundPrimaryDefault }]} disabled={disabled} onPress={onPress} - hitSlop={AUDIO_BUTTON_HIT_SLOP} - > + hitSlop={AUDIO_BUTTON_HIT_SLOP}> ); diff --git a/app/containers/AudioPlayer/PlaybackSpeed.tsx b/app/containers/AudioPlayer/PlaybackSpeed.tsx index 4df4164c4..40264324c 100644 --- a/app/containers/AudioPlayer/PlaybackSpeed.tsx +++ b/app/containers/AudioPlayer/PlaybackSpeed.tsx @@ -20,8 +20,7 @@ const PlaybackSpeed = () => { return ( + style={[styles.containerPlaybackSpeed, { backgroundColor: colors.buttonBackgroundSecondaryDefault }]}> {playbackSpeed}x ); diff --git a/app/containers/Button/index.tsx b/app/containers/Button/index.tsx index c3822b838..48ccd1550 100644 --- a/app/containers/Button/index.tsx +++ b/app/containers/Button/index.tsx @@ -66,8 +66,7 @@ const Button = ({ style ]} accessibilityLabel={title} - {...otherProps} - > + {...otherProps}> {loading ? ( ) : ( diff --git a/app/containers/CallHeader.tsx b/app/containers/CallHeader.tsx index 713f27cbc..21e70b093 100644 --- a/app/containers/CallHeader.tsx +++ b/app/containers/CallHeader.tsx @@ -49,16 +49,14 @@ export const CallHeader = ({ mic, cam, setCam, setMic, title, avatar, uid, name, onPress={() => setCam(!cam)} style={[style.iconCallContainerRight, { backgroundColor: handleColors(cam).button }]} hitSlop={BUTTON_HIT_SLOP} - disabled={calling} - > + disabled={calling}> setMic(!mic)} style={[style.iconCallContainer, { backgroundColor: handleColors(mic).button }]} hitSlop={BUTTON_HIT_SLOP} - disabled={calling} - > + disabled={calling}> diff --git a/app/containers/Chip/index.tsx b/app/containers/Chip/index.tsx index 6725a6700..44b2a64a7 100644 --- a/app/containers/Chip/index.tsx +++ b/app/containers/Chip/index.tsx @@ -57,8 +57,7 @@ const Chip = ({ avatar, text, onPress, testID, style }: IChip) => { onPress={() => onPress?.()} android_ripple={{ color: colors.bannerBackground - }} - > + }}> {avatar ? : null} diff --git a/app/containers/CollapsibleText/index.tsx b/app/containers/CollapsibleText/index.tsx index 514740b16..92d23513c 100644 --- a/app/containers/CollapsibleText/index.tsx +++ b/app/containers/CollapsibleText/index.tsx @@ -67,15 +67,13 @@ const CollapsibleText = ({ msg, style = [], linesToTruncate = 1 }: ICollapsibleT } else { setShowTruncated(false); } - }} - > + }}> {m} {truncatedText ? ( setShowTruncated(true)} - style={[styles.textInfo, { color: colors.actionTintColor }]} - > + style={[styles.textInfo, { color: colors.actionTintColor }]}> {` ${I18n.t('Show_less')}`} ) : null} diff --git a/app/containers/EmojiPicker/Footer.tsx b/app/containers/EmojiPicker/Footer.tsx index 2e7b92b10..232b139a0 100644 --- a/app/containers/EmojiPicker/Footer.tsx +++ b/app/containers/EmojiPicker/Footer.tsx @@ -18,8 +18,7 @@ const Footer = ({ onSearchPressed, onBackspacePressed }: IFooterProps): React.Re styles.footerButtonsContainer, { backgroundColor: isIOS && pressed ? colors.buttonBackgroundSecondaryPress : 'transparent' } ]} - testID='emoji-picker-search' - > + testID='emoji-picker-search'> @@ -30,8 +29,7 @@ const Footer = ({ onSearchPressed, onBackspacePressed }: IFooterProps): React.Re styles.footerButtonsContainer, { backgroundColor: isIOS && pressed ? colors.buttonBackgroundSecondaryPress : 'transparent' } ]} - testID='emoji-picker-backspace' - > + testID='emoji-picker-backspace'> diff --git a/app/containers/EmojiPicker/PressableEmoji.tsx b/app/containers/EmojiPicker/PressableEmoji.tsx index 74c6633be..29ce081fd 100644 --- a/app/containers/EmojiPicker/PressableEmoji.tsx +++ b/app/containers/EmojiPicker/PressableEmoji.tsx @@ -20,8 +20,7 @@ export const PressableEmoji = ({ emoji, onPress }: { emoji: IEmoji; onPress: (em { backgroundColor: isIOS && pressed ? colors.buttonBackgroundSecondaryPress : 'transparent' } - ]} - > + ]}> ); diff --git a/app/containers/EmojiPicker/TabBar.tsx b/app/containers/EmojiPicker/TabBar.tsx index acddb953c..d6c98a12c 100644 --- a/app/containers/EmojiPicker/TabBar.tsx +++ b/app/containers/EmojiPicker/TabBar.tsx @@ -23,8 +23,7 @@ const TabBar = ({ activeTab, tabs, goToPage }: ITabBarProps): React.ReactElement { backgroundColor: isIOS && pressed ? colors.buttonBackgroundSecondaryPress : 'transparent' } - ]} - > + ]}> + style={{ backgroundColor: colors.surfaceLight }}> {categories.tabs.map((tab: any, i) => renderCategory(tab.category, i, tab.tabLabel))} )} diff --git a/app/containers/FormContainer.tsx b/app/containers/FormContainer.tsx index 985003313..36af98164 100644 --- a/app/containers/FormContainer.tsx +++ b/app/containers/FormContainer.tsx @@ -33,15 +33,13 @@ const FormContainer = ({ children, testID, ...props }: IFormContainer) => { + keyboardVerticalOffset={128}> + {...props}> {children} diff --git a/app/containers/HeaderButton/HeaderButtonItem.tsx b/app/containers/HeaderButton/HeaderButtonItem.tsx index 46a81c8f5..eb5d02a18 100644 --- a/app/containers/HeaderButton/HeaderButtonItem.tsx +++ b/app/containers/HeaderButton/HeaderButtonItem.tsx @@ -53,8 +53,7 @@ const Item = ({ title, iconName, onPress, testID, badge, color, disabled, ...pro { opacity: disabled ? 0.5 : 1 } - ]} - > + ]}> <> {iconName ? ( diff --git a/app/containers/InAppNotification/IncomingCallNotification/index.tsx b/app/containers/InAppNotification/IncomingCallNotification/index.tsx index df2552abf..f43a90c62 100644 --- a/app/containers/InAppNotification/IncomingCallNotification/index.tsx +++ b/app/containers/InAppNotification/IncomingCallNotification/index.tsx @@ -51,8 +51,7 @@ const IncomingCallHeader = React.memo( { marginTop: insets.top } - ]} - > + ]}> + style={styles.closeButton}> + style={styles.cancelButton}> {i18n.t('decline')} + style={styles.acceptButton}> {i18n.t('accept')} diff --git a/app/containers/InAppNotification/NotifierComponent.tsx b/app/containers/InAppNotification/NotifierComponent.tsx index 8aa4b351a..8184cdadd 100644 --- a/app/containers/InAppNotification/NotifierComponent.tsx +++ b/app/containers/InAppNotification/NotifierComponent.tsx @@ -107,15 +107,13 @@ const NotifierComponent = React.memo(({ notification, isMasterDetail }: INotifie borderColor: themes[theme].separatorColor, marginTop: insets.top } - ]} - > + ]}> + testID={`in-app-notification-${text}`}> <> diff --git a/app/containers/KeyboardView.tsx b/app/containers/KeyboardView.tsx index 99df6f923..09284b524 100644 --- a/app/containers/KeyboardView.tsx +++ b/app/containers/KeyboardView.tsx @@ -16,8 +16,7 @@ const KeyboardView = ({ style, contentContainerStyle, scrollEnabled, keyboardVer contentContainerStyle={contentContainerStyle} scrollEnabled={scrollEnabled} alwaysBounceVertical={false} - extraHeight={keyboardVerticalOffset} - > + extraHeight={keyboardVerticalOffset}> {children} ); diff --git a/app/containers/List/ListContainer.tsx b/app/containers/List/ListContainer.tsx index daff46069..fc74852e9 100644 --- a/app/containers/List/ListContainer.tsx +++ b/app/containers/List/ListContainer.tsx @@ -18,8 +18,7 @@ const ListContainer = ({ children, ...props }: IListContainer) => ( contentContainerStyle={styles.container} scrollIndicatorInsets={{ right: 1 }} // https://github.com/facebook/react-native/issues/26610#issuecomment-539843444 {...scrollPersistTaps} - {...props} - > + {...props}> {children} ); diff --git a/app/containers/List/ListItem.tsx b/app/containers/List/ListItem.tsx index 9e75ea876..6c58bab13 100644 --- a/app/containers/List/ListItem.tsx +++ b/app/containers/List/ListItem.tsx @@ -92,8 +92,7 @@ const Content = React.memo( return ( + testID={testID}> {left ? {left()} : null} @@ -138,8 +137,7 @@ const Button = React.memo(({ onPress, backgroundColor, underlayColor, ...props } onPress={() => onPress(props.title)} style={{ backgroundColor: backgroundColor || themes[props.theme].backgroundColor }} underlayColor={underlayColor} - enabled={!props.disabled} - > + enabled={!props.disabled}> )); diff --git a/app/containers/Loading/Loading.test.tsx b/app/containers/Loading/Loading.test.tsx index 6f0adea12..4676ed733 100644 --- a/app/containers/Loading/Loading.test.tsx +++ b/app/containers/Loading/Loading.test.tsx @@ -15,9 +15,9 @@ describe('Loading', () => { // receive event and expect loading to be rendered act(() => sendLoadingEvent({ visible: true })); await waitFor(() => { - expect(() => getByTestId(LOADING_TEST_ID)); + expect(() => getByTestId(LOADING_TEST_ID)).toBeTruthy(); }); - expect(() => getByTestId(LOADING_IMAGE_TEST_ID)); + expect(() => getByTestId(LOADING_IMAGE_TEST_ID)).toBeTruthy(); // receive event and expect loading not to be rendered act(() => sendLoadingEvent({ visible: false })); await waitFor(() => { @@ -29,10 +29,10 @@ describe('Loading', () => { const { getByTestId } = render(); getByTestIdAndThrow(getByTestId, LOADING_TEST_ID); act(() => sendLoadingEvent({ visible: true })); - expect(() => getByTestId(LOADING_TEST_ID)); + expect(() => getByTestId(LOADING_TEST_ID)).toBeTruthy(); fireEvent.press(getByTestId(LOADING_BUTTON_TEST_ID)); await waitFor(() => { - expect(() => getByTestId(LOADING_TEST_ID)); + expect(() => getByTestId(LOADING_TEST_ID)).toBeTruthy(); }); }); @@ -42,7 +42,7 @@ describe('Loading', () => { getByTestIdAndThrow(getByTestId, LOADING_TEST_ID); act(() => sendLoadingEvent({ visible: true, onCancel: mockFn })); await waitFor(() => { - expect(() => getByTestId(LOADING_TEST_ID)); + expect(() => getByTestId(LOADING_TEST_ID)).toBeTruthy(); }); fireEvent.press(getByTestId(LOADING_BUTTON_TEST_ID)); await waitFor(() => { @@ -58,11 +58,11 @@ describe('Loading', () => { getByTestIdAndThrow(getByTestId, LOADING_TEST_ID); act(() => sendLoadingEvent({ visible: true, onCancel: mockFn })); await waitFor(() => { - expect(() => getByTestId(LOADING_TEST_ID)); + expect(() => getByTestId(LOADING_TEST_ID)).toBeTruthy(); }); act(() => sendLoadingEvent({ visible: true, onCancel: mockFn2 })); await waitFor(() => { - expect(() => getByTestId(LOADING_TEST_ID)); + expect(() => getByTestId(LOADING_TEST_ID)).toBeTruthy(); }); fireEvent.press(getByTestId(LOADING_BUTTON_TEST_ID)); await waitFor(() => { diff --git a/app/containers/LoginServices/ButtonService.tsx b/app/containers/LoginServices/ButtonService.tsx index 048cdcb77..124490e0f 100644 --- a/app/containers/LoginServices/ButtonService.tsx +++ b/app/containers/LoginServices/ButtonService.tsx @@ -16,8 +16,7 @@ const ButtonService = ({ name, authType, onPress, backgroundColor, buttonText, i onPress={onPress} style={[styles.serviceButton, { backgroundColor }]} activeOpacity={0.5} - underlayColor={colors.buttonText} - > + underlayColor={colors.buttonText}> {authType === 'oauth' || authType === 'apple' ? ( diff --git a/app/containers/MessageActions/Header.tsx b/app/containers/MessageActions/Header.tsx index e7bfab1c0..f9abdfe85 100644 --- a/app/containers/MessageActions/Header.tsx +++ b/app/containers/MessageActions/Header.tsx @@ -65,8 +65,7 @@ const HeaderItem = ({ item, onReaction, theme }: THeaderItem) => ( onReaction({ emoji: item })} - style={[styles.headerItem, { backgroundColor: themes[theme].auxiliaryBackground }]} - > + style={[styles.headerItem, { backgroundColor: themes[theme].auxiliaryBackground }]}> {typeof item === 'string' ? ( {shortnameToUnicode(`:${item}:`)} ) : ( @@ -79,8 +78,7 @@ const HeaderFooter = ({ onReaction, theme }: THeaderFooter) => ( onReaction(param)} - style={[styles.headerItem, { backgroundColor: themes[theme].auxiliaryBackground }]} - > + style={[styles.headerItem, { backgroundColor: themes[theme].auxiliaryBackground }]}> ); diff --git a/app/containers/MessageComposer/components/Autocomplete/Autocomplete.tsx b/app/containers/MessageComposer/components/Autocomplete/Autocomplete.tsx index 0b9488dd7..95d8c88b4 100644 --- a/app/containers/MessageComposer/components/Autocomplete/Autocomplete.tsx +++ b/app/containers/MessageComposer/components/Autocomplete/Autocomplete.tsx @@ -37,8 +37,7 @@ export const Autocomplete = ({ onPress }: { onPress: IAutocompleteItemProps['onP { bottom: viewBottom } - ]} - > + ]}> { underlayColor={colors.buttonBackgroundPrimaryPress} style={{ backgroundColor: colors.surfaceLight }} rippleColor={colors.buttonBackgroundPrimaryPress} - testID={`autocomplete-item-${getTestIDSuffix(item)}`} - > + testID={`autocomplete-item-${getTestIDSuffix(item)}`}> {item.type === '@' || item.type === '#' ? : null} {item.type === ':' ? : null} diff --git a/app/containers/MessageComposer/components/Autocomplete/AutocompletePreview.tsx b/app/containers/MessageComposer/components/Autocomplete/AutocompletePreview.tsx index a70c38e16..3a09d3eed 100644 --- a/app/containers/MessageComposer/components/Autocomplete/AutocompletePreview.tsx +++ b/app/containers/MessageComposer/components/Autocomplete/AutocompletePreview.tsx @@ -28,8 +28,7 @@ export const AutocompletePreview = ({ item, onPress }: IAutocompleteItemProps) = onPress={() => onPress(item)} underlayColor={colors.buttonBackgroundPrimaryPress} style={styles.previewItem} - rippleColor={colors.buttonBackgroundPrimaryPress} - > + rippleColor={colors.buttonBackgroundPrimaryPress}> {content} ); diff --git a/app/containers/MessageComposer/components/EmojiKeyboard.tsx b/app/containers/MessageComposer/components/EmojiKeyboard.tsx index 6cba7259f..5a265d619 100644 --- a/app/containers/MessageComposer/components/EmojiKeyboard.tsx +++ b/app/containers/MessageComposer/components/EmojiKeyboard.tsx @@ -21,8 +21,7 @@ const EmojiKeyboard = ({ theme }: { theme: TSupportedThemes }) => { value={{ theme, colors: colors[theme] - }} - > + }}> diff --git a/app/containers/MessageComposer/components/EmojiSearchbar.tsx b/app/containers/MessageComposer/components/EmojiSearchbar.tsx index 788d8971f..99848c0d6 100644 --- a/app/containers/MessageComposer/components/EmojiSearchbar.tsx +++ b/app/containers/MessageComposer/components/EmojiSearchbar.tsx @@ -64,8 +64,7 @@ export const EmojiSearchbar = (): React.ReactElement | null => { style={({ pressed }: { pressed: boolean }) => [styles.backButton, { opacity: pressed ? 0.7 : 1 }]} onPress={openEmojiKeyboard} hitSlop={BUTTON_HIT_SLOP} - testID='openback-emoji-keyboard' - > + testID='openback-emoji-keyboard'> diff --git a/app/containers/MessageComposer/components/RecordAudio/ReviewButton.tsx b/app/containers/MessageComposer/components/RecordAudio/ReviewButton.tsx index 04e93b440..c025056ca 100644 --- a/app/containers/MessageComposer/components/RecordAudio/ReviewButton.tsx +++ b/app/containers/MessageComposer/components/RecordAudio/ReviewButton.tsx @@ -17,8 +17,7 @@ export const ReviewButton = ({ onPress }: { onPress: Function }): ReactElement = } ]} onPress={() => onPress()} - hitSlop={hitSlop} - > + hitSlop={hitSlop}> diff --git a/app/containers/MessageComposer/components/SendThreadToChannel.tsx b/app/containers/MessageComposer/components/SendThreadToChannel.tsx index 2411dc6f6..c090e5d16 100644 --- a/app/containers/MessageComposer/components/SendThreadToChannel.tsx +++ b/app/containers/MessageComposer/components/SendThreadToChannel.tsx @@ -70,8 +70,7 @@ export const SendThreadToChannel = (): React.ReactElement | null => { setAlsoSendThreadToChannel(!alsoSendThreadToChannel)} - testID='message-composer-send-to-channel' - > + testID='message-composer-send-to-channel'> + }}> {children} ); diff --git a/app/containers/MessageComposer/helpers/getMentionRegexp.test.js b/app/containers/MessageComposer/helpers/getMentionRegexp.test.js index 948bcb9e3..4faefe7d9 100644 --- a/app/containers/MessageComposer/helpers/getMentionRegexp.test.js +++ b/app/containers/MessageComposer/helpers/getMentionRegexp.test.js @@ -35,21 +35,21 @@ describe('getMentionRegexpUser', function () { }); describe('getMentionRegexpEmoji', function () { - test('removing query text on emoji suggestion autocomplete ', () => { + test('removing query text on emoji suggestion autocomplete', () => { const message = 'Hey :smiley'; expect(message.replace(regexp, '')).toBe('Hey :'); }); }); describe('getMentionRegexpCommand', function () { - test('removing query text on emoji suggestion autocomplete ', () => { + test('removing query text on slash command suggestion autocomplete', () => { const message = '/archive'; expect(message.replace(regexp, '')).toBe('/'); }); }); describe('getMentionRegexpRoom', function () { - test('removing query text on emoji suggestion autocomplete ', () => { + test('removing query text on channel suggestion autocomplete', () => { const message = 'Check #general'; expect(message.replace(regexp, '')).toBe('Check #'); }); diff --git a/app/containers/Passcode/Base/Button.tsx b/app/containers/Passcode/Base/Button.tsx index 28e9a7234..00cde8cda 100644 --- a/app/containers/Passcode/Base/Button.tsx +++ b/app/containers/Passcode/Base/Button.tsx @@ -26,8 +26,7 @@ const Button = React.memo(({ style, text, disabled, onPress, icon }: IPasscodeBu underlayColor={themes[theme].passcodeButtonActive} rippleColor={themes[theme].passcodeButtonActive} enabled={!disabled} - onPress={press} - > + onPress={press}> {icon ? ( ) : ( diff --git a/app/containers/ReactionsList/ReactionsTabBar.tsx b/app/containers/ReactionsList/ReactionsTabBar.tsx index 01f00b34a..2e4633c6b 100644 --- a/app/containers/ReactionsList/ReactionsTabBar.tsx +++ b/app/containers/ReactionsList/ReactionsTabBar.tsx @@ -33,8 +33,7 @@ const TabBarItem = ({ tab, index, goToPage, getCustomEmoji }: ITabBarItem) => { style={({ pressed }: { pressed: boolean }) => ({ opacity: pressed ? 0.7 : 1 })} - testID={`tabBarItem-${tab.emoji}`} - > + testID={`tabBarItem-${tab.emoji}`}> {tab._id === 'All' ? ( {I18n.t('All')} @@ -70,8 +69,7 @@ const ReactionsTabBar = ({ tabs, activeTab, goToPage, getCustomEmoji }: IReactio borderBottomWidth: isActiveTab ? 2 : 1, borderColor: isActiveTab ? colors.tintActive : colors.separatorColor }} - key={tab.emoji} - > + key={tab.emoji}> ); diff --git a/app/containers/RoomHeader/RoomHeader.tsx b/app/containers/RoomHeader/RoomHeader.tsx index e28f10aaa..fccb282db 100644 --- a/app/containers/RoomHeader/RoomHeader.tsx +++ b/app/containers/RoomHeader/RoomHeader.tsx @@ -179,8 +179,7 @@ const Header = React.memo( onPress={handleOnPress} style={styles.container} disabled={!!tmid} - hitSlop={HIT_SLOP} - > + hitSlop={HIT_SLOP}> {tmid ? null : ( + ]}> + ]}> + ]}> + displayMode={displayMode}> + sourceType={sourceType}> {showLastMessage && displayMode === DisplayMode.Expanded ? ( <> diff --git a/app/containers/RoomItem/Title.tsx b/app/containers/RoomItem/Title.tsx index 301215fd3..ce9ff03b6 100644 --- a/app/containers/RoomItem/Title.tsx +++ b/app/containers/RoomItem/Title.tsx @@ -11,8 +11,7 @@ const Title = React.memo(({ name, hideUnreadStatus, alert }: ITitleProps) => { + numberOfLines={1}> {name} ); diff --git a/app/containers/RoomItem/Touchable.tsx b/app/containers/RoomItem/Touchable.tsx index 881a24cbf..433a4ee0e 100644 --- a/app/containers/RoomItem/Touchable.tsx +++ b/app/containers/RoomItem/Touchable.tsx @@ -224,8 +224,7 @@ const Touchable = ({ testID={testID} style={{ backgroundColor: isFocused ? colors.chatComponentBackground : colors.backgroundColor - }} - > + }}> {children} diff --git a/app/containers/RoomItem/UpdatedAt.tsx b/app/containers/RoomItem/UpdatedAt.tsx index e520dea30..f51ccc870 100644 --- a/app/containers/RoomItem/UpdatedAt.tsx +++ b/app/containers/RoomItem/UpdatedAt.tsx @@ -28,8 +28,7 @@ const UpdatedAt = React.memo(({ date, hideUnreadStatus, alert }: IUpdatedAtProps ] ]} ellipsizeMode='tail' - numberOfLines={1} - > + numberOfLines={1}> {capitalize(date)} ); diff --git a/app/containers/RoomItem/Wrapper.tsx b/app/containers/RoomItem/Wrapper.tsx index b2d96c592..4fcccb6d2 100644 --- a/app/containers/RoomItem/Wrapper.tsx +++ b/app/containers/RoomItem/Wrapper.tsx @@ -12,8 +12,7 @@ const Wrapper = ({ accessibilityLabel, children, displayMode, ...props }: IWrapp return ( + accessibilityLabel={accessibilityLabel}> + ]}> {children} diff --git a/app/containers/SafeAreaView.tsx b/app/containers/SafeAreaView.tsx index fe88ea771..74a40ef05 100644 --- a/app/containers/SafeAreaView.tsx +++ b/app/containers/SafeAreaView.tsx @@ -25,8 +25,7 @@ const SafeAreaView = React.memo(({ style, children, vertical = true, ...props }: + {...props}> {children} ); diff --git a/app/containers/SearchBox/index.tsx b/app/containers/SearchBox/index.tsx index c1d1243df..eed365351 100644 --- a/app/containers/SearchBox/index.tsx +++ b/app/containers/SearchBox/index.tsx @@ -17,7 +17,7 @@ const SearchBox = ({ onChangeText, onSubmitEditing, testID }: TextInputProps): J const { colors } = useTheme(); - const internalOnChangeText = useCallback(value => { + const internalOnChangeText = useCallback((value: string) => { setText(value); onChangeText?.(value); }, []); diff --git a/app/containers/ServerItem/ServerItem.stories.tsx b/app/containers/ServerItem/ServerItem.stories.tsx index 6074b375b..a6bb24da1 100644 --- a/app/containers/ServerItem/ServerItem.stories.tsx +++ b/app/containers/ServerItem/ServerItem.stories.tsx @@ -31,8 +31,7 @@ const ServerItem = ({ value={{ theme, colors: themes[theme] - }} - > + }}> ); diff --git a/app/containers/ServerItem/index.tsx b/app/containers/ServerItem/index.tsx index 830d2b188..e0e568777 100644 --- a/app/containers/ServerItem/index.tsx +++ b/app/containers/ServerItem/index.tsx @@ -34,8 +34,7 @@ const ServerItem = React.memo(({ item, onPress, onLongPress, hasCheck }: IServer android_ripple={{ color: themes[theme].bannerBackground }} style={({ pressed }: { pressed: boolean }) => ({ backgroundColor: isIOS && pressed ? themes[theme].bannerBackground : themes[theme].backgroundColor - })} - > + })}> {item.iconURL ? ( + numberOfLines={1}> {count} diff --git a/app/containers/Toast.tsx b/app/containers/Toast.tsx index 0834ba3f6..cf23d9eb6 100644 --- a/app/containers/Toast.tsx +++ b/app/containers/Toast.tsx @@ -44,7 +44,6 @@ const Toast = (): React.ReactElement => { return ( (({ children, onPress, un activeOpacity={1} underlayColor={underlayColor || colors.bannerBackground} rippleColor={colors.bannerBackground} - {...props} - > + {...props}> {children} ); diff --git a/app/containers/TwoFactor/index.tsx b/app/containers/TwoFactor/index.tsx index f753d3e76..991c5a534 100644 --- a/app/containers/TwoFactor/index.tsx +++ b/app/containers/TwoFactor/index.tsx @@ -111,8 +111,7 @@ const TwoFactor = React.memo(({ isMasterDetail }: { isMasterDetail: boolean }) = styles.content, isMasterDetail && [sharedStyles.modalFormSheet, styles.tablet], { backgroundColor: themes[theme].backgroundColor } - ]} - > + ]}> {I18n.t(method?.title || 'Two_Factor_Authentication')} {method?.text ? {I18n.t(method.text)} : null} { + const onChange: BaseProps['onChange'] = ({ nativeEvent: { timestamp } }, date?) => { if (date || timestamp) { const newDate = date || new Date(timestamp); unstable_batchedUpdates(() => { @@ -67,8 +65,7 @@ export const DatePicker = ({ element, language, action, context, loading, value, onShow(!show)} style={{ backgroundColor: themes[theme].backgroundColor }} - background={Touchable.Ripple(themes[theme].bannerBackground)} - > + background={Touchable.Ripple(themes[theme].bannerBackground)}> {currentDate.toLocaleDateString(language)} diff --git a/app/containers/UIKit/MultiSelect/Chips.tsx b/app/containers/UIKit/MultiSelect/Chips.tsx index ac10c932d..6fe4735be 100644 --- a/app/containers/UIKit/MultiSelect/Chips.tsx +++ b/app/containers/UIKit/MultiSelect/Chips.tsx @@ -31,8 +31,7 @@ const Chip = ({ item, onSelect, style }: IChip) => { onPress={() => onSelect(item)} style={[styles.chip, { backgroundColor: colors.auxiliaryBackground }, style]} background={Touchable.Ripple(colors.bannerBackground)} - testID={`multi-select-chip-${item.value}`} - > + testID={`multi-select-chip-${item.value}`}> <> {item.imageUrl ? : null} diff --git a/app/containers/UIKit/MultiSelect/Input.tsx b/app/containers/UIKit/MultiSelect/Input.tsx index f4d19fbe0..cbc7e41f7 100644 --- a/app/containers/UIKit/MultiSelect/Input.tsx +++ b/app/containers/UIKit/MultiSelect/Input.tsx @@ -24,8 +24,8 @@ const Input = ({ children, onPress, loading, inputStyle, placeholder, disabled, onPress={onPress} style={[{ backgroundColor: colors.backgroundColor }, styles.inputBorder, inputStyle]} background={Touchable.Ripple(colors.bannerBackground)} - disabled={disabled} - > + // @ts-ignore + disabled={disabled}> {placeholder ? {placeholder} : children} {loading ? ( diff --git a/app/containers/UIKit/Overflow.tsx b/app/containers/UIKit/Overflow.tsx index da24e2ae0..dfb49b6c1 100644 --- a/app/containers/UIKit/Overflow.tsx +++ b/app/containers/UIKit/Overflow.tsx @@ -30,8 +30,7 @@ const Option = ({ option: { text, value }, onOptionPress, parser, theme }: IOpti onOptionPress({ value })} background={Touchable.Ripple(themes[theme].bannerBackground)} - style={styles.option} - > + style={styles.option}> {parser.text(text)} ); @@ -65,8 +64,7 @@ export const Overflow = ({ element, loading, action, parser }: IOverflow) => { background={Touchable.Ripple(themes[theme].bannerBackground)} onPress={() => onShow(!show)} hitSlop={BUTTON_HIT_SLOP} - style={styles.menu} - > + style={styles.menu}> {!loading ? ( ) : ( @@ -78,8 +76,7 @@ export const Overflow = ({ element, loading, action, parser }: IOverflow) => { // fromView exists in Popover Component /* @ts-ignore*/ fromView={touchable[blockId]} - onRequestClose={() => onShow(false)} - > + onRequestClose={() => onShow(false)}> diff --git a/app/containers/UIKit/Select.tsx b/app/containers/UIKit/Select.tsx index 7500931d4..856561d48 100644 --- a/app/containers/UIKit/Select.tsx +++ b/app/containers/UIKit/Select.tsx @@ -87,8 +87,6 @@ export const Select = ({ options = [], placeholder, onChange, loading, disabled, }} Icon={Icon} textInputProps={{ - // style property was Omitted in lib, but can be used normally - // @ts-ignore style: { ...styles.pickerText, color: selected ? themes[theme].titleText : themes[theme].auxiliaryText } }} /> diff --git a/app/containers/UIKit/UiKitMessage.stories.tsx b/app/containers/UIKit/UiKitMessage.stories.tsx index 8b3a14ea2..804ef0f98 100644 --- a/app/containers/UIKit/UiKitMessage.stories.tsx +++ b/app/containers/UIKit/UiKitMessage.stories.tsx @@ -41,8 +41,7 @@ export default { onDiscussionPress: () => {}, onReactionLongPress: () => {}, threadBadgeColor: themes.light.tunreadColor - }} - > + }}> diff --git a/app/containers/UIKit/UiKitModal.stories.tsx b/app/containers/UIKit/UiKitModal.stories.tsx index e6aa083a6..e6748715a 100644 --- a/app/containers/UIKit/UiKitModal.stories.tsx +++ b/app/containers/UIKit/UiKitModal.stories.tsx @@ -43,8 +43,7 @@ export default { onDiscussionPress: () => {}, onReactionLongPress: () => {}, threadBadgeColor: themes.light.tunreadColor - }} - > + }}> diff --git a/app/containers/UIKit/VideoConferenceBlock/components/VideoConferenceBaseContainer.tsx b/app/containers/UIKit/VideoConferenceBlock/components/VideoConferenceBaseContainer.tsx index 622a4d180..309efeac5 100644 --- a/app/containers/UIKit/VideoConferenceBlock/components/VideoConferenceBaseContainer.tsx +++ b/app/containers/UIKit/VideoConferenceBlock/components/VideoConferenceBaseContainer.tsx @@ -49,8 +49,7 @@ export const VideoConferenceBaseContainer = ({ variant, children }: VideoConfMes style={{ ...style.iconContainer, backgroundColor: iconStyle[variant].backgroundColor - }} - > + }}> {iconStyle[variant].label} diff --git a/app/containers/UnreadBadge/UnreadBadge.stories.tsx b/app/containers/UnreadBadge/UnreadBadge.stories.tsx index 2491cafc6..337647dfc 100644 --- a/app/containers/UnreadBadge/UnreadBadge.stories.tsx +++ b/app/containers/UnreadBadge/UnreadBadge.stories.tsx @@ -16,8 +16,7 @@ const StoryTester = ({ children }: { children: React.ReactElement | React.ReactE flexDirection: 'row', alignItems: 'center', justifyContent: 'space-evenly' - }} - > + }}> {children} ); diff --git a/app/containers/UnreadBadge/getUnreadStyle.test.js b/app/containers/UnreadBadge/getUnreadStyle.test.js index 03dd850af..41fef8aca 100644 --- a/app/containers/UnreadBadge/getUnreadStyle.test.js +++ b/app/containers/UnreadBadge/getUnreadStyle.test.js @@ -89,6 +89,12 @@ const testsForTheme = theme => { }); }; -describe('getUnreadStyle light theme', () => testsForTheme('light')); -describe('getUnreadStyle dark theme', () => testsForTheme('dark')); -describe('getUnreadStyle black theme', () => testsForTheme('black')); +describe('getUnreadStyle light theme', () => { + testsForTheme('light'); +}); +describe('getUnreadStyle dark theme', () => { + testsForTheme('dark'); +}); +describe('getUnreadStyle black theme', () => { + testsForTheme('black'); +}); diff --git a/app/containers/UnreadBadge/index.tsx b/app/containers/UnreadBadge/index.tsx index 6ac6e5f9c..ef7840549 100644 --- a/app/containers/UnreadBadge/index.tsx +++ b/app/containers/UnreadBadge/index.tsx @@ -103,8 +103,7 @@ const UnreadBadge = React.memo( small ? styles.unreadNumberContainerSmall : styles.unreadNumberContainerNormal, { backgroundColor, minWidth }, style - ]} - > + ]}> {text} diff --git a/app/containers/UserGeneratedContentRules.tsx b/app/containers/UserGeneratedContentRules.tsx index 2f156f638..b3dea1af8 100644 --- a/app/containers/UserGeneratedContentRules.tsx +++ b/app/containers/UserGeneratedContentRules.tsx @@ -44,15 +44,13 @@ const UGCRules = ({ styleContainer }: { styleContainer?: ViewStyle }) => { {`${I18n.t('Onboarding_agree_terms')}\n`} openContract('terms-of-service')} - > + onPress={() => openContract('terms-of-service')}> {I18n.t('Terms_of_Service')} {' '} {I18n.t('and')} openContract('privacy-policy')} - > + onPress={() => openContract('privacy-policy')}> {' '} {I18n.t('Privacy_Policy')} diff --git a/app/containers/UserItem.tsx b/app/containers/UserItem.tsx index 02739d2f8..82ef18bd8 100644 --- a/app/containers/UserItem.tsx +++ b/app/containers/UserItem.tsx @@ -58,8 +58,7 @@ const UserItem = ({ name, username, onPress, testID, onLongPress, style, icon, i }} style={({ pressed }: any) => ({ backgroundColor: isIOS && pressed ? colors.bannerBackground : 'transparent' - })} - > + })}> diff --git a/app/containers/markdown/AtMention.tsx b/app/containers/markdown/AtMention.tsx index 694f5d403..1f535754c 100644 --- a/app/containers/markdown/AtMention.tsx +++ b/app/containers/markdown/AtMention.tsx @@ -27,8 +27,7 @@ const AtMention = React.memo(({ mention, mentions, username, navToRoomInfo, styl color: themes[theme].mentionGroupColor }, ...style - ]} - > + ]}> {mention} ); diff --git a/app/containers/markdown/Hashtag.tsx b/app/containers/markdown/Hashtag.tsx index 0d92f3d18..f6ecb8331 100644 --- a/app/containers/markdown/Hashtag.tsx +++ b/app/containers/markdown/Hashtag.tsx @@ -58,8 +58,7 @@ const Hashtag = React.memo(({ hashtag, channels, navToRoomInfo, style = [] }: IH }, ...style ]} - onPress={handlePress} - > + onPress={handlePress}> {`#${hashtag}`} ); diff --git a/app/containers/markdown/Preview.tsx b/app/containers/markdown/Preview.tsx index 7cd9471cd..03571ea16 100644 --- a/app/containers/markdown/Preview.tsx +++ b/app/containers/markdown/Preview.tsx @@ -26,8 +26,7 @@ const MarkdownPreview = ({ msg, numberOfLines = 1, style = [], testID }: IMarkdo accessibilityLabel={m} style={[styles.text, { color: themes[theme].bodyText }, ...style]} numberOfLines={numberOfLines} - testID={testID || `markdown-preview-${m}`} - > + testID={testID || `markdown-preview-${m}`}> {m} ); diff --git a/app/containers/markdown/Table.tsx b/app/containers/markdown/Table.tsx index 2df34a383..d45de1683 100644 --- a/app/containers/markdown/Table.tsx +++ b/app/containers/markdown/Table.tsx @@ -55,8 +55,7 @@ const Table = React.memo(({ children, numColumns, theme }: ITable) => { style={[ styles.containerTable, { maxWidth: getTableWidth(), maxHeight: MAX_HEIGHT, borderColor: themes[theme].borderColor } - ]} - > + ]}> {renderRows(false)} {I18n.t('Full_table')} diff --git a/app/containers/markdown/index.tsx b/app/containers/markdown/index.tsx index 6d42e960c..7c284ddf6 100644 --- a/app/containers/markdown/index.tsx +++ b/app/containers/markdown/index.tsx @@ -161,8 +161,7 @@ class Markdown extends PureComponent { borderColor: themes[theme!].bannerBackground }, ...style - ]} - > + ]}> {literal} ); @@ -180,8 +179,7 @@ class Markdown extends PureComponent { borderColor: themes[theme!].bannerBackground }, ...style - ]} - > + ]}> {literal} ); diff --git a/app/containers/markdown/new/Code.tsx b/app/containers/markdown/new/Code.tsx index c47f81dd6..9680e0b03 100644 --- a/app/containers/markdown/new/Code.tsx +++ b/app/containers/markdown/new/Code.tsx @@ -21,8 +21,7 @@ const Code = ({ value }: ICodeProps): React.ReactElement => { backgroundColor: colors.bannerBackground, borderColor: colors.borderColor } - ]} - > + ]}> {value.map(block => { switch (block.type) { case 'CODE_LINE': diff --git a/app/containers/markdown/new/InlineCode.tsx b/app/containers/markdown/new/InlineCode.tsx index 7934aea3a..c66996db5 100644 --- a/app/containers/markdown/new/InlineCode.tsx +++ b/app/containers/markdown/new/InlineCode.tsx @@ -22,8 +22,7 @@ const InlineCode = ({ value }: IInlineCodeProps) => { backgroundColor: themes[theme].bannerBackground, borderColor: themes[theme].borderColor } - ]} - > + ]}> {(block => { switch (block.type) { case 'PLAIN_TEXT': diff --git a/app/containers/markdown/new/index.tsx b/app/containers/markdown/new/index.tsx index e1f77e3f3..e682da29b 100644 --- a/app/containers/markdown/new/index.tsx +++ b/app/containers/markdown/new/index.tsx @@ -50,8 +50,7 @@ const Body = ({ navToRoomInfo, getCustomEmoji, onLinkPress - }} - > + }}> {tokens?.map(block => { switch (block.type) { case 'BIG_EMOJI': diff --git a/app/containers/message/Broadcast.tsx b/app/containers/message/Broadcast.tsx index ce7dbacb4..2e102eaf2 100644 --- a/app/containers/message/Broadcast.tsx +++ b/app/containers/message/Broadcast.tsx @@ -24,8 +24,7 @@ const Broadcast = React.memo(({ author, broadcast }: IMessageBroadcast) => { background={Touchable.Ripple(themes[theme].bannerBackground)} style={[styles.button, { backgroundColor: themes[theme].tintColor }]} hitSlop={BUTTON_HIT_SLOP} - testID='message-broadcast-reply' - > + testID='message-broadcast-reply'> <> {I18n.t('Reply')} diff --git a/app/containers/message/CallButton.tsx b/app/containers/message/CallButton.tsx index 265ebb268..e9fa703ec 100644 --- a/app/containers/message/CallButton.tsx +++ b/app/containers/message/CallButton.tsx @@ -18,8 +18,7 @@ const CallButton = React.memo(({ handleEnterCall }: IMessageCallButton) => { onPress={handleEnterCall} background={Touchable.Ripple(themes[theme].bannerBackground)} style={[styles.button, { backgroundColor: themes[theme].tintColor }]} - hitSlop={BUTTON_HIT_SLOP} - > + hitSlop={BUTTON_HIT_SLOP}> <> {I18n.t('Click_to_join')} diff --git a/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.stories.tsx b/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.stories.tsx index 81962663a..1b837d04e 100644 --- a/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.stories.tsx +++ b/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.stories.tsx @@ -28,8 +28,7 @@ export const Item = () => ( value={{ onLongPress: () => {}, user: { username: 'Marcos' } - }} - > + }}> null} timeFormat='LT' /> diff --git a/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.test.tsx b/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.test.tsx index c0b56a1ba..021d01cff 100644 --- a/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.test.tsx +++ b/app/containers/message/Components/CollapsibleQuote/CollapsibleQuote.test.tsx @@ -25,8 +25,7 @@ const Render = () => ( value={{ onLongPress: () => {}, user: { username: 'Marcos' } - }} - > + }}> ); diff --git a/app/containers/message/Components/CollapsibleQuote/index.tsx b/app/containers/message/Components/CollapsibleQuote/index.tsx index c2e4103d3..f83cdc266 100644 --- a/app/containers/message/Components/CollapsibleQuote/index.tsx +++ b/app/containers/message/Components/CollapsibleQuote/index.tsx @@ -162,8 +162,7 @@ const CollapsibleQuote = React.memo( } ]} background={Touchable.Ripple(themes[theme].bannerBackground)} - hitSlop={BUTTON_HIT_SLOP} - > + hitSlop={BUTTON_HIT_SLOP}> diff --git a/app/containers/message/Discussion.tsx b/app/containers/message/Discussion.tsx index a46075161..58f9ecbca 100644 --- a/app/containers/message/Discussion.tsx +++ b/app/containers/message/Discussion.tsx @@ -31,8 +31,7 @@ const Discussion = React.memo( onPress={onDiscussionPress} background={Touchable.Ripple(themes[theme].bannerBackground)} style={[styles.button, { backgroundColor: themes[theme].tintColor }]} - hitSlop={BUTTON_HIT_SLOP} - > + hitSlop={BUTTON_HIT_SLOP}> <> {buttonText} diff --git a/app/containers/message/Image.tsx b/app/containers/message/Image.tsx index 23ed6e607..72c902159 100644 --- a/app/containers/message/Image.tsx +++ b/app/containers/message/Image.tsx @@ -45,8 +45,7 @@ const Button = React.memo(({ children, onPress, disabled }: IMessageButton) => { disabled={disabled} onPress={onPress} style={styles.imageContainer} - background={Touchable.Ripple(colors.bannerBackground)} - > + background={Touchable.Ripple(colors.bannerBackground)}> {children} ); diff --git a/app/containers/message/Message.stories.tsx b/app/containers/message/Message.stories.tsx index 9c0d304fa..71cc742ab 100644 --- a/app/containers/message/Message.stories.tsx +++ b/app/containers/message/Message.stories.tsx @@ -57,8 +57,7 @@ export default { onDiscussionPress: () => {}, onReactionLongPress: () => {}, threadBadgeColor: themes.light.tunreadColor - }} - > + }}> diff --git a/app/containers/message/Message.tsx b/app/containers/message/Message.tsx index 2222403f3..7560472a7 100644 --- a/app/containers/message/Message.tsx +++ b/app/containers/message/Message.tsx @@ -151,8 +151,7 @@ const MessageTouchable = React.memo((props: IMessageTouchable & IMessage) => { onLongPress={onLongPress} onPress={onPress} disabled={(props.isInfo && !props.isThreadReply) || props.archived || props.isTemp || props.type === 'jitsi_call_started'} - style={{ backgroundColor }} - > + style={{ backgroundColor }}> diff --git a/app/containers/message/Reactions.tsx b/app/containers/message/Reactions.tsx index f817836b6..2cdb0b408 100644 --- a/app/containers/message/Reactions.tsx +++ b/app/containers/message/Reactions.tsx @@ -37,8 +37,7 @@ const AddReaction = React.memo(({ theme }: { theme: TSupportedThemes }) => { testID='message-add-reaction' style={[styles.reactionButton, { backgroundColor: themes[theme].backgroundColor }]} background={Touchable.Ripple(themes[theme].bannerBackground)} - hitSlop={BUTTON_HIT_SLOP} - > + hitSlop={BUTTON_HIT_SLOP}> @@ -60,8 +59,7 @@ const Reaction = React.memo(({ reaction, getCustomEmoji, theme }: IMessageReacti { backgroundColor: reacted ? themes[theme].bannerBackground : themes[theme].backgroundColor } ]} background={Touchable.Ripple(themes[theme].bannerBackground)} - hitSlop={BUTTON_HIT_SLOP} - > + hitSlop={BUTTON_HIT_SLOP}> + disabled={loading || attachment.message_link}> <Description attachment={attachment} getCustomEmoji={getCustomEmoji} theme={theme} /> @@ -264,8 +263,7 @@ const Reply = React.memo( style={[ styles.backdrop, { backgroundColor: themes[theme].bannerBackground, opacity: themes[theme].attachmentLoadingOpacity } - ]} - ></View> + ]}></View> <RCActivityIndicator /> </View> ) : null} diff --git a/app/containers/message/Urls.tsx b/app/containers/message/Urls.tsx index 7397863e2..916c734fc 100644 --- a/app/containers/message/Urls.tsx +++ b/app/containers/message/Urls.tsx @@ -128,8 +128,7 @@ const Url = React.memo( }, imageLoadedState === 'loading' && styles.loading ]} - background={Touchable.Ripple(themes[theme].bannerBackground)} - > + background={Touchable.Ripple(themes[theme].bannerBackground)}> <> {image ? ( <FastImage diff --git a/app/containers/message/Video.tsx b/app/containers/message/Video.tsx index 87919300a..45ce3c823 100644 --- a/app/containers/message/Video.tsx +++ b/app/containers/message/Video.tsx @@ -225,8 +225,7 @@ const Video = ({ file, showAttachment, getCustomEmoji, style, isReply, msg }: IM <Touchable onPress={onPress} style={[styles.button, { backgroundColor: themes[theme].videoBackground }]} - background={Touchable.Ripple(themes[theme].bannerBackground)} - > + background={Touchable.Ripple(themes[theme].bannerBackground)}> <Thumbnail loading={loading} cached={cached} /> </Touchable> </> diff --git a/app/containers/message/index.tsx b/app/containers/message/index.tsx index a0572d8d8..fff514f2f 100644 --- a/app/containers/message/index.tsx +++ b/app/containers/message/index.tsx @@ -429,8 +429,7 @@ class MessageContainer extends React.Component<IMessageContainerProps, IMessageC toggleFollowThread, replies, translateLanguage: canTranslateMessage ? autoTranslateLanguage : undefined - }} - > + }}> {/* @ts-ignore*/} <Message id={id} diff --git a/app/definitions/TUserStatus.ts b/app/definitions/TUserStatus.ts index 2afceecaa..d86787ec8 100644 --- a/app/definitions/TUserStatus.ts +++ b/app/definitions/TUserStatus.ts @@ -1,3 +1,3 @@ export const STATUSES = ['offline', 'online', 'away', 'busy', 'disabled', 'loading'] as const; -export type TUserStatus = typeof STATUSES[number]; +export type TUserStatus = (typeof STATUSES)[number]; diff --git a/app/ee/omnichannel/reducers/inquiry.test.ts b/app/ee/omnichannel/reducers/inquiry.test.ts index 63c0b3973..c907a1377 100644 --- a/app/ee/omnichannel/reducers/inquiry.test.ts +++ b/app/ee/omnichannel/reducers/inquiry.test.ts @@ -84,13 +84,8 @@ describe('test inquiry reduce', () => { expect(inquiry).toEqual({ ...initialState, queued: [queued] }); }); - it('after inquiry state is modified, should return inquiry state as initial state after dispatch inquiryReset action', () => { - mockedStore.dispatch(inquiryReset()); - const { inquiry } = mockedStore.getState(); - expect(inquiry).toEqual(initialState); - }); - it('should return correct inquiry state after dispatch inquiryFailure action', () => { + mockedStore.dispatch(inquiryReset()); mockedStore.dispatch(inquiryFailure(error)); const { inquiry } = mockedStore.getState(); expect(inquiry).toEqual({ ...initialState, error }); diff --git a/app/ee/omnichannel/views/QueueListView.tsx b/app/ee/omnichannel/views/QueueListView.tsx index 8ebb3cb39..c606faefd 100644 --- a/app/ee/omnichannel/views/QueueListView.tsx +++ b/app/ee/omnichannel/views/QueueListView.tsx @@ -27,7 +27,7 @@ type TNavigation = CompositeNavigationProp< >; const INITIAL_NUM_TO_RENDER = isTablet ? 20 : 12; -const getItemLayout = (data: IOmnichannelRoom[] | null | undefined, index: number) => ({ +const getItemLayout = (data: ArrayLike<IOmnichannelRoom> | null | undefined, index: number) => ({ length: ROW_HEIGHT, offset: ROW_HEIGHT * index, index diff --git a/app/index.tsx b/app/index.tsx index a020c294d..287ed94cc 100644 --- a/app/index.tsx +++ b/app/index.tsx @@ -1,5 +1,5 @@ import React from 'react'; -import { Dimensions, Linking } from 'react-native'; +import { Dimensions, EmitterSubscription, Linking } from 'react-native'; import { GestureHandlerRootView } from 'react-native-gesture-handler'; import Orientation from 'react-native-orientation-locker'; import { SafeAreaProvider, initialWindowMetrics } from 'react-native-safe-area-context'; @@ -73,6 +73,7 @@ const parseDeepLinking = (url: string) => { export default class Root extends React.Component<{}, IState> { private listenerTimeout!: any; + private dimensionsListener?: EmitterSubscription; constructor(props: any) { super(props); @@ -108,12 +109,12 @@ export default class Root extends React.Component<{}, IState> { } }); }, 5000); - Dimensions.addEventListener('change', this.onDimensionsChange); + this.dimensionsListener = Dimensions.addEventListener('change', this.onDimensionsChange); } componentWillUnmount() { clearTimeout(this.listenerTimeout); - Dimensions.removeEventListener('change', this.onDimensionsChange); + this.dimensionsListener?.remove?.(); unsubscribeTheme(); } @@ -201,8 +202,7 @@ export default class Root extends React.Component<{}, IState> { return ( <SafeAreaProvider initialMetrics={initialWindowMetrics} - style={{ backgroundColor: themes[this.state.theme].backgroundColor }} - > + style={{ backgroundColor: themes[this.state.theme].backgroundColor }}> <Provider store={store}> <ThemeContext.Provider value={{ @@ -210,8 +210,7 @@ export default class Root extends React.Component<{}, IState> { themePreferences, setTheme: this.setTheme, colors: colors[theme] - }} - > + }}> <DimensionsContext.Provider value={{ width, @@ -219,8 +218,7 @@ export default class Root extends React.Component<{}, IState> { scale, fontScale, setDimensions: this.setDimensions - }} - > + }}> <GestureHandlerRootView style={{ flex: 1 }}> <ActionSheetProvider> <AppContainer /> diff --git a/app/lib/encryption/encryption.ts b/app/lib/encryption/encryption.ts index 05071d074..927c3b9d0 100644 --- a/app/lib/encryption/encryption.ts +++ b/app/lib/encryption/encryption.ts @@ -388,7 +388,7 @@ class Encryption { } try { - const batch: (Model | null | void | false | Promise<void>)[] = []; + const batch: (Model | null | void | false)[] = []; // If the subscription doesn't exists yet if (!subRecord) { // Let's create the subscription with the data received diff --git a/app/lib/hooks/useEndpointData.test.tsx b/app/lib/hooks/useEndpointData.test.tsx index 6785a80ec..178f255ac 100644 --- a/app/lib/hooks/useEndpointData.test.tsx +++ b/app/lib/hooks/useEndpointData.test.tsx @@ -8,7 +8,7 @@ import sdk from '../services/sdk'; const url = 'chat.getMessage'; -export const message = { +const message = { _id: '9tYkmJ67wMwmvQouD', t: 'uj', rid: 'GENERAL', diff --git a/app/lib/hooks/useVideoConf/StartACallActionSheet.tsx b/app/lib/hooks/useVideoConf/StartACallActionSheet.tsx index 06d2ba574..d394e58a0 100644 --- a/app/lib/hooks/useVideoConf/StartACallActionSheet.tsx +++ b/app/lib/hooks/useVideoConf/StartACallActionSheet.tsx @@ -47,8 +47,7 @@ export default function StartACallActionSheet({ return ( <View style={[style.actionSheetContainer, { paddingBottom: bottom }]} - onLayout={e => setContainerWidth(e.nativeEvent.layout.width / 2)} - > + onLayout={e => setContainerWidth(e.nativeEvent.layout.width / 2)}> {calling && roomType === SubscriptionType.DIRECT ? <Ringer ringer={ERingerSounds.DIALTONE} /> : null} <CallHeader title={calling && user.direct ? i18n.t('Calling') : i18n.t('Start_a_call')} @@ -65,8 +64,7 @@ export default function StartACallActionSheet({ style={[ style.actionSheetPhotoContainer, { backgroundColor: cam ? undefined : colors.conferenceCallPhotoBackground, width: containerWidth } - ]} - > + ]}> {cam ? ( <Camera style={[style.cameraContainer, { width: containerWidth }]} type={CameraType.front} /> ) : ( diff --git a/app/lib/methods/helpers/navigation/conditional.ts b/app/lib/methods/helpers/navigation/conditional.ts index 84c76d83a..19936c865 100644 --- a/app/lib/methods/helpers/navigation/conditional.ts +++ b/app/lib/methods/helpers/navigation/conditional.ts @@ -11,10 +11,10 @@ const { add, multiply } = Animated; * @param fallback Animated Node to use if the condition is `false` */ export default function conditional( - condition: Animated.AnimatedInterpolation, + condition: Animated.AnimatedInterpolation<number>, main: Animated.Animated, fallback: Animated.Animated -): Animated.AnimatedAddition { +): Animated.AnimatedAddition<number> { // To implement this behavior, we multiply the main node with the condition. // So if condition is 0, result will be 0, and if condition is 1, result will be main node. // Then we multiple reverse of the condition (0 if condition is 1) with the fallback. diff --git a/app/reducers/permissions.ts b/app/reducers/permissions.ts index d2887a555..398582d91 100644 --- a/app/reducers/permissions.ts +++ b/app/reducers/permissions.ts @@ -2,7 +2,7 @@ import { PERMISSIONS } from '../actions/actionsTypes'; import { TActionPermissions } from '../actions/permissions'; import { SUPPORTED_PERMISSIONS } from '../lib/methods/getPermissions'; -export type TSupportedPermissions = typeof SUPPORTED_PERMISSIONS[number]; +export type TSupportedPermissions = (typeof SUPPORTED_PERMISSIONS)[number]; export type IPermissionsState = { [K in TSupportedPermissions]?: string[]; diff --git a/app/reducers/sortPreferences.test.ts b/app/reducers/sortPreferences.test.ts index 5ef0ff94d..f3ef6d866 100644 --- a/app/reducers/sortPreferences.test.ts +++ b/app/reducers/sortPreferences.test.ts @@ -10,7 +10,7 @@ describe('test sortPreferences reducer', () => { expect(state).toEqual(initialState); }); - it('should return correctly value after call setPreference action', () => { + it('should return correctly value after call setAllPreferences action', () => { const preferences: IPreferences = { displayMode: DisplayMode.Condensed, groupByType: true, diff --git a/app/share.tsx b/app/share.tsx index 255becb90..0f0f730ba 100644 --- a/app/share.tsx +++ b/app/share.tsx @@ -41,7 +41,9 @@ const InsideStack = () => { return ( <Inside.Navigator screenOptions={screenOptions}> + {/* @ts-ignore */} <Inside.Screen name='ShareListView' component={ShareListView} /> + {/* @ts-ignore */} <Inside.Screen name='ShareView' component={ShareView} /> <Inside.Screen name='SelectServerView' component={SelectServerView} /> </Inside.Navigator> @@ -117,8 +119,7 @@ const Root = (): React.ReactElement => { height, scale, fontScale - }} - > + }}> <NavigationContainer theme={navTheme} ref={Navigation.navigationRef} @@ -129,8 +130,7 @@ const Root = (): React.ReactElement => { setCurrentScreen(currentRouteName); } Navigation.routeNameRef.current = currentRouteName; - }} - > + }}> <App root={root} /> <Loading /> </NavigationContainer> diff --git a/app/stacks/InsideStack.tsx b/app/stacks/InsideStack.tsx index ce595691a..555b8071a 100644 --- a/app/stacks/InsideStack.tsx +++ b/app/stacks/InsideStack.tsx @@ -98,6 +98,7 @@ const ChatsStackNavigator = () => { <ChatsStack.Screen name='RoomsListView' component={RoomsListView} /> <ChatsStack.Screen name='RoomView' component={RoomView} /> <ChatsStack.Screen name='RoomActionsView' component={RoomActionsView} options={RoomActionsView.navigationOptions} /> + {/* @ts-ignore */} <ChatsStack.Screen name='SelectListView' component={SelectListView} options={SelectListView.navigationOptions} /> <ChatsStack.Screen name='RoomInfoView' component={RoomInfoView} /> <ChatsStack.Screen name='ReportUserView' component={ReportUserView} /> @@ -105,22 +106,28 @@ const ChatsStackNavigator = () => { <ChatsStack.Screen name='RoomInfoEditView' component={RoomInfoEditView} options={RoomInfoEditView.navigationOptions} /> <ChatsStack.Screen name='ChangeAvatarView' component={ChangeAvatarView} /> <ChatsStack.Screen name='RoomMembersView' component={RoomMembersView} /> + {/* @ts-ignore */} <ChatsStack.Screen name='DiscussionsView' component={DiscussionsView} /> <ChatsStack.Screen name='SearchMessagesView' + // @ts-ignore component={SearchMessagesView} options={SearchMessagesView.navigationOptions} /> <ChatsStack.Screen name='SelectedUsersView' component={SelectedUsersView} /> + {/* @ts-ignore */} <ChatsStack.Screen name='InviteUsersView' component={InviteUsersView} /> <ChatsStack.Screen name='InviteUsersEditView' component={InviteUsersEditView} /> <ChatsStack.Screen name='MessagesView' component={MessagesView} /> <ChatsStack.Screen name='AutoTranslateView' component={AutoTranslateView} /> + {/* @ts-ignore */} <ChatsStack.Screen name='DirectoryView' component={DirectoryView} options={DirectoryView.navigationOptions} /> <ChatsStack.Screen name='NotificationPrefView' component={NotificationPrefView} /> <ChatsStack.Screen name='PushTroubleshootView' component={PushTroubleshootView} /> <ChatsStack.Screen name='ForwardLivechatView' component={ForwardLivechatView} /> + {/* @ts-ignore */} <ChatsStack.Screen name='CloseLivechatView' component={CloseLivechatView} /> + {/* @ts-ignore */} <ChatsStack.Screen name='LivechatEditView' component={LivechatEditView} options={LivechatEditView.navigationOptions} /> <ChatsStack.Screen name='PickerView' component={PickerView} /> {/* @ts-ignore */} @@ -131,6 +138,7 @@ const ChatsStackNavigator = () => { <ChatsStack.Screen name='AddExistingChannelView' component={AddExistingChannelView} /> {/* @ts-ignore */} <ChatsStack.Screen name='MarkdownTableView' component={MarkdownTableView} /> + {/* @ts-ignore */} <ChatsStack.Screen name='ReadReceiptsView' component={ReadReceiptsView} options={ReadReceiptsView.navigationOptions} /> <ChatsStack.Screen name='QueueListView' component={QueueListView} /> <ChatsStack.Screen name='CannedResponsesListView' component={CannedResponsesListView} /> @@ -179,6 +187,7 @@ const SettingsStackNavigator = () => { <SettingsStack.Screen name='MediaAutoDownloadView' component={MediaAutoDownloadView} /> <SettingsStack.Screen name='ScreenLockConfigView' + // @ts-ignore component={ScreenLockConfigView} options={ScreenLockConfigView.navigationOptions} /> @@ -249,6 +258,7 @@ const NewMessageStackNavigator = () => { <NewMessageStack.Screen name='NewMessageView' component={NewMessageView} /> <NewMessageStack.Screen name='SelectedUsersViewCreateChannel' component={SelectedUsersView} /> <NewMessageStack.Screen name='CreateChannelView' component={CreateChannelView} /> + {/* @ts-ignore */} <NewMessageStack.Screen name='CreateDiscussionView' component={CreateDiscussionView} /> <NewMessageStack.Screen name='ForwardMessageView' component={ForwardMessageView} /> </NewMessageStack.Navigator> @@ -304,7 +314,9 @@ const InsideStackNavigator = () => { /> <InsideStack.Screen name='AttachmentView' component={AttachmentView} /> <InsideStack.Screen name='StatusView' component={StatusView} /> + {/* @ts-ignore */} <InsideStack.Screen name='ShareView' component={ShareView} /> + {/* @ts-ignore */} <InsideStack.Screen name='ModalBlockView' component={ModalBlockView} options={ModalBlockView.navigationOptions} /> </InsideStack.Navigator> ); diff --git a/app/stacks/MasterDetailStack/ModalContainer.tsx b/app/stacks/MasterDetailStack/ModalContainer.tsx index 1a45e1835..333663dba 100644 --- a/app/stacks/MasterDetailStack/ModalContainer.tsx +++ b/app/stacks/MasterDetailStack/ModalContainer.tsx @@ -52,8 +52,7 @@ export const ModalContainer = ({ navigation, children, theme }: IModalContainer) style={{ ...sharedStyles.modalFormSheet, height: heightModal - }} - > + }}> {children} </View> </View> diff --git a/app/stacks/MasterDetailStack/index.tsx b/app/stacks/MasterDetailStack/index.tsx index 49aa3baae..78ead1b65 100644 --- a/app/stacks/MasterDetailStack/index.tsx +++ b/app/stacks/MasterDetailStack/index.tsx @@ -87,8 +87,7 @@ const ChatsStackNavigator = React.memo(() => { return ( <ChatsStack.Navigator - screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...StackAnimation } as StackNavigationOptions} - > + screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...StackAnimation } as StackNavigationOptions}> <ChatsStack.Screen name='RoomView' component={RoomView} options={{ headerShown: false }} /> </ChatsStack.Navigator> ); @@ -99,8 +98,7 @@ const Drawer = createDrawerNavigator<MasterDetailDrawerParamList>(); const DrawerNavigator = React.memo(() => ( <Drawer.Navigator screenOptions={{ drawerType: 'permanent', headerShown: false, drawerStyle: { ...drawerStyle } }} - drawerContent={({ navigation, state }) => <RoomsListView navigation={navigation} state={state} />} - > + drawerContent={({ navigation, state }) => <RoomsListView navigation={navigation} state={state} />}> <Drawer.Screen name='ChatsStackNavigator' component={ChatsStackNavigator} /> </Drawer.Navigator> )); @@ -115,23 +113,25 @@ const ModalStackNavigator = React.memo(({ navigation }: INavigation) => { return ( <ModalContainer navigation={navigation} theme={theme}> <ModalStack.Navigator - screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...StackAnimation } as StackNavigationOptions} - > + screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...StackAnimation } as StackNavigationOptions}> <ModalStack.Screen name='RoomActionsView' component={RoomActionsView} options={RoomActionsView.navigationOptions} /> {/* @ts-ignore */} <ModalStack.Screen name='RoomInfoView' component={RoomInfoView} /> <ModalStack.Screen name='ReportUserView' component={ReportUserView} /> {/* @ts-ignore */} <ModalStack.Screen name='SelectListView' component={SelectListView} /> + {/* @ts-ignore */} <ModalStack.Screen name='RoomInfoEditView' component={RoomInfoEditView} options={RoomInfoEditView.navigationOptions} /> <ModalStack.Screen name='ChangeAvatarView' component={ChangeAvatarView} /> <ModalStack.Screen name='RoomMembersView' component={RoomMembersView} /> <ModalStack.Screen name='SearchMessagesView' + // @ts-ignore component={SearchMessagesView} options={SearchMessagesView.navigationOptions} /> <ModalStack.Screen name='SelectedUsersView' component={SelectedUsersView} /> + {/* @ts-ignore */} <ModalStack.Screen name='InviteUsersView' component={InviteUsersView} /> <ModalStack.Screen name='AddChannelTeamView' component={AddChannelTeamView} /> <ModalStack.Screen name='AddExistingChannelView' component={AddExistingChannelView} /> @@ -140,6 +140,7 @@ const ModalStackNavigator = React.memo(({ navigation }: INavigation) => { <ModalStack.Screen name='AutoTranslateView' component={AutoTranslateView} /> <ModalStack.Screen name='DirectoryView' + // @ts-ignore component={DirectoryView} options={props => DirectoryView.navigationOptions!({ ...props, isMasterDetail: true })} /> @@ -148,18 +149,24 @@ const ModalStackNavigator = React.memo(({ navigation }: INavigation) => { <ModalStack.Screen name='ForwardMessageView' component={ForwardMessageView} /> {/* @ts-ignore */} <ModalStack.Screen name='ForwardLivechatView' component={ForwardLivechatView} /> + {/* @ts-ignore */} <ModalStack.Screen name='CloseLivechatView' component={CloseLivechatView} /> <ModalStack.Screen name='CannedResponsesListView' component={CannedResponsesListView} /> + {/* @ts-ignore */} <ModalStack.Screen name='CannedResponseDetail' component={CannedResponseDetail} /> + {/* @ts-ignore */} <ModalStack.Screen name='LivechatEditView' component={LivechatEditView} options={LivechatEditView.navigationOptions} /> <ModalStack.Screen name='PickerView' component={PickerView} /> {/* @ts-ignore */} <ModalStack.Screen name='ThreadMessagesView' component={ThreadMessagesView} /> + {/* @ts-ignore */} <ModalStack.Screen name='DiscussionsView' component={DiscussionsView} /> <ModalStack.Screen name='TeamChannelsView' component={TeamChannelsView} options={TeamChannelsView.navigationOptions} /> + {/* @ts-ignore */} <ModalStack.Screen name='MarkdownTableView' component={MarkdownTableView} /> <ModalStack.Screen name='ReadReceiptsView' + // @ts-ignore component={ReadReceiptsView} options={props => ReadReceiptsView.navigationOptions!({ ...props, isMasterDetail: true })} /> @@ -169,6 +176,7 @@ const ModalStackNavigator = React.memo(({ navigation }: INavigation) => { <ModalStack.Screen name='DefaultBrowserView' component={DefaultBrowserView} /> <ModalStack.Screen name='ScreenLockConfigView' + // @ts-ignore component={ScreenLockConfigView} options={ScreenLockConfigView.navigationOptions} /> @@ -179,6 +187,7 @@ const ModalStackNavigator = React.memo(({ navigation }: INavigation) => { <ModalStack.Screen name='NewMessageView' component={NewMessageView} /> <ModalStack.Screen name='SelectedUsersViewCreateChannel' component={SelectedUsersView} /> <ModalStack.Screen name='CreateChannelView' component={CreateChannelView} /> + {/* @ts-ignore */} <ModalStack.Screen name='CreateDiscussionView' component={CreateDiscussionView} /> <ModalStack.Screen name='E2ESaveYourPasswordView' component={E2ESaveYourPasswordView} /> <ModalStack.Screen name='E2EHowItWorksView' component={E2EHowItWorksView} /> @@ -208,17 +217,18 @@ const InsideStackNavigator = React.memo(() => { ...FadeFromCenterModal, presentation: 'transparentModal' } as StackNavigationOptions - } - > + }> <InsideStack.Screen name='DrawerNavigator' component={DrawerNavigator} options={{ headerShown: false }} /> <InsideStack.Screen name='ModalStackNavigator' component={ModalStackNavigator} options={{ headerShown: false }} /> <InsideStack.Screen name='AttachmentView' component={AttachmentView} /> + {/* @ts-ignore */} <InsideStack.Screen name='ModalBlockView' component={ModalBlockView} options={ModalBlockView.navigationOptions} /> <InsideStack.Screen name='JitsiMeetView' component={JitsiMeetView} options={{ headerShown: false, animationEnabled: isIOS }} /> + {/* @ts-ignore */} <InsideStack.Screen name='ShareView' component={ShareView} /> </InsideStack.Navigator> ); diff --git a/app/stacks/OutsideStack.tsx b/app/stacks/OutsideStack.tsx index 40a3c9cb1..406570444 100644 --- a/app/stacks/OutsideStack.tsx +++ b/app/stacks/OutsideStack.tsx @@ -22,13 +22,17 @@ const _OutsideStack = () => { return ( <Outside.Navigator screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...StackAnimation } as StackNavigationOptions}> + {/* @ts-ignore */} <Outside.Screen name='NewServerView' component={NewServerView} options={NewServerView.navigationOptions} /> <Outside.Screen name='WorkspaceView' component={WorkspaceView} /> {/* @ts-ignore */} <Outside.Screen name='LoginView' component={LoginView} options={LoginView.navigationOptions} /> <Outside.Screen name='ForgotPasswordView' component={ForgotPasswordView} /> + {/* @ts-ignore */} <Outside.Screen name='SendEmailConfirmationView' component={SendEmailConfirmationView} /> + {/* @ts-ignore */} <Outside.Screen name='RegisterView' component={RegisterView} options={RegisterView.navigationOptions} /> + {/* @ts-ignore */} <Outside.Screen name='LegalView' component={LegalView} /> </Outside.Navigator> ); @@ -47,8 +51,7 @@ const OutsideStackModal = () => { return ( <OutsideModal.Navigator - screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...ModalAnimation, presentation: 'transparentModal' }} - > + screenOptions={{ ...defaultHeader, ...themedHeader(theme), ...ModalAnimation, presentation: 'transparentModal' }}> <OutsideModal.Screen name='OutsideStack' component={OutsideStack} options={{ headerShown: false }} /> <OutsideModal.Screen name='AuthenticationWebView' component={AuthenticationWebView} /> </OutsideModal.Navigator> diff --git a/app/theme.tsx b/app/theme.tsx index b11488119..01b0aef8d 100644 --- a/app/theme.tsx +++ b/app/theme.tsx @@ -6,7 +6,7 @@ import { TNavigationOptions } from './definitions/navigationTypes'; import { colors } from './lib/constants'; export type TSupportedThemes = keyof typeof colors; -export type TColors = typeof colors[TSupportedThemes]; +export type TColors = (typeof colors)[TSupportedThemes]; export interface IThemeContextProps { theme: TSupportedThemes; diff --git a/app/views/CannedResponsesListView/Dropdown/index.tsx b/app/views/CannedResponsesListView/Dropdown/index.tsx index 9da55f407..cdffbbb16 100644 --- a/app/views/CannedResponsesListView/Dropdown/index.tsx +++ b/app/views/CannedResponsesListView/Dropdown/index.tsx @@ -74,8 +74,7 @@ const Dropdown = ({ currentDepartment, onClose, onDepartmentSelected, department backgroundColor: colors.backgroundColor, borderColor: colors.separatorColor } - ]} - > + ]}> <DropdownItemHeader department={currentDepartment} onPress={close} /> <List.Separator /> <FlatList diff --git a/app/views/ChangeAvatarView/index.tsx b/app/views/ChangeAvatarView/index.tsx index 494c8ff21..7d1a803df 100644 --- a/app/views/ChangeAvatarView/index.tsx +++ b/app/views/ChangeAvatarView/index.tsx @@ -162,15 +162,13 @@ const ChangeAvatarView = () => { <KeyboardView style={{ backgroundColor: colors.auxiliaryBackground }} contentContainerStyle={sharedStyles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <SafeAreaView testID='change-avatar-view'> <ScrollView contentContainerStyle={sharedStyles.containerScrollView} testID='change-avatar-view-list' - {...scrollPersistTaps} - > + {...scrollPersistTaps}> <View style={styles.avatarContainer} testID='change-avatar-view-avatar'> {deletingRoomAvatar ? ( <AvatarPresentational diff --git a/app/views/CloseLivechatView.tsx b/app/views/CloseLivechatView.tsx index 564f7d3ad..399d0c6db 100644 --- a/app/views/CloseLivechatView.tsx +++ b/app/views/CloseLivechatView.tsx @@ -75,8 +75,7 @@ const CloseLivechatView = ({ navigation, route }: IBaseScreen<ChatsStackParamLis <KeyboardView style={{ backgroundColor: colors.auxiliaryBackground }} contentContainerStyle={sharedStyles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <ScrollView {...scrollPersistTaps} style={styles.container}> <SafeAreaView> <FormTextInput diff --git a/app/views/CreateChannelView/RoomSettings/SwitchItemEncrypted.test.tsx b/app/views/CreateChannelView/RoomSettings/SwitchItemEncrypted.test.tsx index a5f536d5a..1f18b44a6 100644 --- a/app/views/CreateChannelView/RoomSettings/SwitchItemEncrypted.test.tsx +++ b/app/views/CreateChannelView/RoomSettings/SwitchItemEncrypted.test.tsx @@ -45,7 +45,7 @@ describe('SwitchItemEncrypted', () => { const component = screen.queryByTestId(testEncrypted.testSwitchID); expect(component).toBeTruthy(); }); - + it('should change value of switch', () => { render( <SwitchItemEncrypted @@ -62,7 +62,7 @@ describe('SwitchItemEncrypted', () => { expect(onPressMock).toHaveReturnedWith({ value: !testEncrypted.encrypted }); } }); - + it('label when encrypted and isTeam are false and is a public channel', () => { render( <SwitchItemEncrypted @@ -76,7 +76,7 @@ describe('SwitchItemEncrypted', () => { const component = screen.queryByTestId(testEncrypted.testLabelID); expect(component?.props.children).toBe(i18n.t('Channel_hint_encrypted_not_available')); }); - + it('label when encrypted and isTeam are true and is a private team', () => { testEncrypted.isTeam = true; testEncrypted.type = true; diff --git a/app/views/CreateChannelView/index.tsx b/app/views/CreateChannelView/index.tsx index 44b841b91..39579f827 100644 --- a/app/views/CreateChannelView/index.tsx +++ b/app/views/CreateChannelView/index.tsx @@ -142,8 +142,7 @@ const CreateChannelView = () => { <KeyboardView style={{ backgroundColor: colors.backgroundColor }} contentContainerStyle={[sharedStyles.container, styles.container]} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <SafeAreaView style={{ backgroundColor: colors.backgroundColor }} testID='create-channel-view'> <ScrollView {...scrollPersistTaps}> diff --git a/app/views/CreateDiscussionView/index.tsx b/app/views/CreateDiscussionView/index.tsx index af59b3150..68a8dc568 100644 --- a/app/views/CreateDiscussionView/index.tsx +++ b/app/views/CreateDiscussionView/index.tsx @@ -147,8 +147,7 @@ class CreateChannelView extends React.Component<ICreateChannelViewProps, ICreate <KeyboardView style={{ backgroundColor: themes[theme].auxiliaryBackground }} contentContainerStyle={styles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <SafeAreaView testID='create-discussion-view' style={styles.container}> <ScrollView {...scrollPersistTaps}> diff --git a/app/views/DirectoryView/index.tsx b/app/views/DirectoryView/index.tsx index 131ef2cb4..4fe6d7a0c 100644 --- a/app/views/DirectoryView/index.tsx +++ b/app/views/DirectoryView/index.tsx @@ -220,8 +220,7 @@ class DirectoryView extends React.Component<IDirectoryViewProps, IDirectoryViewS sharedStyles.separatorVertical, styles.toggleDropdownContainer, { borderColor: themes[theme].separatorColor } - ]} - > + ]}> <CustomIcon name={icon} size={20} color={themes[theme].tintColor} style={styles.toggleDropdownIcon} /> <Text style={[styles.toggleDropdownText, { color: themes[theme].tintColor }]}>{I18n.t(text)}</Text> <CustomIcon diff --git a/app/views/DiscussionsView/Item.tsx b/app/views/DiscussionsView/Item.tsx index 02fe7909e..63bf92428 100644 --- a/app/views/DiscussionsView/Item.tsx +++ b/app/views/DiscussionsView/Item.tsx @@ -66,8 +66,7 @@ const Item = ({ item, onPress }: IItem): React.ReactElement => { <Touchable onPress={() => onPress(item)} testID={`discussions-view-${item.msg}`} - style={{ backgroundColor: colors.backgroundColor }} - > + style={{ backgroundColor: colors.backgroundColor }}> <View style={styles.container}> <Avatar style={styles.avatar} text={item?.u?.username} size={36} borderRadius={4} /> <View style={styles.contentContainer}> diff --git a/app/views/E2EEnterYourPasswordView.tsx b/app/views/E2EEnterYourPasswordView.tsx index 18245da63..b14dcf2c0 100644 --- a/app/views/E2EEnterYourPasswordView.tsx +++ b/app/views/E2EEnterYourPasswordView.tsx @@ -46,8 +46,7 @@ const E2EEnterYourPasswordView = (): React.ReactElement => { <KeyboardView style={{ backgroundColor: colors.backgroundColor }} contentContainerStyle={sharedStyles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <ScrollView {...scrollPersistTaps} style={sharedStyles.container} contentContainerStyle={sharedStyles.containerScrollView}> <SafeAreaView style={{ backgroundColor: colors.backgroundColor }} testID='e2e-enter-your-password-view'> diff --git a/app/views/ForwardMessageView/index.tsx b/app/views/ForwardMessageView/index.tsx index c76bac12e..c9fd97ec1 100644 --- a/app/views/ForwardMessageView/index.tsx +++ b/app/views/ForwardMessageView/index.tsx @@ -79,8 +79,7 @@ const ForwardMessageView = () => { <KeyboardView style={{ backgroundColor: colors.auxiliaryBackground }} contentContainerStyle={styles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <SafeAreaView testID='forward-message-view' style={styles.container}> <ScrollView {...scrollPersistTaps}> diff --git a/app/views/InviteUsersView/index.tsx b/app/views/InviteUsersView/index.tsx index b83ca6f54..6c094d7a0 100644 --- a/app/views/InviteUsersView/index.tsx +++ b/app/views/InviteUsersView/index.tsx @@ -89,8 +89,7 @@ const InviteUsersView = ({ route, navigation }: IInviteUsersViewProps): React.Re <ScrollView {...scrollPersistTaps} style={{ backgroundColor: colors.auxiliaryBackground }} - showsVerticalScrollIndicator={false} - > + showsVerticalScrollIndicator={false}> <StatusBar /> <View style={styles.innerContainer}> <FormTextInput label={I18n.t('Invite_Link')} value={invite && invite.url} editable={false} /> diff --git a/app/views/JitsiMeetView/index.tsx b/app/views/JitsiMeetView/index.tsx index 5a341d9f4..a7ab2530b 100644 --- a/app/views/JitsiMeetView/index.tsx +++ b/app/views/JitsiMeetView/index.tsx @@ -3,7 +3,7 @@ import { RouteProp, useNavigation, useRoute } from '@react-navigation/native'; import { activateKeepAwake, deactivateKeepAwake } from 'expo-keep-awake'; import React, { useCallback, useEffect, useState } from 'react'; import { ActivityIndicator, BackHandler, Linking, SafeAreaView, StyleSheet, View } from 'react-native'; -import WebView from 'react-native-webview'; +import WebView, { WebViewNavigation } from 'react-native-webview'; import { userAgent } from '../../lib/constants'; import { useAppSelector } from '../../lib/hooks'; @@ -65,7 +65,7 @@ const JitsiMeetView = (): React.ReactElement => { }, [rid, videoConf]); const onNavigationStateChange = useCallback( - webViewState => { + (webViewState: WebViewNavigation) => { const roomId = getRoomIdFromJitsiCallUrl(url); if (webViewState.url.includes('auth-static')) { setAuthModal(true); diff --git a/app/views/LivechatEditView.tsx b/app/views/LivechatEditView.tsx index 98d195956..80c9b70d4 100644 --- a/app/views/LivechatEditView.tsx +++ b/app/views/LivechatEditView.tsx @@ -185,8 +185,7 @@ const LivechatEditView = ({ user, navigation, route, theme }: ILivechatEditViewP <KeyboardView style={{ backgroundColor: themes[theme].auxiliaryBackground }} contentContainerStyle={sharedStyles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <ScrollView {...scrollPersistTaps} style={styles.container}> <SafeAreaView> <Title title={visitor?.username} theme={theme} /> diff --git a/app/views/LoginView/UserForm.tsx b/app/views/LoginView/UserForm.tsx index e334f6c6f..5bcaba0ec 100644 --- a/app/views/LoginView/UserForm.tsx +++ b/app/views/LoginView/UserForm.tsx @@ -154,8 +154,7 @@ const UserForm = () => { <Text style={[styles.bottomContainerTextBold, { color: colors.actionTintColor }]} onPress={register} - testID='login-view-register' - > + testID='login-view-register'> {I18n.t('Create_account')} </Text> </View> diff --git a/app/views/ModalBlockView.tsx b/app/views/ModalBlockView.tsx index 057378d50..d74578ecc 100644 --- a/app/views/ModalBlockView.tsx +++ b/app/views/ModalBlockView.tsx @@ -257,8 +257,7 @@ class ModalBlockView extends React.Component<IModalBlockViewProps, IModalBlockVi return ( <KeyboardAwareScrollView style={[styles.container, { backgroundColor: themes[theme].auxiliaryBackground }]} - keyboardShouldPersistTaps='always' - > + keyboardShouldPersistTaps='always'> <View style={styles.content}> {React.createElement( modalBlockWithContext({ diff --git a/app/views/NewServerView/ServerInput/index.tsx b/app/views/NewServerView/ServerInput/index.tsx index 0f1e5cd50..1e12cf7d7 100644 --- a/app/views/NewServerView/ServerInput/index.tsx +++ b/app/views/NewServerView/ServerInput/index.tsx @@ -70,8 +70,7 @@ const ServerInput = ({ style={[ styles.serverHistory, { backgroundColor: themes[theme].backgroundColor, borderColor: themes[theme].separatorColor } - ]} - > + ]}> <FlatList data={serversHistory} renderItem={({ item }) => ( diff --git a/app/views/NewServerView/index.tsx b/app/views/NewServerView/index.tsx index ab4ec2f3d..6454ce0a2 100644 --- a/app/views/NewServerView/index.tsx +++ b/app/views/NewServerView/index.tsx @@ -301,23 +301,19 @@ class NewServerView extends React.Component<INewServerViewProps, INewServerViewS { marginBottom: verticalScale({ size: previousServer && !isTablet ? 10 : 30, height }) } - ]} - > + ]}> <Text style={[ styles.chooseCertificateTitle, { color: themes[theme].auxiliaryText, fontSize: moderateScale({ size: 13, width }) } - ]} - > + ]}> {certificate ? I18n.t('Your_certificate') : I18n.t('Do_you_have_a_certificate')} </Text> <TouchableOpacity onPress={certificate ? this.handleRemove : this.chooseCertificate} - testID='new-server-choose-certificate' - > + testID='new-server-choose-certificate'> <Text - style={[styles.chooseCertificate, { color: themes[theme].tintColor, fontSize: moderateScale({ size: 13, width }) }]} - > + style={[styles.chooseCertificate, { color: themes[theme].tintColor, fontSize: moderateScale({ size: 13, width }) }]}> {certificate ?? I18n.t('Apply_Your_Certificate')} </Text> </TouchableOpacity> @@ -354,8 +350,7 @@ class NewServerView extends React.Component<INewServerViewProps, INewServerViewS fontSize: moderateScale({ size: 22, width }), marginBottom: verticalScale({ size: 8, height }) } - ]} - > + ]}> Rocket.Chat </Text> <Text @@ -366,8 +361,7 @@ class NewServerView extends React.Component<INewServerViewProps, INewServerViewS fontSize: moderateScale({ size: 16, width }), marginBottom: verticalScale({ size: 30, height }) } - ]} - > + ]}> {I18n.t('Onboarding_subtitle')} </Text> <ServerInput @@ -399,8 +393,7 @@ class NewServerView extends React.Component<INewServerViewProps, INewServerViewS fontSize: moderateScale({ size: 14, width }), marginBottom: verticalScale({ size: 16, height }) } - ]} - > + ]}> {I18n.t('Onboarding_join_open_description')} </Text> <Button diff --git a/app/views/ProfileView/index.tsx b/app/views/ProfileView/index.tsx index 0b6bd2b8e..adb40b3df 100644 --- a/app/views/ProfileView/index.tsx +++ b/app/views/ProfileView/index.tsx @@ -321,8 +321,7 @@ class ProfileView extends React.Component<IProfileViewProps, IProfileViewState> testID={key} onPress={onPress} style={[styles.avatarButton, { opacity: disabled ? 0.5 : 1 }, { backgroundColor: themes[theme].borderColor }]} - enabled={!disabled} - > + enabled={!disabled}> {child} </Touch> ); @@ -349,8 +348,7 @@ class ProfileView extends React.Component<IProfileViewProps, IProfileViewState> newValue[key] = value; this.setState({ customFields: { ...customFields, ...newValue } }); }} - value={customFields[key]} - > + value={customFields[key]}> <FormTextInput inputRef={e => { // @ts-ignore @@ -438,8 +436,7 @@ class ProfileView extends React.Component<IProfileViewProps, IProfileViewState> <KeyboardView style={{ backgroundColor: themes[theme].auxiliaryBackground }} contentContainerStyle={sharedStyles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <SafeAreaView testID='profile-view'> <ScrollView contentContainerStyle={sharedStyles.containerScrollView} testID='profile-view-list' {...scrollPersistTaps}> diff --git a/app/views/PushTroubleshootView/components/DeviceNotificationSettings.tsx b/app/views/PushTroubleshootView/components/DeviceNotificationSettings.tsx index 6cf93c898..deda98ec4 100644 --- a/app/views/PushTroubleshootView/components/DeviceNotificationSettings.tsx +++ b/app/views/PushTroubleshootView/components/DeviceNotificationSettings.tsx @@ -35,8 +35,7 @@ export default function DeviceNotificationSettings(): React.ReactElement { return ( <CustomListSection title='Device_notification_settings' - statusColor={!deviceNotificationEnabled ? colors.userPresenceBusy : colors.userPresenceOnline} - > + statusColor={!deviceNotificationEnabled ? colors.userPresenceBusy : colors.userPresenceOnline}> <List.Separator /> <List.Item title={!deviceNotificationEnabled ? 'Allow_push_notifications_for_rocket_chat' : 'No_further_action_is_needed'} diff --git a/app/views/PushTroubleshootView/components/PushGatewayConnection.tsx b/app/views/PushTroubleshootView/components/PushGatewayConnection.tsx index a0f10396a..c96c45c8c 100644 --- a/app/views/PushTroubleshootView/components/PushGatewayConnection.tsx +++ b/app/views/PushTroubleshootView/components/PushGatewayConnection.tsx @@ -49,8 +49,7 @@ export default function PushGatewayConnection(): React.ReactElement | null { return ( <CustomListSection title={!defaultPushGateway ? 'Custom_push_gateway_connection' : 'Push_gateway_connection'} - statusColor={statusColor} - > + statusColor={statusColor}> <List.Separator /> <List.Item title='Test_push_notification' diff --git a/app/views/ReadReceiptView/index.tsx b/app/views/ReadReceiptView/index.tsx index 99b2b9bb1..a6838c82c 100644 --- a/app/views/ReadReceiptView/index.tsx +++ b/app/views/ReadReceiptView/index.tsx @@ -107,8 +107,7 @@ class ReadReceiptView extends React.Component<IReadReceiptViewProps, IReadReceip return ( <View style={[styles.listEmptyContainer, { backgroundColor: themes[theme].chatComponentBackground }]} - testID='read-receipt-view' - > + testID='read-receipt-view'> <Text style={[styles.emptyText, { color: themes[theme].auxiliaryTintColor }]}>{I18n.t('No_Read_Receipts')}</Text> </View> ); @@ -134,8 +133,7 @@ class ReadReceiptView extends React.Component<IReadReceiptViewProps, IReadReceip { color: themes[theme].auxiliaryText } - ]} - >{`@${item.user.username}`}</Text> + ]}>{`@${item.user.username}`}</Text> </View> </View> ); diff --git a/app/views/RegisterView.tsx b/app/views/RegisterView.tsx index 83789f84d..a9920ace9 100644 --- a/app/views/RegisterView.tsx +++ b/app/views/RegisterView.tsx @@ -176,8 +176,7 @@ class RegisterView extends React.Component<IProps, any> { newValue[key] = value; this.setState({ customFields: { ...customFields, ...newValue } }); }} - value={customFields[key]} - > + value={customFields[key]}> <FormTextInput inputRef={e => { // @ts-ignore diff --git a/app/views/ReportUserView/index.tsx b/app/views/ReportUserView/index.tsx index 4febc2abf..e31324a91 100644 --- a/app/views/ReportUserView/index.tsx +++ b/app/views/ReportUserView/index.tsx @@ -80,8 +80,7 @@ const ReportUserView = () => { <KeyboardView style={{ backgroundColor: colors.auxiliaryBackground }} contentContainerStyle={styles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <SafeAreaView style={[styles.containerView, { backgroundColor: colors.auxiliaryBackground }]} testID='report-user-view'> <ScrollView contentContainerStyle={[styles.scroll, { backgroundColor: colors.auxiliaryBackground }]}> <StatusBar /> diff --git a/app/views/RoomActionsView/index.tsx b/app/views/RoomActionsView/index.tsx index 04f945ffa..e098be844 100644 --- a/app/views/RoomActionsView/index.tsx +++ b/app/views/RoomActionsView/index.tsx @@ -268,6 +268,7 @@ class RoomActionsView extends React.Component<IRoomActionsViewProps, IRoomAction // @ts-ignore logEvent(events[`RA_GO_${route.replace('View', '').toUpperCase()}${params.name ? params.name.toUpperCase() : ''}`]); const { navigation } = this.props; + // @ts-ignore navigation.navigate(route, params); } if (event) { @@ -796,8 +797,7 @@ class RoomActionsView extends React.Component<IRoomActionsViewProps, IRoomAction style={{ backgroundColor: themes[theme].backgroundColor }} accessibilityLabel={I18n.t('Room_Info')} enabled={!isGroupChatHandler} - testID='room-actions-info' - > + testID='room-actions-info'> <View style={[styles.roomInfoContainer, { height: 72 * fontScale }]}> <Avatar text={avatar} style={styles.avatar} size={50 * fontScale} type={t} rid={rid}> {t === 'd' && member._id ? ( diff --git a/app/views/RoomInfoEditView/SwitchContainer.tsx b/app/views/RoomInfoEditView/SwitchContainer.tsx index 690a95019..7d4cb26c4 100644 --- a/app/views/RoomInfoEditView/SwitchContainer.tsx +++ b/app/views/RoomInfoEditView/SwitchContainer.tsx @@ -1,4 +1,4 @@ -import React from 'react'; +import React, { ReactElement } from 'react'; import { Switch, Text, TextStyle, View, ViewStyle } from 'react-native'; import { TSupportedThemes } from '../../theme'; @@ -6,6 +6,7 @@ import { SWITCH_TRACK_COLOR, themes } from '../../lib/constants'; import styles from './styles'; interface ISwitchContainer { + children?: ReactElement | null; value: boolean; disabled?: boolean; leftLabelPrimary: string; diff --git a/app/views/RoomInfoEditView/index.tsx b/app/views/RoomInfoEditView/index.tsx index 8b94b459a..e26cab415 100644 --- a/app/views/RoomInfoEditView/index.tsx +++ b/app/views/RoomInfoEditView/index.tsx @@ -523,15 +523,13 @@ class RoomInfoEditView extends React.Component<IRoomInfoEditViewProps, IRoomInfo <KeyboardView style={{ backgroundColor: themes[theme].backgroundColor }} contentContainerStyle={sharedStyles.container} - keyboardVerticalOffset={128} - > + keyboardVerticalOffset={128}> <StatusBar /> <SafeAreaView testID='room-info-edit-view' style={{ backgroundColor: themes[theme].backgroundColor }}> <ScrollView contentContainerStyle={sharedStyles.containerScrollView} testID='room-info-edit-view-list' - {...scrollPersistTaps} - > + {...scrollPersistTaps}> <View style={styles.avatarContainer}> <AvatarWithEdit type={room.t} text={room.name} rid={room.rid} handleEdit={this.handleEditAvatar} /> </View> @@ -665,8 +663,7 @@ class RoomInfoEditView extends React.Component<IRoomInfoEditViewProps, IRoomInfo testID='room-info-edit-switch-system-messages' onValueChange={this.toggleHideSystemMessages} labelContainerStyle={styles.hideSystemMessages} - leftLabelStyle={styles.systemMessagesLabel} - > + leftLabelStyle={styles.systemMessagesLabel}> {this.renderSystemMessages()} </SwitchContainer> ) : null} @@ -691,8 +688,7 @@ class RoomInfoEditView extends React.Component<IRoomInfoEditViewProps, IRoomInfo ]} onPress={this.submit} disabled={!this.formIsChanged()} - testID='room-info-edit-view-submit' - > + testID='room-info-edit-view-submit'> <Text style={[styles.button, { color: themes[theme].buttonText }]} accessibilityRole='button'> {I18n.t('SAVE')} </Text> @@ -707,12 +703,10 @@ class RoomInfoEditView extends React.Component<IRoomInfoEditViewProps, IRoomInfo ]} onPress={this.reset} disabled={!this.formIsChanged()} - testID='room-info-edit-view-reset' - > + testID='room-info-edit-view-reset'> <Text style={[styles.button, styles.button_inverted, { color: themes[theme].bodyText }]} - accessibilityRole='button' - > + accessibilityRole='button'> {I18n.t('RESET')} </Text> </TouchableOpacity> @@ -727,8 +721,7 @@ class RoomInfoEditView extends React.Component<IRoomInfoEditViewProps, IRoomInfo ]} onPress={this.toggleArchive} disabled={archived ? !permissions['unarchive-room'] : !permissions['archive-room']} - testID={archived ? 'room-info-edit-view-unarchive' : 'room-info-edit-view-archive'} - > + testID={archived ? 'room-info-edit-view-unarchive' : 'room-info-edit-view-archive'}> <Text style={[styles.button, styles.button_inverted, { color: dangerColor }]}> {archived ? I18n.t('UNARCHIVE') : I18n.t('ARCHIVE')} </Text> @@ -745,8 +738,7 @@ class RoomInfoEditView extends React.Component<IRoomInfoEditViewProps, IRoomInfo ]} onPress={room.teamMain ? this.deleteTeam : this.delete} disabled={!this.hasDeletePermission()} - testID='room-info-edit-view-delete' - > + testID='room-info-edit-view-delete'> <Text style={[styles.button, styles.button_inverted, { color: dangerColor }]} accessibilityRole='button'> {I18n.t('DELETE')} </Text> diff --git a/app/views/RoomInfoView/Direct.tsx b/app/views/RoomInfoView/Direct.tsx index c8d258914..d54c2af98 100644 --- a/app/views/RoomInfoView/Direct.tsx +++ b/app/views/RoomInfoView/Direct.tsx @@ -21,8 +21,7 @@ const Roles = ({ roles }: { roles?: string[] }) => { <View style={[styles.roleBadge, { backgroundColor: colors.chatComponentBackground }]} key={role} - testID={`user-role-${role.replace(/ /g, '-')}`} - > + testID={`user-role-${role.replace(/ /g, '-')}`}> <Text style={[styles.role, { color: colors.titleText }]}>{role}</Text> </View> ) : null diff --git a/app/views/RoomInfoView/components/RoomInfoViewAvatar.tsx b/app/views/RoomInfoView/components/RoomInfoViewAvatar.tsx index dd6f2ff1d..dcb079c36 100644 --- a/app/views/RoomInfoView/components/RoomInfoViewAvatar.tsx +++ b/app/views/RoomInfoView/components/RoomInfoViewAvatar.tsx @@ -33,8 +33,7 @@ const RoomInfoViewAvatar = ({ style={styles.avatar} type={type} rid={rid} - handleEdit={showAvatarEdit ? handleEditAvatar : undefined} - > + handleEdit={showAvatarEdit ? handleEditAvatar : undefined}> {type === SubscriptionType.DIRECT && userId ? ( <View style={[sharedStyles.status, { backgroundColor: colors.auxiliaryBackground }]}> <Status size={20} id={userId} /> diff --git a/app/views/RoomInfoView/components/RoomInfoViewTitle.tsx b/app/views/RoomInfoView/components/RoomInfoViewTitle.tsx index 70f0892c1..31d4a7a49 100644 --- a/app/views/RoomInfoView/components/RoomInfoViewTitle.tsx +++ b/app/views/RoomInfoView/components/RoomInfoViewTitle.tsx @@ -27,8 +27,7 @@ const RoomInfoViewTitle = ({ room, name, username, statusText, type }: IRoomInfo {username && ( <Text testID='room-info-view-username' - style={[styles.roomUsername, { color: colors.auxiliaryText }]} - >{`@${username}`}</Text> + style={[styles.roomUsername, { color: colors.auxiliaryText }]}>{`@${username}`}</Text> )} {!!statusText && ( <View testID='room-info-view-custom-status'> diff --git a/app/views/RoomMembersView/components/ActionsSection.tsx b/app/views/RoomMembersView/components/ActionsSection.tsx index 7dcf34a0a..174e51c7c 100644 --- a/app/views/RoomMembersView/components/ActionsSection.tsx +++ b/app/views/RoomMembersView/components/ActionsSection.tsx @@ -46,6 +46,7 @@ export default function ActionsSection({ rid, t, joined }: IActionsSection): Rea route: keyof ChatsStackParamList; params: ChatsStackParamList[keyof ChatsStackParamList]; }) => { + // @ts-ignore navigate(route, params); // @ts-ignore logEvent(events[`RM_GO_${route.replace('View', '').toUpperCase()}`]); diff --git a/app/views/RoomView/Banner.tsx b/app/views/RoomView/Banner.tsx index 30b3e78c9..e458e9a18 100644 --- a/app/views/RoomView/Banner.tsx +++ b/app/views/RoomView/Banner.tsx @@ -29,8 +29,7 @@ const Banner = React.memo( <BorderlessButton style={[styles.bannerContainer, { backgroundColor: themes[theme].bannerBackground }]} testID='room-view-banner' - onPress={toggleModal} - > + onPress={toggleModal}> <MarkdownPreview msg={text} style={[styles.bannerText]} /> <BorderlessButton onPress={closeBanner}> <CustomIcon color={themes[theme].auxiliaryText} name='close' size={20} /> @@ -42,8 +41,7 @@ const Banner = React.memo( useNativeDriver isVisible={showModal} animationIn='fadeIn' - animationOut='fadeOut' - > + animationOut='fadeOut'> <View style={[styles.modalView, { backgroundColor: themes[theme].bannerBackground }]}> <Text style={[styles.bannerModalTitle, { color: themes[theme].auxiliaryText }]}>{title}</Text> <ScrollView style={styles.modalScrollView}> diff --git a/app/views/RoomView/JoinCode.tsx b/app/views/RoomView/JoinCode.tsx index e3d74a4e9..6a51d920f 100644 --- a/app/views/RoomView/JoinCode.tsx +++ b/app/views/RoomView/JoinCode.tsx @@ -84,8 +84,7 @@ const JoinCode = React.memo( styles.content, isMasterDetail && [sharedStyles.modalFormSheet, styles.tablet], { backgroundColor: themes[theme].backgroundColor } - ]} - > + ]}> <Text style={[styles.title, { color: themes[theme].titleText }]}>{I18n.t('Insert_Join_Code')}</Text> <FormTextInput value={code} diff --git a/app/views/RoomView/UploadProgress.tsx b/app/views/RoomView/UploadProgress.tsx index 6c78ef204..dbdbc02ae 100644 --- a/app/views/RoomView/UploadProgress.tsx +++ b/app/views/RoomView/UploadProgress.tsx @@ -175,8 +175,7 @@ class UploadProgress extends Component<IUploadProgressProps, IUploadProgressStat <CustomIcon name='attach' size={20} color={themes[theme!].auxiliaryText} /> <Text style={[styles.descriptionContainer, styles.descriptionText, { color: themes[theme!].auxiliaryText }]} - numberOfLines={1} - > + numberOfLines={1}> {I18n.t('Uploading')} {item.name} </Text> <CustomIcon name='close' size={20} color={themes[theme!].auxiliaryText} onPress={() => this.handleCancelUpload(item)} /> @@ -217,8 +216,7 @@ class UploadProgress extends Component<IUploadProgressProps, IUploadProgressStat backgroundColor: themes[theme!].chatComponentBackground, borderColor: themes[theme!].borderColor } - ]} - > + ]}> {this.renderItemContent(item)} </View> ); diff --git a/app/views/RoomView/index.tsx b/app/views/RoomView/index.tsx index 0679db48f..83b98b840 100644 --- a/app/views/RoomView/index.tsx +++ b/app/views/RoomView/index.tsx @@ -1371,8 +1371,7 @@ class RoomView extends React.Component<IRoomViewProps, IRoomViewState> { <Touch onPress={this.resumeRoom} style={[styles.joinRoomButton, { backgroundColor: themes[theme].actionTintColor }]} - enabled={!loading} - > + enabled={!loading}> <Text style={[styles.joinRoomText, { color: themes[theme].buttonText }]} testID='room-view-chat-on-hold-button'> {I18n.t('Resume')} </Text> @@ -1387,8 +1386,7 @@ class RoomView extends React.Component<IRoomViewProps, IRoomViewState> { <Touch onPress={this.joinRoom} style={[styles.joinRoomButton, { backgroundColor: themes[theme].actionTintColor }]} - enabled={!loading} - > + enabled={!loading}> <Text style={[styles.joinRoomText, { color: themes[theme].buttonText }]} testID='room-view-join-button'> {I18n.t(this.isOmnichannel ? 'Take_it' : 'Join')} </Text> @@ -1465,8 +1463,7 @@ class RoomView extends React.Component<IRoomViewProps, IRoomViewState> { onSendMessage: this.handleSendMessage, setQuotesAndText: this.setQuotesAndText, getText: this.getText - }} - > + }}> <SafeAreaView style={{ backgroundColor: themes[theme].backgroundColor }} testID='room-view'> <StatusBar /> <Banner title={I18n.t('Announcement')} text={announcement} bannerClosed={bannerClosed} closeBanner={this.closeBanner} /> diff --git a/app/views/RoomsListView/Header/Header.tsx b/app/views/RoomsListView/Header/Header.tsx index 518913640..9d39736ee 100644 --- a/app/views/RoomsListView/Header/Header.tsx +++ b/app/views/RoomsListView/Header/Header.tsx @@ -91,8 +91,7 @@ const Header = React.memo( <Text testID='rooms-list-header-server-subtitle' style={[styles.subtitle, { color: colors.auxiliaryText }]} - numberOfLines={1} - > + numberOfLines={1}> {subtitle} </Text> ) : null} diff --git a/app/views/RoomsListView/ServerDropdown.tsx b/app/views/RoomsListView/ServerDropdown.tsx index d2cefc43f..6e3207c0d 100644 --- a/app/views/RoomsListView/ServerDropdown.tsx +++ b/app/views/RoomsListView/ServerDropdown.tsx @@ -193,8 +193,7 @@ const ServerDropdown = () => { borderColor: colors.separatorColor } ]} - testID='rooms-list-header-server-dropdown' - > + testID='rooms-list-header-server-dropdown'> <View style={[styles.dropdownContainerHeader, styles.serverHeader, { borderColor: colors.separatorColor }]}> <Text style={[styles.serverHeaderText, { color: colors.auxiliaryText }]}>{I18n.t('Server')}</Text> <TouchableOpacity onPress={addServer} testID='rooms-list-header-server-add'> diff --git a/app/views/RoomsListView/index.tsx b/app/views/RoomsListView/index.tsx index 729c09698..533624bf5 100644 --- a/app/views/RoomsListView/index.tsx +++ b/app/views/RoomsListView/index.tsx @@ -155,7 +155,7 @@ const sortPreferencesShouldUpdate = ['sortBy', 'groupByType', 'showFavorites', ' const displayPropsShouldUpdate = ['showAvatar', 'displayMode']; -const getItemLayout = (data: ISubscription[] | null | undefined, index: number, height: number) => ({ +const getItemLayout = (data: ArrayLike<ISubscription> | null | undefined, index: number, height: number) => ({ length: height, offset: height * index, index @@ -847,6 +847,7 @@ class RoomsListView extends React.Component<IRoomsListViewProps, IRoomsListViewS navigation.navigate('ModalStackNavigator', { screen }); } else { const screen = isSavePassword ? 'E2ESaveYourPasswordStackNavigator' : 'E2EEnterYourPasswordStackNavigator'; + // @ts-ignore navigation.navigate(screen); } }; diff --git a/app/views/ScreenLockedView.tsx b/app/views/ScreenLockedView.tsx index 8cebb6f23..bd968e744 100644 --- a/app/views/ScreenLockedView.tsx +++ b/app/views/ScreenLockedView.tsx @@ -74,8 +74,7 @@ const ScreenLockedView = (): JSX.Element => { hideModalContentWhileAnimating style={{ margin: 0 }} animationIn='fadeIn' - animationOut='fadeOut' - > + animationOut='fadeOut'> <PasscodeEnter hasBiometry={!!data?.hasBiometry} finishProcess={onSubmit} /> {data?.force ? ( <Touchable onPress={onCancel} style={styles.close}> diff --git a/app/views/ShareListView/Header/Header.ios.tsx b/app/views/ShareListView/Header/Header.ios.tsx index fff5dc4bf..59058fbda 100644 --- a/app/views/ShareListView/Header/Header.ios.tsx +++ b/app/views/ShareListView/Header/Header.ios.tsx @@ -44,8 +44,7 @@ const Header = React.memo(({ searching, onChangeSearchText, initSearch, cancelSe borderColor: themes[theme].separatorColor, backgroundColor: themes[theme].headerBackground } - ]} - > + ]}> {!searching ? <HeaderButton.CancelModal onPress={ShareExtension.close} testID='share-extension-close' /> : null} <SearchBox value={text} diff --git a/app/views/ShareListView/Header/SearchBox.tsx b/app/views/ShareListView/Header/SearchBox.tsx index a9f3d336f..68fff6cd0 100644 --- a/app/views/ShareListView/Header/SearchBox.tsx +++ b/app/views/ShareListView/Header/SearchBox.tsx @@ -67,8 +67,7 @@ const SearchBox = ({ hasCancel, onCancelPress, inputRef, ...props }: ISearchBox) style={[ styles.container, { backgroundColor: isIOS ? themes[theme].headerBackground : themes[theme].headerSecondaryBackground } - ]} - > + ]}> <View style={[styles.searchBox, { backgroundColor: themes[theme].searchboxBackground }]}> <CustomIcon name='search' size={14} color={themes[theme].auxiliaryText} /> <TextInput diff --git a/app/views/ShareListView/index.tsx b/app/views/ShareListView/index.tsx index 6906cb1f7..5af971191 100644 --- a/app/views/ShareListView/index.tsx +++ b/app/views/ShareListView/index.tsx @@ -108,13 +108,19 @@ class ShareListView extends React.Component<IShareListViewProps, IState> { .filter(item => item.type === 'media') .map(file => FileSystem.getInfoAsync(this.uriToPath(file.value), { size: true })) ); - const attachments = info.map(file => ({ - filename: decodeURIComponent(file.uri.substring(file.uri.lastIndexOf('/') + 1)), - description: '', - size: file.size, - mime: mime.lookup(file.uri), - path: file.uri - })) as IFileToShare[]; + const attachments = info.map(file => { + if (!file.exists) { + return null; + } + + return { + filename: decodeURIComponent(file.uri.substring(file.uri.lastIndexOf('/') + 1)), + description: '', + size: file.size, + mime: mime.lookup(file.uri), + path: file.uri + }; + }) as IFileToShare[]; const text = data.filter(item => item.type === 'text').reduce((acc, item) => `${item.value}\n${acc}`, ''); this.setState({ text, @@ -433,8 +439,7 @@ class ShareListView extends React.Component<IShareListViewProps, IState> { <SafeAreaView> <ScrollView style={{ backgroundColor: themes[theme].backgroundColor }} - contentContainerStyle={[styles.container, styles.centered, { backgroundColor: themes[theme].backgroundColor }]} - > + contentContainerStyle={[styles.container, styles.centered, { backgroundColor: themes[theme].backgroundColor }]}> <Text style={[styles.permissionTitle, { color: themes[theme].titleText }]}>{I18n.t('Read_External_Permission')}</Text> <Text style={[styles.permissionMessage, { color: themes[theme].bodyText }]}> {I18n.t('Read_External_Permission_Message')} diff --git a/app/views/ShareView/Preview.tsx b/app/views/ShareView/Preview.tsx index efc144928..0b8b7e36d 100644 --- a/app/views/ShareView/Preview.tsx +++ b/app/views/ShareView/Preview.tsx @@ -49,8 +49,7 @@ interface IIconPreview { const IconPreview = React.memo(({ iconName, title, description, theme, width, height, danger }: IIconPreview) => ( <ScrollView style={{ backgroundColor: themes[theme].auxiliaryBackground }} - contentContainerStyle={[styles.fileContainer, { width, height }]} - > + contentContainerStyle={[styles.fileContainer, { width, height }]}> <CustomIcon name={iconName} size={56} color={danger ? themes[theme].dangerColor : themes[theme].tintColor} /> <Text style={[styles.fileName, { color: themes[theme].titleText }]}>{title}</Text> {description ? <Text style={[styles.fileSize, { color: themes[theme].bodyText }]}>{description}</Text> : null} diff --git a/app/views/ShareView/Thumbs.tsx b/app/views/ShareView/Thumbs.tsx index 2750f9550..f38e9c06d 100644 --- a/app/views/ShareView/Thumbs.tsx +++ b/app/views/ShareView/Thumbs.tsx @@ -123,8 +123,7 @@ const Thumb = ({ item, theme, isShareExtension, onPress, onRemove }: IThumb) => style={[styles.removeButton, { backgroundColor: themes[theme].bodyText, borderColor: themes[theme].auxiliaryBackground }]} activeOpacity={1} rippleColor={themes[theme].bannerBackground} - onPress={() => onRemove(item)} - > + onPress={() => onRemove(item)}> <View style={[styles.removeView, { borderColor: themes[theme].auxiliaryBackground }]}> <CustomIcon name='close' color={themes[theme].backgroundColor} size={14} /> </View> diff --git a/app/views/ShareView/index.tsx b/app/views/ShareView/index.tsx index ac0c045e7..60ced6d46 100644 --- a/app/views/ShareView/index.tsx +++ b/app/views/ShareView/index.tsx @@ -126,7 +126,9 @@ class ShareView extends Component<IShareViewProps, IShareViewState> { // if is share extension show default back button if (!this.isShareExtension) { - options.headerLeft = () => <HeaderButton.CloseModal navigation={navigation} color={themes[theme].previewTintColor} testID='share-view-close' />; + options.headerLeft = () => ( + <HeaderButton.CloseModal navigation={navigation} color={themes[theme].previewTintColor} testID='share-view-close' /> + ); } if (!attachments.length && !readOnly) { @@ -348,8 +350,7 @@ class ShareView extends Component<IShareViewProps, IShareViewState> { selectedMessages, onSendMessage: this.send, onRemoveQuoteMessage: this.onRemoveQuoteMessage - }} - > + }}> <View style={styles.container}> <Preview // using key just to reset zoom/move after change selected diff --git a/app/views/SidebarView/SidebarItem.tsx b/app/views/SidebarView/SidebarItem.tsx index 0c39663a9..66dd545fa 100644 --- a/app/views/SidebarView/SidebarItem.tsx +++ b/app/views/SidebarView/SidebarItem.tsx @@ -22,15 +22,13 @@ const Item = React.memo(({ left, right, text, onPress, testID, current, theme, t key={testID} testID={testID} onPress={onPress} - style={[styles.item, current && { backgroundColor: themes[theme].borderColor }]} - > + style={[styles.item, current && { backgroundColor: themes[theme].borderColor }]}> <View style={styles.itemHorizontal}>{left}</View> <View style={styles.itemCenter}> <Text style={[styles.itemText, { color: textColor || themes[theme].titleText }]} numberOfLines={1} - accessibilityLabel={text} - > + accessibilityLabel={text}> {text} </Text> </View> diff --git a/app/views/SidebarView/index.tsx b/app/views/SidebarView/index.tsx index 8e8976cf4..96d2f8c3e 100644 --- a/app/views/SidebarView/index.tsx +++ b/app/views/SidebarView/index.tsx @@ -335,8 +335,7 @@ class Sidebar extends Component<ISidebarProps, ISidebarState> { backgroundColor: isMasterDetail ? themes[theme!].backgroundColor : themes[theme!].focusedBackground } ]} - {...scrollPersistTaps} - > + {...scrollPersistTaps}> <TouchableWithoutFeedback onPress={this.onPressUser} testID='sidebar-close-drawer'> <View style={styles.header}> <Avatar text={user.username} style={styles.avatar} size={30} /> @@ -349,8 +348,7 @@ class Sidebar extends Component<ISidebarProps, ISidebarState> { <Text style={[styles.currentServerText, { color: themes[theme!].titleText }]} numberOfLines={1} - accessibilityLabel={`Connected to ${baseUrl}`} - > + accessibilityLabel={`Connected to ${baseUrl}`}> {Site_Name} </Text> </View> diff --git a/app/views/TeamChannelsView.tsx b/app/views/TeamChannelsView.tsx index 68eae9e5a..dfb435329 100644 --- a/app/views/TeamChannelsView.tsx +++ b/app/views/TeamChannelsView.tsx @@ -33,7 +33,7 @@ import { Services } from '../lib/services'; const API_FETCH_COUNT = 25; -const getItemLayout = (data: IItem[] | null | undefined, index: number) => ({ +const getItemLayout = (data: ArrayLike<IItem> | null | undefined, index: number) => ({ length: data?.length || 0, offset: ROW_HEIGHT * index, index diff --git a/app/views/ThreadMessagesView/Dropdown/index.tsx b/app/views/ThreadMessagesView/Dropdown/index.tsx index a2c1b74b7..5b14bcc87 100644 --- a/app/views/ThreadMessagesView/Dropdown/index.tsx +++ b/app/views/ThreadMessagesView/Dropdown/index.tsx @@ -76,8 +76,7 @@ const Dropdown = ({ isMasterDetail, currentFilter, onClose, onFilterSelected }: backgroundColor: colors.backgroundColor, borderColor: colors.separatorColor } - ]} - > + ]}> <DropdownItemHeader currentFilter={currentFilter} onPress={close} /> <List.Separator /> <DropdownItemFilter currentFilter={currentFilter} value={Filter.All} onPress={onFilterSelected} /> diff --git a/app/views/ThreadMessagesView/Item.tsx b/app/views/ThreadMessagesView/Item.tsx index 96fba4196..ebccc6ed5 100644 --- a/app/views/ThreadMessagesView/Item.tsx +++ b/app/views/ThreadMessagesView/Item.tsx @@ -77,8 +77,7 @@ const Item = ({ item, useRealName, user, badgeColor, onPress, toggleFollowThread <Touchable onPress={() => onPress(item)} testID={`thread-messages-view-${item.msg}`} - style={{ backgroundColor: themes[theme].backgroundColor }} - > + style={{ backgroundColor: themes[theme].backgroundColor }}> <View style={styles.container}> <Avatar style={styles.avatar} text={item?.u?.username} size={36} borderRadius={4} /> <View style={styles.contentContainer}> diff --git a/app/views/UserPreferencesView/index.tsx b/app/views/UserPreferencesView/index.tsx index fe9595a6d..d021282a5 100644 --- a/app/views/UserPreferencesView/index.tsx +++ b/app/views/UserPreferencesView/index.tsx @@ -34,6 +34,7 @@ const UserPreferencesView = ({ navigation }: IUserPreferencesViewProps): JSX.Ele const navigateToScreen = (screen: keyof ProfileStackParamList) => { logEvent(events.UP_GO_USER_NOTIFICATION_PREF); + // @ts-ignore navigation.navigate(screen); }; diff --git a/e2e/tests/assorted/05-joinpublicroom.spec.ts b/e2e/tests/assorted/05-joinpublicroom.spec.ts index 95a7dc34f..236c63e08 100644 --- a/e2e/tests/assorted/05-joinpublicroom.spec.ts +++ b/e2e/tests/assorted/05-joinpublicroom.spec.ts @@ -35,7 +35,7 @@ describe('Join public room', () => { // Render - Header describe('Header', () => { - it('should have actions button ', async () => { + it('should have actions button', async () => { await expect(element(by.id('room-header'))).toBeVisible(); }); }); diff --git a/e2e/tests/assorted/15-change-avatar.spec.ts b/e2e/tests/assorted/15-change-avatar.spec.ts index 26b117afb..03c234b09 100644 --- a/e2e/tests/assorted/15-change-avatar.spec.ts +++ b/e2e/tests/assorted/15-change-avatar.spec.ts @@ -44,7 +44,7 @@ describe('Profile screen', () => { await sleep(300); }); - it('should appear the discard alert when click the back icon ', async () => { + it('should appear the discard alert when click the back icon', async () => { await tapBack(); await waitFor(element(by[textMatcher]('Discard changes?')).atIndex(0)) .toBeVisible() diff --git a/e2e/tests/room/05-threads.spec.ts b/e2e/tests/room/05-threads.spec.ts index c346ad320..7fbf61e3e 100644 --- a/e2e/tests/room/05-threads.spec.ts +++ b/e2e/tests/room/05-threads.spec.ts @@ -38,11 +38,11 @@ describe('Threads', () => { // Render - Header describe('Header', () => { - it('should have actions button ', async () => { + it('should have actions button', async () => { await expect(element(by.id('room-header'))).toExist(); }); - it('should have threads button ', async () => { + it('should have threads button', async () => { await expect(element(by.id('room-view-header-threads'))).toExist(); }); }); diff --git a/e2e/tests/room/12-autotranslate.spec.ts b/e2e/tests/room/12-autotranslate.spec.ts index b1d1123f1..ffbe00cd0 100644 --- a/e2e/tests/room/12-autotranslate.spec.ts +++ b/e2e/tests/room/12-autotranslate.spec.ts @@ -58,19 +58,19 @@ async function searchMessage(msg: string, textMatcher: TTextMatcher) { await sleep(10000); } -export function waitForVisible(id: string) { +function waitForVisible(id: string) { return waitFor(element(by.id(id))) .toBeVisible() .withTimeout(10000); } -export function waitForVisibleTextMatcher(msg: string, textMatcher: TTextMatcher) { +function waitForVisibleTextMatcher(msg: string, textMatcher: TTextMatcher) { return waitFor(element(by[textMatcher](msg)).atIndex(0)) .toExist() .withTimeout(10000); } -export function waitForNotVisible(id: string) { +function waitForNotVisible(id: string) { return waitFor(element(by.id(id))) .not.toBeVisible() .withTimeout(10000); diff --git a/e2e/tests/team/02-team.spec.ts b/e2e/tests/team/02-team.spec.ts index a66b41e60..d4bbbe33f 100644 --- a/e2e/tests/team/02-team.spec.ts +++ b/e2e/tests/team/02-team.spec.ts @@ -94,19 +94,19 @@ describe('Team', () => { describe('Team Room', () => { describe('Team Header', () => { - it('should have actions button ', async () => { + it('should have actions button', async () => { await expect(element(by.id('room-header'))).toExist(); }); - it('should have call button ', async () => { + it('should have call button', async () => { await expect(element(by.id('room-view-header-call'))).toExist(); }); - it('should have threads button ', async () => { + it('should have threads button', async () => { await expect(element(by.id('room-view-header-threads'))).toExist(); }); - it('should have search button ', async () => { + it('should have search button', async () => { await expect(element(by.id('room-view-search'))).toExist(); }); }); @@ -122,15 +122,15 @@ describe('Team', () => { }); describe('Team Channels Header', () => { - it('should have actions button ', async () => { + it('should have actions button', async () => { await expect(element(by.id('room-header')).atIndex(0)).toExist(); }); - it('should have team channels button ', async () => { + it('should have team channels button', async () => { await expect(element(by.id('team-channels-view-create'))).toExist(); }); - it('should have threads button ', async () => { + it('should have threads button', async () => { await expect(element(by.id('team-channels-view-search'))).toExist(); }); }); diff --git a/jest.setup.js b/jest.setup.js index e8e2bcfcd..2ea537aa7 100644 --- a/jest.setup.js +++ b/jest.setup.js @@ -1,6 +1,3 @@ -// https://github.com/facebook/react/issues/20756#issuecomment-780927519 -import 'react-16-node-hanging-test-fix'; - import React from 'react'; import '@testing-library/react-native/extend-expect'; import mockClipboard from '@react-native-clipboard/clipboard/jest/clipboard-mock.js'; diff --git a/package.json b/package.json index aed797ef8..395b35e65 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,7 @@ "commonmark-react-renderer": "git+https://github.com/RocketChat/commonmark-react-renderer.git", "dequal": "2.0.3", "ejson": "2.2.3", - "expo": "^50.0.13", + "expo": "^50.0.14", "expo-apple-authentication": "^6.3.0", "expo-av": "^13.10.5", "expo-camera": "^14.1.1", @@ -110,7 +110,7 @@ "react-native-notifications": "4.3.3", "react-native-notifier": "1.6.1", "react-native-orientation-locker": "1.1.8", - "react-native-picker-select": "8.0.4", + "react-native-picker-select": "9.0.1", "react-native-platform-touchable": "1.1.1", "react-native-popover-view": "5.1.7", "react-native-progress": "5.0.0", @@ -152,7 +152,6 @@ "resolutions": { "ua-parser-js": "1.0.2", "jpeg-js": "0.4.4", - "@types/react": "18", "react-native-reanimated": "3.8.1" }, "devDependencies": { @@ -161,7 +160,7 @@ "@babel/eslint-plugin": "^7.23.5", "@babel/plugin-proposal-decorators": "^7.24.1", "@babel/plugin-transform-named-capturing-groups-regex": "^7.22.5", - "@babel/preset-env": "7.24.1", + "@babel/preset-env": "^7.24.3", "@babel/runtime": "^7.24.1", "@bugsnag/source-maps": "^2.2.0", "@react-native/babel-preset": "0.73.21", @@ -180,14 +179,13 @@ "@types/jest": "^29.5.12", "@types/jsrsasign": "^10.5.8", "@types/lodash": "^4.14.188", - "@types/react": "^17.0.14", - "@types/react-native": "0.68.1", - "@types/react-native-background-timer": "2.0.0", - "@types/react-native-config-reader": "4.1.0", - "@types/react-native-platform-touchable": "1.1.2", - "@types/react-native-scrollable-tab-view": "0.10.2", - "@types/react-native-vector-icons": "6.4.12", - "@types/react-test-renderer": "18.0.0", + "@types/react": "^18.2.6", + "@types/react-native-background-timer": "^2.0.2", + "@types/react-native-config-reader": "^4.1.3", + "@types/react-native-platform-touchable": "^1.1.6", + "@types/react-native-scrollable-tab-view": "^0.10.11", + "@types/react-native-vector-icons": "^6.4.18", + "@types/react-test-renderer": "^18.0.7", "@types/semver": "7.3.13", "@types/ua-parser-js": "^0.7.36", "@types/url-parse": "^1.4.8", @@ -210,13 +208,12 @@ "identity-obj-proxy": "^3.0.0", "jest": "^29.7.0", "jest-cli": "^29.7.0", - "jest-expo": "^46.0.1", + "jest-expo": "^50.0.4", "jest-junit": "^16.0.0", "otp.js": "1.2.0", "patch-package": "8.0.0", "prettier": "2.8.8", - "react-16-node-hanging-test-fix": "1.0.0", - "react-dom": "18.1.0", + "react-dom": "^18.2.0", "react-native-dotenv": "3.4.8", "react-test-renderer": "18.2.0", "reactotron-redux": "3.1.3", diff --git a/patches/react-native-easy-toast+2.3.0.patch b/patches/react-native-easy-toast+2.3.0.patch new file mode 100644 index 000000000..cbbc0a897 --- /dev/null +++ b/patches/react-native-easy-toast+2.3.0.patch @@ -0,0 +1,12 @@ +diff --git a/node_modules/react-native-easy-toast/index.d.ts b/node_modules/react-native-easy-toast/index.d.ts +index 930ba7b..192c6cc 100644 +--- a/node_modules/react-native-easy-toast/index.d.ts ++++ b/node_modules/react-native-easy-toast/index.d.ts +@@ -10,6 +10,7 @@ import { Component, ReactNode } from "react"; + + interface ToastComponentProps { + position?: "bottom" | "center" | "top"; ++ style?: {}; + textStyle?: {}; + positionValue?: number; + fadeInDuration?: number; diff --git a/patches/react-native-picker-select+9.0.1.patch b/patches/react-native-picker-select+9.0.1.patch new file mode 100644 index 000000000..856a38d4b --- /dev/null +++ b/patches/react-native-picker-select+9.0.1.patch @@ -0,0 +1,13 @@ +diff --git a/node_modules/react-native-picker-select/index.d.ts b/node_modules/react-native-picker-select/index.d.ts +index 33983db..64e23ce 100644 +--- a/node_modules/react-native-picker-select/index.d.ts ++++ b/node_modules/react-native-picker-select/index.d.ts +@@ -53,7 +53,7 @@ export interface PickerStyle { + type CustomModalProps = Omit<ModalProps, 'visible' | 'transparent' | 'animationType'>; + // 'testID', 'supportedOrientations', and 'onOrientationChange' are also used, but can be overwritten safely + +-type CustomTextInputProps = Omit<TextInputProps, 'style' | 'value' | 'ref' | 'editable'>; ++type CustomTextInputProps = Omit<TextInputProps, 'value' | 'ref' | 'editable'>; + // 'testID' is also used, but can be overwritten safely + + type CustomPickerProps = Omit<PickerProps, 'onValueChange' | 'selectedValue'>; diff --git a/patches/react-native-ui-lib+7.2.1.patch b/patches/react-native-ui-lib+7.2.1.patch index dc9ecd2c0..6d9ae8b13 100644 --- a/patches/react-native-ui-lib+7.2.1.patch +++ b/patches/react-native-ui-lib+7.2.1.patch @@ -332,20 +332,22 @@ index 0ba2020..0965094 100644 }; export default asBaseComponent<TextFieldProps, StaticMembers>(forwardRef(TextField as any), { diff --git a/node_modules/react-native-ui-lib/src/incubator/TouchableOpacity.tsx b/node_modules/react-native-ui-lib/src/incubator/TouchableOpacity.tsx -index cb3d69d..5084ec8 100644 +index cb3d69d..790929c 100644 --- a/node_modules/react-native-ui-lib/src/incubator/TouchableOpacity.tsx +++ b/node_modules/react-native-ui-lib/src/incubator/TouchableOpacity.tsx -@@ -148,13 +148,11 @@ function TouchableOpacity(props: Props) { +@@ -148,13 +148,13 @@ function TouchableOpacity(props: Props) { return ( <TapGestureHandler - // @ts-expect-error ++ // @ts-ignore onGestureEvent={tapGestureHandler} shouldCancelWhenOutside enabled={!disabled} > <Reanimated.View> - {/* @ts-expect-error */} ++ {/* @ts-ignore */} <Container onGestureEvent={longPressGestureHandler} shouldCancelWhenOutside> <Reanimated.View {...others} @@ -390,6 +392,34 @@ index 346d706..eb2f04e 100644 DEFAULT_DIRECTIONS, DEFAULT_ANIMATION_CONFIG }; +diff --git a/node_modules/react-native-ui-lib/src/incubator/panView/usePanGesture.ts b/node_modules/react-native-ui-lib/src/incubator/panView/usePanGesture.ts +index 0fc7cad..2d2f6d3 100644 +--- a/node_modules/react-native-ui-lib/src/incubator/panView/usePanGesture.ts ++++ b/node_modules/react-native-ui-lib/src/incubator/panView/usePanGesture.ts +@@ -55,6 +55,7 @@ const DEFAULT_ANIMATION_VELOCITY = 300; + export const DEFAULT_ANIMATION_CONFIG = {velocity: DEFAULT_ANIMATION_VELOCITY, damping: 18, stiffness: 100, mass: 0.4}; + const SPRING_BACK_ANIMATION_CONFIG = {velocity: DEFAULT_ANIMATION_VELOCITY, damping: 20, stiffness: 300, mass: 0.8}; + ++// @ts-ignore + const usePanGesture = (props: PanGestureProps) => { + const { + directions = DEFAULT_DIRECTIONS, +@@ -113,12 +114,15 @@ const usePanGesture = (props: PanGestureProps) => { + }, [animateToOrigin]); + + const onGestureEvent = useAnimatedGestureHandler({ ++ // @ts-ignore + onStart: (_event: PanGestureHandlerEventPayload, context: {initialTranslation: Frame}) => { + context.initialTranslation = {x: translationX.value, y: translationY.value}; + }, ++ // @ts-ignore + onActive: (event: PanGestureHandlerEventPayload, context: {initialTranslation: Frame}) => { + setTranslation(event, context.initialTranslation); + }, ++ // @ts-ignore + onEnd: (event: PanGestureHandlerEventPayload) => { + if (dismissible) { + const velocity = getDismissVelocity(event, directions, getTranslationOptions(), threshold); diff --git a/node_modules/react-native-ui-lib/src/style/index.ts b/node_modules/react-native-ui-lib/src/style/index.ts index da8cb97..995207b 100644 --- a/node_modules/react-native-ui-lib/src/style/index.ts diff --git a/yarn.lock b/yarn.lock index f571d73d0..015bd9316 100644 --- a/yarn.lock +++ b/yarn.lock @@ -237,13 +237,6 @@ "@jridgewell/gen-mapping" "^0.3.2" jsesc "^2.5.1" -"@babel/helper-annotate-as-pure@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.16.7.tgz#bb2339a7534a9c128e3102024c60760a3a7f3862" - integrity sha512-s6t2w/IPQVTAET1HitoowRGXooX8mCgtuP5195wD/QJPV6wYjpujCGF7JuMODVX2ZAJOf1GT6DT9MHEZvLOFSw== - dependencies: - "@babel/types" "^7.16.7" - "@babel/helper-annotate-as-pure@^7.18.6": version "7.18.6" resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz#eaa49f6f80d5a33f9a5dd2276e6d6e451be0a6bb" @@ -537,7 +530,7 @@ resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.10.4.tgz#2f75a831269d4f677de49986dff59927533cf375" integrity sha512-O4KCvQA6lLiMU9l2eawBPMf1xPP8xPfB3iEQw150hOVTqj/rfXz0ThTb4HEzqQfs2Bmo5Ay8BzxfzVtBrr9dVg== -"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.24.0", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.18.9", "@babel/helper-plugin-utils@^7.24.0", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": version "7.24.0" resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.0.tgz#945681931a52f15ce879fd5b86ce2dae6d3d7f2a" integrity sha512-9cUznXMG0+FxRuJfvL82QlTqIzhVW9sL0KjMPHhAOOvpQGL8QtdxnBKILjBqxlHyliz0yCa1G903ZXI/FuHy2w== @@ -663,7 +656,7 @@ resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz#9c97e30d31b2b8c72a1d08984f2ca9b574d7a076" integrity sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g== -"@babel/helper-validator-identifier@^7.22.20", "@babel/helper-validator-identifier@^7.9.5": +"@babel/helper-validator-identifier@^7.22.20", "@babel/helper-validator-identifier@^7.9.0", "@babel/helper-validator-identifier@^7.9.5": version "7.22.20" resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz#c4ae002c61d2879e724581d96665583dbc1dc0e0" integrity sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A== @@ -1184,10 +1177,10 @@ "@babel/helper-remap-async-to-generator" "^7.22.20" "@babel/plugin-syntax-async-generators" "^7.8.4" -"@babel/plugin-transform-async-generator-functions@^7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.24.1.tgz#b38009d650b3c419e6708ec5ab4fa5eeffe7b489" - integrity sha512-OTkLJM0OtmzcpOgF7MREERUCdCnCBtBsq3vVFbuq/RKMK0/jdYqdMexWi3zNs7Nzd95ase65MbTGrpFJflOb6A== +"@babel/plugin-transform-async-generator-functions@^7.24.3": + version "7.24.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.24.3.tgz#8fa7ae481b100768cc9842c8617808c5352b8b89" + integrity sha512-Qe26CMYVjpQxJ8zxM1340JFNjZaF+ISWpr1Kt/jGo+ZTUzKkfw/pphEWbRCb+lmSM6k/TOgfYLvmbHkUQ0asIg== dependencies: "@babel/helper-environment-visitor" "^7.22.20" "@babel/helper-plugin-utils" "^7.24.0" @@ -2004,92 +1997,6 @@ "@babel/helper-create-regexp-features-plugin" "^7.22.15" "@babel/helper-plugin-utils" "^7.24.0" -"@babel/preset-env@7.24.1": - version "7.24.1" - resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.24.1.tgz#e63a3f95d9922c07f4a53649b5c2f53f611f2e6c" - integrity sha512-CwCMz1Z28UHLI2iE+cbnWT2epPMV9bzzoBGM6A3mOS22VQd/1TPoWItV7S7iL9TkPmPEf5L/QzurmztyyDN9FA== - dependencies: - "@babel/compat-data" "^7.24.1" - "@babel/helper-compilation-targets" "^7.23.6" - "@babel/helper-plugin-utils" "^7.24.0" - "@babel/helper-validator-option" "^7.23.5" - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.24.1" - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.24.1" - "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly" "^7.24.1" - "@babel/plugin-proposal-private-property-in-object" "7.21.0-placeholder-for-preset-env.2" - "@babel/plugin-syntax-async-generators" "^7.8.4" - "@babel/plugin-syntax-class-properties" "^7.12.13" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - "@babel/plugin-syntax-import-assertions" "^7.24.1" - "@babel/plugin-syntax-import-attributes" "^7.24.1" - "@babel/plugin-syntax-import-meta" "^7.10.4" - "@babel/plugin-syntax-json-strings" "^7.8.3" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - "@babel/plugin-syntax-top-level-await" "^7.14.5" - "@babel/plugin-syntax-unicode-sets-regex" "^7.18.6" - "@babel/plugin-transform-arrow-functions" "^7.24.1" - "@babel/plugin-transform-async-generator-functions" "^7.24.1" - "@babel/plugin-transform-async-to-generator" "^7.24.1" - "@babel/plugin-transform-block-scoped-functions" "^7.24.1" - "@babel/plugin-transform-block-scoping" "^7.24.1" - "@babel/plugin-transform-class-properties" "^7.24.1" - "@babel/plugin-transform-class-static-block" "^7.24.1" - "@babel/plugin-transform-classes" "^7.24.1" - "@babel/plugin-transform-computed-properties" "^7.24.1" - "@babel/plugin-transform-destructuring" "^7.24.1" - "@babel/plugin-transform-dotall-regex" "^7.24.1" - "@babel/plugin-transform-duplicate-keys" "^7.24.1" - "@babel/plugin-transform-dynamic-import" "^7.24.1" - "@babel/plugin-transform-exponentiation-operator" "^7.24.1" - "@babel/plugin-transform-export-namespace-from" "^7.24.1" - "@babel/plugin-transform-for-of" "^7.24.1" - "@babel/plugin-transform-function-name" "^7.24.1" - "@babel/plugin-transform-json-strings" "^7.24.1" - "@babel/plugin-transform-literals" "^7.24.1" - "@babel/plugin-transform-logical-assignment-operators" "^7.24.1" - "@babel/plugin-transform-member-expression-literals" "^7.24.1" - "@babel/plugin-transform-modules-amd" "^7.24.1" - "@babel/plugin-transform-modules-commonjs" "^7.24.1" - "@babel/plugin-transform-modules-systemjs" "^7.24.1" - "@babel/plugin-transform-modules-umd" "^7.24.1" - "@babel/plugin-transform-named-capturing-groups-regex" "^7.22.5" - "@babel/plugin-transform-new-target" "^7.24.1" - "@babel/plugin-transform-nullish-coalescing-operator" "^7.24.1" - "@babel/plugin-transform-numeric-separator" "^7.24.1" - "@babel/plugin-transform-object-rest-spread" "^7.24.1" - "@babel/plugin-transform-object-super" "^7.24.1" - "@babel/plugin-transform-optional-catch-binding" "^7.24.1" - "@babel/plugin-transform-optional-chaining" "^7.24.1" - "@babel/plugin-transform-parameters" "^7.24.1" - "@babel/plugin-transform-private-methods" "^7.24.1" - "@babel/plugin-transform-private-property-in-object" "^7.24.1" - "@babel/plugin-transform-property-literals" "^7.24.1" - "@babel/plugin-transform-regenerator" "^7.24.1" - "@babel/plugin-transform-reserved-words" "^7.24.1" - "@babel/plugin-transform-shorthand-properties" "^7.24.1" - "@babel/plugin-transform-spread" "^7.24.1" - "@babel/plugin-transform-sticky-regex" "^7.24.1" - "@babel/plugin-transform-template-literals" "^7.24.1" - "@babel/plugin-transform-typeof-symbol" "^7.24.1" - "@babel/plugin-transform-unicode-escapes" "^7.24.1" - "@babel/plugin-transform-unicode-property-regex" "^7.24.1" - "@babel/plugin-transform-unicode-regex" "^7.24.1" - "@babel/plugin-transform-unicode-sets-regex" "^7.24.1" - "@babel/preset-modules" "0.1.6-no-external-plugins" - babel-plugin-polyfill-corejs2 "^0.4.10" - babel-plugin-polyfill-corejs3 "^0.10.1" - babel-plugin-polyfill-regenerator "^0.6.1" - core-js-compat "^3.31.0" - semver "^6.3.1" - "@babel/preset-env@^7.12.11", "@babel/preset-env@^7.20.0": version "7.24.0" resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.24.0.tgz#11536a7f4b977294f0bdfad780f01a8ac8e183fc" @@ -2176,6 +2083,92 @@ core-js-compat "^3.31.0" semver "^6.3.1" +"@babel/preset-env@^7.24.3": + version "7.24.3" + resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.24.3.tgz#f3f138c844ffeeac372597b29c51b5259e8323a3" + integrity sha512-fSk430k5c2ff8536JcPvPWK4tZDwehWLGlBp0wrsBUjZVdeQV6lePbwKWZaZfK2vnh/1kQX1PzAJWsnBmVgGJA== + dependencies: + "@babel/compat-data" "^7.24.1" + "@babel/helper-compilation-targets" "^7.23.6" + "@babel/helper-plugin-utils" "^7.24.0" + "@babel/helper-validator-option" "^7.23.5" + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.24.1" + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.24.1" + "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly" "^7.24.1" + "@babel/plugin-proposal-private-property-in-object" "7.21.0-placeholder-for-preset-env.2" + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-class-properties" "^7.12.13" + "@babel/plugin-syntax-class-static-block" "^7.14.5" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + "@babel/plugin-syntax-import-assertions" "^7.24.1" + "@babel/plugin-syntax-import-attributes" "^7.24.1" + "@babel/plugin-syntax-import-meta" "^7.10.4" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-private-property-in-object" "^7.14.5" + "@babel/plugin-syntax-top-level-await" "^7.14.5" + "@babel/plugin-syntax-unicode-sets-regex" "^7.18.6" + "@babel/plugin-transform-arrow-functions" "^7.24.1" + "@babel/plugin-transform-async-generator-functions" "^7.24.3" + "@babel/plugin-transform-async-to-generator" "^7.24.1" + "@babel/plugin-transform-block-scoped-functions" "^7.24.1" + "@babel/plugin-transform-block-scoping" "^7.24.1" + "@babel/plugin-transform-class-properties" "^7.24.1" + "@babel/plugin-transform-class-static-block" "^7.24.1" + "@babel/plugin-transform-classes" "^7.24.1" + "@babel/plugin-transform-computed-properties" "^7.24.1" + "@babel/plugin-transform-destructuring" "^7.24.1" + "@babel/plugin-transform-dotall-regex" "^7.24.1" + "@babel/plugin-transform-duplicate-keys" "^7.24.1" + "@babel/plugin-transform-dynamic-import" "^7.24.1" + "@babel/plugin-transform-exponentiation-operator" "^7.24.1" + "@babel/plugin-transform-export-namespace-from" "^7.24.1" + "@babel/plugin-transform-for-of" "^7.24.1" + "@babel/plugin-transform-function-name" "^7.24.1" + "@babel/plugin-transform-json-strings" "^7.24.1" + "@babel/plugin-transform-literals" "^7.24.1" + "@babel/plugin-transform-logical-assignment-operators" "^7.24.1" + "@babel/plugin-transform-member-expression-literals" "^7.24.1" + "@babel/plugin-transform-modules-amd" "^7.24.1" + "@babel/plugin-transform-modules-commonjs" "^7.24.1" + "@babel/plugin-transform-modules-systemjs" "^7.24.1" + "@babel/plugin-transform-modules-umd" "^7.24.1" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.22.5" + "@babel/plugin-transform-new-target" "^7.24.1" + "@babel/plugin-transform-nullish-coalescing-operator" "^7.24.1" + "@babel/plugin-transform-numeric-separator" "^7.24.1" + "@babel/plugin-transform-object-rest-spread" "^7.24.1" + "@babel/plugin-transform-object-super" "^7.24.1" + "@babel/plugin-transform-optional-catch-binding" "^7.24.1" + "@babel/plugin-transform-optional-chaining" "^7.24.1" + "@babel/plugin-transform-parameters" "^7.24.1" + "@babel/plugin-transform-private-methods" "^7.24.1" + "@babel/plugin-transform-private-property-in-object" "^7.24.1" + "@babel/plugin-transform-property-literals" "^7.24.1" + "@babel/plugin-transform-regenerator" "^7.24.1" + "@babel/plugin-transform-reserved-words" "^7.24.1" + "@babel/plugin-transform-shorthand-properties" "^7.24.1" + "@babel/plugin-transform-spread" "^7.24.1" + "@babel/plugin-transform-sticky-regex" "^7.24.1" + "@babel/plugin-transform-template-literals" "^7.24.1" + "@babel/plugin-transform-typeof-symbol" "^7.24.1" + "@babel/plugin-transform-unicode-escapes" "^7.24.1" + "@babel/plugin-transform-unicode-property-regex" "^7.24.1" + "@babel/plugin-transform-unicode-regex" "^7.24.1" + "@babel/plugin-transform-unicode-sets-regex" "^7.24.1" + "@babel/preset-modules" "0.1.6-no-external-plugins" + babel-plugin-polyfill-corejs2 "^0.4.10" + babel-plugin-polyfill-corejs3 "^0.10.4" + babel-plugin-polyfill-regenerator "^0.6.1" + core-js-compat "^3.31.0" + semver "^6.3.1" + "@babel/preset-flow@^7.12.1", "@babel/preset-flow@^7.13.13": version "7.24.0" resolved "https://registry.yarnpkg.com/@babel/preset-flow/-/preset-flow-7.24.0.tgz#0de60271b0a439b415501c5b28f685fbcb080e1c" @@ -2487,7 +2480,7 @@ "@babel/helper-validator-identifier" "^7.18.6" to-fast-properties "^2.0.0" -"@babel/types@^7.20.0", "@babel/types@^7.20.7", "@babel/types@^7.22.19", "@babel/types@^7.23.4", "@babel/types@^7.24.0": +"@babel/types@^7.20.0", "@babel/types@^7.20.7", "@babel/types@^7.22.19", "@babel/types@^7.23.4", "@babel/types@^7.23.9", "@babel/types@^7.24.0": version "7.24.0" resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.24.0.tgz#3b951f435a92e7333eba05b7566fd297960ea1bf" integrity sha512-+j7a5c253RfKh8iABBhywc8NSfP5LURe7Uh4qpsh6jc+aLJguvmIUBdjSdEMQv2bENrCR5MfRdjGo7vzS/ob7w== @@ -2908,32 +2901,6 @@ xcode "^3.0.1" xml2js "0.6.0" -"@expo/config-plugins@~5.0.3": - version "5.0.4" - resolved "https://registry.yarnpkg.com/@expo/config-plugins/-/config-plugins-5.0.4.tgz#216fea6558fe66615af1370de55193f4181cb23e" - integrity sha512-vzUcVpqOMs3h+hyRdhGwk+eGIOhXa5xYdd92yO17RMNHav3v/+ekMbs7XA2c3lepMO8Yd4/5hqmRw9ZTL6jGzg== - dependencies: - "@expo/config-types" "^47.0.0" - "@expo/json-file" "8.2.36" - "@expo/plist" "0.0.18" - "@expo/sdk-runtime-versions" "^1.0.0" - "@react-native/normalize-color" "^2.0.0" - chalk "^4.1.2" - debug "^4.3.1" - find-up "~5.0.0" - getenv "^1.0.0" - glob "7.1.6" - resolve-from "^5.0.0" - semver "^7.3.5" - slash "^3.0.0" - xcode "^3.0.1" - xml2js "0.4.23" - -"@expo/config-types@^47.0.0": - version "47.0.0" - resolved "https://registry.yarnpkg.com/@expo/config-types/-/config-types-47.0.0.tgz#99eeabe0bba7a776e0f252b78beb0c574692c38d" - integrity sha512-r0pWfuhkv7KIcXMUiNACJmJKKwlTBGMw9VZHNdppS8/0Nve8HZMTkNRFQzTHW1uH3pBj8jEXpyw/2vSWDHex9g== - "@expo/config-types@^50.0.0", "@expo/config-types@^50.0.0-alpha.1": version "50.0.0" resolved "https://registry.yarnpkg.com/@expo/config-types/-/config-types-50.0.0.tgz#b534d3ec997ec60f8af24f6ad56244c8afc71a0b" @@ -2956,23 +2923,6 @@ slugify "^1.3.4" sucrase "3.34.0" -"@expo/config@~7.0.0": - version "7.0.3" - resolved "https://registry.yarnpkg.com/@expo/config/-/config-7.0.3.tgz#c9c634e76186de25e296485e51418f1e52966e6e" - integrity sha512-joVtB5o+NF40Tmsdp65UzryRtbnCuMbXkVO4wJnNJO4aaK0EYLdHCYSewORVqNcDfGN0LphQr8VTG2npbd9CJA== - dependencies: - "@babel/code-frame" "~7.10.4" - "@expo/config-plugins" "~5.0.3" - "@expo/config-types" "^47.0.0" - "@expo/json-file" "8.2.36" - getenv "^1.0.0" - glob "7.1.6" - require-from-string "^2.0.2" - resolve-from "^5.0.0" - semver "7.3.2" - slugify "^1.3.4" - sucrase "^3.20.0" - "@expo/devcert@^1.0.0": version "1.1.0" resolved "https://registry.yarnpkg.com/@expo/devcert/-/devcert-1.1.0.tgz#d148eb9180db6753c438192e73a123fb13b662ac" @@ -3032,15 +2982,6 @@ semver "7.3.2" tempy "0.3.0" -"@expo/json-file@8.2.36": - version "8.2.36" - resolved "https://registry.yarnpkg.com/@expo/json-file/-/json-file-8.2.36.tgz#62a505cb7f30a34d097386476794680a3f7385ff" - integrity sha512-tOZfTiIFA5KmMpdW9KF7bc6CFiGjb0xnbieJhTGlHrLL+ps2G0OkqmuZ3pFEXBOMnJYUVpnSy++52LFxvpa5ZQ== - dependencies: - "@babel/code-frame" "~7.10.4" - json5 "^1.0.1" - write-file-atomic "^2.3.0" - "@expo/json-file@^8.2.37", "@expo/json-file@~8.3.0": version "8.3.0" resolved "https://registry.yarnpkg.com/@expo/json-file/-/json-file-8.3.0.tgz#fc84af77b532a4e9bfb5beafd0e3b7f692b6bd7e" @@ -3102,15 +3043,6 @@ split "^1.0.1" sudo-prompt "9.1.1" -"@expo/plist@0.0.18": - version "0.0.18" - resolved "https://registry.yarnpkg.com/@expo/plist/-/plist-0.0.18.tgz#9abcde78df703a88f6d9fa1a557ee2f045d178b0" - integrity sha512-+48gRqUiz65R21CZ/IXa7RNBXgAI/uPSdvJqoN9x1hfL44DNbUoWHgHiEXTx7XelcATpDwNTz6sHLfy0iNqf+w== - dependencies: - "@xmldom/xmldom" "~0.7.0" - base64-js "^1.2.3" - xmlbuilder "^14.0.0" - "@expo/plist@^0.1.0": version "0.1.0" resolved "https://registry.yarnpkg.com/@expo/plist/-/plist-0.1.0.tgz#eabc95f951d14e10c87fd0443ee01d567371f058" @@ -3249,18 +3181,6 @@ resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz#d9fae00a2d5cb40f92cfe64b47ad749fbc38f917" integrity sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw== -"@isaacs/cliui@^8.0.2": - version "8.0.2" - resolved "https://registry.yarnpkg.com/@isaacs/cliui/-/cliui-8.0.2.tgz#b37667b7bc181c168782259bab42474fbf52b550" - integrity sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA== - dependencies: - string-width "^5.1.2" - string-width-cjs "npm:string-width@^4.2.0" - strip-ansi "^7.0.1" - strip-ansi-cjs "npm:strip-ansi@^6.0.1" - wrap-ansi "^8.1.0" - wrap-ansi-cjs "npm:wrap-ansi@^7.0.0" - "@isaacs/ttlcache@^1.4.1": version "1.4.1" resolved "https://registry.yarnpkg.com/@isaacs/ttlcache/-/ttlcache-1.4.1.tgz#21fb23db34e9b6220c6ba023a0118a2dd3461ea2" @@ -3282,18 +3202,6 @@ resolved "https://registry.yarnpkg.com/@istanbuljs/schema/-/schema-0.1.3.tgz#e45e384e4b8ec16bce2fd903af78450f6bf7ec98" integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA== -"@jest/console@^27.5.1": - version "27.5.1" - resolved "https://registry.yarnpkg.com/@jest/console/-/console-27.5.1.tgz#260fe7239602fe5130a94f1aa386eff54b014bba" - integrity sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg== - dependencies: - "@jest/types" "^27.5.1" - "@types/node" "*" - chalk "^4.0.0" - jest-message-util "^27.5.1" - jest-util "^27.5.1" - slash "^3.0.0" - "@jest/console@^29.7.0": version "29.7.0" resolved "https://registry.yarnpkg.com/@jest/console/-/console-29.7.0.tgz#cd4822dbdb84529265c5a2bdb529a3c9cc950ffc" @@ -3340,14 +3248,7 @@ slash "^3.0.0" strip-ansi "^6.0.0" -"@jest/create-cache-key-function@^27.0.1": - version "27.5.1" - resolved "https://registry.yarnpkg.com/@jest/create-cache-key-function/-/create-cache-key-function-27.5.1.tgz#7448fae15602ea95c828f5eceed35c202a820b31" - integrity sha512-dmH1yW+makpTSURTy8VzdUwFnfQh1G8R+DxO2Ho2FFmBbKFEVm+3jWdvFhE2VqB/LATCTokkP0dotjyQyw5/AQ== - dependencies: - "@jest/types" "^27.5.1" - -"@jest/create-cache-key-function@^29.6.3": +"@jest/create-cache-key-function@^29.2.1", "@jest/create-cache-key-function@^29.6.3": version "29.7.0" resolved "https://registry.yarnpkg.com/@jest/create-cache-key-function/-/create-cache-key-function-29.7.0.tgz#793be38148fab78e65f40ae30c36785f4ad859f0" integrity sha512-4QqS3LY5PBmTRHj9sAg1HLoPzqAI0uOX6wI/TRqHIcOxlFidy6YEmCQJk6FSZjNLGCeubDMfmkWL+qaLKhSGQA== @@ -3447,16 +3348,6 @@ callsites "^3.0.0" graceful-fs "^4.2.9" -"@jest/test-result@^27.5.1": - version "27.5.1" - resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-27.5.1.tgz#56a6585fa80f7cdab72b8c5fc2e871d03832f5bb" - integrity sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag== - dependencies: - "@jest/console" "^27.5.1" - "@jest/types" "^27.5.1" - "@types/istanbul-lib-coverage" "^2.0.0" - collect-v8-coverage "^1.0.0" - "@jest/test-result@^29.7.0": version "29.7.0" resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-29.7.0.tgz#8db9a80aa1a097bb2262572686734baed9b1657c" @@ -3530,17 +3421,6 @@ "@types/yargs" "^15.0.0" chalk "^4.0.0" -"@jest/types@^27.5.1": - version "27.5.1" - resolved "https://registry.yarnpkg.com/@jest/types/-/types-27.5.1.tgz#3c79ec4a8ba61c170bf937bcf9e98a9df175ec80" - integrity sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw== - dependencies: - "@types/istanbul-lib-coverage" "^2.0.0" - "@types/istanbul-reports" "^3.0.0" - "@types/node" "*" - "@types/yargs" "^16.0.0" - chalk "^4.0.0" - "@jest/types@^29.6.3": version "29.6.3" resolved "https://registry.yarnpkg.com/@jest/types/-/types-29.6.3.tgz#1131f8cf634e7e84c5e77bab12f052af585fba59" @@ -3760,11 +3640,6 @@ mkdirp "^1.0.4" rimraf "^3.0.2" -"@pkgjs/parseargs@^0.11.0": - version "0.11.0" - resolved "https://registry.yarnpkg.com/@pkgjs/parseargs/-/parseargs-0.11.0.tgz#a77ea742fab25775145434eb1d2328cf5013ac33" - integrity sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg== - "@pmmmwh/react-refresh-webpack-plugin@^0.4.3": version "0.4.3" resolved "https://registry.yarnpkg.com/@pmmmwh/react-refresh-webpack-plugin/-/react-refresh-webpack-plugin-0.4.3.tgz#1eec460596d200c0236bf195b078a5d1df89b766" @@ -4024,11 +3899,6 @@ resolved "https://registry.yarnpkg.com/@react-native-masked-view/masked-view/-/masked-view-0.3.1.tgz#5bd76f17004a6ccbcec03856893777ee91f23d29" integrity sha512-uVm8U6nwFIlUd1iDIB5cS+lDadApKR+l8k4k84d9hn+GN4lzAIJhUZ9syYX7c022MxNgAlbxoFLt0pqKoyaAGg== -"@react-native-picker/picker@^1.8.3": - version "1.16.8" - resolved "https://registry.yarnpkg.com/@react-native-picker/picker/-/picker-1.16.8.tgz#2126ca54d4a5a3e9ea5e3f39ad1e6643f8e4b3d4" - integrity sha512-pacdQDX6V6EmjF+HoiIh6u++qx4mTK0WnhgUHRc01B+Qt5eoeUwseBqmqfTSXTx/aHDEd6PiIw7UGvKgFoqgFQ== - "@react-native-picker/picker@^2.6.1": version "2.6.1" resolved "https://registry.yarnpkg.com/@react-native-picker/picker/-/picker-2.6.1.tgz#3b20ddd1385fab0487db103dc6519570f8892e6d" @@ -5250,6 +5120,11 @@ resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82" integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== +"@tootallnate/once@2": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-2.0.0.tgz#f544a148d3ab35801c1f633a7441fd87c2e484bf" + integrity sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A== + "@tsconfig/node10@^1.0.7": version "1.0.9" resolved "https://registry.yarnpkg.com/@tsconfig/node10/-/node10-1.0.9.tgz#df4907fc07a886922637b15e02d4cebc4c0021b2" @@ -5270,7 +5145,7 @@ resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.4.tgz#0b92dcc0cc1c81f6f306a381f28e31b1a56536e9" integrity sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA== -"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.14", "@types/babel__core@^7.1.7": +"@types/babel__core@^7.1.14": version "7.20.5" resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.20.5.tgz#3df15f27ba85319caa07ba08d0721889bb39c017" integrity sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA== @@ -5438,6 +5313,15 @@ jest-diff "^26.0.0" pretty-format "^26.0.0" +"@types/jsdom@^20.0.0": + version "20.0.1" + resolved "https://registry.yarnpkg.com/@types/jsdom/-/jsdom-20.0.1.tgz#07c14bc19bd2f918c1929541cdaacae894744808" + integrity sha512-d0r18sZPmMQr1eG35u12FZfhIXNrnsPU/g5wvRKCUf/tOGilKKwYMYGqh33BNR6ba+2gkHw1EUiHoN3mn7E5IQ== + dependencies: + "@types/node" "*" + "@types/tough-cookie" "*" + parse5 "^7.0.0" + "@types/json-schema@^7.0.12": version "7.0.15" resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841" @@ -5573,51 +5457,44 @@ dependencies: "@types/react" "*" -"@types/react-native-background-timer@2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@types/react-native-background-timer/-/react-native-background-timer-2.0.0.tgz#c44c57f8fbca9d9d5521fdd72a8f55232b79381e" - integrity sha512-y5VW82dL/ESOLg+5QQHyBdsFVA4ZklENxmOyxv8o06T+3HBG2JOSuz/CIPz1vKdB7dmWDGPZNuPosdtnp+xv2A== +"@types/react-native-background-timer@^2.0.2": + version "2.0.2" + resolved "https://registry.yarnpkg.com/@types/react-native-background-timer/-/react-native-background-timer-2.0.2.tgz#22f9126124068a0ee6a812e16f98e270c2b9b2c7" + integrity sha512-cMAep0M5yqUHjiiRPvGiviqiJYdI45KSjbI5ufsIFSQGFwHwrHJC/8yawNhy0G3Gix6fufWLsEj6jC5niUNHiQ== -"@types/react-native-config-reader@4.1.0": - version "4.1.0" - resolved "https://registry.yarnpkg.com/@types/react-native-config-reader/-/react-native-config-reader-4.1.0.tgz#33066cd0452b86b605b41bed47b38470dd85d428" - integrity sha512-meRB7e21CUmeS+so51CthLRQxZBymHZoDpq3UaDQHP9ucYbdeA7E0WFoI9vQE1h6kX3Mau3wyU2wQTZiD2674Q== +"@types/react-native-config-reader@^4.1.3": + version "4.1.3" + resolved "https://registry.yarnpkg.com/@types/react-native-config-reader/-/react-native-config-reader-4.1.3.tgz#fe6566b8e2a54c1ec962da946674f6fc763ce8fb" + integrity sha512-AjBqk0MQKnuQRdyMD3mcBNVwxSlf30HWqzMOTjOYj4JGCSTijv+8JKUokOOicpRxcpQdaHu3umFHL6oat9vRJA== -"@types/react-native-platform-touchable@1.1.2": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@types/react-native-platform-touchable/-/react-native-platform-touchable-1.1.2.tgz#c0060f679ffe2ff96960cfde8b60c0fe87168ebf" - integrity sha512-nRA5GuDdG1e2I3f5Ukwdlbw1d0H2GbBU+j0H16/cNelVYPz3zLoxcCHhkNdZ9Wr8LVgVcvqK7vKXG+mzepvpMw== +"@types/react-native-platform-touchable@^1.1.6": + version "1.1.6" + resolved "https://registry.yarnpkg.com/@types/react-native-platform-touchable/-/react-native-platform-touchable-1.1.6.tgz#39244b487cf93afe0cc6aeda692c4e1099169d2c" + integrity sha512-Cci9GPL+s56AcyskL259e/kJHM2AUOwcDNST+xS1Mg8iXIT6/DrWTvHGenQVhUJcCPDIGKieyhNkMt7k5u6C1g== dependencies: "@types/react" "*" - "@types/react-native" "*" - -"@types/react-native-scrollable-tab-view@0.10.2": - version "0.10.2" - resolved "https://registry.yarnpkg.com/@types/react-native-scrollable-tab-view/-/react-native-scrollable-tab-view-0.10.2.tgz#a6006efcad320b9dffd23b080cfe153cebcbc1a6" - integrity sha512-N6IObGTHFKIi2/lFqMLcUICjzqA8phbNWUC6apAdfBnJSrGWkHjTctPt28qpYaQA6KqtCsmhZ19RpzszDje0pg== - dependencies: - "@types/react" "*" - "@types/react-native" "*" - -"@types/react-native-vector-icons@6.4.12": - version "6.4.12" - resolved "https://registry.yarnpkg.com/@types/react-native-vector-icons/-/react-native-vector-icons-6.4.12.tgz#4b9c63bf85eb42fca7c5b0a55ec317900e4fb427" - integrity sha512-gSXtv3NMOsRwSXJ/gvGebm7CNjHbkeFKCse9h/Pvi+x2yjCLOkJR1FBfec06DhaFJpsK7Y8WRQpwOS0eLqx5Rg== - dependencies: - "@types/react" "*" - "@types/react-native" "*" - -"@types/react-native@*": - version "0.73.0" - resolved "https://registry.yarnpkg.com/@types/react-native/-/react-native-0.73.0.tgz#b316be230745779814caa533360262140b0f5984" - integrity sha512-6ZRPQrYM72qYKGWidEttRe6M5DZBEV5F+MHMHqd4TTYx0tfkcdrUFGdef6CCxY0jXU7wldvd/zA/b0A/kTeJmA== - dependencies: react-native "*" -"@types/react-native@0.68.1": - version "0.68.1" - resolved "https://registry.yarnpkg.com/@types/react-native/-/react-native-0.68.1.tgz#56eda448c13fa24f90fd57fa9c7299819e44fb54" - integrity sha512-S+r6VamWqVutlQ3q/vhTn4b0F/DdZj8R6AIDdgwV9xN9Ln1kRdQd7o3mo7FnfdddVdzEkWMUVlK2sbkFOJFAiQ== +"@types/react-native-scrollable-tab-view@^0.10.11": + version "0.10.11" + resolved "https://registry.yarnpkg.com/@types/react-native-scrollable-tab-view/-/react-native-scrollable-tab-view-0.10.11.tgz#f3803eaa5f893b5f5e1bc37e1fc8f3a60d549aef" + integrity sha512-Cqc3o5DiQhaeDnDGZBmA5/aIw41bD5Bs8llMHMktkuEOQUVJH5uiXIVzjMV2cVaJRApj93wg/z+o5h4Ru9/8Jg== + dependencies: + "@types/react" "*" + react-native "*" + +"@types/react-native-vector-icons@^6.4.18": + version "6.4.18" + resolved "https://registry.yarnpkg.com/@types/react-native-vector-icons/-/react-native-vector-icons-6.4.18.tgz#18671c617b9d0958747bc959903470dde91a8c79" + integrity sha512-YGlNWb+k5laTBHd7+uZowB9DpIK3SXUneZqAiKQaj1jnJCZM0x71GDim5JCTMi4IFkhc9m8H/Gm28T5BjyivUw== + dependencies: + "@types/react" "*" + "@types/react-native" "^0.70" + +"@types/react-native@^0.70": + version "0.70.19" + resolved "https://registry.yarnpkg.com/@types/react-native/-/react-native-0.70.19.tgz#b4e651dcf7f49c69ff3a4c3072584cad93155582" + integrity sha512-c6WbyCgWTBgKKMESj/8b4w+zWcZSsCforson7UdXtXMecG3MxCinYi6ihhrHVPyUrVzORsvEzK8zg32z4pK6Sg== dependencies: "@types/react" "*" @@ -5628,14 +5505,14 @@ dependencies: "@types/react" "*" -"@types/react-test-renderer@18.0.0": - version "18.0.0" - resolved "https://registry.yarnpkg.com/@types/react-test-renderer/-/react-test-renderer-18.0.0.tgz#7b7f69ca98821ea5501b21ba24ea7b6139da2243" - integrity sha512-C7/5FBJ3g3sqUahguGi03O79b8afNeSD6T8/GU50oQrJCU0bVCCGQHaGKUbg2Ce8VQEEqTw8/HiS6lXHHdgkdQ== +"@types/react-test-renderer@^18.0.7": + version "18.0.7" + resolved "https://registry.yarnpkg.com/@types/react-test-renderer/-/react-test-renderer-18.0.7.tgz#2cfe657adb3688cdf543995eceb2e062b5a68728" + integrity sha512-1+ANPOWc6rB3IkSnElhjv6VLlKg2dSv/OWClUyZimbLsQyBn8Js9Vtdsi3UICJ2rIQ3k2la06dkB+C92QfhKmg== dependencies: "@types/react" "*" -"@types/react@*", "@types/react@18", "@types/react@^17.0.0": +"@types/react@*": version "18.2.66" resolved "https://registry.yarnpkg.com/@types/react/-/react-18.2.66.tgz#d2eafc8c4e70939c5432221adb23d32d76bfe451" integrity sha512-OYTmMI4UigXeFMF/j4uv0lBBEbongSgptPrHBxqME44h9+yNov+oL6Z3ocJKo0WyXR84sQUNeyIp9MRfckvZpg== @@ -5644,7 +5521,7 @@ "@types/scheduler" "*" csstype "^3.0.2" -"@types/react@^17.0.14": +"@types/react@^17.0.0": version "17.0.80" resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.80.tgz#a5dfc351d6a41257eb592d73d3a85d3b7dbcbb41" integrity sha512-LrgHIu2lEtIo8M7d1FcI3BdwXWoRQwMoXOZ7+dPTW0lYREjmlHl3P0U1VD0i/9tppOuv8/sam7sOjx34TxSFbA== @@ -5653,6 +5530,14 @@ "@types/scheduler" "^0.16" csstype "^3.0.2" +"@types/react@^18.2.6": + version "18.2.73" + resolved "https://registry.yarnpkg.com/@types/react/-/react-18.2.73.tgz#0579548ad122660d99e00499d22e33b81e73ed94" + integrity sha512-XcGdod0Jjv84HOC7N5ziY3x+qL0AfmubvKOZ9hJjJ2yd5EE+KYjWhdOjt387e9HPheHkdggF9atTifMRtyAaRA== + dependencies: + "@types/prop-types" "*" + csstype "^3.0.2" + "@types/scheduler@*", "@types/scheduler@^0.16": version "0.16.8" resolved "https://registry.yarnpkg.com/@types/scheduler/-/scheduler-0.16.8.tgz#ce5ace04cfeabe7ef87c0091e50752e36707deff" @@ -5683,6 +5568,11 @@ resolved "https://registry.yarnpkg.com/@types/tapable/-/tapable-1.0.12.tgz#bc2cab12e87978eee89fb21576b670350d6d86ab" integrity sha512-bTHG8fcxEqv1M9+TD14P8ok8hjxoOCkfKc8XXLaaD05kI7ohpeI956jtDOD3XHKBQrlyPughUtzm1jtVhHpA5Q== +"@types/tough-cookie@*": + version "4.0.5" + resolved "https://registry.yarnpkg.com/@types/tough-cookie/-/tough-cookie-4.0.5.tgz#cb6e2a691b70cb177c6e3ae9c1d2e8b2ea8cd304" + integrity sha512-/Ad8+nIOV7Rl++6f1BdKxFSMgmoqEoYbHRpPcx3JEfv8VRsQe9Z4mCXeJBzxs7mbHY/XOZZuXlRNfhpVPbs6ZA== + "@types/ua-parser-js@^0.7.36": version "0.7.39" resolved "https://registry.yarnpkg.com/@types/ua-parser-js/-/ua-parser-js-0.7.39.tgz#832c58e460c9435e4e34bb866e85e9146e12cdbb" @@ -5748,13 +5638,6 @@ dependencies: "@types/yargs-parser" "*" -"@types/yargs@^16.0.0": - version "16.0.9" - resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-16.0.9.tgz#ba506215e45f7707e6cbcaf386981155b7ab956e" - integrity sha512-tHhzvkFXZQeTECenFoRljLBYPZJ7jAVxqqtEI0qTLOmuultnFp4I9yKE17vTuhf7BkhCu7I4XuemPgikDVuYqA== - dependencies: - "@types/yargs-parser" "*" - "@types/yargs@^17.0.8": version "17.0.32" resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-17.0.32.tgz#030774723a2f7faafebf645f4e5a48371dca6229" @@ -5816,6 +5699,14 @@ "@typescript-eslint/visitor-keys" "7.4.0" debug "^4.3.4" +"@typescript-eslint/scope-manager@5.27.1": + version "5.27.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.27.1.tgz#4d1504392d01fe5f76f4a5825991ec78b7b7894d" + integrity sha512-fQEOSa/QroWE6fAEg+bJxtRZJTH8NTskggybogHt4H9Da8zd4cJji76gA5SBlR0MgtwF7rebxTbDKB49YUCpAg== + dependencies: + "@typescript-eslint/types" "5.27.1" + "@typescript-eslint/visitor-keys" "5.27.1" + "@typescript-eslint/scope-manager@5.62.0": version "5.62.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz#d9457ccc6a0b8d6b37d0eb252a23022478c5460c" @@ -5852,6 +5743,11 @@ debug "^4.3.4" ts-api-utils "^1.0.1" +"@typescript-eslint/types@5.27.1": + version "5.27.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.27.1.tgz#34e3e629501349d38be6ae97841298c03a6ffbf1" + integrity sha512-LgogNVkBhCTZU/m8XgEYIWICD6m4dmEDbKXESCbqOXfKZxRKeqpiJXQIErv66sdopRKZPo5l32ymNqibYEH/xg== + "@typescript-eslint/types@5.62.0": version "5.62.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.62.0.tgz#258607e60effa309f067608931c3df6fed41fd2f" @@ -5862,6 +5758,19 @@ resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.4.0.tgz#ee9dafa75c99eaee49de6dcc9348b45d354419b6" integrity sha512-mjQopsbffzJskos5B4HmbsadSJQWaRK0UxqQ7GuNA9Ga4bEKeiO6b2DnB6cM6bpc8lemaPseh0H9B/wyg+J7rw== +"@typescript-eslint/typescript-estree@5.27.1": + version "5.27.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.27.1.tgz#7621ee78607331821c16fffc21fc7a452d7bc808" + integrity sha512-DnZvvq3TAJ5ke+hk0LklvxwYsnXpRdqUY5gaVS0D4raKtbznPz71UJGnPTHEFo0GDxqLOLdMkkmVZjSpET1hFw== + dependencies: + "@typescript-eslint/types" "5.27.1" + "@typescript-eslint/visitor-keys" "5.27.1" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + semver "^7.3.7" + tsutils "^3.21.0" + "@typescript-eslint/typescript-estree@5.62.0": version "5.62.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz#7d17794b77fabcac615d6a48fb143330d962eb9b" @@ -5928,6 +5837,14 @@ eslint-scope "^5.1.1" eslint-utils "^3.0.0" +"@typescript-eslint/visitor-keys@5.27.1": + version "5.27.1" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.27.1.tgz#05a62666f2a89769dac2e6baa48f74e8472983af" + integrity sha512-xYs6ffo01nhdJgPieyk7HAOpjhTsx7r/oB9LWEhwAXgwn33tkr+W8DI2ChboqhZlC4q3TC6geDYPoiX8ROqyOQ== + dependencies: + "@typescript-eslint/types" "5.27.1" + eslint-visitor-keys "^3.3.0" + "@typescript-eslint/visitor-keys@5.62.0": version "5.62.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz#2174011917ce582875954ffe2f6912d5931e353e" @@ -6123,7 +6040,7 @@ resolved "https://registry.yarnpkg.com/@xmldom/xmldom/-/xmldom-0.8.10.tgz#a1337ca426aa61cef9fe15b5b28e340a72f6fa99" integrity sha512-2WALfTl4xo2SkGCYRt6rDTFfk9R1czmBvUQy12gK2KuRKIpWEhcbbzy8EZXtz/jkRqHX8bFEc6FC1HjX4TUWYw== -"@xmldom/xmldom@~0.7.0", "@xmldom/xmldom@~0.7.7": +"@xmldom/xmldom@~0.7.7": version "0.7.13" resolved "https://registry.yarnpkg.com/@xmldom/xmldom/-/xmldom-0.7.13.tgz#ff34942667a4e19a9f4a0996a76814daac364cf3" integrity sha512-lm2GW5PkosIzccsaZIz7tp8cPADSIlIHWDFTR1N0SzfinhhYgeIQjFMz4rYzanCScr3DqQLeomUDArp6MWKm+g== @@ -6143,6 +6060,11 @@ resolved "https://registry.yarnpkg.com/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz#e77a97fbd345b76d83245edcd17d393b1b41fb31" integrity sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ== +abab@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.6.tgz#41b80f2c871d19686216b82309231cfd3cb3d291" + integrity sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA== + abort-controller@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" @@ -6163,12 +6085,20 @@ accepts@^1.3.7, accepts@^1.3.8, accepts@~1.3.5, accepts@~1.3.7, accepts@~1.3.8: mime-types "~2.1.34" negotiator "0.6.3" +acorn-globals@^7.0.0: + version "7.0.1" + resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-7.0.1.tgz#0dbf05c44fa7c94332914c02066d5beff62c40c3" + integrity sha512-umOSDSDrfHbTNPuNpC2NSnnA3LUrqpevPb4T9jRx4MagXNS0rs+gwiTcAvqCRmsD6utzsrzNt+ebm00SNWiC3Q== + dependencies: + acorn "^8.1.0" + acorn-walk "^8.0.2" + acorn-jsx@^5.3.2: version "5.3.2" resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== -acorn-walk@^8.1.1: +acorn-walk@^8.0.2, acorn-walk@^8.1.1: version "8.3.2" resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.3.2.tgz#7703af9415f1b6db9315d6895503862e231d34aa" integrity sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A== @@ -6178,16 +6108,16 @@ acorn@^6.4.1: resolved "https://registry.yarnpkg.com/acorn/-/acorn-6.4.2.tgz#35866fd710528e92de10cf06016498e47e39e1e6" integrity sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ== +acorn@^8.1.0, acorn@^8.8.1, acorn@^8.8.2, acorn@^8.9.0: + version "8.11.3" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.11.3.tgz#71e0b14e13a4ec160724b38fb7b0f233b1b81d7a" + integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== + acorn@^8.4.1: version "8.8.0" resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.0.tgz#88c0187620435c7f6015803f5539dae05a9dbea8" integrity sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w== -acorn@^8.8.2, acorn@^8.9.0: - version "8.11.3" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.11.3.tgz#71e0b14e13a4ec160724b38fb7b0f233b1b81d7a" - integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== - address@1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/address/-/address-1.1.2.tgz#bf1116c9c758c51b7a933d296b72c221ed9428b6" @@ -6317,13 +6247,18 @@ ansi-colors@^4.1.1: resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.3.tgz#37611340eb2243e70cc604cad35d63270d48781b" integrity sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw== -ansi-escapes@^4.2.1, ansi-escapes@^4.3.0, ansi-escapes@^4.3.1, ansi-escapes@^4.3.2: +ansi-escapes@^4.2.1, ansi-escapes@^4.3.0, ansi-escapes@^4.3.2: version "4.3.2" resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== dependencies: type-fest "^0.21.3" +ansi-escapes@^6.0.0: + version "6.2.1" + resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-6.2.1.tgz#76c54ce9b081dad39acec4b5d53377913825fb0f" + integrity sha512-4nJ3yixlEthEJ9Rk4vPcdBRkZvQZlYyu8j4/Mqz5sgIkddmEnH2Yj2ZrnP9S3tQOvSNRUIgVNF/1yPpRAGNRig== + ansi-fragments@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/ansi-fragments/-/ansi-fragments-0.2.1.tgz#24409c56c4cc37817c3d7caa99d8969e2de5a05e" @@ -6382,11 +6317,6 @@ ansi-styles@^5.0.0: resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== -ansi-styles@^6.1.0: - version "6.2.1" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-6.2.1.tgz#0e62320cf99c21afff3b3012192546aacbfb05c5" - integrity sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug== - ansi-to-html@^0.6.11: version "0.6.15" resolved "https://registry.yarnpkg.com/ansi-to-html/-/ansi-to-html-0.6.15.tgz#ac6ad4798a00f6aa045535d7f6a9cb9294eebea7" @@ -6533,7 +6463,7 @@ array-includes@^3.0.3: get-intrinsic "^1.1.1" is-string "^1.0.7" -array-includes@^3.1.6, array-includes@^3.1.7: +array-includes@^3.1.4, array-includes@^3.1.6, array-includes@^3.1.7: version "3.1.8" resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.8.tgz#5e370cbe172fdd5dd6530c1d4aadda25281ba97d" integrity sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ== @@ -6772,7 +6702,7 @@ autoprefixer@^9.8.6: postcss "^7.0.32" postcss-value-parser "^4.1.0" -available-typed-arrays@^1.0.7: +available-typed-arrays@^1.0.5, available-typed-arrays@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz#a5cc375d6a03c2efc87a553f3e0b1522def14846" integrity sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ== @@ -6809,21 +6739,7 @@ babel-core@^7.0.0-bridge.0: resolved "https://registry.yarnpkg.com/babel-core/-/babel-core-7.0.0-bridge.0.tgz#95a492ddd90f9b4e9a4a1da14eb335b87b634ece" integrity sha512-poPX9mZH/5CSanm50Q+1toVci6pv5KSRv/5TWCwtzQS5XEwn40BcCrgIeMFWP9CKKIniKXNxoIOnOq4VVlGXhg== -babel-jest@^26.6.3: - version "26.6.3" - resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-26.6.3.tgz#d87d25cb0037577a0c89f82e5755c5d293c01056" - integrity sha512-pl4Q+GAVOHwvjrck6jKjvmGhnO3jHX/xuB9d27f+EJZ/6k+6nMuPjorrYp7s++bKKdANwzElBWnLWaObvTnaZA== - dependencies: - "@jest/transform" "^26.6.2" - "@jest/types" "^26.6.2" - "@types/babel__core" "^7.1.7" - babel-plugin-istanbul "^6.0.0" - babel-preset-jest "^26.6.2" - chalk "^4.0.0" - graceful-fs "^4.2.4" - slash "^3.0.0" - -babel-jest@^29.7.0: +babel-jest@^29.2.1, babel-jest@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-29.7.0.tgz#f4369919225b684c56085998ac63dbd05be020d5" integrity sha512-BrvGY3xZSwEcCzKvKsCi2GgHqDqsYkOP4/by5xCgIwGXQxIEh+8ew3gmrE1y7XRR6LHZIj6yLYnUi/mm2KXKBg== @@ -6901,16 +6817,6 @@ babel-plugin-istanbul@^6.0.0, babel-plugin-istanbul@^6.1.1: istanbul-lib-instrument "^5.0.4" test-exclude "^6.0.0" -babel-plugin-jest-hoist@^26.6.2: - version "26.6.2" - resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-26.6.2.tgz#8185bd030348d254c6d7dd974355e6a28b21e62d" - integrity sha512-PO9t0697lNTmcEHH69mdtYiOIkkOlj9fySqfO3K1eCcdISevLAE0xY59VLLUj0SoiPiTX/JU2CYFpILydUa5Lw== - dependencies: - "@babel/template" "^7.3.3" - "@babel/types" "^7.3.3" - "@types/babel__core" "^7.0.0" - "@types/babel__traverse" "^7.0.6" - babel-plugin-jest-hoist@^29.6.3: version "29.6.3" resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.6.3.tgz#aadbe943464182a8922c3c927c3067ff40d24626" @@ -6961,13 +6867,13 @@ babel-plugin-polyfill-corejs3@^0.1.0: "@babel/helper-define-polyfill-provider" "^0.1.5" core-js-compat "^3.8.1" -babel-plugin-polyfill-corejs3@^0.10.1: - version "0.10.1" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.10.1.tgz#cd8750e0b7da30ec2f66007b6151792f02e1138e" - integrity sha512-XiFei6VGwM4ii6nKC1VCenGD8Z4bjiNYcrdkM8oqM3pbuemmyb8biMgrDX1ZHSbIuMLXatM6JJ/StPYIuTl6MQ== +babel-plugin-polyfill-corejs3@^0.10.4: + version "0.10.4" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.10.4.tgz#789ac82405ad664c20476d0233b485281deb9c77" + integrity sha512-25J6I8NGfa5YkCDogHRID3fVCadIR8/pGl1/spvCkzb6lVn6SR3ojpx9nOn9iEBcUsjY24AmdKm5khcfKdylcg== dependencies: "@babel/helper-define-polyfill-provider" "^0.6.1" - core-js-compat "^3.36.0" + core-js-compat "^3.36.1" babel-plugin-polyfill-corejs3@^0.9.0: version "0.9.0" @@ -7103,14 +7009,6 @@ babel-preset-fbjs@^3.4.0: "@babel/plugin-transform-template-literals" "^7.0.0" babel-plugin-syntax-trailing-function-commas "^7.0.0-beta.0" -babel-preset-jest@^26.6.2: - version "26.6.2" - resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-26.6.2.tgz#747872b1171df032252426586881d62d31798fee" - integrity sha512-YvdtlVm9t3k777c5NPQIv6cxFFFapys25HiUmuSgHwIZhfifweR5c5Sf5nwE3MAbfu327CYSvps8Yx6ANLyleQ== - dependencies: - babel-plugin-jest-hoist "^26.6.2" - babel-preset-current-node-syntax "^1.0.0" - babel-preset-jest@^29.6.3: version "29.6.3" resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-29.6.3.tgz#fa05fa510e7d493896d7b0dd2033601c840f171c" @@ -7778,6 +7676,11 @@ char-regex@^1.0.2: resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== +char-regex@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-2.0.1.tgz#6dafdb25f9d3349914079f010ba8d0e6ff9cd01e" + integrity sha512-oSvEeo6ZUD7NepqAat3RqoucZ5SeqLJgOvVIwkafu6IP3V0pO38s/ypdVUmDDK6qIIHNlYHJAKX9E7R7HoKElw== + character-entities-legacy@^1.0.0: version "1.1.4" resolved "https://registry.yarnpkg.com/character-entities-legacy/-/character-entities-legacy-1.1.4.tgz#94bc1845dce70a5bb9d2ecc748725661293d8fc1" @@ -8418,7 +8321,7 @@ core-js-compat@^3.31.0, core-js-compat@^3.34.0, core-js-compat@^3.8.1: dependencies: browserslist "^4.22.3" -core-js-compat@^3.36.0: +core-js-compat@^3.36.1: version "3.36.1" resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.36.1.tgz#1818695d72c99c25d621dca94e6883e190cea3c8" integrity sha512-Dk997v9ZCt3X/npqzyGdTlq6t7lDBhZwGvV94PKzDArjp7BTRm7WlDAXYd/OWdeFHO8OChQYRJNJvUCqCbrtKA== @@ -8435,6 +8338,11 @@ core-js-pure@^3.8.2: resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.24.1.tgz#8839dde5da545521bf282feb7dc6d0b425f39fd3" integrity sha512-r1nJk41QLLPyozHUUPmILCEMtMw24NG4oWK6RbsDdjzQgg9ZvrUsPBj1MnG0wXXp1DCDU6j+wUvEmBSrtRbLXg== +core-js@^1.0.0: + version "1.2.7" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-1.2.7.tgz#652294c14651db28fa93bd2d5ff2983a4f08c636" + integrity sha512-ZiPp9pZlgxpWRu0M+YWbm6+aQ84XEfH1JRXvfOc/fILWI0VKhLC2LX13X1NYq4fULzLMq7Hfh43CSo2/aIaUPA== + core-js@^3.0.4: version "3.6.5" resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.6.5.tgz#7395dc273af37fb2e50e9bd3d9fe841285231d1a" @@ -8704,6 +8612,23 @@ cssesc@^3.0.0: resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee" integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg== +cssom@^0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.5.0.tgz#d254fa92cd8b6fbd83811b9fbaed34663cc17c36" + integrity sha512-iKuQcq+NdHqlAcwUY0o/HL69XQrUaQdMjmStJ8JFmUaiiQErlhrmuigkg/CU4E2J0IyUKUrMAgl36TvN67MqTw== + +cssom@~0.3.6: + version "0.3.8" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" + integrity sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg== + +cssstyle@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-2.3.0.tgz#ff665a0ddbdc31864b09647f34163443d90b0852" + integrity sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A== + dependencies: + cssom "~0.3.6" + csstype@^2.5.7: version "2.6.21" resolved "https://registry.yarnpkg.com/csstype/-/csstype-2.6.21.tgz#2efb85b7cc55c80017c66a5ad7cbd931fda3a90e" @@ -8729,6 +8654,15 @@ damerau-levenshtein@^1.0.8: resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz#b43d286ccbd36bc5b2f7ed41caf2d0aba1f8a6e7" integrity sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA== +data-urls@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-3.0.2.tgz#9cf24a477ae22bcef5cd5f6f0bfbc1d2d3be9143" + integrity sha512-Jy/tj3ldjZJo63sVAvg6LHt2mHvl4V6AgRAmNDtLdm7faqtsx+aJG42rsyCo9JCoRVKwPFzKlIPx3DIibwSIaQ== + dependencies: + abab "^2.0.6" + whatwg-mimetype "^3.0.0" + whatwg-url "^11.0.0" + data-view-buffer@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/data-view-buffer/-/data-view-buffer-1.0.1.tgz#8ea6326efec17a2e42620696e671d7d5a8bc66b2" @@ -8813,6 +8747,11 @@ decamelize@^4.0.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== +decimal.js@^10.4.2: + version "10.4.3" + resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.4.3.tgz#1044092884d245d1b7f65725fa4ad4c6f781cc23" + integrity sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA== + decode-uri-component@^0.2.0, 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" @@ -8884,7 +8823,7 @@ define-lazy-prop@^2.0.0: resolved "https://registry.yarnpkg.com/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz#3f7ae421129bcaaac9bc74905c98a0009ec9ee7f" integrity sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og== -define-properties@^1.1.2, define-properties@^1.1.3, define-properties@^1.2.0, define-properties@^1.2.1: +define-properties@^1.1.2, define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0, define-properties@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.1.tgz#10781cc616eb951a80a034bafcaa7377f6af2b6c" integrity sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg== @@ -9156,6 +9095,13 @@ domelementtype@^2.0.1, domelementtype@^2.2.0, domelementtype@^2.3.0: resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d" integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== +domexception@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/domexception/-/domexception-4.0.0.tgz#4ad1be56ccadc86fc76d033353999a8037d03673" + integrity sha512-A2is4PLG+eeSfoTMA95/s4pvAoSo2mKtiM5jlHkAVewmiO8ISFTFKZjH7UAM1Atli/OT/7JHOrJRJiMKUZKYBw== + dependencies: + webidl-conversions "^7.0.0" + domhandler@^4.0.0, domhandler@^4.2.0, domhandler@^4.3.1: version "4.3.1" resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.3.1.tgz#8d792033416f59d68bc03a5aa7b018c1ca89279c" @@ -9280,11 +9226,6 @@ duplexify@^3.4.2, duplexify@^3.6.0: readable-stream "^2.0.0" stream-shift "^1.0.0" -eastasianwidth@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.2.0.tgz#696ce2ec0aa0e6ea93a397ffcf24aa7840c827cb" - integrity sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA== - easy-stack@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/easy-stack/-/easy-stack-1.0.1.tgz#8afe4264626988cabb11f3c704ccd0c835411066" @@ -9359,6 +9300,13 @@ encodeurl@~1.0.2: resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== +encoding@^0.1.11: + version "0.1.13" + resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" + integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== + dependencies: + iconv-lite "^0.6.2" + end-of-stream@^1.0.0, end-of-stream@^1.1.0, end-of-stream@^1.4.1: version "1.4.4" resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" @@ -9396,7 +9344,7 @@ entities@^2.0.0: resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== -entities@^4.2.0: +entities@^4.2.0, entities@^4.4.0: version "4.5.0" resolved "https://registry.yarnpkg.com/entities/-/entities-4.5.0.tgz#5d268ea5e7113ec74c4d033b79ea5a35a488fb48" integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw== @@ -9450,7 +9398,7 @@ errorhandler@^1.5.1: accepts "~1.3.7" escape-html "~1.0.3" -es-abstract@^1.22.1, es-abstract@^1.22.3, es-abstract@^1.23.0, es-abstract@^1.23.1, es-abstract@^1.23.2: +es-abstract@^1.17.0-next.1, es-abstract@^1.19.1, es-abstract@^1.19.5, es-abstract@^1.20.0, es-abstract@^1.22.1, es-abstract@^1.22.3, es-abstract@^1.23.0, es-abstract@^1.23.1, es-abstract@^1.23.2: version "1.23.2" resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.23.2.tgz#693312f3940f967b8dd3eebacb590b01712622e0" integrity sha512-60s3Xv2T2p1ICykc7c+DNDPLDMm9t4QxCOUU0K9JxiLjM3C1zB9YVdN7tjxrFd4+AkZ8CdX1ovUga4P2+1e+/w== @@ -9689,6 +9637,17 @@ escape-string-regexp@^4.0.0: resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== +escodegen@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-2.1.0.tgz#ba93bbb7a43986d29d6041f99f5262da773e2e17" + integrity sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w== + dependencies: + esprima "^4.0.1" + estraverse "^5.2.0" + esutils "^2.0.2" + optionalDependencies: + source-map "~0.6.1" + eslint-config-prettier@^8.5.0: version "8.10.0" resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.10.0.tgz#3a06a662130807e2502fc3ff8b4143d8a0658e11" @@ -9891,7 +9850,14 @@ eslint-scope@^7.2.2: esrecurse "^4.3.0" estraverse "^5.2.0" -eslint-visitor-keys@^2.1.0: +eslint-utils@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-3.0.0.tgz#8aebaface7345bb33559db0a1f13a1d2d48c3672" + integrity sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA== + dependencies: + eslint-visitor-keys "^2.0.0" + +eslint-visitor-keys@^2.0.0, eslint-visitor-keys@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz#f65328259305927392c938ed44eb0a5c9b2bd303" integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw== @@ -9959,7 +9925,7 @@ espree@^9.6.0, espree@^9.6.1: acorn-jsx "^5.3.2" eslint-visitor-keys "^3.4.1" -esprima@^4.0.0, esprima@~4.0.0: +esprima@^4.0.0, esprima@^4.0.1, esprima@~4.0.0: version "4.0.1" resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== @@ -10231,10 +10197,10 @@ expo-web-browser@^12.8.2: compare-urls "^2.0.0" url "^0.11.0" -expo@^50.0.13: - version "50.0.13" - resolved "https://registry.yarnpkg.com/expo/-/expo-50.0.13.tgz#fac1ba0dd002598bc90bda3657b69aea55119f94" - integrity sha512-p0FYrhUJZe92YOwOXx6GZ/WaxF6YtsLXtWkql9pFIIocYBN6iQ3OMGsbQCRSu0ao8rlxsk7HgQDEWK4D+y9tAg== +expo@^50.0.14: + version "50.0.14" + resolved "https://registry.yarnpkg.com/expo/-/expo-50.0.14.tgz#ddcae86aa0ba8d1be3da9ad1bdda23fa539dc97d" + integrity sha512-yLPdxCMVAbmeEIpzzyAuJ79wvr6ToDDtQmuLDMAgWtjqP8x3CGddXxUe07PpKEQgzwJabdHvCLP5Bv94wMFIjQ== dependencies: "@babel/runtime" "^7.20.0" "@expo/cli" "0.17.8" @@ -10423,6 +10389,19 @@ fbjs-css-vars@^1.0.0: resolved "https://registry.yarnpkg.com/fbjs-css-vars/-/fbjs-css-vars-1.0.2.tgz#216551136ae02fe255932c3ec8775f18e2c078b8" integrity sha512-b2XGFAFdWZWg0phtAWLHCk836A1Xann+I+Dgd3Gk64MHKZO44FfoD1KxyvbSh0qZsIoXQGGlVztIY+oitJPpRQ== +fbjs@^0.8.9: + version "0.8.18" + resolved "https://registry.yarnpkg.com/fbjs/-/fbjs-0.8.18.tgz#9835e0addb9aca2eff53295cd79ca1cfc7c9662a" + integrity sha512-EQaWFK+fEPSoibjNy8IxUtaFOMXcWsY0JaVrQoZR9zC8N2Ygf9iDITPWjUTVIax95b6I742JFLqASHfsag/vKA== + dependencies: + core-js "^1.0.0" + isomorphic-fetch "^2.1.1" + loose-envify "^1.0.0" + object-assign "^4.1.0" + promise "^7.1.1" + setimmediate "^1.0.5" + ua-parser-js "^0.7.30" + fbjs@^3.0.0: version "3.0.5" resolved "https://registry.yarnpkg.com/fbjs/-/fbjs-3.0.5.tgz#aa0edb7d5caa6340011790bd9249dbef8a81128d" @@ -10702,14 +10681,6 @@ foreground-child@^2.0.0: cross-spawn "^7.0.0" signal-exit "^3.0.2" -foreground-child@^3.1.0: - version "3.1.1" - resolved "https://registry.yarnpkg.com/foreground-child/-/foreground-child-3.1.1.tgz#1d173e776d75d2772fed08efe4a0de1ea1b12d0d" - integrity sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg== - dependencies: - cross-spawn "^7.0.0" - signal-exit "^4.0.1" - fork-ts-checker-webpack-plugin@4.1.6, fork-ts-checker-webpack-plugin@^4.1.6: version "4.1.6" resolved "https://registry.yarnpkg.com/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-4.1.6.tgz#5055c703febcf37fa06405d400c122b905167fc5" @@ -11083,17 +11054,6 @@ glob@7.1.6: once "^1.3.0" path-is-absolute "^1.0.0" -glob@^10.3.10: - version "10.3.10" - resolved "https://registry.yarnpkg.com/glob/-/glob-10.3.10.tgz#0351ebb809fd187fe421ab96af83d3a70715df4b" - integrity sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g== - dependencies: - foreground-child "^3.1.0" - jackspeak "^2.3.5" - minimatch "^9.0.1" - minipass "^5.0.0 || ^6.0.2 || ^7.0.0" - path-scurry "^1.10.1" - glob@^6.0.1: version "6.0.4" resolved "https://registry.yarnpkg.com/glob/-/glob-6.0.4.tgz#0f08860f6a155127b2fadd4f9ce24b1aab6e4d22" @@ -11556,6 +11516,13 @@ hosted-git-info@^3.0.2: dependencies: lru-cache "^6.0.0" +html-encoding-sniffer@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-3.0.0.tgz#2cb1a8cf0db52414776e5b2a7a04d5dd98158de9" + integrity sha512-oWv4T4yJ52iKrufjnyZPkrN0CH3QnrUqdB6In1g5Fe1mia8GmF36gnfNySxoZtxD5+NmYw1EElVXiBk93UeskA== + dependencies: + whatwg-encoding "^2.0.0" + html-entities@^1.2.1: version "1.4.0" resolved "https://registry.yarnpkg.com/html-entities/-/html-entities-1.4.0.tgz#cfbd1b01d2afaf9adca1b10ae7dffab98c71d2dc" @@ -11634,6 +11601,15 @@ http-proxy-agent@^4.0.0: agent-base "6" debug "4" +http-proxy-agent@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz#5129800203520d434f142bc78ff3c170800f2b43" + integrity sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w== + dependencies: + "@tootallnate/once" "2" + agent-base "6" + debug "4" + https-browserify@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73" @@ -11664,6 +11640,13 @@ iconv-lite@0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" +iconv-lite@0.6.3, iconv-lite@^0.6.2: + version "0.6.3" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" + integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== + dependencies: + safer-buffer ">= 2.1.2 < 3.0.0" + icss-utils@^4.0.0, icss-utils@^4.1.1: version "4.1.1" resolved "https://registry.yarnpkg.com/icss-utils/-/icss-utils-4.1.1.tgz#21170b53789ee27447c2f47dd683081403f9a467" @@ -11805,7 +11788,7 @@ internal-ip@4.3.0: default-gateway "^4.2.0" ipaddr.js "^1.9.0" -internal-slot@^1.0.4, internal-slot@^1.0.5, internal-slot@^1.0.7: +internal-slot@^1.0.3, internal-slot@^1.0.4, internal-slot@^1.0.7: version "1.0.7" resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.7.tgz#c06dcca3ed874249881007b0a5523b172a190802" integrity sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g== @@ -12171,6 +12154,11 @@ is-plain-object@^2.0.3, is-plain-object@^2.0.4: dependencies: isobject "^3.0.1" +is-potential-custom-element-name@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5" + integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ== + is-regex@^1.1.2, is-regex@^1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" @@ -12208,7 +12196,7 @@ is-shared-array-buffer@^1.0.3: dependencies: call-bind "^1.0.7" -is-stream@^1.1.0: +is-stream@^1.0.1, is-stream@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" integrity sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ== @@ -12232,7 +12220,7 @@ is-symbol@^1.0.2, is-symbol@^1.0.3: dependencies: has-symbols "^1.0.2" -is-typed-array@^1.1.13: +is-typed-array@^1.1.13, is-typed-array@^1.1.9: version "1.1.13" resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.13.tgz#d6c5ca56df62334959322d7d7dd1cca50debe229" integrity sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw== @@ -12356,6 +12344,14 @@ isobject@^4.0.0: resolved "https://registry.yarnpkg.com/isobject/-/isobject-4.0.0.tgz#3f1c9155e73b192022a80819bacd0343711697b0" integrity sha512-S/2fF5wH8SJA/kmwr6HYhK/RI/OkhD84k8ntalo0iJjZikgq1XFvR5M8NPT1x5F7fBwCG3qHfnzeP/Vh/ZxCUA== +isomorphic-fetch@^2.1.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz#611ae1acf14f5e81f729507472819fe9733558a9" + integrity sha512-9c4TNAKYXM5PRyVcwUZrF3W09nQ+sO7+jydgs4ZGW9dhsLG2VOlISJABombdQqQRXCwuYG3sYV/puGf5rp0qmA== + dependencies: + node-fetch "^1.0.1" + whatwg-fetch ">=0.10.0" + istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: version "3.2.2" resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz#2d166c4b0644d43a39f04bf6c2edd1e585f31756" @@ -12433,15 +12429,6 @@ iterator.prototype@^1.1.2: reflect.getprototypeof "^1.0.4" set-function-name "^2.0.1" -jackspeak@^2.3.5: - version "2.3.6" - resolved "https://registry.yarnpkg.com/jackspeak/-/jackspeak-2.3.6.tgz#647ecc472238aee4b06ac0e461acc21a8c505ca8" - integrity sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ== - dependencies: - "@isaacs/cliui" "^8.0.2" - optionalDependencies: - "@pkgjs/parseargs" "^0.11.0" - jest-changed-files@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-29.7.0.tgz#1c06d07e77c78e1585d020424dedc10d6e17ac3a" @@ -12574,6 +12561,20 @@ jest-environment-emit@^1.0.5: strip-ansi "^6.0.0" tslib "^2.5.3" +jest-environment-jsdom@^29.2.1: + version "29.7.0" + resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-29.7.0.tgz#d206fa3551933c3fd519e5dfdb58a0f5139a837f" + integrity sha512-k9iQbsf9OyOfdzWH8HDmrRT0gSIcX+FLNW7IQq94tFX0gynPwqDTW0Ho6iMVNjGz/nb+l/vW3dWM2bbLLpkbXA== + dependencies: + "@jest/environment" "^29.7.0" + "@jest/fake-timers" "^29.7.0" + "@jest/types" "^29.6.3" + "@types/jsdom" "^20.0.0" + "@types/node" "*" + jest-mock "^29.7.0" + jest-util "^29.7.0" + jsdom "^20.0.0" + jest-environment-node@^29.6.3, jest-environment-node@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-29.7.0.tgz#0b93e111dda8ec120bc8300e6d1fb9576e164376" @@ -12586,20 +12587,23 @@ jest-environment-node@^29.6.3, jest-environment-node@^29.7.0: jest-mock "^29.7.0" jest-util "^29.7.0" -jest-expo@^46.0.1: - version "46.0.2" - resolved "https://registry.yarnpkg.com/jest-expo/-/jest-expo-46.0.2.tgz#10f7a0e81e2135868aadaacd3f23393bd97c1d86" - integrity sha512-VEmIVY+LIOJvQ+I8njQ34NLjq+AHCYiXGoq663v3CMqbQ351yuvJfsKGEdq/p5Q/JuXK0kyvPryksyhCJjGopw== +jest-expo@^50.0.4: + version "50.0.4" + resolved "https://registry.yarnpkg.com/jest-expo/-/jest-expo-50.0.4.tgz#3e72524982487dd1fa2a77de716c86f0a5fd2b1a" + integrity sha512-qtCqtdGaQtEcA3vc6UPN5Xn78jAyoBJj6Pxpk2raizdwI7carsg9Us9Wc+D4kl+7+ffhBMeS3cYWeJqVIZl1pA== dependencies: - "@expo/config" "~7.0.0" - "@jest/create-cache-key-function" "^27.0.1" - babel-jest "^26.6.3" + "@expo/config" "~8.5.0" + "@expo/json-file" "^8.2.37" + "@jest/create-cache-key-function" "^29.2.1" + babel-jest "^29.2.1" find-up "^5.0.0" + jest-environment-jsdom "^29.2.1" jest-watch-select-projects "^2.0.0" - jest-watch-typeahead "0.6.4" - json5 "^2.1.0" + jest-watch-typeahead "2.2.1" + json5 "^2.2.3" lodash "^4.17.19" - react-test-renderer "~18.1.0" + react-test-renderer "18.2.0" + stacktrace-js "^2.0.2" jest-get-type@^26.3.0: version "26.3.0" @@ -12704,21 +12708,6 @@ jest-message-util@^26.6.2: slash "^3.0.0" stack-utils "^2.0.2" -jest-message-util@^27.5.1: - version "27.5.1" - resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-27.5.1.tgz#bdda72806da10d9ed6425e12afff38cd1458b6cf" - integrity sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g== - dependencies: - "@babel/code-frame" "^7.12.13" - "@jest/types" "^27.5.1" - "@types/stack-utils" "^2.0.0" - chalk "^4.0.0" - graceful-fs "^4.2.9" - micromatch "^4.0.4" - pretty-format "^27.5.1" - slash "^3.0.0" - stack-utils "^2.0.3" - jest-message-util@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-29.7.0.tgz#8bc392e204e95dfe7564abbe72a404e28e51f7f3" @@ -12753,12 +12742,7 @@ jest-regex-util@^26.0.0: resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-26.0.0.tgz#d25e7184b36e39fd466c3bc41be0971e821fee28" integrity sha512-Gv3ZIs/nA48/Zvjrl34bf+oD76JHiGDUxNOVgUjh3j890sblXryjY4rss71fPtD/njchl6PSE2hIhvyWa1eT0A== -jest-regex-util@^27.0.0: - version "27.5.1" - resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-27.5.1.tgz#4da143f7e9fd1e542d4aa69617b38e4a78365b95" - integrity sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg== - -jest-regex-util@^29.6.3: +jest-regex-util@^29.0.0, jest-regex-util@^29.6.3: version "29.6.3" resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-29.6.3.tgz#4a556d9c776af68e1c5f48194f4d0327d24e8a52" integrity sha512-KJJBsRCyyLNWCNBOvZyRDnAIfUiRJ8v+hOBQYGn8gDyF3UegwiP4gwRR3/SDa42g1YbVycTidUF3rKjyLFDWbg== @@ -12930,18 +12914,6 @@ jest-util@^26.6.2: is-ci "^2.0.0" micromatch "^4.0.2" -jest-util@^27.5.1: - version "27.5.1" - resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-27.5.1.tgz#3ba9771e8e31a0b85da48fe0b0891fb86c01c2f9" - integrity sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw== - dependencies: - "@jest/types" "^27.5.1" - "@types/node" "*" - chalk "^4.0.0" - ci-info "^3.2.0" - graceful-fs "^4.2.9" - picomatch "^2.2.3" - jest-util@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-29.7.0.tgz#23c2b62bfb22be82b44de98055802ff3710fc0bc" @@ -12975,33 +12947,20 @@ jest-watch-select-projects@^2.0.0: chalk "^3.0.0" prompts "^2.2.1" -jest-watch-typeahead@0.6.4: - version "0.6.4" - resolved "https://registry.yarnpkg.com/jest-watch-typeahead/-/jest-watch-typeahead-0.6.4.tgz#ea70bf1bec34bd4f55b5b72d471b02d997899c3e" - integrity sha512-tGxriteVJqonyrDj/xZHa0E2glKMiglMLQqISLCjxLUfeueRBh9VoRF2FKQyYO2xOqrWDTg7781zUejx411ZXA== +jest-watch-typeahead@2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/jest-watch-typeahead/-/jest-watch-typeahead-2.2.1.tgz#36601520a2a30fd561788552dbda9c76bb44814a" + integrity sha512-jYpYmUnTzysmVnwq49TAxlmtOAwp8QIqvZyoofQFn8fiWhEDZj33ZXzg3JA4nGnzWFm1hbWf3ADpteUokvXgFA== dependencies: - ansi-escapes "^4.3.1" + ansi-escapes "^6.0.0" chalk "^4.0.0" - jest-regex-util "^27.0.0" - jest-watcher "^27.0.0" - slash "^3.0.0" - string-length "^4.0.1" - strip-ansi "^6.0.0" + jest-regex-util "^29.0.0" + jest-watcher "^29.0.0" + slash "^5.0.0" + string-length "^5.0.1" + strip-ansi "^7.0.1" -jest-watcher@^27.0.0: - version "27.5.1" - resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-27.5.1.tgz#71bd85fb9bde3a2c2ec4dc353437971c43c642a2" - integrity sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw== - dependencies: - "@jest/test-result" "^27.5.1" - "@jest/types" "^27.5.1" - "@types/node" "*" - ansi-escapes "^4.2.1" - chalk "^4.0.0" - jest-util "^27.5.1" - string-length "^4.0.1" - -jest-watcher@^29.7.0: +jest-watcher@^29.0.0, jest-watcher@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-29.7.0.tgz#7810d30d619c3a62093223ce6bb359ca1b28a2f2" integrity sha512-49Fg7WXkU3Vl2h6LbLtMQ/HyB6rXSIX7SqvBLQmssRBGN9I0PNvPmAmCWSOY6SOvrjhI/F7/bGAv9RtnsPA03g== @@ -13167,6 +13126,38 @@ jscodeshift@^0.14.0: temp "^0.8.4" write-file-atomic "^2.3.0" +jsdom@^20.0.0: + version "20.0.3" + resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-20.0.3.tgz#886a41ba1d4726f67a8858028c99489fed6ad4db" + integrity sha512-SYhBvTh89tTfCD/CRdSOm13mOBa42iTaTyfyEWBdKcGdPxPtLFBXuHR8XHb33YNYaP+lLbmSvBTsnoesCNJEsQ== + dependencies: + abab "^2.0.6" + acorn "^8.8.1" + acorn-globals "^7.0.0" + cssom "^0.5.0" + cssstyle "^2.3.0" + data-urls "^3.0.2" + decimal.js "^10.4.2" + domexception "^4.0.0" + escodegen "^2.0.0" + form-data "^4.0.0" + html-encoding-sniffer "^3.0.0" + http-proxy-agent "^5.0.0" + https-proxy-agent "^5.0.1" + is-potential-custom-element-name "^1.0.1" + nwsapi "^2.2.2" + parse5 "^7.1.1" + saxes "^6.0.0" + symbol-tree "^3.2.4" + tough-cookie "^4.1.2" + w3c-xmlserializer "^4.0.0" + webidl-conversions "^7.0.0" + whatwg-encoding "^2.0.0" + whatwg-mimetype "^3.0.0" + whatwg-url "^11.0.0" + ws "^8.11.0" + xml-name-validator "^4.0.0" + jsesc@^2.5.1: version "2.5.2" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" @@ -13248,7 +13239,7 @@ json5@^1.0.1, json5@^1.0.2: dependencies: minimist "^1.2.0" -json5@^2.1.0, json5@^2.1.2, json5@^2.1.3: +json5@^2.1.2, json5@^2.1.3: version "2.2.1" resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.1.tgz#655d50ed1e6f95ad1a3caababd2b0efda10b395c" integrity sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA== @@ -13699,11 +13690,6 @@ lru-cache@^6.0.0: dependencies: yallist "^4.0.0" -"lru-cache@^9.1.1 || ^10.0.0": - version "10.2.0" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-10.2.0.tgz#0bd445ca57363465900f4d1f9bd8db343a4d95c3" - integrity sha512-2bIM8x+VAf6JT4bKAljS1qUWgMsqZRPGJS6FSahIMPVvctcNhyVp7AJu7quxOW9jwkryBReKZY5tY5JYv2n/7Q== - make-dir@^2.0.0, make-dir@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" @@ -14260,7 +14246,7 @@ minimatch@3.0.4: dependencies: brace-expansion "^1.1.7" -minimatch@9.0.3, minimatch@^9.0.1: +minimatch@9.0.3: version "9.0.3" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.3.tgz#a6e00c3de44c3a542bfaae70abfc22420a6da825" integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== @@ -14317,11 +14303,6 @@ minipass@^5.0.0: resolved "https://registry.yarnpkg.com/minipass/-/minipass-5.0.0.tgz#3e9788ffb90b694a5d0ec94479a45b5d8738133d" integrity sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ== -"minipass@^5.0.0 || ^6.0.2 || ^7.0.0": - version "7.0.4" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-7.0.4.tgz#dbce03740f50a4786ba994c1fb908844d27b038c" - integrity sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ== - minizlib@^2.1.1: version "2.1.2" resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" @@ -14588,6 +14569,14 @@ node-dir@^0.1.10, node-dir@^0.1.17: dependencies: minimatch "^3.0.2" +node-fetch@^1.0.1: + version "1.7.3" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-1.7.3.tgz#980f6f72d85211a5347c6b2bc18c5b84c3eb47ef" + integrity sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ== + dependencies: + encoding "^0.1.11" + is-stream "^1.0.1" + node-fetch@^2.2.0, node-fetch@^2.6.0, node-fetch@^2.6.1, node-fetch@^2.6.12, node-fetch@^2.6.7: version "2.7.0" resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.7.0.tgz#d0f0fa6e3e2dc1d27efcd8ad99d550bda94d187d" @@ -14769,6 +14758,11 @@ number-is-nan@^1.0.0: resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" integrity sha512-4jbtZXNAsfZbAHiiqjLPBiCl16dES1zI4Hpzzxw61Tk+loF+sBDBKx1ICKKKwIqQ7M0mFn1TmkN7euSncWgHiQ== +nwsapi@^2.2.2: + version "2.2.7" + resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.7.tgz#738e0707d3128cb750dddcfe90e4610482df0f30" + integrity sha512-ub5E4+FBPKwAZx0UwIQOjYWGHTEq5sPqHQNRN8Z9e4A7u3Tj1weLJsL59yH9vmvqEtBHaOmT6cYQKIZOxp35FQ== + ob1@0.80.6: version "0.80.6" resolved "https://registry.yarnpkg.com/ob1/-/ob1-0.80.6.tgz#61d7881f458333ed2a73b90cea4aa62f8ca9e045" @@ -14805,7 +14799,7 @@ object-visit@^1.0.0: dependencies: isobject "^3.0.0" -object.assign@^4.1.4, object.assign@^4.1.5: +object.assign@^4.1.2, object.assign@^4.1.4, object.assign@^4.1.5: version "4.1.5" resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.5.tgz#3a833f9ab7fdb80fc9e8d2300c803d216d8fdbb0" integrity sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ== @@ -15284,6 +15278,13 @@ parse5@^6.0.0: resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b" integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== +parse5@^7.0.0, parse5@^7.1.1: + version "7.1.2" + resolved "https://registry.yarnpkg.com/parse5/-/parse5-7.1.2.tgz#0736bebbfd77793823240a23b7fc5e010b7f8e32" + integrity sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw== + dependencies: + entities "^4.4.0" + parseurl@~1.3.2, parseurl@~1.3.3: version "1.3.3" resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" @@ -15376,14 +15377,6 @@ path-parse@^1.0.5, path-parse@^1.0.7: resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== -path-scurry@^1.10.1: - version "1.10.1" - resolved "https://registry.yarnpkg.com/path-scurry/-/path-scurry-1.10.1.tgz#9ba6bf5aa8500fe9fd67df4f0d9483b2b0bfc698" - integrity sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ== - dependencies: - lru-cache "^9.1.1 || ^10.0.0" - minipass "^5.0.0 || ^6.0.2 || ^7.0.0" - path-to-regexp@0.1.7: version "0.1.7" resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" @@ -15683,15 +15676,6 @@ pretty-format@^26.0.0, pretty-format@^26.5.2, pretty-format@^26.6.2: ansi-styles "^4.0.0" react-is "^17.0.1" -pretty-format@^27.5.1: - version "27.5.1" - resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-27.5.1.tgz#2181879fdea51a7a5851fb39d920faa63f01d88e" - integrity sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ== - dependencies: - ansi-regex "^5.0.1" - ansi-styles "^5.0.0" - react-is "^17.0.1" - pretty-format@^29.0.0, pretty-format@^29.7.0: version "29.7.0" resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-29.7.0.tgz#ca42c758310f365bfa71a0bda0a807160b776812" @@ -15861,6 +15845,11 @@ pseudomap@^1.0.2: resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3" integrity sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ== +psl@^1.1.33: + version "1.9.0" + resolved "https://registry.yarnpkg.com/psl/-/psl-1.9.0.tgz#d0df2a137f00794565fcaf3b2c00cd09f8d5a5a7" + integrity sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag== + public-encrypt@^4.0.0: version "4.0.3" resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.3.tgz#4fcc9d77a07e48ba7527e7cbe0de33d0701331e0" @@ -16055,13 +16044,6 @@ rc@^1.2.7, rc@~1.2.7: minimist "^1.2.0" strip-json-comments "~2.0.1" -react-16-node-hanging-test-fix@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/react-16-node-hanging-test-fix/-/react-16-node-hanging-test-fix-1.0.0.tgz#9fef3f7d983789d64971311d3cd17116849a56b3" - integrity sha512-D22iNNa+0MuMPA49nZ5ILBHiJ7h9PTeUUuZee38pFSEWlHOYnHEWzUjOlYjEo6Ji+axHrRnT+y1QRIJOcIcj4w== - dependencies: - semver "^7.3.4" - react-colorful@^5.1.2: version "5.6.1" resolved "https://registry.yarnpkg.com/react-colorful/-/react-colorful-5.6.1.tgz#7dc2aed2d7c72fac89694e834d179e32f3da563b" @@ -16126,13 +16108,13 @@ react-docgen@^5.0.0: node-dir "^0.1.10" strip-indent "^3.0.0" -react-dom@18.1.0: - version "18.1.0" - resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.1.0.tgz#7f6dd84b706408adde05e1df575b3a024d7e8a2f" - integrity sha512-fU1Txz7Budmvamp7bshe4Zi32d0ll7ect+ccxNu9FlObT605GOEB8BfO4tmRJ39R5Zj831VCpvQ05QPBW5yb+w== +react-dom@^18.2.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.2.0.tgz#22aaf38708db2674ed9ada224ca4aa708d821e3d" + integrity sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g== dependencies: loose-envify "^1.1.0" - scheduler "^0.22.0" + scheduler "^0.23.0" react-draggable@^4.4.3: version "4.4.6" @@ -16180,7 +16162,7 @@ react-hook-form@7.34.2: resolved "https://registry.yarnpkg.com/react-hook-form/-/react-hook-form-7.34.2.tgz#9ac6d1a309a7c4aaa369d1269357a70e9e9bf4de" integrity sha512-1lYWbEqr0GW7HHUjMScXMidGvV0BE2RJV3ap2BL7G0EJirkqpccTaawbsvBO8GZaB3JjCeFBEbnEWI1P8ZoLRQ== -"react-is@^16.12.0 || ^17.0.0 || ^18.0.0", react-is@^18.0.0, react-is@^18.1.0, react-is@^18.2.0: +"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== @@ -16373,12 +16355,11 @@ react-native-orientation-locker@1.1.8: resolved "https://registry.yarnpkg.com/react-native-orientation-locker/-/react-native-orientation-locker-1.1.8.tgz#45d1c9e002496b8d286ec8932d6e3e7d341f9c85" integrity sha512-+Vd7x6O/3zGqYIMXpeDlaw3ma074Dtnocm8ryT9v5SvaiEcWSzII4frPgXaUcc/MiCq4OWZ1JtVoyw75mdomQw== -react-native-picker-select@8.0.4: - version "8.0.4" - resolved "https://registry.yarnpkg.com/react-native-picker-select/-/react-native-picker-select-8.0.4.tgz#3f7f1f42df69b06e7d2c10338288332a6c40fd10" - integrity sha512-orBjPIwBkV5oipyVw263YNMI56f6Kj3p/ejabZoCYYNSG3AiLVVhC2RqsxMgDA7IayyURAW+AlV+mDJyVqLBkg== +react-native-picker-select@9.0.1: + version "9.0.1" + resolved "https://registry.yarnpkg.com/react-native-picker-select/-/react-native-picker-select-9.0.1.tgz#af454433061a18b7307a725fc045c05ad494e300" + integrity sha512-iIhb82OSH1vqB/HoipvbuX3RCzmeaQmIASlaRbv6X8imNjzh1DH/LaKoF4+DAZJLT0iX7QG79vpwZu8wjWap3Q== dependencies: - "@react-native-picker/picker" "^1.8.3" lodash.isequal "^4.5.0" react-native-platform-touchable@1.1.1: @@ -16667,15 +16648,6 @@ react-test-renderer@18.2.0: react-shallow-renderer "^16.13.1" scheduler "^0.20.2" -react-test-renderer@~18.1.0: - version "18.1.0" - resolved "https://registry.yarnpkg.com/react-test-renderer/-/react-test-renderer-18.1.0.tgz#35b75754834cf9ab517b6813db94aee0a6b545c3" - integrity sha512-OfuueprJFW7h69GN+kr4Ywin7stcuqaYAt1g7airM5cUgP0BoF5G5CXsPGmXeDeEkncb2fqYNECO4y18sSqphg== - dependencies: - react-is "^18.1.0" - react-shallow-renderer "^16.15.0" - scheduler "^0.22.0" - react-textarea-autosize@^8.3.0: version "8.5.3" resolved "https://registry.yarnpkg.com/react-textarea-autosize/-/react-textarea-autosize-8.5.3.tgz#d1e9fe760178413891484847d3378706052dd409" @@ -16897,7 +16869,7 @@ regex-not@^1.0.0, regex-not@^1.0.2: extend-shallow "^3.0.2" safe-regex "^1.1.0" -regexp.prototype.flags@^1.5.0, regexp.prototype.flags@^1.5.2: +regexp.prototype.flags@^1.4.1, regexp.prototype.flags@^1.5.2: version "1.5.2" resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz#138f644a3350f981a858c44f6bb1a61ff59be334" integrity sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw== @@ -16907,18 +16879,6 @@ regexp.prototype.flags@^1.5.0, regexp.prototype.flags@^1.5.2: es-errors "^1.3.0" set-function-name "^2.0.1" -regexpu-core@^5.0.1: - version "5.3.2" - resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.3.2.tgz#11a2b06884f3527aec3e93dbbf4a3b958a95546b" - integrity sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ== - dependencies: - "@babel/regjsgen" "^0.8.0" - regenerate "^1.4.2" - regenerate-unicode-properties "^10.1.0" - regjsparser "^0.9.1" - unicode-match-property-ecmascript "^2.0.0" - unicode-match-property-value-ecmascript "^2.1.0" - regexpu-core@^5.1.0: version "5.1.0" resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.1.0.tgz#2f8504c3fd0ebe11215783a41541e21c79942c6d" @@ -16931,6 +16891,18 @@ regexpu-core@^5.1.0: unicode-match-property-ecmascript "^2.0.0" unicode-match-property-value-ecmascript "^2.0.0" +regexpu-core@^5.3.1: + version "5.3.2" + resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.3.2.tgz#11a2b06884f3527aec3e93dbbf4a3b958a95546b" + integrity sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ== + dependencies: + "@babel/regjsgen" "^0.8.0" + regenerate "^1.4.2" + regenerate-unicode-properties "^10.1.0" + regjsparser "^0.9.1" + unicode-match-property-ecmascript "^2.0.0" + unicode-match-property-value-ecmascript "^2.1.0" + regjsgen@^0.6.0: version "0.6.0" resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.6.0.tgz#83414c5354afd7d6627b16af5f10f41c4e71808d" @@ -17295,7 +17267,7 @@ safe-regex@^1.1.0: dependencies: ret "~0.1.10" -"safer-buffer@>= 2.1.2 < 3": +"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0": version "2.1.2" resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== @@ -17327,6 +17299,13 @@ sax@>=0.6.0: resolved "https://registry.yarnpkg.com/sax/-/sax-1.3.0.tgz#a5dbe77db3be05c9d1ee7785dbd3ea9de51593d0" integrity sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA== +saxes@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/saxes/-/saxes-6.0.0.tgz#fe5b4a4768df4f14a201b1ba6a65c1f3d9988cc5" + integrity sha512-xAg7SOnEhrm5zI3puOOKyy1OMcMlIJZYNJY7xLBwSze0UjhPLnWfj2GF2EpT0jmzaJKIWKHLsaSSajf35bcYnA== + dependencies: + xmlchars "^2.2.0" + scheduler@0.24.0-canary-efb381bbf-20230505: version "0.24.0-canary-efb381bbf-20230505" resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.24.0-canary-efb381bbf-20230505.tgz#5dddc60e29f91cd7f8b983d7ce4a99c2202d178f" @@ -17342,13 +17321,6 @@ scheduler@^0.20.2: loose-envify "^1.1.0" object-assign "^4.1.1" -scheduler@^0.22.0: - version "0.22.0" - resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.22.0.tgz#83a5d63594edf074add9a7198b1bae76c3db01b8" - integrity sha512-6QAm1BgQI88NPYymgGQLCZgvep4FyePDWFpXVK+zNSUgHwlqpJy8VEh8Et0KxTACS4VWwMousBElAZOH9nkkoQ== - dependencies: - loose-envify "^1.1.0" - scheduler@^0.23.0: version "0.23.0" resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.0.tgz#ba8041afc3d30eb206a487b6b384002e4e61fdfe" @@ -17547,7 +17519,7 @@ set-function-length@^1.2.1: gopd "^1.0.1" has-property-descriptors "^1.0.2" -set-function-name@^2.0.0, set-function-name@^2.0.1, set-function-name@^2.0.2: +set-function-name@^2.0.1, set-function-name@^2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/set-function-name/-/set-function-name-2.0.2.tgz#16a705c5a0dc2f5e638ca96d8a8cd4e1c2b90985" integrity sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ== @@ -17674,11 +17646,6 @@ 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== -signal-exit@^4.0.1: - version "4.1.0" - resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-4.1.0.tgz#952188c1cbd546070e2dd20d0f41c0ae0530cb04" - integrity sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw== - simple-concat@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/simple-concat/-/simple-concat-1.0.1.tgz#f46976082ba35c2263f1c8ab5edfe26c41c9552f" @@ -17724,6 +17691,11 @@ slash@^3.0.0: resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== +slash@^5.0.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-5.1.0.tgz#be3adddcdf09ac38eebe8dcdc7b1a57a75b095ce" + integrity sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg== + slice-ansi@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-2.1.0.tgz#cacd7693461a637a5788d92a7dd4fba068e81636" @@ -18115,20 +18087,19 @@ string-length@^4.0.1: char-regex "^1.0.2" strip-ansi "^6.0.0" +string-length@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/string-length/-/string-length-5.0.1.tgz#3d647f497b6e8e8d41e422f7e0b23bc536c8381e" + integrity sha512-9Ep08KAMUn0OadnVaBuRdE2l615CQ508kr0XMadjClfYpdCyvrbFp6Taebo8yyxokQ4viUd/xPPUA4FGgUa0ow== + dependencies: + char-regex "^2.0.0" + strip-ansi "^7.0.1" + string-natural-compare@^3.0.1: version "3.0.1" resolved "https://registry.yarnpkg.com/string-natural-compare/-/string-natural-compare-3.0.1.tgz#7a42d58474454963759e8e8b7ae63d71c1e7fdf4" integrity sha512-n3sPwynL1nwKi3WJ6AIsClwBMa0zTi54fn2oLU6ndfTSIO05xaznjSf15PcBZU6FNWbmN5Q6cxT4V5hGvB4taw== -"string-width-cjs@npm:string-width@^4.2.0", "string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: - version "4.2.3" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" - integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== - dependencies: - emoji-regex "^8.0.0" - is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.1" - string-width@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" @@ -18138,14 +18109,14 @@ string-width@^1.0.1: is-fullwidth-code-point "^1.0.0" strip-ansi "^3.0.0" -string-width@^5.0.1, string-width@^5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-5.1.2.tgz#14f8daec6d81e7221d2a357e668cab73bdbca794" - integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== +"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: + version "4.2.3" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" + integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== dependencies: - eastasianwidth "^0.2.0" - emoji-regex "^9.2.2" - strip-ansi "^7.0.1" + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.1" "string.prototype.matchall@^4.0.0 || ^3.0.1": version "4.0.7" @@ -18271,13 +18242,6 @@ stringify-object@^3.3.0: is-obj "^1.0.1" is-regexp "^1.0.0" -"strip-ansi-cjs@npm:strip-ansi@^6.0.1", strip-ansi@^6.0.0, strip-ansi@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" - integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== - dependencies: - ansi-regex "^5.0.1" - strip-ansi@6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" @@ -18299,6 +18263,13 @@ strip-ansi@^5.0.0, strip-ansi@^5.2.0: dependencies: ansi-regex "^4.1.0" +strip-ansi@^6.0.0, strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + strip-ansi@^7.0.1: version "7.1.0" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.1.0.tgz#d5b6568ca689d8561370b0707685d22434faff45" @@ -18386,19 +18357,6 @@ sucrase@3.34.0: pirates "^4.0.1" ts-interface-checker "^0.1.9" -sucrase@^3.20.0: - version "3.35.0" - resolved "https://registry.yarnpkg.com/sucrase/-/sucrase-3.35.0.tgz#57f17a3d7e19b36d8995f06679d121be914ae263" - integrity sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA== - dependencies: - "@jridgewell/gen-mapping" "^0.3.2" - commander "^4.0.0" - glob "^10.3.10" - lines-and-columns "^1.1.6" - mz "^2.7.0" - pirates "^4.0.1" - ts-interface-checker "^0.1.9" - sudo-prompt@9.1.1: version "9.1.1" resolved "https://registry.yarnpkg.com/sudo-prompt/-/sudo-prompt-9.1.1.tgz#73853d729770392caec029e2470db9c221754db0" @@ -18461,6 +18419,11 @@ svg-arc-to-cubic-bezier@^3.0.0: resolved "https://registry.yarnpkg.com/svg-arc-to-cubic-bezier/-/svg-arc-to-cubic-bezier-3.2.0.tgz#390c450035ae1c4a0104d90650304c3bc814abe6" integrity sha512-djbJ/vZKZO+gPoSDThGNpKDO+o+bAeA4XQKovvkNCqnIS2t+S4qnLAGQhyyrulhCFRl1WWzAp0wUDV8PpTVU3g== +symbol-tree@^3.2.4: + version "3.2.4" + resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" + integrity sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw== + symbol.prototype.description@^1.0.0: version "1.0.6" resolved "https://registry.yarnpkg.com/symbol.prototype.description/-/symbol.prototype.description-1.0.6.tgz#abd49d4e2d8fcd2bf8e4d6ecec735ddabd271b67" @@ -18867,6 +18830,23 @@ toposort@^2.0.2: resolved "https://registry.yarnpkg.com/toposort/-/toposort-2.0.2.tgz#ae21768175d1559d48bef35420b2f4962f09c330" integrity sha512-0a5EOkAUp8D4moMi2W8ZF8jcga7BgZd91O/yabJCFY8az+XSzeGyTKs0Aoo897iV1Nj6guFq8orWDS96z91oGg== +tough-cookie@^4.1.2: + version "4.1.3" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.1.3.tgz#97b9adb0728b42280aa3d814b6b999b2ff0318bf" + integrity sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw== + dependencies: + psl "^1.1.33" + punycode "^2.1.1" + universalify "^0.2.0" + url-parse "^1.5.3" + +tr46@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-3.0.0.tgz#555c4e297a950617e8eeddef633c87d4d9d6cbf9" + integrity sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA== + dependencies: + punycode "^2.1.1" + tr46@~0.0.3: version "0.0.3" resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" @@ -19154,7 +19134,7 @@ typical@^5.2.0: resolved "https://registry.yarnpkg.com/typical/-/typical-5.2.0.tgz#4daaac4f2b5315460804f0acf6cb69c52bb93066" integrity sha512-dvdQgNDNJo+8B2uBQoqdb11eUCE1JQXhvjC/CZtgvZseVd5TYMXnq0+vuUemXbd/Se29cTaUuPX3YIc2xgbvIg== -ua-parser-js@1.0.2, ua-parser-js@^1.0.35: +ua-parser-js@1.0.2, ua-parser-js@^0.7.30, ua-parser-js@^1.0.35: version "1.0.2" resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-1.0.2.tgz#e2976c34dbfb30b15d2c300b2a53eac87c57a775" integrity sha512-00y/AXhx0/SsnI51fTc0rLRmafiGOM4/O+ny10Ps7f+j/b8p/ZY11ytMgznXkOVo4GQ+KwQG5UQLkLGirsACRg== @@ -19357,6 +19337,11 @@ universalify@^0.1.0: resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== +universalify@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.2.0.tgz#6451760566fa857534745ab1dde952d1b1761be0" + integrity sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg== + universalify@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/universalify/-/universalify-1.0.0.tgz#b61a1da173e8435b2fe3c67d29b9adf8594bd16d" @@ -19424,7 +19409,7 @@ url-loader@^4.1.1: mime-types "^2.1.27" schema-utils "^3.0.0" -url-parse@1.5.10, url-parse@^1.2.0: +url-parse@1.5.10, url-parse@^1.2.0, url-parse@^1.5.3: version "1.5.10" resolved "https://registry.yarnpkg.com/url-parse/-/url-parse-1.5.10.tgz#9d3c2f736c1d75dd3bd2be507dcc111f1e2ea9c1" integrity sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ== @@ -19638,6 +19623,13 @@ vm-browserify@^1.0.1: resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-1.1.2.tgz#78641c488b8e6ca91a75f511e7a3b32a86e5dda0" integrity sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ== +w3c-xmlserializer@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-4.0.0.tgz#aebdc84920d806222936e3cdce408e32488a3073" + integrity sha512-d+BFHzbiCx6zGfz0HyQ6Rg69w9k19nviJspaj4yNscGjrHu94sVP+aRm75yEbCh+r2/yR+7q6hux9LVtbuTGBw== + dependencies: + xml-name-validator "^4.0.0" + walker@^1.0.7, walker@^1.0.8, walker@~1.0.5: version "1.0.8" resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.8.tgz#bd498db477afe573dc04185f011d3ab8a8d7653f" @@ -19697,6 +19689,11 @@ webidl-conversions@^5.0.0: resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-5.0.0.tgz#ae59c8a00b121543a2acc65c0434f57b0fc11aff" integrity sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA== +webidl-conversions@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-7.0.0.tgz#256b4e1882be7debbf01d05f0aa2039778ea080a" + integrity sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g== + webpack-dev-middleware@^3.7.3: version "3.7.3" resolved "https://registry.yarnpkg.com/webpack-dev-middleware/-/webpack-dev-middleware-3.7.3.tgz#0639372b143262e2b84ab95d3b91a7597061c2c5" @@ -19774,11 +19771,23 @@ webpack@4: watchpack "^1.7.4" webpack-sources "^1.4.1" -whatwg-fetch@^3.0.0: +whatwg-encoding@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-2.0.0.tgz#e7635f597fd87020858626805a2729fa7698ac53" + integrity sha512-p41ogyeMUrw3jWclHWTQg1k05DSVXPLcVxRTYsXUk+ZooOCZLcoYgPZ/HL/D/N+uQPOtcp1me1WhBEaX02mhWg== + dependencies: + iconv-lite "0.6.3" + +whatwg-fetch@>=0.10.0, whatwg-fetch@^3.0.0: version "3.6.20" resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.6.20.tgz#580ce6d791facec91d37c72890995a0b48d31c70" integrity sha512-EqhiFU6daOA8kpjOWTL0olhVOF3i7OrFzSYiGsEMB8GcXS+RrzauAERX65xMeNWVqxA6HXH2m69Z9LaKKdisfg== +whatwg-mimetype@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz#5fa1a7623867ff1af6ca3dc72ad6b8a4208beba7" + integrity sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q== + whatwg-url-without-unicode@8.0.0-3: version "8.0.0-3" resolved "https://registry.yarnpkg.com/whatwg-url-without-unicode/-/whatwg-url-without-unicode-8.0.0-3.tgz#ab6df4bf6caaa6c85a59f6e82c026151d4bb376b" @@ -19788,6 +19797,14 @@ whatwg-url-without-unicode@8.0.0-3: punycode "^2.1.1" webidl-conversions "^5.0.0" +whatwg-url@^11.0.0: + version "11.0.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-11.0.0.tgz#0a849eebb5faf2119b901bb76fd795c2848d4018" + integrity sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ== + dependencies: + tr46 "^3.0.0" + webidl-conversions "^7.0.0" + whatwg-url@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" @@ -19939,15 +19956,6 @@ worker-rpc@^0.1.0: dependencies: microevent.ts "~0.1.1" -"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0", wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== - dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" - wrap-ansi@^6.2.0: version "6.2.0" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-6.2.0.tgz#e9393ba07102e6c91a3b221478f0257cd2856e53" @@ -19957,14 +19965,14 @@ wrap-ansi@^6.2.0: string-width "^4.1.0" strip-ansi "^6.0.0" -wrap-ansi@^8.1.0: - version "8.1.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-8.1.0.tgz#56dc22368ee570face1b49819975d9b9a5ead214" - integrity sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ== +wrap-ansi@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" + integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== dependencies: - ansi-styles "^6.1.0" - string-width "^5.0.1" - strip-ansi "^7.0.1" + ansi-styles "^4.0.0" + string-width "^4.1.0" + strip-ansi "^6.0.0" wrappy@1: version "1.0.2" @@ -20019,7 +20027,7 @@ ws@^7, ws@^7.0.0, ws@^7.5.1: resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.9.tgz#54fa7db29f4c7cec68b1ddd3a89de099942bb591" integrity sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q== -ws@^8.12.1: +ws@^8.11.0, ws@^8.12.1: version "8.16.0" resolved "https://registry.yarnpkg.com/ws/-/ws-8.16.0.tgz#d1cd774f36fbc07165066a60e40323eab6446fd4" integrity sha512-HS0c//TP7Ina87TfiPUz1rQzMhHrl/SG2guqRcTOIUYD2q8uhUdNHZYJUaQ8aTGPzCh+c6oawMKW35nFl1dxyQ== @@ -20032,13 +20040,10 @@ xcode@^3.0.1: simple-plist "^1.1.0" uuid "^7.0.3" -xml2js@0.4.23: - version "0.4.23" - resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.23.tgz#a0c69516752421eb2ac758ee4d4ccf58843eac66" - integrity sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug== - dependencies: - sax ">=0.6.0" - xmlbuilder "~11.0.0" +xml-name-validator@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-4.0.0.tgz#79a006e2e63149a8600f15430f0a4725d1524835" + integrity sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw== xml2js@0.6.0: version "0.6.0" @@ -20068,6 +20073,11 @@ xmlbuilder@~11.0.0: resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-11.0.1.tgz#be9bae1c8a046e76b31127726347d0ad7002beb3" integrity sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA== +xmlchars@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" + integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw== + xmldom-sre@0.1.31: version "0.1.31" resolved "https://registry.yarnpkg.com/xmldom-sre/-/xmldom-sre-0.1.31.tgz#10860d5bab2c603144597d04bf2c4980e98067f4"