Skip to content

Commit

Permalink
chore: bring in line with latest arc template (#165)
Browse files Browse the repository at this point in the history
  • Loading branch information
MichaelDeBoey authored Sep 7, 2023
1 parent af4c898 commit efb2440
Show file tree
Hide file tree
Showing 15 changed files with 95 additions and 28 deletions.
1 change: 0 additions & 1 deletion .env.example
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
NODE_ENV="development"
SESSION_SECRET="super-duper-s3cret"
6 changes: 3 additions & 3 deletions .eslintrc.js → .eslintrc.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,9 @@ module.exports = {
"cypress/globals": true,
},
plugins: ["cypress"],
// we're using vitest which has a very similar API to jest
// (so the linting plugins work nicely), but it 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.
settings: {
jest: {
version: 28,
Expand Down
2 changes: 1 addition & 1 deletion .eslintrc.repo.js → .eslintrc.repo.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ const WARN = 1;
/** @type {import('eslint').Linter.Config} */
module.exports = {
extends: [
"./.eslintrc.js",
"./.eslintrc.cjs",
"@remix-run/eslint-config/internal",
"plugin:markdown/recommended",
],
Expand Down
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ pnpm-lock.yml
node_modules

/public/build
/server/index.mjs
/server/index.mjs.map
/server/metafile.*
preferences.arc
sam.json
sam.yaml
Expand Down
12 changes: 10 additions & 2 deletions app.arc
Original file line number Diff line number Diff line change
@@ -1,15 +1,23 @@
@app
grunge-stack-template

# @aws
# region us-east-2
@aws
runtime nodejs16.x
# concurrency 1
# memory 1152
# profile default
# region us-west-1
# timeout 30

@http
/*
method any
src server

@plugins
plugin-remix
src plugin-remix.js

@static

@tables
Expand Down
3 changes: 1 addition & 2 deletions app/root.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,6 @@ import stylesheet from "~/tailwind.css";
export const links: LinksFunction = () => [
{ rel: "stylesheet", href: stylesheet },
...(cssBundleHref ? [{ rel: "stylesheet", href: cssBundleHref }] : []),
// NOTE: Architect deploys the public directory to /_static/
{ rel: "icon", href: "/_static/favicon.ico" },
];

export const loader = async ({ request }: LoaderArgs) => {
Expand All @@ -30,6 +28,7 @@ export default function App() {
<head>
<meta charSet="utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1" />
<link rel="icon" href="/_static/favicon.ico" />
<Meta />
<Links />
</head>
Expand Down
File renamed without changes.
12 changes: 10 additions & 2 deletions mocks/index.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,14 @@
const { setupServer } = require("msw/node");
import { rest } from "msw";
import { setupServer } from "msw/node";

const server = setupServer();
// put one-off handlers that don't really need an entire file to themselves here
const miscHandlers = [
rest.post(`${process.env.REMIX_DEV_HTTP_ORIGIN}/ping`, (req) =>
req.passthrough(),
),
];

const server = setupServer(...miscHandlers);

server.listen({ onUnhandledRequest: "bypass" });

Expand Down
6 changes: 4 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,15 @@
"name": "grunge-stack-template",
"private": true,
"sideEffects": false,
"type": "module",
"scripts": {
"build": "remix build",
"dev": "remix dev --manual -c \"arc sandbox -e testing\"",
"format": "prettier --write .",
"format:repo": "npm run format && npm run lint:repo -- --fix",
"lint": "eslint --cache --cache-location ./node_modules/.cache/eslint .",
"lint:repo": "npm run lint -- --config ./.eslintrc.repo.js",
"lint:repo": "npm run lint -- --config ./.eslintrc.repo.cjs",
"start": "cross-env NODE_ENV=production arc sandbox",
"test": "vitest",
"test:e2e:dev": "start-server-and-test dev http://localhost:3000 \"npx cypress open\"",
"test:e2e:run": "cross-env PORT=8811 start-server-and-test dev http://localhost:8811 \"npx cypress run\"",
Expand Down Expand Up @@ -75,6 +77,6 @@
"vitest": "^0.34.2"
},
"engines": {
"node": ">=14"
"node": ">=14.0.0"
}
}
49 changes: 49 additions & 0 deletions plugin-remix.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
// This should eventually be a npm package, but for now it lives here.
// Its job is to notify the remix dev server of the version of the running
// app to trigger HMR / HDR.

import * as fs from "node:fs";
import * as path from "node:path";

import { logDevReady } from "@remix-run/node";

const buildPath = "server/index.mjs";

let lastTimeout;

export default {
sandbox: {
async watcher() {
if (lastTimeout) {
clearTimeout(lastTimeout);
}

lastTimeout = setTimeout(async () => {
const contents = fs.readFileSync(
path.resolve(process.cwd(), buildPath),
"utf8"
);
const manifestMatches = contents.matchAll(/manifest-([A-f0-9]+)\.js/g);
const sent = new Set();
for (const match of manifestMatches) {
const buildHash = match[1];
if (!sent.has(buildHash)) {
sent.add(buildHash);
logDevReady({ assets: { version: buildHash } });
}
}
}, 300);
},
},
set: {
env() {
// Pass matching env variables through to the application in dev mode.
const passthruKeys = /^NODE_ENV$|^REMIX_DEV_/;
return {
testing: Object.fromEntries(
Object.entries(process.env).filter(([key]) => passthruKeys.test(key))
),
};
},
},
};
File renamed without changes.
19 changes: 9 additions & 10 deletions remix.config.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
const path = require("path");
import path from "node:path";

/** @type {import('@remix-run/dev').AppConfig} */
module.exports = {
export default {
cacheDirectory: "./node_modules/.cache/remix",
future: {
v2_dev: true,
Expand All @@ -14,22 +14,21 @@ module.exports = {
ignoredRouteFiles: ["**/.*", "**/*.test.{js,jsx,ts,tsx}"],
publicPath: "/_static/build/",
postcss: true,
server: "./server.ts",
serverBuildPath: "server/index.js",
serverModuleFormat: "cjs",
server: "server.ts",
serverBuildPath: "server/index.mjs",
serverModuleFormat: "esm",
tailwind: true,
routes(defineRoutes) {
return defineRoutes((route) => {
routes: (defineRoutes) =>
defineRoutes((route) => {
if (process.env.NODE_ENV === "production") return;

console.log("⚠️ Test routes enabled.");

const appDir = path.join(__dirname, "app");
const appDir = path.join(process.cwd(), "app");

route(
"__tests/create-user",
path.relative(appDir, "cypress/support/test-routes/create-user.ts"),
);
});
},
}),
};
6 changes: 3 additions & 3 deletions remix.init/gitignore
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
node_modules

/server/index.js
/server/index.js.map
/server/metafile.*
/public/build
/server/index.mjs
/server/index.mjs.map
/server/metafile.*
preferences.arc
sam.json
sam.yaml
Expand Down
2 changes: 1 addition & 1 deletion remix.init/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ const main = async ({ isTypeScript, packageManager, rootDirectory }) => {
fs.rm(path.join(rootDirectory, ".github", "workflows", "no-response.yml")),
fs.rm(path.join(rootDirectory, ".github", "dependabot.yml")),
fs.rm(path.join(rootDirectory, ".github", "PULL_REQUEST_TEMPLATE.md")),
fs.rm(path.join(rootDirectory, ".eslintrc.repo.js")),
fs.rm(path.join(rootDirectory, ".eslintrc.repo.cjs")),
fs.rm(path.join(rootDirectory, "LICENSE.md")),
];

Expand Down
2 changes: 1 addition & 1 deletion tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
"isolatedModules": true,
"esModuleInterop": true,
"jsx": "react-jsx",
"module": "CommonJS",
"module": "ES2020",
"moduleResolution": "node",
"resolveJsonModule": true,
"target": "ES2019",
Expand Down

0 comments on commit efb2440

Please sign in to comment.