Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ThijmenGThN/directus-themebuilder
✦ A Theme Builder for Directus
https://github.com/ThijmenGThN/directus-themebuilder
directus docker nextjs tailwind theme-builder
Last synced: about 2 months ago
JSON representation
✦ A Theme Builder for Directus
- Host: GitHub
- URL: https://github.com/ThijmenGThN/directus-themebuilder
- Owner: ThijmenGThN
- License: mit
- Created: 2022-11-18T19:19:20.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-12-08T16:13:41.000Z (about 1 year ago)
- Last Synced: 2024-11-30T09:33:59.522Z (about 2 months ago)
- Topics: directus, docker, nextjs, tailwind, theme-builder
- Language: TypeScript
- Homepage: https://heuve.link/directus-themebuilder
- Size: 510 KB
- Stars: 44
- Watchers: 1
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
### A Theme Builder for Directus
Customizing the Directus app with a specific color can be a hassle due to the need to convert the color to a CSS object. To simplify this process, a web application has been built that offers an easier way to apply a custom color using a color converter. The application eliminates the need to go through the tedious process of converting a single color and provides a more efficient solution. Try it out by clicking on the link below.
> _**TLDR**: Easier way to apply a custom color with a webapp color converter._
**https://heuve.link/directus-themebuilder**
![Preview](https://i.imgur.com/TjqUTRp.png)
# Build with
- NextJS [(site)](https://nextjs.org)
- NextAuth [(site)](https://next-auth.js.org/)
- Prisma [(site)](https://www.prisma.io)
- TailwindCSS [(site)](https://tailwindcss.com)# Getting started
## Dependencies
- NodeJS [(site)](https://nodejs.org) ` >16.8 `
- Docker [(site)](https://docker.com/get-started/) ` >24 `
- Docker Compose [(site)](https://docs.docker.com/compose/install) ` >1.28 `## Setup
1. Clone the repository to your system.
```sh
git clone https://github.com/ThijmenGThN/next-leaflet
```
```sh
cd next-leaflet
```2. Preparing the environment, it is recommend to use the sample file.
```sh
cp sample.env .env
```
```sh
nano .env
```3. Install the required dependencies, by default we do this with yarn.
```
yarn install
```
> Don't have yarn installed?
> You can install it via npm.
> ```sh
> npm i -g yarn
> ```## Development
1. Running Next.js in devmode.
```sh
yarn dev
```2. Starting the database.
```sh
docker-compose up -d
```
> A fresh installation needs an additional step.
> Apply prisma's schema to the database.
> ```sh
> npx prisma db push
> ```## Deployment
To deploy next-leaflet we use docker by default, if you'd like to do it without docker, follow the Development procedure whilst changing step 1 to ` yarn deploy `.
> Set the right variables.
> Ensure that ` COMPOSE_PROFILES ` has been set to ` prod ` in the environment file so docker knows to also deploy the ` app ` service alongside the ` database `.
>
> Also make sure that the ` PRISMA_CONNECTOR ` has been set right, the default "localhost" won't work in deployment, instead replace it with "database".0. Pull down any existing services that might run in the background.
```sh
docker-compose down
```1. Start next-leaflet in deployment-mode.
```sh
docker-compose up -d
```> next-leaflet should (after a while) go up on port ` 3000 `.
> Display the console logs if the service is not going online. Do take note that the port might differ if adjusted in the environment file.
> ```sh
> docker-compose logs
> ```### GitHub Actions
Setting up CI/CD with next-leaflet is not only a breeze to setup but also very useful to eliminate deployment steps.
This setup will guide you to deploy your next-leaflet app on an ssh-accessible host.
#### Configure environment variables
0. Requirements
- Ensure that you have access to an active GitHub Actions (runner).
- Install docker(-compose) on the server you'd like to deploy next-leaflet on.
- Docker [(site)](https://docker.com/get-started/) ` >24 `
- Docker Compose [(site)](https://docs.docker.com/compose/install) ` >1.28 `1. Within GitHub navigate to ` Settings > Secrets and variables > Actions `.
2. Create the following repository secrets:
Name|Expects|Description
-|-|-
SSH_KEY|Private Key|Generate a new ssh key without a password.
SSH_HOST|IP Address|The address of your server with an Actions (runner) active.
SSH_USER|Username|Host system user where next-leaflet should be deploy on.
SSH_PORT|Port Number|This usually refers to the default ssh port 22.
APP_ENV|Environment|A copy of .env.sample with adjusted values for deployment.3. Designate a trigger branch within the ` .github/deploy.yml ` file.
> Any change pushed to the targeted branch should now trigger a request to deploy next-leaflet via docker-compose.