Merge pull request #71 from aleleba/PR-420915

PR-420915: Changing the logic for aliases for one source of truth on tsconfig.json and updating packages.
This commit is contained in:
Alejandro Lembke Barrientos 2023-02-20 18:15:44 -06:00 committed by GitHub
commit f3f0095674
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
15 changed files with 1279 additions and 1154 deletions

View File

@ -9,7 +9,7 @@ Tech(Library or Framework) | Version |
React (Render Library) | 18.2.0 React (Render Library) | 18.2.0
Redux (Global State Management) | 4.2.1 Redux (Global State Management) | 4.2.1
React Router DOM (Routing) | 6.8.1 React Router DOM (Routing) | 6.8.1
Jest (Testing) | 29.4.2 Jest (Testing) | 29.4.3
Typescript | 4.9.5 Typescript | 4.9.5
## Setup ## Setup

View File

@ -13,3 +13,5 @@ export const config = {
PREFIX_URL: process.env.PREFIX_URL ? process.env.PREFIX_URL : deFaultValues.PREFIX_URL, PREFIX_URL: process.env.PREFIX_URL ? process.env.PREFIX_URL : deFaultValues.PREFIX_URL,
ONLY_EXACT_PATH: process.env.ONLY_EXACT_PATH ? process.env.ONLY_EXACT_PATH === 'true' : deFaultValues.ONLY_EXACT_PATH, ONLY_EXACT_PATH: process.env.ONLY_EXACT_PATH ? process.env.ONLY_EXACT_PATH === 'true' : deFaultValues.ONLY_EXACT_PATH,
}; };
export default config

View File

@ -1,11 +1,17 @@
const { pathsToModuleNameMapper } = require("ts-jest");
const { compilerOptions } = require("./tsconfig");
const aliases = pathsToModuleNameMapper(compilerOptions.paths, {
prefix: "<rootDir>"
})
module.exports = { module.exports = {
setupFilesAfterEnv: ['<rootDir>/setupTest.ts'], setupFilesAfterEnv: ['<rootDir>/setupTest.ts'],
"testEnvironment": "jsdom", testEnvironment: "jsdom",
moduleFileExtensions: ["ts", "tsx", "js", "jsx", "json"],
moduleNameMapper: { moduleNameMapper: {
...aliases,
"\\.(jpg|ico|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/src/__mocks__/fileMock.ts", "\\.(jpg|ico|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/src/__mocks__/fileMock.ts",
"@components": "<rootDir>/src/frontend/components/", "\\.(css|sass|scss|less)$": "identity-obj-proxy",
"@styles": "<rootDir>/src/frontend/styles/", }
"@config": "<rootDir>/config/",
"\\.(css|sass|scss|less)$": "identity-obj-proxy"
},
}; };

