We use superplate CLI with the following settings:
✔ Features: · fetch,axios,storybook,svgr,env
✔ Hooks · react-query
✔ State Management: · redux
✔ Do you want to use RTK Query ? · none
✔ i18n – Internationalization · next-i18next
✔ Linting tools: · eslint,prettier
✔ Do you want to use lint-staged? · lint-staged
✔ Testing Framework: · testing-library
✔ E2E Testing framework: · cypress
✔ Docker integration: · Docker
✔ Continuous integration: · github-actions
data:image/s3,"s3://crabby-images/e6fc6/e6fc6d2c1ea69fdb6ef9498877e478579ee863b5" alt=""
data:image/s3,"s3://crabby-images/f12cc/f12ccf3db032b646fd5ec58d9acb5002c1c9cb8f" alt=""
data:image/s3,"s3://crabby-images/9bb38/9bb3886a49dc671e9e237e37326cab185d910644" alt=""
data:image/s3,"s3://crabby-images/568a3/568a39bff1d3e332e4fb6655be9a55965372544a" alt=""
data:image/s3,"s3://crabby-images/622db/622db24787bde4b2c0bfcfc3e930383e24f94115" alt=""
why next-i18next: Next.js — The Scalable Way to Internationalize Using next-i18next
data:image/s3,"s3://crabby-images/94625/946253aa5a2c7575cefbfaa70358e319986cd511" alt=""
data:image/s3,"s3://crabby-images/0d6bb/0d6bb42658c8093f84ff4943e0d14d06fa2bc0db" alt=""
data:image/s3,"s3://crabby-images/cea49/cea491262d5b9b30437eccc3ea6af588b1518291" alt=""
Why RTL and not “pure Jest”? Cypress vs. RTL.
We can still use Cypress later if RTL is not enough.
data:image/s3,"s3://crabby-images/9e2bb/9e2bb65d86247e3febb7dfb8b41b8971808e801a" alt=""
data:image/s3,"s3://crabby-images/10abf/10abf98260043c486c1326631a566f9f6e3d083f" alt=""
data:image/s3,"s3://crabby-images/b45f1/b45f19770b3e0da1c33b9ac14f2dd5628440e33b" alt=""
Then:
- Upgrade Node.js to v11 or later
- Upgrade next-i18next to v8 or later
- Replace .prettierrc with NestJS style:
{
"singleQuote": true,
"arrowParens": "avoid",
"trailingComma": "all"
}
Use yarn v3+:
yarn set version berry
Change .gitignore to https://www.toptal.com/developers/gitignore/api/windows,macos,linux,visualstudiocode,node,yarn,react .
But use NON-Zero Install:
# if you are NOT using Zero-installs, then:
# comment the following lines
# !.yarn/cache
# and uncomment the following lines
.pnp.*
Use .yarnrc
without nodeLinker: node_modules
to use PnP mode.
To support VS Code:
yarn dlx @yarnpkg/sdks vscode
Change your VSCode workspace configuration to add the following:
"settings": {
"typescript.tsdk": "tmra-next/.yarn/sdks/typescript/lib"
}
Then Ctrl+Shift+P > Select TypeScript version… > Use Workspace Version.
When building in CI, use: yarn install --immutable
React Router Server Side Rendering (SSR) in Next.js
TL;DR: Don’t. Just use Next.js routing with next/link and next/router.
Alternatives: https://ui.dev/react-router-server-rendering/
Troubleshooting: Error Importing CSS
error - ./pages/_app.tsx:2:0
Module not found: Can't resolve 'simplebar/src/simplebar.css'
1 | // scroll bar
> 2 | import 'simplebar/src/simplebar.css';
Solution: Add to tsconfig.json: (then restart yarn dev)
"allowSyntheticDefaultImports": true,
Troubleshooting: NextJS stuck with “build page: /next/dist/pages/_error” and “compiled successfully”
Problem:
event - build page: /next/dist/pages/_error
event - build page: /next/dist/pages/_error
event - compiled successfully
Cause: Yarn’s nodeLinker is pnp. See next.js#21828.
Workaround:
Better workaround: yarn unplug next
from https://github.com/vercel/next.js/issues/21828#issuecomment-782014156
Older workaround: Edit .yarnrc.yml and change nodeLinker: node-modules.
You can reenable pnp after it’s working again.
Troubleshooting: Type error: Property ‘borderRadiusMd’ does not exist on type ‘Shape’. Did you mean ‘borderRadius’?
Invalid module name in augmentation, module '@mui/system' cannot be found.ts(2664)
module "@mui/system"
Cause: Declaration merging not working due to specified module not added to package.json.
Partial Solution 1: yarn add @mui/system
Partial Solution 2: yarn unplug @mui/system then “re-plug” by editing package.json dependenciesMeta
./src/components/_external-pages/landing/LandingAdvertisement.tsx:15:29
Type error: Property 'borderRadiusMd' does not exist on type 'Shape'. Did you mean 'borderRadius'?
13 | overflow: 'hidden',
14 | paddingBottom: theme.spacing(10),
> 15 | borderRadius: theme.shape.borderRadiusMd,
| ^
16 | backgroundImage: `linear-gradient(135deg,
17 | ${theme.palette.primary.main} 0%,
18 | ${theme.palette.primary.dark} 100%)`,
info - Checking validity of types
Cause: ?
Workaround: ?