$ Budget
Using the REMIX RACE STACK. Learn more about Remix Stacks here.
- Cloudflare Pages for hosting
- Cloudflare D1 and Drizzle ORM for database
- Email/Password Authentication with remix-auth - easily extensible to other auth providers like github, google etc.
- Styling with Tailwind, shadcn/ui, Radix-UI, and Lucide Icons
- Dark mode using cookies
- Posthog for analytics, can be easily changed to another analytics provider. Analytics are only imported when user opts in.
- Form validation with remix-validation-form and zod
- Code formatting with Prettier
- Linting with ESLint
- Static Types with TypeScript
Want to modify something on the stack? Create an issue or fork it, change it, and use npx create-remix --template your/repo
! Make it your own.
This project uses D1 for its database. Steps are straightforward and can be found in the D1 docs. If the following doesn't work, please refer to the docs mentioned above. We will be utilizing Wrangler for local development to emulate the Cloudflare runtime.
- Install wrangler -
npm install -g wrangler
- Create a new D1 database named
race-stack
(or whatever you want to name it) -wrangler d1 create race-stack
- Make sure your wrangler.toml file has the correct database name and id (check ./wrangler.toml for an example)
- Modify your drizzle schema
app/lib/schema.ts
to match your needs - Run
npm run generate
to generate your sql file - Run
wrangler d1 execute race-stack --local --file=./drizzle/<file>.sql
to migrate your database - Install project dependencies -
npm install
- Start the server -
npm run dev
Open up http://127.0.0.1:8788 and you should be ready to go!
This is a simple app, but it's a good example of how you can build a full stack app with Remix fully deployed on the edge using Cloudflare products. The main functionality is creating users, logging in and out, and creating teams that may include one or more users. The code that handles this is in:
- drizzle database schema ./app/lib/schema.ts
- auth for login ./app/lib/auth.server.ts and ./app/routes/login.tsx
- auth for register ./app/routes/register.tsx
- creating teams ./app/routes/app.teams.new
- Fork this repo
- If you don't already have an account, then create a Cloudflare account here and after verifying your email address with Cloudflare, go to your dashboard and follow the Cloudflare Pages deployment guide.
- Connect your forked repo to your new Cloudflare Pages project
- Create a new D1 database named
race-stack
(or whatever you want to name it) -wrangler d1 create race-stack
- Make sure your wrangler.toml file has the correct database name and id (check ./wrangler.toml for an example)
- Go into the project settings in Cloudflare Pages project, visit the functions tab, and create a D1 database binding. Variable name should be
DB
and the value should be the database name you got from step 1. - Deploy the database by running
wrangler d1 execute race-stack --file=./drizzle/<file>.sql
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.