data:image/s3,"s3://crabby-images/cceee/cceee3531a13a0b627e7eb16dfda2bea7499241c" alt="Logo"
gittech. site
for different kinds of informations and explorations.
PageZERO β Full-Stack Web App Starter for Cloudflare
PageZERO
An open-source TypeScript starter for full-stack web development on Cloudflare.
Guiding principles:
- Easy to learn
- Fast to build
- Pleasure to develop
- Cheap to maintain
β‘οΈ Quick start
In 4 steps:
git clone --depth 1 https://github.com/pagezero-dev/pagezero.git <your-project-name>
cd <your-project-name>
npm run setup
npm run dev
You should be able to access http://localhost:3000/ development page now.
If you wish to start a new GitHub repository based on PageZero:
gh repo create <your-project-name> -c --template pagezero-dev/pagezero
βΉοΈ Above command requires GitHub CLI
π§βπ» The stack
Building on strong foundations:
- Vite
- React
- Cloudflare Pages (hosting)
- Cloudflare D1 (database)
- TypeScript
- TailwindCSS
- React Router v7
- Drizzle ORM
- Github Actions
- Prettier
- ESLint
- Vitest
- Playwright
- Storybook
- MDX
β¨ Scripts
Essential npm scripts:
npm run setup
- performs npm install, setups basic env vars, database and playwright browser driversnpm run dev
- boots development servernpm run build
- builds the appnpm start
- runs built app; this is how your app will be run on productionnpm test
- executes unit testsnpm run test:types
- typescript types checknpm run test:e2e:ui
- executes browser tests in UI mode, perfect for developmentnpm run lint
- eslint checknpm run format
- prettier checknpm run storybook
- boots Storybooknpm run doctor
- runs all basic sanity checks: format, lint, types check and unit tests
π Deployment
Deployment in PageZERO happens through the GitHub Actions CI/CD pipeline. That means once the pipeline is set,
every merge to the main
branch will trigger deployment to Cloudflare Pages and database migration for Cloudflare D1.
Additionally, every PR will trigger "preview deployment", so you can access the version of your app for every PR. More about preview deployments: https://developers.cloudflare.com/pages/configuration/preview-deployments/.
The database for preview deployments is shared. If you wish to reset it, you can manually trigger the "Reset preview database" workflow in GitHub Actions.
However, to make it all work, we must go through a few setup steps...
Cloudflare services setup
- If you don't have Cloudflare account yet, create one
- In the Cloudflare dashboard, go to "Storage & Databases / D1 SQL Database"
- Create 2 databases:
<project-name>_production
and<project-name>_preview
- In the Cloudflare dashboard, go to "Compute (Workers) / Workers & Pages"
- Create a new "Pages" project through "Create using direct upload" method; however, do not upload any assets
- Once the "Pages" project is created, open up the project from the "Workers & Pages" list
- In the "Settings" section, for the "production" environment, create:
- The following variables:
APP_ENV=production
DB_BINDING=DB_PRODUCTION
- Bindings:
- [D1 database]
DB_PRODUCTION=<project-name>_production
- [D1 database]
- The following variables:
- In the "Settings" section, for the "preview" environment, create:
- The following variables:
APP_ENV=preview
DB_BINDING=DB_PREVIEW
- Bindings:
- [D1 database]
DB_PREVIEW=<project-name>_preview
- [D1 database]
- The following variables:
GitHub actions setup
The only thing we need to do on the GitHub side is to set proper secrets and variables in your GitHub project "Settings". This will allow GitHub actions to perform deploys to Cloudflare Pages and migrations for your Cloudflare D1 database.
In "Settings / Secrets and variables / Actions", set the following VARIABLES:
Variable name | Value |
---|---|
CLOUDFLARE_PROJECT_NAME | Your Cloudflare Pages project name |
DB_NAME_PRODUCTION | <project-name>_production |
DB_NAME_PREVIEW | <project-name>_preview |
CLOUDFLARE_DATABASE_ID_PRODUCTION | Cloudflare D1 production database ID |
CLOUDFLARE_DATABASE_ID_PREVIEW | Cloudflare D1 preview database ID |
CLOUDFLARE_ACCOUNT_ID | Your Cloudflare account ID |
βΉοΈ Database IDs can be obtained through the Cloudflare dashboard under "Storage & Databases / D1 SQL Database"
βΉοΈ Cloudflare account ID can be obtained through the Cloudflare dashboard under "Compute (Workers) / Workers & Pages" in the right sidebar
In "Settings / Secrets and variables / Actions", set the following SECRETS:
Variable name | Value |
---|---|
CLOUDFLARE_API_TOKEN | Cloudflare API token |
βΉοΈ Cloudflare API token can be obtained through the Cloudflare dashboard under "Manage account / Account API Tokens". You have to create the token there. The token will require the following permissions: D1:Edit, Cloudflare Pages:Edit.
In "Settings / Secrets and variables / Dependabot", set the following SECRETS:
Variable name | Value |
---|---|
CLOUDFLARE_API_TOKEN | Cloudflare API token |
βΉοΈ Dependabot has a separate set of secrets, so to make preview deployments work for Dependabot PRs, you will need to set the
CLOUDFLARE_API_TOKEN
secret for Dependabot.
Test everything out
Now, you can test everything out. Create a PR in your project GitHub repository. You should notice an action in the "Actions" section being triggered. If the basic checks pass, the workflow will perform preview deployment to GitHub pages and database migration on your preview database. After deployment, the "View deployment" button should appear in your PR, with a link to your PR "preview" deployment.
When you merge PR to "main", production deployment will happen, and database migration will be performed on your production DB.