A modern club website for KS3CKC (Kansas City Amateur Radio Club) built with Next.js and TypeScript. This application provides club members and visitors with access to club information, events, and amateur radio resources.
This website is built with modern web technologies:
🟦 TypeScript, ⚛️ React, ⚫️ NextJS, ⚡️ Chakra UI, 🟦 tRPC, ▲ Prisma, 🏖️ TanStack Query, 📕 Storybook, 🎭 Playwright, 🐜 Formiz, 🌍 React i18next
Ensure you have the following installed on your development machine:
- NodeJS >=18
- Pnpm
- Docker (or a PostgreSQL database)
- Clone the repository
git clone https://github.com/patrickrb/ks3ckc-website.git
cd ks3ckc-website- Copy environment variables
cp .env.example .envNote
Quick advice for local development
- DON'T update the EMAIL_SERVER variable, because the default value will be used to catch emails during development.
- Install dependencies
pnpm install- Setup and start the database with Docker
pnpm dk:initNote
Don't want to use docker?
Setup a PostgreSQL database (locally or online) and replace the DATABASE_URL environment variable. Then you can run pnpm db:push to update your database schema and then run pnpm db:seed to seed your database.
Start the development environment:
# Run the database in Docker (if not already started)
pnpm dk:start
# Run the development server
pnpm devIn development, the emails will not be sent and will be catched by maildev.
The maildev UI is available at 0.0.0.0:1080.
Emails templates are built with react-email components in the src/emails folder.
You can preview an email template at http://localhost:3000/devtools/email/{template} where {template} is the name of the template file in the src/emails/templates folder.
Example: Login Code
Add the language in the preview url like http://localhost:3000/devtools/email/{template}/{language} where {language} is the language key (en, fr, ...)
You can add search params to the preview url to pass as props to the template.
http://localhost:3000/devtools/email/{template}/?{propsName}={propsValue}
pnpm storybookWhen adding or updating theme components, component variations, sizes, colors and other theme foundations, you can extend the internal theme typings to provide nice autocomplete.
Just run the following command after updating the theme:
pnpm theme:generate-typingPut the custom svg files into the src/components/Icons/svg-sources folder and then run the following command:
pnpm theme:generate-iconsWarning
All svg icons should be svg files prefixed by icon- (example: icon-externel-link) with 24x24px size, only one shape and filled with #000 color (will be replaced by currentColor).
You can update the storage key used to detect the color mode by updating this constant in the src/theme/config.ts file:
export const COLOR_MODE_STORAGE_KEY = 'ks3ckc-color-mode'; // Update the key according to your needsE2E tests are setup with Playwright.
pnpm e2e     # Run tests in headless mode, this is the command executed in CI
pnpm e2e:ui  # Open a UI which allow you to run specific tests and see test executionTests are written in the e2e folder; there is also a e2e/utils folder which contains some utils to help writing tests.
To show environment indicators during development, set these environment variables:
NEXT_PUBLIC_DEV_ENV_NAME="staging"
NEXT_PUBLIC_DEV_ENV_COLOR_SCHEME="teal"This will display visual indicators in your app to distinguish between different environments.
We recommended using the i18n Ally plugin for VS Code for translations management.
Create or edit the .vscode/settings.json file with the following settings:
{
  "i18n-ally.localesPaths": ["src/locales"],
  "i18n-ally.keystyle": "nested",
  "i18n-ally.enabledFrameworks": ["general", "react", "i18next"],
  "i18n-ally.namespace": true,
  "i18n-ally.defaultNamespace": "common",
  "i18n-ally.extract.autoDetect": true,
  "i18n-ally.keysInUse": ["common.languages.*"]
}This website is deployed on Vercel for seamless continuous deployment.
- Production: Pushes to the mainbranch are automatically deployed to production
- Preview: Pull requests automatically generate preview deployments
- The application uses Vercel's built-in PostgreSQL database and environment variables
The following environment variables are required for production deployment:
- DATABASE_URL- PostgreSQL connection string
- AUTH_SECRET- Authentication secret (generate with- openssl rand -base64 32)
- EMAIL_SERVER- SMTP server configuration
- EMAIL_FROM- From email address
- CLOUDLOG_API_KEY- (Optional) CloudLog API integration
- CLOUDLOG_API_URL- (Optional) CloudLog API URL
For manual deployments or other hosting providers:
pnpm install
pnpm build
pnpm startTo test a production build locally:
pnpm install
pnpm build
pnpm startTo include Storybook in your build:
pnpm storybook:build # Will expose Storybook at `/storybook`- Build the Docker image
docker build -t ks3ckc-website .- Run the Docker image
docker run -p 80:3000 ks3ckc-websiteThe application will be available at http://localhost.
We welcome contributions to the KS3CKC website! Please see our GitHub Actions for automated code quality checks and testing that run on all pull requests.
- Linting: ESLint and TypeScript checks run automatically
- Testing: Playwright E2E tests ensure functionality
- Formatting: Prettier maintains consistent code style
- Patrick Burns - @patrickrb
- Reid Crowe - @Reid-n0rc
This project is licensed under the MIT License - see the package.json file for details.