2304
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
{ {
"name": "@aleleba/create-react-ssr", "name": "@aleleba/create-react-ssr",
"version": "3.6.2", "version": "3.7.0",
"description": "Starter Kit of server side render of react", "description": "Starter Kit of server side render of react",
"bin": "./bin/cli.js", "bin": "./bin/cli.js",
"main": "src/server/index", "main": "src/server/index",
@ -11,7 +11,8 @@
"lint": "eslint ./ --ext .js --ext .ts --ext .jsx --ext .tsx", "lint": "eslint ./ --ext .js --ext .ts --ext .jsx --ext .tsx",
"lint:fix": "eslint ./ --ext .js --ext .ts --ext .jsx --ext .tsx --fix", "lint:fix": "eslint ./ --ext .js --ext .ts --ext .jsx --ext .tsx --fix",
"test": "jest", "test": "jest",
"test:watch": "jest --watch" "test:watch": "jest --watch",
"check-updates": "npx npm-check-updates -u && npm i"
}, },
"repository": { "repository": {
"type": "git", "type": "git",
@ -31,7 +32,7 @@
}, },
"homepage": "https://github.com/aleleba/create-react-ssr#readme", "homepage": "https://github.com/aleleba/create-react-ssr#readme",
"dependencies": { "dependencies": {
"@babel/register": "^7.18.9", "@babel/register": "^7.21.0",
"dotenv": "^16.0.3", "dotenv": "^16.0.3",
"express": "^4.18.2", "express": "^4.18.2",
"helmet": "^6.0.1", "helmet": "^6.0.1",
@ -59,25 +60,25 @@
"workbox-streams": "^6.5.4" "workbox-streams": "^6.5.4"
}, },
"devDependencies": { "devDependencies": {
"@babel/core": "^7.20.12", "@babel/core": "^7.21.0",
"@babel/preset-env": "^7.20.2", "@babel/preset-env": "^7.20.2",
"@babel/preset-react": "^7.18.6", "@babel/preset-react": "^7.18.6",
"@babel/preset-typescript": "^7.18.6", "@babel/preset-typescript": "^7.21.0",
"@pmmmwh/react-refresh-webpack-plugin": "^0.5.10", "@pmmmwh/react-refresh-webpack-plugin": "^0.5.10",
"@redux-devtools/extension": "^3.2.5", "@redux-devtools/extension": "^3.2.5",
"@testing-library/jest-dom": "^5.16.5", "@testing-library/jest-dom": "^5.16.5",
"@testing-library/react": "^13.4.0", "@testing-library/react": "^14.0.0",
"@testing-library/user-event": "^14.4.3", "@testing-library/user-event": "^14.4.3",
"@types/jest": "^29.4.0", "@types/jest": "^29.4.0",
"@types/node": "^18.13.0", "@types/node": "^18.14.0",
"@types/react": "^18.0.27", "@types/react": "^18.0.28",
"@types/react-dom": "^18.0.10", "@types/react-dom": "^18.0.11",
"@types/webpack": "^5.28.0", "@types/webpack": "^5.28.0",
"@types/webpack-hot-middleware": "^2.25.6", "@types/webpack-hot-middleware": "^2.25.6",
"@types/webpack-node-externals": "^2.5.3", "@types/webpack-node-externals": "^3.0.0",
"@typescript-eslint/eslint-plugin": "^5.51.0", "@typescript-eslint/eslint-plugin": "^5.53.0",
"@typescript-eslint/parser": "^5.51.0", "@typescript-eslint/parser": "^5.53.0",
"babel-jest": "^29.4.2", "babel-jest": "^29.4.3",
"babel-loader": "^9.1.2", "babel-loader": "^9.1.2",
"clean-webpack-plugin": "^4.0.0", "clean-webpack-plugin": "^4.0.0",
"compression-webpack-plugin": "^10.0.0", "compression-webpack-plugin": "^10.0.0",
@ -89,15 +90,17 @@
"eslint-webpack-plugin": "^4.0.0", "eslint-webpack-plugin": "^4.0.0",
"file-loader": "^6.2.0", "file-loader": "^6.2.0",
"identity-obj-proxy": "^3.0.0", "identity-obj-proxy": "^3.0.0",
"jest": "^29.4.2", "jest": "^29.4.3",
"jest-environment-jsdom": "^29.4.2", "jest-environment-jsdom": "^29.4.3",
"jest-fetch-mock": "^3.0.3", "jest-fetch-mock": "^3.0.3",
"mini-css-extract-plugin": "^2.7.2", "mini-css-extract-plugin": "^2.7.2",
"react-refresh": "^0.14.0", "react-refresh": "^0.14.0",
"sass": "^1.58.0", "resolve-ts-aliases": "^1.0.1",
"sass": "^1.58.3",
"sass-loader": "^13.2.0", "sass-loader": "^13.2.0",
"style-loader": "^3.3.1", "style-loader": "^3.3.1",
"terser-webpack-plugin": "^5.3.6", "terser-webpack-plugin": "^5.3.6",
"ts-jest": "^29.0.5",
"ts-loader": "^9.4.2", "ts-loader": "^9.4.2",
"typescript": "^4.9.5", "typescript": "^4.9.5",
"url-loader": "^4.1.1", "url-loader": "^4.1.1",

View File

@ -2,7 +2,3 @@ declare module "*.svg" {
const content: any; const content: any;
export default content; export default content;
} }
declare module "@config" {
export const config: any;
}

View File

@ -5,7 +5,7 @@ import { createMemoryHistory } from 'history';
import initialStateReducer from '../frontend/reducers/initialState'; import initialStateReducer from '../frontend/reducers/initialState';
import setStore from '../frontend/setStore'; import setStore from '../frontend/setStore';
const ProviderMock = ({ children, initialState }) => { export const ProviderMock = ({ children, initialState }: { children: any, initialState?: any}) => {
let initialStateMock = initialStateReducer let initialStateMock = initialStateReducer
if(initialState !== undefined){ if(initialState !== undefined){

View File

@ -1 +1,2 @@
module.exports = ''; export const fileMock = '';
module.exports = fileMock;

1
src/__mocks__/index.ts Normal file
View File

@ -0,0 +1 @@
export * from './ProviderMock';

View File

@ -14,7 +14,7 @@ export interface IChangeHelloPayload {
export type TTest = IChangeHello export type TTest = IChangeHello
const changeHello = (payload: string) => ({ const changeHello = (payload: string) => ({
type: 'CREATE_USER', type: ActionTypesTest.ChangeHello,
payload payload
}) })

View File

@ -1,7 +1,7 @@
import React from 'react'; import React from 'react';
import { render } from '@testing-library/react'; import { render } from '@testing-library/react';
import ProviderMock from '../../../__mocks__/ProviderMock'; import { ProviderMock } from '@mocks';
import App from '../App'; import App from '@components/App';
describe('<App/> Component', () => { describe('<App/> Component', () => {
beforeEach(() => { beforeEach(() => {
@ -15,7 +15,7 @@ describe('<App/> Component', () => {
})); }));
render( render(
<ProviderMock initialState={undefined}> <ProviderMock>
<App /> <App />
</ProviderMock> </ProviderMock>
) )

View File

@ -26,13 +26,27 @@
"node" "node"
], ],
"sourceMap": true, "sourceMap": true,
"baseUrl": "**/*", "baseUrl": ".",
"outDir": "build", "outDir": "build",
"skipLibCheck": true, "skipLibCheck": true,
"noImplicitAny": false "noImplicitAny": false,
"paths": {
"@components/*": ["src/frontend/components/*"],
"@components": ["src/frontend/components"],
"@styles/*": ["src/frontend/styles/*"],
"@styles": ["src/frontend/styles"],
"@actions/*": ["src/frontend/actions/*"],
"@actions": ["src/frontend/actions"],
"@reducers/*": ["src/frontend/reducers"],
"@reducers": ["src/frontend/reducers"],
"@config/*": ["config/*"],
"@config": ["config"],
"@mocks/*": ["src/__mocks__/*"],
"@mocks": ["src/__mocks__"]
}
}, },
"include": [ "include": [
"**/*" "."
], ],
"exclude": [ "exclude": [
"node_modules", "node_modules",

View File

@ -1,6 +1,7 @@
import MiniCssExtractPlugin from 'mini-css-extract-plugin'; import MiniCssExtractPlugin from 'mini-css-extract-plugin';
import webpackNodeExternals from 'webpack-node-externals'; import webpackNodeExternals from 'webpack-node-externals';
import WebpackShellPluginNext from 'webpack-shell-plugin-next'; import WebpackShellPluginNext from 'webpack-shell-plugin-next';
import { resolveTsAliases } from "resolve-ts-aliases";
import path from 'path'; import path from 'path';
import { Configuration } from 'webpack'; import { Configuration } from 'webpack';
const ROOT_DIR = path.resolve(__dirname); const ROOT_DIR = path.resolve(__dirname);
@ -10,6 +11,7 @@ const scriptExtensions = /\.(tsx|ts|js|jsx|mjs)$/;
const styleExtensions = /\.(css|less|styl|scss|sass|sss)$/; const styleExtensions = /\.(css|less|styl|scss|sass|sss)$/;
const fontsExtensions = /\.(eot|otf|ttf|woff|woff2)$/; const fontsExtensions = /\.(eot|otf|ttf|woff|woff2)$/;
const fontsAndImagesExtensions = /\.(png|jpg|jpeg|gif|svg|ico|mp4|avi|ttf|otf|eot|woff|woff2|pdf)$/; const fontsAndImagesExtensions = /\.(png|jpg|jpeg|gif|svg|ico|mp4|avi|ttf|otf|eot|woff|woff2|pdf)$/;
const alias = resolveTsAliases(path.resolve("tsconfig.json"));
const config: Configuration = { const config: Configuration = {
target: 'node', target: 'node',
@ -20,11 +22,7 @@ const config: Configuration = {
}, },
resolve: { resolve: {
extensions: ['.js', '.jsx', '.json', '.ts', '.tsx'], extensions: ['.js', '.jsx', '.json', '.ts', '.tsx'],
alias: { alias,
'@components': path.resolve(__dirname, 'src/frontend/components/'),
'@styles': path.resolve(__dirname, 'src/frontend/styles/'),
'@config': path.resolve(__dirname, 'config/'),
},
}, },
module: { module: {
rules: [ rules: [

View File

@ -6,10 +6,12 @@ import MiniCssExtractPlugin from 'mini-css-extract-plugin';
import ReactRefreshWebpackPlugin from '@pmmmwh/react-refresh-webpack-plugin'; import ReactRefreshWebpackPlugin from '@pmmmwh/react-refresh-webpack-plugin';
import ESLintPlugin from 'eslint-webpack-plugin'; import ESLintPlugin from 'eslint-webpack-plugin';
import CopyPlugin from 'copy-webpack-plugin'; import CopyPlugin from 'copy-webpack-plugin';
import { resolveTsAliases } from "resolve-ts-aliases";
const ROOT_DIR = path.resolve(__dirname); const ROOT_DIR = path.resolve(__dirname);
const resolvePath = (...args: string[]) => path.resolve(ROOT_DIR, ...args); const resolvePath = (...args: string[]) => path.resolve(ROOT_DIR, ...args);
const BUILD_DIR = resolvePath('build'); const BUILD_DIR = resolvePath('build');
const alias = resolveTsAliases(path.resolve("tsconfig.json"));
const copyPatterns = [ const copyPatterns = [
{ {
@ -41,11 +43,7 @@ const config: Configuration = {
}, },
resolve: { resolve: {
extensions: ['.js', '.jsx','.ts','.tsx', '.json'], extensions: ['.js', '.jsx','.ts','.tsx', '.json'],
alias: { alias,
'@components': path.resolve(__dirname, '../src/frontend/components/'),
'@styles': path.resolve(__dirname, '../src/frontend/styles/'),
'@config': path.resolve(__dirname, '../config/'),
},
}, },
devtool: 'inline-source-map', devtool: 'inline-source-map',
mode: 'development', mode: 'development',

View File

@ -10,12 +10,14 @@ import { WebpackManifestPlugin } from 'webpack-manifest-plugin';
import { CleanWebpackPlugin } from 'clean-webpack-plugin'; import { CleanWebpackPlugin } from 'clean-webpack-plugin';
import ESLintPlugin from 'eslint-webpack-plugin'; import ESLintPlugin from 'eslint-webpack-plugin';
import CopyPlugin from 'copy-webpack-plugin'; import CopyPlugin from 'copy-webpack-plugin';
import { resolveTsAliases } from "resolve-ts-aliases";
const ROOT_DIR = path.resolve(__dirname); const ROOT_DIR = path.resolve(__dirname);
const resolvePath = (...args) => path.resolve(ROOT_DIR, ...args); const resolvePath = (...args) => path.resolve(ROOT_DIR, ...args);
const BUILD_DIR = resolvePath('build'); const BUILD_DIR = resolvePath('build');
const { InjectManifest } = require('workbox-webpack-plugin'); const { InjectManifest } = require('workbox-webpack-plugin');
const nodeExternals = require('webpack-node-externals'); const nodeExternals = require('webpack-node-externals');
const alias = resolveTsAliases(path.resolve("tsconfig.json"));
const copyPatterns = [ const copyPatterns = [
{ {
@ -50,11 +52,7 @@ const frontendConfig = {
}, },
resolve: { resolve: {
extensions: ['.js', '.jsx','.ts','.tsx', '.json'], extensions: ['.js', '.jsx','.ts','.tsx', '.json'],
alias: { alias,
'@components': path.resolve(__dirname, 'src/frontend/components/'),
'@styles': path.resolve(__dirname, 'src/frontend/styles/'),
'@config': path.resolve(__dirname, 'config/'),
}
}, },
mode: 'production', mode: 'production',
module: { module: {
@ -160,11 +158,7 @@ const serverConfig = {
}, },
resolve: { resolve: {
extensions: ['.js', '.jsx','.ts','.tsx', '.json'], extensions: ['.js', '.jsx','.ts','.tsx', '.json'],
alias: { alias,
'@components': path.resolve(__dirname, 'src/frontend/components/'),
'@styles': path.resolve(__dirname, 'src/frontend/styles/'),
'@config': path.resolve(__dirname, 'config/'),
}
}, },
mode: 'production', mode: 'production',
module: { module: {