Skip to content

Commit

Permalink
Update to eslint9
Browse files Browse the repository at this point in the history
rework eslint config

steal some from content-sources-frontend

Add globals dep for eslint config

Manual fixes for eslint9

Removed some JSX chunks with `false && <element>` syntax
  • Loading branch information
mshriver committed Dec 19, 2024
1 parent f662524 commit 00fa2cf
Show file tree
Hide file tree
Showing 65 changed files with 1,480 additions and 1,473 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ jobs:
node-version-file: 'frontend/.nvmrc'
cache: 'yarn'
cache-dependency-path: 'frontend/yarn.lock'
- run: yarn install --frozen-lockfile
- run: yarn install
working-directory: ./frontend
- run: yarn lint
working-directory: ./frontend
Expand Down
2 changes: 1 addition & 1 deletion .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -27,4 +27,4 @@ repos:
- repo: https://github.com/AleksaC/hadolint-py
rev: v2.12.1b3
hooks:
- id: hadolint
- id: hadolint
2 changes: 1 addition & 1 deletion frontend/.nvmrc
Original file line number Diff line number Diff line change
@@ -1 +1 @@
v18
v20
45 changes: 45 additions & 0 deletions frontend/.yarnclean
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
# test directories
__tests__
test
tests
powered-test

# asset directories
docs
doc
website
images
assets

# examples
example
examples

# code coverage directories
coverage
.nyc_output

# build scripts
Makefile
Gulpfile.js
Gruntfile.js

# configs
appveyor.yml
circle.yml
codeship-services.yml
codeship-steps.yml
wercker.yml
.tern-project
.gitattributes
.editorconfig
.*ignore
.eslintrc
.jshintrc
.flowconfig
.documentup.json
.yarn-metadata.json
.travis.yml

