Fredagslunchen is a app where you can create groups to rate your lunches together.
-
Initial setup:
npm run setup
The database seed script creates a new user with some data you can use to get started:
- Email:
[email protected]
- Password:
woopwoop
Start dev server:
npm run dev
This starts your app in development mode, rebuilding assets on file changes.
We use Prisma to manage our database migrations. To create a new migration:
prisma migrate dev --name migration-name
To make changes to the database schema without creating a migration (for prototyping etc):
prisma db push
Commit your changes by creating a new migration.
Note: This will force you to reset your local db. See Schema prototyping with db push for more details.
We have an overview of all available components on the /kitchensink
route. If you add a new component, add an example of how it's used on this route as well.
There's two GitHub Actions that handle automatically deploying to production and staging environments.
Prior to the first deployment, you'll need to do a few things:
-
Sign up and log in to Fly
fly auth signup
Note: If you have more than one Fly account, ensure that you are signed into the same account in the Fly CLI as you are in the browser. In your terminal, run
fly auth whoami
and ensure the email matches the Fly account signed into the browser. -
Create two apps on Fly, one for staging and one for production:
fly create fredagslunchen-something fly create fredagslunchen-something-staging
-
Add a
FLY_API_TOKEN
to your GitHub repo. To do this, go to your user settings on Fly and create a new token, then add it to your repo secrets with the nameFLY_API_TOKEN
. -
Add a
SESSION_SECRET
to your fly app secrets, to do this you can run the following commands:fly secrets set SESSION_SECRET=$(openssl rand -hex 32) --app fredagslunchen-something fly secrets set SESSION_SECRET=$(openssl rand -hex 32) --app fredagslunchen-something-staging
If you don't have openssl installed, you can also use 1password to generate a random secret, just replace
$(openssl rand -hex 32)
with the generated secret. -
Create a persistent volume for the sqlite database for both your staging and production environments. Run the following:
fly volumes create data --size 1 --app fredagslunchen-something fly volumes create data --size 1 --app fredagslunchen-something-staging
Now that everything is set up you can commit and push your changes to your repo. Every commit to your main
branch will trigger a deployment to your production environment, and every commit to your dev
branch will trigger a deployment to your staging environment.
The sqlite database lives at /data/sqlite.db
in your deployed application. You can connect to the live database by running fly ssh console -C database-cli
.
We use GitHub Actions for continuous integration and deployment. Anything that gets into the main
branch will be deployed to production after running tests/build/etc. Anything in the dev
branch will be deployed to staging.
For lower level tests of utilities and individual components, we use vitest
. We have DOM-specific assertion helpers via @testing-library/jest-dom
.
This project uses TypeScript. It's recommended to get TypeScript set up for your editor to get a really great in-editor experience with type checking and auto-complete. To run type checking across the whole project, run npm run typecheck
.
This project uses ESLint for linting. That is configured in .eslintrc.js
.
We use Prettier for auto-formatting in this project. It's recommended to install an editor plugin (like the VSCode Prettier plugin) to get auto-formatting on save. There's also a npm run format
script you can run to format all files in the project.