Go to file
saml33 b16b08e9f5 rough layout 2023-09-14 23:18:39 +10:00
.github/workflows init commit 2023-09-12 23:45:15 -04:00
.husky init commit 2023-09-12 23:45:15 -04:00
components rough layout 2023-09-14 23:18:39 +10:00
fonts init commit 2023-09-12 23:45:15 -04:00
hooks init commit 2023-09-12 23:45:15 -04:00
pages rough layout 2023-09-14 23:18:39 +10:00
public init commit 2023-09-12 23:45:15 -04:00
store fix loading 2023-09-12 23:59:43 -04:00
styles rough layout 2023-09-14 23:18:39 +10:00
types init commit 2023-09-12 23:45:15 -04:00
utils init commit 2023-09-12 23:45:15 -04:00
.eslintignore init commit 2023-09-12 23:45:15 -04:00
.eslintrc.json init commit 2023-09-12 23:45:15 -04:00
.gitignore init commit 2023-09-12 23:45:15 -04:00
.prettierignore init commit 2023-09-12 23:45:15 -04:00
.yarnrc init commit 2023-09-12 23:45:15 -04:00
.yarnrc.yml init commit 2023-09-12 23:45:15 -04:00
LICENSE init commit 2023-09-12 23:45:15 -04:00
README.md init commit 2023-09-12 23:45:15 -04:00
next-env.d.ts init commit 2023-09-12 23:45:15 -04:00
next-i18next.config.js init commit 2023-09-12 23:45:15 -04:00
next.config.js init commit 2023-09-12 23:45:15 -04:00
package.json init commit 2023-09-12 23:45:15 -04:00
postcss.config.js init commit 2023-09-12 23:45:15 -04:00
prettier.config.js init commit 2023-09-12 23:45:15 -04:00
sentry.client.config.ts init commit 2023-09-12 23:45:15 -04:00
sentry.edge.config.ts init commit 2023-09-12 23:45:15 -04:00
sentry.server.config.ts init commit 2023-09-12 23:45:15 -04:00
tailwind.config.js init commit 2023-09-12 23:45:15 -04:00
tsconfig.json init commit 2023-09-12 23:45:15 -04:00
yarn.lock rough layout 2023-09-14 23:18:39 +10:00

README.md

This is a Next.js project bootstrapped with create-next-app.

Dependency Management

When updating dependencies, there are various files that must be kept up-to-date. Newly added, or updated dependencies can introduce unwanted/malicious scripts that can introduce risks for users and/or developers. The lavamoat allow-scripts feature allows us to deny by default, but adds some additional steps to the usual workflow.

yarn.lock:

  • Instead of running yarn or yarn install, run yarn setup to ensure the yarn.lock file is in sync and that dependency scripts are run according to the allowScripts policy (set in packages.json)
  • If lavamoat detects new scripts that are not explicitely allowed/denied, it'll throw and error with details (see below)
  • Running yarn setup will also dedupe the yarn.lock file to reduce the dependency tree. Note CI will fail if there are dupes in yarn.lock!

The allowScripts configuration in package.json:

  • There are two ways to configure script policies:
    1. Update the allow-scripts section manually by adding the missing package in the allowScripts section in package.json
    2. Run yarn allow-scripts auto to update the allowScripts configuration automatically
  • Review each new package to determine whether the install script needs to run or not, testing if necessary.
  • Use npx can-i-ignore-scripts to help assessing whether scripts are needed

Getting Started

First, run the development server:

npm run dev
# or
yarn dev

Open http://localhost:3000 with your browser to see the result.

You can start editing the page by modifying pages/index.tsx. The page auto-updates as you edit the file.

API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.ts.

The pages/api directory is mapped to /api/*. Files in this directory are treated as API routes instead of React pages.

Learn More

To learn more about Next.js, take a look at the following resources:

You can check out the Next.js GitHub repository - your feedback and contributions are welcome!

Deploy on Vercel

The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.

Check out our Next.js deployment documentation for more details.

Creating Color Themes

  1. Copy one of the other color themes in tailwind.config.js (starting line 25)
  2. Modify the colors. For the variables bkg-* and fgd-* pick a base color for bkg-1 and fgd-1 then adjust the lightness for 2-4. Use this same process to create dark/hover variations for the colors that have these properties. The base color can be anything that works for your theme.
  3. Add your corresponding theme values here. The format needs to be converted to HEX, you can paste the HSL values into Coolors to do this.
  4. Copy one of the other themes in global.css and modify to match your theme name in tailwind.config.js
  5. Add a translation variable for your theme name in locales. Theme names are to be added to settings.json and make sure to add this to each locale (they can all be in English to start with). Make sure the value matches data-theme from your css vars in global.css
  6. Add your theme to the THEMES array in display settings. It should go after mango-classic then in alphabetical order. You need to use the translation key you added to the locales.