From 66acce2bb333caa4338a324f23ef1448df34b717 Mon Sep 17 00:00:00 2001 From: Blazej Kustra Date: Tue, 19 Dec 2023 12:09:56 +0100 Subject: [PATCH] Disallow CSSProperties usage --- .eslintrc.js | 5 +++++ src/components/Icon/svgs/LoungeAccessIcon.tsx | 2 +- src/components/MapView/MapView.website.tsx | 2 +- src/styles/utils/index.ts | 7 +++---- src/styles/utils/objectFit.ts | 3 +-- src/styles/utils/types.ts | 2 ++ src/types/modules/react-native.d.ts | 1 + src/types/onyx/Bank.ts | 3 +-- src/types/onyx/PaymentMethod.ts | 3 +-- 9 files changed, 16 insertions(+), 12 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 39a7c7553261..822a7f66b474 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -24,6 +24,11 @@ const restrictedImportPaths = [ importNames: ['useSafeAreaInsets', 'SafeAreaConsumer', 'SafeAreaInsetsContext'], message: "Please use 'useSafeAreaInsets' from 'src/hooks/useSafeAreaInset' and/or 'SafeAreaConsumer' from 'src/components/SafeAreaConsumer' instead.", }, + { + name: 'react', + importNames: ['CSSProperties'], + message: "Please use 'ViewStyle', 'TextStyle', 'ImageStyle' from 'react-native' instead.", + }, ]; const restrictedImportPatterns = [ diff --git a/src/components/Icon/svgs/LoungeAccessIcon.tsx b/src/components/Icon/svgs/LoungeAccessIcon.tsx index e57573c439f1..0dcf9052ca87 100644 --- a/src/components/Icon/svgs/LoungeAccessIcon.tsx +++ b/src/components/Icon/svgs/LoungeAccessIcon.tsx @@ -1,4 +1,4 @@ -import * as React from 'react'; +import React from 'react'; import Svg, {G, Path, Polygon} from 'react-native-svg'; import useTheme from '@hooks/useTheme'; diff --git a/src/components/MapView/MapView.website.tsx b/src/components/MapView/MapView.website.tsx index 7910d7f93a29..778ef66449d4 100644 --- a/src/components/MapView/MapView.website.tsx +++ b/src/components/MapView/MapView.website.tsx @@ -183,7 +183,7 @@ const MapView = forwardRef( latitude: currentPosition?.latitude, zoom: initialState.zoom, }} - style={StyleUtils.getTextColorStyle(theme.mapAttributionText) as React.CSSProperties} + style={StyleUtils.getTextColorStyle(theme.mapAttributionText)} mapStyle={styleURL} > {waypoints?.map(({coordinate, markerComponent, id}) => { diff --git a/src/styles/utils/index.ts b/src/styles/utils/index.ts index 228643e5ba2e..c6ec9dd3d579 100644 --- a/src/styles/utils/index.ts +++ b/src/styles/utils/index.ts @@ -1,4 +1,3 @@ -import {CSSProperties} from 'react'; import {Animated, DimensionValue, PressableStateCallbackType, StyleProp, StyleSheet, TextStyle, ViewStyle} from 'react-native'; import {EdgeInsets} from 'react-native-safe-area-context'; import {ValueOf} from 'type-fest'; @@ -402,7 +401,7 @@ function getBackgroundColorStyle(backgroundColor: string): ViewStyle { /** * Returns a style for text color */ -function getTextColorStyle(color: string): TextStyle { +function getTextColorStyle(color: string): TextColorStyle { return { color, }; @@ -613,7 +612,7 @@ function getMinimumHeight(minHeight: number): ViewStyle { /** * Get minimum width as style */ -function getMinimumWidth(minWidth: number): ViewStyle | CSSProperties { +function getMinimumWidth(minWidth: number): ViewStyle { return { minWidth, }; @@ -906,7 +905,7 @@ function getMenuItemTextContainerStyle(isSmallAvatarSubscriptMenu: boolean): Vie /** * Returns color style */ -function getColorStyle(color: string): ViewStyle | CSSProperties { +function getColorStyle(color: string): TextColorStyle { return {color}; } diff --git a/src/styles/utils/objectFit.ts b/src/styles/utils/objectFit.ts index 9d5e4141d6de..51f0c33b5457 100644 --- a/src/styles/utils/objectFit.ts +++ b/src/styles/utils/objectFit.ts @@ -1,4 +1,3 @@ -import {CSSProperties} from 'react'; import {ViewStyle} from 'react-native'; export default { @@ -14,4 +13,4 @@ export default { oFNone: { objectFit: 'none', }, -} satisfies Record; +} satisfies Record; diff --git a/src/styles/utils/types.ts b/src/styles/utils/types.ts index c7e1fc60a142..40a261beee71 100644 --- a/src/styles/utils/types.ts +++ b/src/styles/utils/types.ts @@ -42,6 +42,7 @@ type AvatarSize = {width: number}; type WorkspaceColorStyle = {backgroundColor: ColorValue; fill: ColorValue}; type EreceiptColorStyle = {backgroundColor: ColorValue; color: ColorValue}; +type TextColorStyle = {color: string}; export type { AllStyles, @@ -56,4 +57,5 @@ export type { AvatarSize, WorkspaceColorStyle, EreceiptColorStyle, + TextColorStyle, }; diff --git a/src/types/modules/react-native.d.ts b/src/types/modules/react-native.d.ts index 27cc16b912d5..25ff1c6c73b8 100644 --- a/src/types/modules/react-native.d.ts +++ b/src/types/modules/react-native.d.ts @@ -3,6 +3,7 @@ /* eslint-disable @typescript-eslint/no-empty-interface */ /* eslint-disable @typescript-eslint/consistent-type-definitions */ +// eslint-disable-next-line no-restricted-imports import {CSSProperties, FocusEventHandler, KeyboardEventHandler, MouseEventHandler, PointerEventHandler, UIEventHandler, WheelEventHandler} from 'react'; import 'react-native'; import {BootSplashModule} from '@libs/BootSplash/types'; diff --git a/src/types/onyx/Bank.ts b/src/types/onyx/Bank.ts index b6312e039079..43346f956cb0 100644 --- a/src/types/onyx/Bank.ts +++ b/src/types/onyx/Bank.ts @@ -1,4 +1,3 @@ -import {CSSProperties} from 'react'; import {ViewStyle} from 'react-native'; import {SvgProps} from 'react-native-svg'; import {ValueOf} from 'type-fest'; @@ -9,7 +8,7 @@ type BankIcon = { iconSize?: number; iconHeight?: number; iconWidth?: number; - iconStyles?: Array; + iconStyles?: ViewStyle[]; }; type BankName = ValueOf; diff --git a/src/types/onyx/PaymentMethod.ts b/src/types/onyx/PaymentMethod.ts index 4a9722911bf9..f62234b021b9 100644 --- a/src/types/onyx/PaymentMethod.ts +++ b/src/types/onyx/PaymentMethod.ts @@ -1,4 +1,3 @@ -import {CSSProperties} from 'react'; import {ViewStyle} from 'react-native'; import {SvgProps} from 'react-native-svg'; import BankAccount from './BankAccount'; @@ -10,7 +9,7 @@ type PaymentMethod = (BankAccount | Fund) & { iconSize?: number; iconHeight?: number; iconWidth?: number; - iconStyles?: Array; + iconStyles?: ViewStyle[]; }; export default PaymentMethod;