Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Setup App for TypeScript #20179

Merged
Merged
Show file tree
Hide file tree
Changes from 83 commits
Commits
Show all changes
88 commits
Select commit Hold shift + click to select a range
9e32fbe
[WIP]: Create early Typescript configuration
blazejkustra Jun 5, 2023
8980fb4
Add end of file lines, revert unintented change in babel config file
blazejkustra Jun 5, 2023
4012d0b
Add typecheck to package.json
blazejkustra Jun 6, 2023
3d69491
Adddd more eslint rules
blazejkustra Jun 6, 2023
73c4df8
Add typecheck to workflows
blazejkustra Jun 6, 2023
51fcbe5
Add skipLibCheck option to tsconfig
blazejkustra Jun 6, 2023
0efb8a7
Include ts files in weback config
blazejkustra Jun 6, 2023
185e166
Remove .json as it was added by mistake
blazejkustra Jun 6, 2023
fb48821
Remove unnecessary eslint settings option
blazejkustra Jun 6, 2023
050782b
Improve webpack extenstions option
blazejkustra Jun 6, 2023
6ac0040
Restructurize typescript eslint configuration
blazejkustra Jun 7, 2023
7d872b5
Add include option to tsconfig + format tsconfig with prettier
blazejkustra Jun 7, 2023
503c540
Add declarations.d.ts to enable images and react-native-device-info i…
blazejkustra Jun 7, 2023
9879098
Remove settings from eslintrc config
blazejkustra Jun 7, 2023
e5f39ee
Clean eslintrc config
blazejkustra Jun 7, 2023
a29cdd3
Add DOM in tsconfig's lib option to enable usage of 'document' for web
blazejkustra Jun 7, 2023
4b56d1d
Improve typescript performance by excluding node_modules and dist cat…
blazejkustra Jun 7, 2023
ef87729
Use settings in eslintrc as before + add typescript extensions.
blazejkustra Jun 7, 2023
8e6e484
Fix webpack missing modules errors
blazejkustra Jun 12, 2023
2d31bc0
Remove unused dependencies
blazejkustra Jun 12, 2023
7bd0a30
Add json schema to tsconfig
blazejkustra Jun 12, 2023
9bd7b19
Fix eslint config after PR feedback
blazejkustra Jun 12, 2023
9e81d51
Fix no-restricted-imports & restrict lodash and underscore get imports
blazejkustra Jun 12, 2023
6fb4e7c
Turn off restritive eslint options around type 'any'
blazejkustra Jun 13, 2023
69f1ef2
Remove unnecessary tsc script option
blazejkustra Jun 13, 2023
3407827
Tests with TS in Picker component
fabioh8010 Jun 13, 2023
0fb7d77
Disable some rules that don't make sense for TS/TSX files
fabioh8010 Jun 13, 2023
14088b6
Remove baseUrl from tsconfig.json to solve issues with file imports i…
fabioh8010 Jun 13, 2023
85a14c5
Add eslint rule to allow importing tsx/ts files in javascript files
blazejkustra Jun 14, 2023
f88861b
Turn off react/static-property-placement
blazejkustra Jun 14, 2023
f396d4a
Remove unrelated dependencies from package.json
blazejkustra Jun 14, 2023
fc6aeb7
Fix import/resolver option for JS files
blazejkustra Jun 14, 2023
e566784
Fix slow eslint runs
blazejkustra Jun 14, 2023
24b5bb2
Install type-fest, library with type utilities
blazejkustra Jun 15, 2023
de5afda
Add more rules related to enums
fabioh8010 Jun 15, 2023
c505088
Revert Picker changes
blazejkustra Jun 16, 2023
e64c690
Revert ScrollViewWithContext changes
blazejkustra Jun 16, 2023
acd3098
Remove usePrevious
blazejkustra Jun 16, 2023
9e5196f
Add endline to eslintignore
blazejkustra Jun 16, 2023
d1298a7
Revert remove of save dependency
blazejkustra Jun 16, 2023
6dbae89
Fix package.json scripts to work with ts files
blazejkustra Jun 16, 2023
8765e68
Update react types package
blazejkustra Jun 16, 2023
fb467c0
Remove unused and unnecessary deps
blazejkustra Jun 19, 2023
bc150f3
Improve png and jpg global decratations
blazejkustra Jun 19, 2023
a0ed333
Reorganize eslint rules into groups
blazejkustra Jun 19, 2023
5d4c44a
Remove static-property-placement rule
blazejkustra Jun 19, 2023
e93e640
Add a comment to remove rules around any after migration is done
blazejkustra Jun 19, 2023
0cbe8fe
Clean TS plugins and extends to not repeat global options in eslintrc
blazejkustra Jun 19, 2023
8e55e56
Rename declarations.d.ts file to global.d.ts
blazejkustra Jun 20, 2023
e2422f2
Standarize array type with eslint rule
blazejkustra Jun 20, 2023
caef64c
Add jsdoc no types rule (only for ts files)
blazejkustra Jun 26, 2023
9be17fd
Add naming-convention eslint rule
blazejkustra Jun 26, 2023
e868b9d
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jun 26, 2023
6e0a38d
Remove unused eslint rules
blazejkustra Jun 27, 2023
06c8c9b
Improve naming-convention eslint rule
blazejkustra Jun 27, 2023
f725a05
Fix restricted imports
blazejkustra Jun 27, 2023
54066d3
Add todo to metro.config.js
blazejkustra Jun 27, 2023
0fb0b5d
Move global.d.ts to src
blazejkustra Jun 28, 2023
099fe59
Restrict some of react-native-gesture-handler imports
blazejkustra Jun 28, 2023
d0180eb
Add TouchableNativeFeedback to restrict array
blazejkustra Jun 28, 2023
f9d92dd
Enable constant properties in naming-convention eslint rule
blazejkustra Jun 28, 2023
72b2c78
Make error message more specific which component from Pressable to use
blazejkustra Jun 29, 2023
a1f6664
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jun 29, 2023
466505c
Fix desktop webpack configuration
blazejkustra Jun 29, 2023
7d5da15
Ban underscore entirely
blazejkustra Jul 3, 2023
6f6866a
Ban object type
blazejkustra Jul 3, 2023
e723cdd
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jul 5, 2023
0692778
Add eslint-plugin-you-dont-need-lodash-underscore package andd disabl…
blazejkustra Jul 6, 2023
f3034a7
Change plugin present to more stricteer version
blazejkustra Jul 6, 2023
4e31da0
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jul 11, 2023
c1e2209
Disable rulesdir/prefer-import-module-contents eslint rule
blazejkustra Jul 11, 2023
238d241
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jul 13, 2023
7a30be4
Turn off require-default-props eslint rule
blazejkustra Jul 13, 2023
8e3eefc
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jul 24, 2023
d08e3d4
Add 'the' to the eslint rule message
blazejkustra Jul 25, 2023
f48892e
Build github actions
blazejkustra Jul 25, 2023
404cefb
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Jul 26, 2023
9b3720a
Trigger
blazejkustra Jul 26, 2023
dd99141
Merge branch 'Expensify:main' into blazejkustra/typescript-poc
blazejkustra Jul 26, 2023
fade5bc
Improve typescript performacne
blazejkustra Jul 27, 2023
9058dad
Add rulesdir/onyx-props-must-have-default rule to both JS and TS
blazejkustra Jul 27, 2023
d234548
Fix some of TS performance issues
blazejkustra Jul 31, 2023
a443163
Introduce a different approach for lottie animations, improve TS perf…
blazejkustra Jul 31, 2023
9088b21
Merge branch 'main' into blazejkustra/typescript-poc
blazejkustra Aug 1, 2023
b9cbce6
Fix fast-xml-parser vulnerability
blazejkustra Aug 1, 2023
ba028fd
Update eslint config, remove redundant rules (already included in rec…
blazejkustra Aug 1, 2023
2c0d3e6
Turn off no-floating-promises rule
blazejkustra Aug 1, 2023
e70832e
Build gh-actions hopefully last time
blazejkustra Aug 1, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .eslintignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
**/node_modules/*
**/dist/*
.github/actions/**/index.js"
hayata-suenaga marked this conversation as resolved.
Show resolved Hide resolved
181 changes: 152 additions & 29 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,28 @@
const restrictedImportPaths = [
{
name: 'react-native',
importNames: ['useWindowDimensions', 'StatusBar', 'TouchableOpacity', 'TouchableWithoutFeedback', 'TouchableNativeFeedback', 'TouchableHighlight', 'Pressable'],
message: [
'',
hayata-suenaga marked this conversation as resolved.
Show resolved Hide resolved
"For 'useWindowDimensions', please use 'src/hooks/useWindowDimensions' instead.",
"For 'TouchableOpacity', 'TouchableWithoutFeedback', 'TouchableNativeFeedback', 'TouchableHighlight', 'Pressable', please use 'PressableWithFeedback' and/or 'PressableWithoutFeedback' from 'src/components/Pressable' instead.",
"For 'StatusBar', please use 'src/libs/StatusBar' instead.",
].join('\n'),
},
{
name: 'react-native-gesture-handler',
importNames: ['TouchableOpacity', 'TouchableWithoutFeedback', 'TouchableNativeFeedback', 'TouchableHighlight'],
message: "Please use 'PressableWithFeedback' and/or 'PressableWithoutFeedback' from 'src/components/Pressable' instead.",
},
];

const restrictedImportPatterns = [
{
group: ['**/assets/animations/**/*.json'],
message: "Do not import animations directly. Please use the 'src/components/LottieAnimations' import instead.",
},
];

module.exports = {
extends: ['expensify', 'plugin:storybook/recommended', 'plugin:react-hooks/recommended', 'prettier', 'plugin:react-native-a11y/basic'],
plugins: ['react-hooks', 'react-native-a11y'],
Expand All @@ -6,40 +31,138 @@ module.exports = {
env: {
jest: true,
},
settings: {
'import/resolver': {
node: {
extensions: ['.js', '.website.js', '.desktop.js', '.native.js', '.ios.js', '.android.js', '.config.js'],
blazejkustra marked this conversation as resolved.
Show resolved Hide resolved
},
},
},
globals: {
__DEV__: 'readonly',
},
rules: {
'no-restricted-imports': [
'error',
{
paths: [
{
name: 'react-native',
importNames: ['useWindowDimensions', 'StatusBar', 'TouchableOpacity', 'TouchableWithoutFeedback', 'TouchableNativeFeedback', 'TouchableHighlight', 'Pressable'],
message: [
'',
"For 'useWindowDimensions', please use 'src/hooks/useWindowDimensions' instead.",
"For 'TouchableOpacity', 'TouchableWithoutFeedback', 'TouchableNativeFeedback', 'TouchableHighlight', 'Pressable', please use 'PressableWithFeedback' and/or 'PressableWithoutFeedback' from 'src/components/Pressable' instead.",
"For 'StatusBar', please use 'src/libs/StatusBar' instead.",
].join('\n'),
overrides: [
hayata-suenaga marked this conversation as resolved.
Show resolved Hide resolved
{
files: ['*.js', '*.jsx', '*.ts', '*.tsx'],
rules: {
'rulesdir/onyx-props-must-have-default': 'off',
'react-native-a11y/has-accessibility-hint': ['off'],
blazejkustra marked this conversation as resolved.
Show resolved Hide resolved
'react-native-a11y/has-valid-accessibility-descriptors': [
'error',
{
touchables: ['PressableWithoutFeedback', 'PressableWithFeedback'],
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The doc for the rule says that this rule doesn't take any arguments...

does specifying touchables work here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's a good question! I asked Michał from SWM who added it to .eslintrc.js file.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Without touchables option it doesn't work, the weird part is that it isn't documented, but I found the code responsible for that.

has-valid-accessibility-descriptors rule implementation calls isTouchable function which actually uses the touchables option 😄

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The touchables option is documented but only for other rules here. Probably they forgot to include react-native-a11y/has-valid-accessibility-descriptors 🤷

},
],
},
],
'react-native-a11y/has-accessibility-hint': ['off'],
'react-native-a11y/has-valid-accessibility-descriptors': [
'error',
{
touchables: ['PressableWithoutFeedback', 'PressableWithFeedback'],
},
{
files: ['*.js', '*.jsx'],
settings: {
'import/resolver': {
hayata-suenaga marked this conversation as resolved.
Show resolved Hide resolved
node: {
extensions: ['.js', '.website.js', '.desktop.js', '.native.js', '.ios.js', '.android.js', '.config.js', '.ts', '.tsx'],
},
},
},
],
},
rules: {
'import/extensions': [
'error',
'ignorePackages',
{
js: 'never',
jsx: 'never',
ts: 'never',
tsx: 'never',
},
],
'no-restricted-imports': [
'error',
{
paths: restrictedImportPaths,
patterns: restrictedImportPatterns,
},
],
},
},
{
files: ['*.ts', '*.tsx'],
extends: [
'airbnb-typescript',
'plugin:@typescript-eslint/recommended',
'plugin:@typescript-eslint/recommended-requiring-type-checking',
'plugin:you-dont-need-lodash-underscore/all',
'prettier',
],
plugins: ['@typescript-eslint', 'jsdoc', 'you-dont-need-lodash-underscore'],
parser: '@typescript-eslint/parser',
parserOptions: {
project: './tsconfig.json',
},
rules: {
blazejkustra marked this conversation as resolved.
Show resolved Hide resolved
// TODO: Remove the following rules after TypeScript migration is complete.
'@typescript-eslint/no-unsafe-argument': 'off',
'@typescript-eslint/no-unsafe-call': 'off',
'@typescript-eslint/no-unsafe-member-access': 'off',
blazejkustra marked this conversation as resolved.
Show resolved Hide resolved
'@typescript-eslint/no-unsafe-assignment': 'off',

'@typescript-eslint/naming-convention': [
'error',
{
selector: ['variable', 'property'],
format: ['camelCase', 'UPPER_CASE', 'PascalCase'],
},
{
selector: 'function',
format: ['camelCase', 'PascalCase'],
},
{
selector: ['typeLike', 'enumMember'],
format: ['PascalCase'],
},
{
selector: ['parameter', 'method'],
format: ['camelCase'],
},
],
'@typescript-eslint/ban-types': [
'error',
{
types: {
object: "Use 'Record<string, T>' instead.",
},
extendDefaults: true,
},
],
'@typescript-eslint/array-type': ['error', {default: 'array-simple'}],
hayata-suenaga marked this conversation as resolved.
Show resolved Hide resolved
'@typescript-eslint/no-unsafe-enum-comparison': 'error',
'@typescript-eslint/prefer-enum-initializers': 'error',
'@typescript-eslint/no-var-requires': 'off',
'@typescript-eslint/no-non-null-assertion': 'error',
'@typescript-eslint/no-explicit-any': 'error',
'@typescript-eslint/switch-exhaustiveness-check': 'error',
'@typescript-eslint/consistent-type-definitions': ['error', 'type'],
'es/no-nullish-coalescing-operators': 'off',
'es/no-optional-chaining': 'off',
'valid-jsdoc': 'off',
'jsdoc/no-types': 'error',
'import/no-extraneous-dependencies': 'off',
'rulesdir/prefer-underscore-method': 'off',
'rulesdir/prefer-import-module-contents': 'off',
'react/require-default-props': 'off',
'no-restricted-syntax': [
'error',
hayata-suenaga marked this conversation as resolved.
Show resolved Hide resolved
{
selector: 'TSEnumDeclaration',
message: "Please don't declare enums, use union types instead.",
},
],
'no-restricted-imports': [
'error',
{
paths: [
...restrictedImportPaths,
{
name: 'underscore',
blazejkustra marked this conversation as resolved.
Show resolved Hide resolved
message: 'Please use the corresponding method from lodash instead',
},
],
patterns: restrictedImportPatterns,
},
],
},
},
],
};
Loading