Next Template
Tech Tracker

How to run:

Clone the Repository & Install Dependencies

git clone https://git.gbrown.org/gib/techtracker.git
cd techtracker

I would recommend using bun to install dependencies.

bun i

You will also need docker installed on whatever host you plan to run the Supabase instance from, whether locally, or on a home server or a VPS or whatever. Or you can just use the Supabase SaaS if you want to have a much easier time, probably. I wouldn't know!

Add your environment variables

Copy the example environment variable files and paste them in the same directory named .env.

cp ./env.example ./.env
cp ./host/convex/docker/env.example ./host/convex/docker/.env

Start self hosted convex

The basic gist is to run the commands below after you have filled out the environment variables you plan to use, but you should ultimately follow the guide they provide

cd ./host/convex/docker
sudo docker compose up -d
sudo docker compose exec convex-backend ./generate_admin_key.sh

Start your development environment.

Run

bun dev

to start your development environment with turbopack

You can also run

bun dev:slow

to start your development environment with webpack

Start your Production Environment.

There are Dockerfiles & docker compose files that can be found in the ./scripts/docker folder for the Next.js website. There is also a script called reload_container located in the ./scripts/ folder which was created to quickly update the container, but this will give you a better idea of what you need to do. First, build the image with

sudo docker compose -f ./host/next/docker/compose.yml build

then you can run the container with

sudo docker compose -f ./host/next/docker/compose up -d

Now, you may end up with some build errors. The reload_containers script swaps out the next config before it runs the docker build to skip any build errors, so you may want to do this as well, though you are welcome to fix the build errors as well, of course!

Fin

I am sure I am missing a lot of stuff so feel free to open an issue if you have any questions or if you feel that I should add something here!

Description
Tech Tracker using Next.js App Router & Self Hosted Convex.
Readme 318 KiB
Languages
TypeScript 79%
JavaScript 12.1%
CSS 8.9%