# misc
*.md
File renamed without changes.
2 changes: 1 addition & 1 deletion frontend/cypress.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ export default defineConfig({
framework: "create-react-app",
bundler: "webpack",
},
specPattern: "src/**/*.cy.{js,jsx,ts,tsx}",
specPattern: "src/**/*.cy.{js,jsx,cjs,mjs,ts,tsx}",
excludeSpecPattern: "**/node_modules/**",
viewportHeight: 660,
viewportWidth: 1000
Expand Down
10 changes: 3 additions & 7 deletions frontend/docker/Dockerfile.frontend
Original file line number Diff line number Diff line change
@@ -1,23 +1,19 @@
# hadolint global ignore=DL3041,DL4006
# hadolint global ignore=DL3041,DL4006,SC2046
# Build the image first
FROM registry.access.redhat.com/ubi9/ubi-minimal:9.4 AS builder

ARG NODEJS_VERSION=18
ENV NODE_ENV=production

WORKDIR /app
COPY . /app

RUN microdnf module disable nodejs -y && \
microdnf module enable nodejs:$NODEJS_VERSION -y && \
microdnf module enable nodejs:$(cut -d "v" -f 2 < .nvmrc) -y && \
microdnf install --nodocs -y --disableplugin=subscription-manager \
nodejs nodejs-nodemon npm findutils tar && \
node -v | grep -qe "^v$NODEJS_VERSION\." && \
echo "Found VERSION $NODEJS_VERSION" && \
microdnf clean all && \
rm -rf /mnt/rootfs/var/cache/* /mnt/rootfs/var/log/dnf* /mnt/rootfs/var/log/yum.*

COPY . /app

RUN npm install --global yarn@^1.22.22 && yarn install && yarn build

# Deploy it using nginx
Expand Down
102 changes: 102 additions & 0 deletions frontend/eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
// eslint.config.mjs
import cypress from 'eslint-plugin-cypress';
import react from 'eslint-plugin-react';
import prettier from 'eslint-plugin-prettier';
import unusedImports from 'eslint-plugin-unused-imports';
import { fileURLToPath } from 'node:url';
import globals from 'globals';
import path from 'node:path';
import js from '@eslint/js';
import { FlatCompat } from '@eslint/eslintrc';
import hooksPlugin from 'eslint-plugin-react-hooks';
import pkg from '@babel/eslint-parser';

const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const compat = new FlatCompat({
baseDirectory: __dirname,
recommendedConfig: js.configs.recommended,
allConfig: js.configs.all,
});

export default [
{
files: ['src/*', 'cypress/*'],
ignores: ['node_modules/*'],
},
...compat.extends(
'eslint:recommended',
'plugin:react/recommended',
'plugin:react-hooks/recommended',
'plugin:cypress/recommended',
'prettier',
),
{
plugins: {
cypress,
prettier,
react,
'unused-imports': unusedImports,
'react-hooks': hooksPlugin,
},
languageOptions: {
globals: {
...globals.browser,
...globals.node,
...globals.cypress,
es202: true,
},
parser: pkg,
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
ecmaFeatures: {
jsx: true,
},
requireConfigFile: false,
plugins: [
'@babel/plugin-transform-class-properties',
'@babel/plugin-transform-private-methods',
'@babel/plugin-syntax-jsx',
],
babelOptions: {
presets: [
'@babel/preset-flow',
'@babel/preset-env',
'@babel/preset-react',
]
},
},
},
rules: {
'cypress/no-assigning-return-values': 'error',
'cypress/no-unnecessary-waiting': 'error',
'cypress/assertion-before-screenshot': 'warn',
'cypress/no-force': 'warn',
'cypress/no-async-tests': 'error',
'cypress/no-async-before': 'error',
'cypress/no-pause': 'error',
'react/jsx-curly-brace-presence': [
'error',
{
props: 'never',
children: 'never',
},
],

'arrow-body-style': ['error', 'as-needed'],
'react/react-in-jsx-scope': 'off',
camelcase: 'off',
'spaced-comment': 'error',
quotes: ['warn', 'single'],
'no-duplicate-imports': 'error',
'unused-imports/no-unused-imports': 'error',
'unused-imports/no-unused-vars': ['warn'],
},
settings: {
react:{
version: 'detect',
}
},
}
]
2 changes: 2 additions & 0 deletions frontend/jest.polyfills.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
// jest.polyfills.js
global.TextEncoder = require('util').TextEncoder;
92 changes: 31 additions & 61 deletions frontend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,95 +4,65 @@
"private": true,
"dependencies": {
"@babel/core": "^7.24.7",
"@babel/eslint-parser": "^7.24.7",
"@babel/eslint-parser": "^7.25.9",
"@babel/helper-call-delegate": "^7.12.13",
"@babel/plugin-proposal-private-property-in-object": "^7.21.11",
"@babel/plugin-syntax-jsx": "^7.24.7",
"@babel/plugin-syntax-flow": "^7.14.5",
"@babel/plugin-transform-class-properties": "^7.24.7",
"@babel/plugin-transform-private-methods": "^7.24.7",
"@babel/plugin-transform-private-property-in-object": "^7.24.7",
"@babel/plugin-transform-react-jsx": "^7.14.9",
"@babel/preset-flow": "^7.24.7",
"@babel/preset-react": "^7.24.7",
"@greatsumini/react-facebook-login": "^3.3.3",
"@monaco-editor/react": "^4.6.0",
"@patternfly/patternfly": "^5.2.1",
"@patternfly/react-charts": "^7.2.2",
"@patternfly/react-core": "^5.2.3",
"@patternfly/react-icons": "^5.2.1",
"@patternfly/react-styles": "^5.2.1",
"@patternfly/react-table": "^5.2.4",
"@patternfly/patternfly": "5.4.2",
"@patternfly/react-charts": "^7.4.7",
"@patternfly/react-core": "^5.4.12",
"@patternfly/react-icons": "^5.4.2",
"@patternfly/react-styles": "^5.4.1",
"@patternfly/react-table": "5.4.12",
"@react-oauth/google": "^0.12.1",
"@testing-library/react": "^14.3.1",
"cypress": "^10.11.0",
"@testing-library/dom": "^10.0.0",
"@testing-library/react": "^16.1.0",
"@types/react": "^18.3.12",
"enzyme": "^3.11.0",
"eslint": "^7.32.0",
"eslint-plugin-cypress": "^2.15.2",
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-react": "^7.34.2",
"fs-extra": "^11.2.0",
"keycloak-js": "^19.0.3",
"globals": "^15.13.0",
"keycloak-js": "^26.0.7",
"monaco-editor": "^0.47.0",
"prop-types": "^15.8.1",
"react": "^18.2.0",
"react-dom": "^18.2.0",
"react": "^18.3.1",
"react-dom": "^18.3.1",
"react-heatmap-grid": "^0.9.0",
"react-json-tree": "^0.19.0",
"react-linkify": "^1.0.0-alpha",
"react-password-strength-bar": "^0.4.1",
"react-router-dom": "^6.22.3",
"react-router-dom": "^6.28.0",
"react-scripts": "^5.0.1",
"react-simple-oauth2-login": "^0.5.4",
"serve": "^12.0.1",
"typescript": "^4.9.5",
"wolfy87-eventemitter": "^5.2.9"
},
"devDependencies": {
"@babel/plugin-proposal-private-property-in-object": "^7.21.11"
"@babel/plugin-proposal-private-property-in-object": "^7.21.11",
"cypress": "^13.17.0",
"eslint": "^9.16.0",
"eslint-config-prettier": "^9.1.0",
"eslint-plugin-cypress": "^4.1.0",
"eslint-plugin-prettier": "^5.2.1",
"eslint-plugin-react": "^7.37.2",
"eslint-plugin-react-hooks": "^5.1.0",
"eslint-plugin-unused-imports": "^4.1.4",
"prettier": "^3.4.2"
},
"scripts": {
"start": "serve -s build -l tcp://0.0.0.0:8080",
"build": "./bin/write-version-file.js && react-scripts build",
"test": "./bin/write-version-file.js && react-scripts test --transformIgnorePatterns \"node_modules/(?!@patternfly)/\" && cypress run --component",
"build": "./bin/write-version-file.cjs && react-scripts build",
"test": "./bin/write-version-file.cjs && react-scripts test --transformIgnorePatterns \"node_modules/(?!@patternfly)/\" && cypress run --component",
"eject": "react-scripts eject",
"devserver": "./bin/write-version-file.js && CI=true react-scripts start",
"lint": "eslint --ext=js --ext=jsx ./src"
},
"eslintConfig": {
"env": {
"browser": true,
"node": true,
"es2017": true,
"jest": true
},
"extends": [
"eslint:recommended",
"plugin:cypress/recommended",
"plugin:react/recommended"
],
"parser": "@babel/eslint-parser",
"parserOptions": {
"sourceType": "module",
"requireConfigFile": false,
"babelOptions": {
"plugins": [
"@babel/plugin-transform-class-properties",
"@babel/plugin-transform-private-methods",
"@babel/plugin-syntax-jsx"
],
"presets": [
"@babel/preset-flow"
]
}
},
"plugins": [
"react",
"import"
],
"settings": {
"react": {
"version": "16.0"
}
}
"devserver": "./bin/write-version-file.cjs && CI=true react-scripts start",
"lint": "eslint"
},
"browserslist": {
"production": [
Expand Down
Loading

0 comments on commit 00fa2cf

Please sign in to comment.