From 00117fe74a7b13890f93ed17c374bf60aae4a12c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C3=ABl=20De=20Boey?= Date: Wed, 6 Sep 2023 21:54:26 +0200 Subject: [PATCH] feat: move to ESM --- .eslintrc.js => .eslintrc.cjs | 6 +++--- README.md | 2 +- cypress/{.eslintrc.js => .eslintrc.cjs} | 0 mocks/index.js | 4 ++-- package.json | 7 ++++--- postcss.config.js | 2 +- prettier.config.js | 2 +- remix.config.js | 3 +-- tsconfig.json | 2 +- 9 files changed, 14 insertions(+), 14 deletions(-) rename .eslintrc.js => .eslintrc.cjs (96%) rename cypress/{.eslintrc.js => .eslintrc.cjs} (100%) diff --git a/.eslintrc.js b/.eslintrc.cjs similarity index 96% rename from .eslintrc.js rename to .eslintrc.cjs index 7c1ad563..17dd597e 100644 --- a/.eslintrc.js +++ b/.eslintrc.cjs @@ -110,9 +110,9 @@ module.exports = { }, settings: { jest: { - // we're using vitest which has a very similar API to jest - // (so the linting plugins work nicely), but it means we have to explicitly - // set the jest version. + // We're using vitest which has a very similar API to jest + // (so the linting plugins work nicely), but it means we + // have to set the jest version explicitly. version: 28, }, }, diff --git a/README.md b/README.md index a2cd9754..0ddfe554 100644 --- a/README.md +++ b/README.md @@ -213,7 +213,7 @@ This project uses TypeScript. It's recommended to get TypeScript set up for your ### Linting -This project uses ESLint for linting. That is configured in `.eslintrc.js`. +This project uses ESLint for linting. That is configured in `.eslintrc.cjs`. ### Formatting diff --git a/cypress/.eslintrc.js b/cypress/.eslintrc.cjs similarity index 100% rename from cypress/.eslintrc.js rename to cypress/.eslintrc.cjs diff --git a/mocks/index.js b/mocks/index.js index ca2210ce..2cbbbe76 100644 --- a/mocks/index.js +++ b/mocks/index.js @@ -1,5 +1,5 @@ -const { http, passthrough } = require("msw"); -const { setupServer } = require("msw/node"); +import { http, passthrough } from "msw"; +import { setupServer } from "msw/node"; // put one-off handlers that don't really need an entire file to themselves here const miscHandlers = [ diff --git a/package.json b/package.json index c3559b7a..0b206550 100644 --- a/package.json +++ b/package.json @@ -2,20 +2,21 @@ "name": "blues-stack-template", "private": true, "sideEffects": false, + "type": "module", "scripts": { "build": "npm-run-all --sequential build:*", "build:remix": "remix build", - "build:server": "esbuild --platform=node --format=cjs ./server.ts --outdir=build --bundle --external:fsevents", + "build:server": "esbuild --platform=node --format=esm ./server.ts --outdir=build --bundle --external:fsevents", "dev": "npm-run-all --parallel dev:*", "dev:server": "cross-env NODE_ENV=development npm run build:server -- --watch", - "dev:remix": "remix dev --manual -c \"node --require ./mocks --watch-path ./build/server.js --watch ./build/server.js\"", + "dev:remix": "remix dev --manual -c \"node --import ./mocks/index.js --watch-path ./build/server.js --watch ./build/server.js\"", "docker": "docker compose up -d", "format": "prettier --write .", "format:repo": "npm run format && npm run lint -- --fix", "lint": "eslint --cache --cache-location ./node_modules/.cache/eslint .", "setup": "prisma generate && prisma migrate deploy && prisma db seed", "start": "cross-env NODE_ENV=production node ./build/server.js", - "start:mocks": "cross-env NODE_ENV=production node --require ./mocks --require dotenv/config ./build/server.js", + "start:mocks": "cross-env NODE_ENV=production node --import ./mocks/index.js --import dotenv/config ./build/server.js", "test": "vitest", "test:e2e:dev": "start-server-and-test dev http://localhost:3000 \"npx cypress open\"", "pretest:e2e:run": "npm run build", diff --git a/postcss.config.js b/postcss.config.js index 12a703d9..2aa7205d 100644 --- a/postcss.config.js +++ b/postcss.config.js @@ -1,4 +1,4 @@ -module.exports = { +export default { plugins: { tailwindcss: {}, autoprefixer: {}, diff --git a/prettier.config.js b/prettier.config.js index 776594f0..fb6fba22 100644 --- a/prettier.config.js +++ b/prettier.config.js @@ -1,4 +1,4 @@ /** @type {import("prettier").Config} */ -module.exports = { +export default { plugins: ["prettier-plugin-tailwindcss"], }; diff --git a/remix.config.js b/remix.config.js index 29582b29..4047ae45 100644 --- a/remix.config.js +++ b/remix.config.js @@ -1,6 +1,5 @@ /** @type {import('@remix-run/dev').AppConfig} */ -module.exports = { +export default { cacheDirectory: "./node_modules/.cache/remix", ignoredRouteFiles: ["**/.*", "**/*.test.{ts,tsx}"], - serverModuleFormat: "cjs", }; diff --git a/tsconfig.json b/tsconfig.json index c0a761dd..17bce856 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -7,7 +7,7 @@ "isolatedModules": true, "esModuleInterop": true, "jsx": "react-jsx", - "module": "CommonJS", + "module": "ES2020", "moduleResolution": "node", "resolveJsonModule": true, "target": "ES2020",