From 7295a1ac3d420454f56e8637356d5cf4e5b478a7 Mon Sep 17 00:00:00 2001 From: Nick Gerleman Date: Wed, 1 Mar 2023 11:36:22 -0800 Subject: [PATCH] Enforce compatibility with `exactOptionalPropertyTypes` (#36345) Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/36345 `exactOptionalPropertyTypes` is a TypeScript 4.4+ option set by users which changes behavior of optional properties, to disable accepting explicit `undefined`. This is not enabled when using `--strict`, and is stricter than Flow, leading to most of the typings having an `| undefined` unique to TypeScript (added with https://github.com/DefinitelyTyped/DefinitelyTyped/commit/694c663a9486dbe7794d5eb894a691ee9ded318a). We have not always followed this (I have myself previously assumed the two are equivalent). We can enforce that the convention is followed with a plugin `eslint-plugin-redundant-undefined`. This forces us to declare that every optional property accepts an explicit undefined (which Flow would allow). Alternatively, if we do not want to support this, we can enable the existing dtslint rule `no-redundant-undefined`. Changelog: [General][Fixed] - Enforce compatibility with `exactOptionalPropertyTypes` Differential Revision: D43700862 fbshipit-source-id: 2dd18244145bd95935effeb1476a2ab010f2a32e --- .eslintrc.js | 10 ++++ Libraries/Alert/Alert.d.ts | 4 +- Libraries/Animated/Animated.d.ts | 2 +- .../AccessibilityInfo/AccessibilityInfo.d.ts | 2 +- Libraries/Components/Pressable/Pressable.d.ts | 2 +- .../Components/ScrollView/ScrollView.d.ts | 4 +- .../TextInput/InputAccessoryView.d.ts | 2 +- .../Touchable/TouchableWithoutFeedback.d.ts | 2 +- .../Components/View/ViewAccessibility.d.ts | 10 ++-- Libraries/Components/View/ViewPropTypes.d.ts | 2 +- Libraries/Image/Image.d.ts | 4 +- Libraries/Lists/FlatList.d.ts | 4 +- Libraries/Lists/SectionList.d.ts | 2 +- Libraries/Text/Text.d.ts | 2 +- .../Utilities/createPerformanceLogger.d.ts | 8 +-- .../src/CodegenSchema.d.ts | 20 +++---- .../src/SchemaValidator.d.ts | 2 +- .../src/parsers/parser.d.ts | 4 +- .../src/parsers/schema/index.d.ts | 2 +- .../SectionList/SectionList-scrollable.js | 2 - .../Lists/VirtualizedList.d.ts | 6 +- repo-config/package.json | 1 + .../__typetests__/fabric-component-sample.ts | 20 +++---- types/modules/Codegen.d.ts | 8 +-- types/modules/globals.d.ts | 20 ++++--- yarn.lock | 60 +++++++++++++++++++ 26 files changed, 138 insertions(+), 67 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index c0548760156568..90f6b7ec578e35 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -91,5 +91,15 @@ module.exports = { 'react/self-closing-comp': 'off', }, }, + { + files: ['**/*.d.ts'], + plugins: ['redundant-undefined'], + rules: { + 'redundant-undefined/redundant-undefined': [ + 'error', + {followExactOptionalPropertyTypes: true}, + ], + }, + }, ], }; diff --git a/Libraries/Alert/Alert.d.ts b/Libraries/Alert/Alert.d.ts index 788f1f5ae72e42..b9bea342ac9e54 100644 --- a/Libraries/Alert/Alert.d.ts +++ b/Libraries/Alert/Alert.d.ts @@ -13,14 +13,14 @@ export interface AlertButton { text?: string | undefined; onPress?: ((value?: string) => void) | undefined; - isPreferred?: boolean; + isPreferred?: boolean | undefined; style?: 'default' | 'cancel' | 'destructive' | undefined; } interface AlertOptions { /** @platform android */ cancelable?: boolean | undefined; - userInterfaceStyle?: 'unspecified' | 'light' | 'dark'; + userInterfaceStyle?: 'unspecified' | 'light' | 'dark' | undefined; /** @platform android */ onDismiss?: (() => void) | undefined; } diff --git a/Libraries/Animated/Animated.d.ts b/Libraries/Animated/Animated.d.ts index fb2aeafc5eaca7..39a5b1d2b039ba 100644 --- a/Libraries/Animated/Animated.d.ts +++ b/Libraries/Animated/Animated.d.ts @@ -579,7 +579,7 @@ export namespace Animated { extends React.FC>> {} export type AnimatedComponentOptions = { - collapsable?: boolean; + collapsable?: boolean | undefined; }; /** diff --git a/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts b/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts index 63912451de65b3..f416c27389cb2e 100644 --- a/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +++ b/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts @@ -137,7 +137,7 @@ export interface AccessibilityInfoStatic { */ announceForAccessibilityWithOptions( announcement: string, - options: {queue?: boolean}, + options: {queue?: boolean | undefined}, ): void; /** diff --git a/Libraries/Components/Pressable/Pressable.d.ts b/Libraries/Components/Pressable/Pressable.d.ts index 640e41261110f9..cb0797ff34735e 100644 --- a/Libraries/Components/Pressable/Pressable.d.ts +++ b/Libraries/Components/Pressable/Pressable.d.ts @@ -158,7 +158,7 @@ export interface PressableProps /** * Duration (in milliseconds) to wait after press down before calling onPressIn. */ - unstable_pressDelay?: number; + unstable_pressDelay?: number | undefined; } // TODO use React.AbstractComponent when available diff --git a/Libraries/Components/ScrollView/ScrollView.d.ts b/Libraries/Components/ScrollView/ScrollView.d.ts index 3d1d94fa8418d4..109a3e0425e202 100644 --- a/Libraries/Components/ScrollView/ScrollView.d.ts +++ b/Libraries/Components/ScrollView/ScrollView.d.ts @@ -730,7 +730,7 @@ export interface ScrollViewProps /** * When true, Sticky header is hidden when scrolling down, and dock at the top when scrolling up. */ - stickyHeaderHiddenOnScroll?: boolean; + stickyHeaderHiddenOnScroll?: boolean | undefined; /** * Style @@ -841,7 +841,7 @@ export class ScrollView extends ScrollViewBase { * The options object has an animated prop, that enables the scrolling animation or not. * The animated prop defaults to true */ - scrollToEnd(options?: {animated?: boolean}): void; + scrollToEnd(options?: {animated?: boolean | undefined}): void; /** * Displays the scroll indicators momentarily. diff --git a/Libraries/Components/TextInput/InputAccessoryView.d.ts b/Libraries/Components/TextInput/InputAccessoryView.d.ts index 00edf5aaf8adae..d64911fcaf4a4e 100644 --- a/Libraries/Components/TextInput/InputAccessoryView.d.ts +++ b/Libraries/Components/TextInput/InputAccessoryView.d.ts @@ -23,7 +23,7 @@ export class InputAccessoryView extends React.Component export interface InputAccessoryViewProps { backgroundColor?: ColorValue | undefined; - children?: React.ReactNode; + children?: React.ReactNode | undefined; /** * An ID which is used to associate this InputAccessoryView to specified TextInput(s). diff --git a/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts b/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts index aa5e14b7e2705d..e0146fc31b356c 100644 --- a/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts +++ b/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts @@ -40,7 +40,7 @@ export interface TouchableWithoutFeedbackProps extends TouchableWithoutFeedbackPropsIOS, TouchableWithoutFeedbackPropsAndroid, AccessibilityProps { - children?: React.ReactNode; + children?: React.ReactNode | undefined; /** * Delay in ms, from onPressIn, before onLongPress is called. diff --git a/Libraries/Components/View/ViewAccessibility.d.ts b/Libraries/Components/View/ViewAccessibility.d.ts index b06d1cbd450420..86f08bf88fa438 100644 --- a/Libraries/Components/View/ViewAccessibility.d.ts +++ b/Libraries/Components/View/ViewAccessibility.d.ts @@ -75,10 +75,10 @@ export interface AccessibilityProps */ accessibilityValue?: AccessibilityValue | undefined; - 'aria-valuemax'?: AccessibilityValue['max']; - 'aria-valuemin'?: AccessibilityValue['min']; - 'aria-valuenow'?: AccessibilityValue['now']; - 'aria-valuetext'?: AccessibilityValue['text']; + 'aria-valuemax'?: AccessibilityValue['max'] | undefined; + 'aria-valuemin'?: AccessibilityValue['min'] | undefined; + 'aria-valuenow'?: AccessibilityValue['now'] | undefined; + 'aria-valuetext'?: AccessibilityValue['text'] | undefined; /** * When `accessible` is true, the system will try to invoke this function when the user performs an accessibility custom action. */ @@ -105,7 +105,7 @@ export interface AccessibilityProps /** * Indicates to accessibility services to treat UI component like a specific role. */ - role?: Role; + role?: Role | undefined; } export type AccessibilityActionInfo = Readonly<{ diff --git a/Libraries/Components/View/ViewPropTypes.d.ts b/Libraries/Components/View/ViewPropTypes.d.ts index b7da46fe4bc5f2..53f5e82c34149b 100644 --- a/Libraries/Components/View/ViewPropTypes.d.ts +++ b/Libraries/Components/View/ViewPropTypes.d.ts @@ -173,7 +173,7 @@ export interface ViewProps Touchable, PointerEvents, AccessibilityProps { - children?: React.ReactNode; + children?: React.ReactNode | undefined; /** * This defines how far a touch event can start away from the view. * Typical interface guidelines recommend touch targets that are at least diff --git a/Libraries/Image/Image.d.ts b/Libraries/Image/Image.d.ts index e650c11fd2aca2..20b3808533f850 100644 --- a/Libraries/Image/Image.d.ts +++ b/Libraries/Image/Image.d.ts @@ -290,7 +290,7 @@ export interface ImagePropsBase * * See https://reactnative.dev/docs/image#crossorigin */ - crossOrigin?: 'anonymous' | 'use-credentials'; + crossOrigin?: 'anonymous' | 'use-credentials' | undefined; /** * Changes the color of all the non-transparent pixels to the tintColor. @@ -359,7 +359,7 @@ export class Image extends ImageBase { } export interface ImageBackgroundProps extends ImagePropsBase { - children?: React.ReactNode; + children?: React.ReactNode | undefined; imageStyle?: StyleProp | undefined; style?: StyleProp | undefined; imageRef?(image: Image): void; diff --git a/Libraries/Lists/FlatList.d.ts b/Libraries/Lists/FlatList.d.ts index d3e350c01971a7..62c1781da4beb3 100644 --- a/Libraries/Lists/FlatList.d.ts +++ b/Libraries/Lists/FlatList.d.ts @@ -50,7 +50,7 @@ export interface FlatListProps extends VirtualizedListProps { * If any of your `renderItem`, Header, Footer, etc. functions depend on anything outside of the `data` prop, * stick it here and treat it immutably. */ - extraData?: any; + extraData?: any | undefined; /** * `getItemLayout` is an optional optimization that lets us skip measurement of dynamic @@ -144,7 +144,7 @@ export interface FlatListProps extends VirtualizedListProps { /** * See `ViewabilityHelper` for flow type and further documentation. */ - viewabilityConfig?: any; + viewabilityConfig?: any | undefined; /** * Note: may have bugs (missing content) in some circumstances - use at your own risk. diff --git a/Libraries/Lists/SectionList.d.ts b/Libraries/Lists/SectionList.d.ts index 0e2313702d6cca..396092286b05d1 100644 --- a/Libraries/Lists/SectionList.d.ts +++ b/Libraries/Lists/SectionList.d.ts @@ -75,7 +75,7 @@ export interface SectionListProps * If any of your `renderItem`, Header, Footer, etc. functions depend on anything outside of the `data` prop, * stick it here and treat it immutably. */ - extraData?: any; + extraData?: any | undefined; /** * `getItemLayout` is an optional optimization that lets us skip measurement of dynamic diff --git a/Libraries/Text/Text.d.ts b/Libraries/Text/Text.d.ts index 8d2b93300fd413..a52f4467e1babe 100644 --- a/Libraries/Text/Text.d.ts +++ b/Libraries/Text/Text.d.ts @@ -107,7 +107,7 @@ export interface TextProps */ allowFontScaling?: boolean | undefined; - children?: React.ReactNode; + children?: React.ReactNode | undefined; /** * This can be one of the following values: diff --git a/Libraries/Utilities/createPerformanceLogger.d.ts b/Libraries/Utilities/createPerformanceLogger.d.ts index 57b590b99da4d1..d5ef6227243cfb 100644 --- a/Libraries/Utilities/createPerformanceLogger.d.ts +++ b/Libraries/Utilities/createPerformanceLogger.d.ts @@ -9,10 +9,10 @@ export type Timespan = { startTime: number; - endTime?: number; - totalTime?: number; - startExtras?: Extras; - endExtras?: Extras; + endTime?: number | undefined; + totalTime?: number | undefined; + startExtras?: Extras | undefined; + endExtras?: Extras | undefined; }; // Extra values should be serializable primitives diff --git a/packages/react-native-codegen/src/CodegenSchema.d.ts b/packages/react-native-codegen/src/CodegenSchema.d.ts index cc12da452933d1..eff7b296186977 100644 --- a/packages/react-native-codegen/src/CodegenSchema.d.ts +++ b/packages/react-native-codegen/src/CodegenSchema.d.ts @@ -47,7 +47,7 @@ export interface VoidTypeAnnotation { export interface ObjectTypeAnnotation { readonly type: 'ObjectTypeAnnotation'; readonly properties: readonly NamedShape[]; - readonly baseTypes?: readonly string[]; + readonly baseTypes?: readonly string[] | undefined; } export interface FunctionTypeAnnotation { @@ -77,10 +77,10 @@ export interface ComponentShape extends OptionsShape { } export interface OptionsShape { - readonly interfaceOnly?: boolean; - readonly paperComponentName?: string; - readonly excludedPlatforms?: readonly PlatformType[]; - readonly paperComponentNameDeprecated?: string; + readonly interfaceOnly?: boolean | undefined; + readonly paperComponentName?: string | undefined; + readonly excludedPlatforms?: readonly PlatformType[] | undefined; + readonly paperComponentNameDeprecated?: string | undefined; } export interface ExtendsPropsShape { @@ -94,10 +94,10 @@ export interface EventTypeShape { | 'direct' | 'bubble'; readonly optional: boolean; - readonly paperTopLevelNameDeprecated?: string; + readonly paperTopLevelNameDeprecated?: string | undefined; readonly typeAnnotation: { readonly type: 'EventTypeAnnotation'; - readonly argument?: ObjectTypeAnnotation; + readonly argument?: ObjectTypeAnnotation | undefined; }; } @@ -211,7 +211,7 @@ export interface NativeModuleSchema { readonly enumMap: NativeModuleEnumMap; readonly spec: NativeModuleSpec; readonly moduleName: string; - readonly excludedPlatforms?: readonly PlatformType[]; + readonly excludedPlatforms?: readonly PlatformType[] | undefined; } export interface NativeModuleSpec { @@ -234,7 +234,7 @@ export type NativeModuleObjectTypeAnnotation = ObjectTypeAnnotation> { readonly type: 'ArrayTypeAnnotation'; - readonly elementType?: T; + readonly elementType?: T | undefined; } export interface NativeModuleStringTypeAnnotation { @@ -294,7 +294,7 @@ export interface NativeModuleTypeAliasTypeAnnotation { export interface NativeModulePromiseTypeAnnotation { readonly type: 'PromiseTypeAnnotation'; - readonly elementType?: Nullable; + readonly elementType?: Nullable | undefined; } export type UnionTypeAnnotationMemberType = diff --git a/packages/react-native-codegen/src/SchemaValidator.d.ts b/packages/react-native-codegen/src/SchemaValidator.d.ts index c5b90a6aa2b058..7fb8125fa8fe63 100644 --- a/packages/react-native-codegen/src/SchemaValidator.d.ts +++ b/packages/react-native-codegen/src/SchemaValidator.d.ts @@ -5,7 +5,7 @@ * LICENSE file in the root directory of this source tree. */ -import type { SchemaType } from "./CodegenSchema"; +import type { SchemaType } from './CodegenSchema'; export declare function getErrors(schema: SchemaType): readonly string[]; export declare function validate(schema: SchemaType): void; diff --git a/packages/react-native-codegen/src/parsers/parser.d.ts b/packages/react-native-codegen/src/parsers/parser.d.ts index 2906c303d51ee9..ae6017a31832d6 100644 --- a/packages/react-native-codegen/src/parsers/parser.d.ts +++ b/packages/react-native-codegen/src/parsers/parser.d.ts @@ -5,8 +5,8 @@ * LICENSE file in the root directory of this source tree. */ -import type { SchemaType } from "../CodegenSchema"; -import type { ParserType } from "./errors"; +import type { SchemaType } from '../CodegenSchema'; +import type { ParserType } from './errors'; // useful members only for downstream export interface Parser { diff --git a/packages/react-native-codegen/src/parsers/schema/index.d.ts b/packages/react-native-codegen/src/parsers/schema/index.d.ts index ccfbef8c54303e..cb298ccc9f15a4 100644 --- a/packages/react-native-codegen/src/parsers/schema/index.d.ts +++ b/packages/react-native-codegen/src/parsers/schema/index.d.ts @@ -5,6 +5,6 @@ * LICENSE file in the root directory of this source tree. */ -import type { SchemaType } from "../../CodegenSchema"; +import type { SchemaType } from '../../CodegenSchema'; export declare function parse(filename: string): SchemaType | undefined; diff --git a/packages/rn-tester/js/examples/SectionList/SectionList-scrollable.js b/packages/rn-tester/js/examples/SectionList/SectionList-scrollable.js index 87099cb9d40527..815eb03bba887b 100644 --- a/packages/rn-tester/js/examples/SectionList/SectionList-scrollable.js +++ b/packages/rn-tester/js/examples/SectionList/SectionList-scrollable.js @@ -281,12 +281,10 @@ export function SectionList_scrollable(Props: { ref={ref} ListHeaderComponent={HeaderComponent} ListFooterComponent={FooterComponent} - // eslint-disable-next-line react/no-unstable-nested-components // $FlowFixMe[missing-local-annot] SectionSeparatorComponent={info => ( )} - // eslint-disable-next-line react/no-unstable-nested-components // $FlowFixMe[missing-local-annot] ItemSeparatorComponent={info => ( diff --git a/packages/virtualized-lists/Lists/VirtualizedList.d.ts b/packages/virtualized-lists/Lists/VirtualizedList.d.ts index a2702d9101e107..f7689d00439393 100644 --- a/packages/virtualized-lists/Lists/VirtualizedList.d.ts +++ b/packages/virtualized-lists/Lists/VirtualizedList.d.ts @@ -23,7 +23,7 @@ export interface ViewToken { key: string; index: number | null; isViewable: boolean; - section?: any; + section?: any | undefined; } export interface ViewabilityConfig { @@ -188,7 +188,7 @@ export interface VirtualizedListWithoutRenderItemProps * The default accessor functions assume this is an Array<{key: string}> but you can override * getItem, getItemCount, and keyExtractor to handle any type of index-based data. */ - data?: any; + data?: any | undefined; /** * `debug` will turn on extra logging and visual overlays to aid with debugging both usage and @@ -208,7 +208,7 @@ export interface VirtualizedListWithoutRenderItemProps * any of your `renderItem`, Header, Footer, etc. functions depend on anything outside of the * `data` prop, stick it here and treat it immutably. */ - extraData?: any; + extraData?: any | undefined; /** * A generic accessor for extracting an item from any sort of data blob. diff --git a/repo-config/package.json b/repo-config/package.json index 7062a336eb7d37..aeb003d3861ec5 100644 --- a/repo-config/package.json +++ b/repo-config/package.json @@ -37,6 +37,7 @@ "eslint-plugin-react": "^7.30.1", "eslint-plugin-react-hooks": "^4.6.0", "eslint-plugin-react-native": "^4.0.0", + "eslint-plugin-redundant-undefined": "^0.4.0", "eslint-plugin-relay": "^1.8.3", "flow-bin": "^0.200.0", "inquirer": "^7.1.0", diff --git a/types/__typetests__/fabric-component-sample.ts b/types/__typetests__/fabric-component-sample.ts index 73d91a6bcee8ee..991727e886e332 100644 --- a/types/__typetests__/fabric-component-sample.ts +++ b/types/__typetests__/fabric-component-sample.ts @@ -27,16 +27,16 @@ type Event = Readonly<{ }>; interface NativeProps extends ViewProps { - string?: string; - number?: number; - boolean?: boolean; - default?: WithDefault<'option1' | 'option2', 'option1'>; - double?: Double; - float?: Float; - int32?: Int32; - unsafeObject?: UnsafeObject; - onBubblingEventHandler?: BubblingEventHandler; - onDirectEventHandler?: DirectEventHandler; + string?: string | undefined; + number?: number | undefined; + boolean?: boolean | undefined; + default?: WithDefault<'option1' | 'option2', 'option1'> | undefined; + double?: Double | undefined; + float?: Float | undefined; + int32?: Int32 | undefined; + unsafeObject?: UnsafeObject | undefined; + onBubblingEventHandler?: BubblingEventHandler | undefined; + onDirectEventHandler?: DirectEventHandler | undefined; } export type SampleViewType = NativeComponentType; diff --git a/types/modules/Codegen.d.ts b/types/modules/Codegen.d.ts index 24de3b099159cc..dd7ddcadf17ee0 100644 --- a/types/modules/Codegen.d.ts +++ b/types/modules/Codegen.d.ts @@ -23,10 +23,10 @@ declare module 'react-native/Libraries/Utilities/codegenNativeComponent' { import type {HostComponent} from 'react-native'; export interface Options { - readonly interfaceOnly?: boolean; - readonly paperComponentName?: string; - readonly paperComponentNameDeprecated?: string; - readonly excludedPlatforms?: ReadonlyArray<'iOS' | 'android'>; + readonly interfaceOnly?: boolean | undefined; + readonly paperComponentName?: string | undefined; + readonly paperComponentNameDeprecated?: string | undefined; + readonly excludedPlatforms?: ReadonlyArray<'iOS' | 'android'> | undefined; } export type NativeComponentType = HostComponent; diff --git a/types/modules/globals.d.ts b/types/modules/globals.d.ts index 3efd94c55fc8d2..1bd4d2ccbe9a0d 100644 --- a/types/modules/globals.d.ts +++ b/types/modules/globals.d.ts @@ -80,7 +80,9 @@ declare var Blob: { new (blobParts?: Array, options?: BlobOptions): Blob; }; -type FormDataValue = string | {name?: string; type?: string; uri: string}; +type FormDataValue = + | string + | {name?: string | undefined; type?: string | undefined; uri: string}; type FormDataPart = | { @@ -90,8 +92,8 @@ type FormDataPart = | { uri: string; headers: {[name: string]: string}; - name?: string; - type?: string; + name?: string | undefined; + type?: string | undefined; }; declare class FormData { @@ -160,7 +162,7 @@ declare interface RequestInit { method?: string | undefined; mode?: RequestMode_ | undefined; referrer?: string | undefined; - window?: any; + window?: any | undefined; signal?: AbortSignal | undefined; } @@ -409,7 +411,7 @@ declare class URLSearchParams { } interface WebSocketMessageEvent extends Event { - data?: any; + data?: any | undefined; } interface WebSocketErrorEvent extends Event { message: string; @@ -493,9 +495,9 @@ declare class AbortSignal implements EventTarget { options?: | boolean | { - capture?: boolean; - once?: boolean; - passive?: boolean; + capture?: boolean | undefined; + once?: boolean | undefined; + passive?: boolean | undefined; }, ) => void; @@ -505,7 +507,7 @@ declare class AbortSignal implements EventTarget { options?: | boolean | { - capture?: boolean; + capture?: boolean | undefined; }, ) => void; } diff --git a/yarn.lock b/yarn.lock index 9e2944f35f2596..ec1969aec35599 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2622,6 +2622,11 @@ resolved "https://registry.yarnpkg.com/@types/scheduler/-/scheduler-0.16.2.tgz#1a62f89525723dde24ba1b01b092bf5df8ad4d39" integrity sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew== +"@types/semver@^7.3.12": + version "7.3.13" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.3.13.tgz#da4bfd73f49bd541d28920ab0e2bf0ee80f71c91" + integrity sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw== + "@types/stack-utils@^2.0.0": version "2.0.1" resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.1.tgz#20f18294f797f2209b5f65c8e3b5c8e8261d127c" @@ -2693,6 +2698,14 @@ "@typescript-eslint/types" "5.37.0" "@typescript-eslint/visitor-keys" "5.37.0" +"@typescript-eslint/scope-manager@5.54.0": + version "5.54.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.54.0.tgz#74b28ac9a3fc8166f04e806c957adb8c1fd00536" + integrity sha512-VTPYNZ7vaWtYna9M4oD42zENOBrb+ZYyCNdFs949GcN8Miwn37b8b7eMj+EZaq7VK9fx0Jd+JhmkhjFhvnovhg== + dependencies: + "@typescript-eslint/types" "5.54.0" + "@typescript-eslint/visitor-keys" "5.54.0" + "@typescript-eslint/type-utils@5.37.0": version "5.37.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-5.37.0.tgz#43ed2f567ada49d7e33a6e4b6f9babd060445fe5" @@ -2708,6 +2721,11 @@ resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.37.0.tgz#09e4870a5f3af7af3f84e08d792644a87d232261" integrity sha512-3frIJiTa5+tCb2iqR/bf7XwU20lnU05r/sgPJnRpwvfZaqCJBrl8Q/mw9vr3NrNdB/XtVyMA0eppRMMBqdJ1bA== +"@typescript-eslint/types@5.54.0": + version "5.54.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.54.0.tgz#7d519df01f50739254d89378e0dcac504cab2740" + integrity sha512-nExy+fDCBEgqblasfeE3aQ3NuafBUxZxgxXcYfzYRZFHdVvk5q60KhCSkG0noHgHRo/xQ/BOzURLZAafFpTkmQ== + "@typescript-eslint/typescript-estree@5.37.0": version "5.37.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.37.0.tgz#956dcf5c98363bcb97bdd5463a0a86072ff79355" @@ -2721,6 +2739,19 @@ semver "^7.3.7" tsutils "^3.21.0" +"@typescript-eslint/typescript-estree@5.54.0": + version "5.54.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.54.0.tgz#f6f3440cabee8a43a0b25fa498213ebb61fdfe99" + integrity sha512-X2rJG97Wj/VRo5YxJ8Qx26Zqf0RRKsVHd4sav8NElhbZzhpBI8jU54i6hfo9eheumj4oO4dcRN1B/zIVEqR/MQ== + dependencies: + "@typescript-eslint/types" "5.54.0" + "@typescript-eslint/visitor-keys" "5.54.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + semver "^7.3.7" + tsutils "^3.21.0" + "@typescript-eslint/utils@5.37.0", "@typescript-eslint/utils@^5.10.0", "@typescript-eslint/utils@^5.30.0": version "5.37.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.37.0.tgz#7784cb8e91390c4f90ccaffd24a0cf9874df81b2" @@ -2733,6 +2764,20 @@ eslint-scope "^5.1.1" eslint-utils "^3.0.0" +"@typescript-eslint/utils@^5.47.1": + version "5.54.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.54.0.tgz#3db758aae078be7b54b8ea8ea4537ff6cd3fbc21" + integrity sha512-cuwm8D/Z/7AuyAeJ+T0r4WZmlnlxQ8wt7C7fLpFlKMR+dY6QO79Cq1WpJhvZbMA4ZeZGHiRWnht7ZJ8qkdAunw== + dependencies: + "@types/json-schema" "^7.0.9" + "@types/semver" "^7.3.12" + "@typescript-eslint/scope-manager" "5.54.0" + "@typescript-eslint/types" "5.54.0" + "@typescript-eslint/typescript-estree" "5.54.0" + eslint-scope "^5.1.1" + eslint-utils "^3.0.0" + semver "^7.3.7" + "@typescript-eslint/visitor-keys@5.37.0": version "5.37.0" resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.37.0.tgz#7b72dd343295ea11e89b624995abc7103c554eee" @@ -2741,6 +2786,14 @@ "@typescript-eslint/types" "5.37.0" eslint-visitor-keys "^3.3.0" +"@typescript-eslint/visitor-keys@5.54.0": + version "5.54.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.54.0.tgz#846878afbf0cd67c19cfa8d75947383d4490db8f" + integrity sha512-xu4wT7aRCakGINTLGeyGqDn+78BwFlggwBjnHa1ar/KaGagnmwLYmlrXIrgAaQ3AE1Vd6nLfKASm7LrFHNbKGA== + dependencies: + "@typescript-eslint/types" "5.54.0" + eslint-visitor-keys "^3.3.0" + abort-controller@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" @@ -4145,6 +4198,13 @@ eslint-plugin-react@^7.30.1: semver "^6.3.0" string.prototype.matchall "^4.0.7" +eslint-plugin-redundant-undefined@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-redundant-undefined/-/eslint-plugin-redundant-undefined-0.4.0.tgz#1445467d1920809f13f965f486a2d59f14f4aa65" + integrity sha512-+nzoUIWJCIwlWxhoFL9LJDPE2y0RCq2Eq8qD8NhfMScTHlNHvBc0haIWdBkjgzJZaN6OX/bkke/4WisV0qs7Vg== + dependencies: + "@typescript-eslint/utils" "^5.47.1" + eslint-plugin-relay@^1.8.3: version "1.8.3" resolved "https://registry.yarnpkg.com/eslint-plugin-relay/-/eslint-plugin-relay-1.8.3.tgz#3f320b79259c14c8112909568b208a08e7a9ebae"