๐ŸคŽ Enjoying my work? Buy me a coffee to support my coding adventures! โ˜•


Docs
Gatsby

Gatsby

Install and configure Gatsby.

Create project

Start by creating a new Gatsby project using create-gatsby:

npm init gatsby

Configure your Gatsby project to use TypeScript and Tailwind CSS

You will be asked a few questions to configure your project:

โœ” What would you like to call your site?
ยท your-app-name
โœ” What would you like to name the folder where your site will be created?
ยท your-app-name
โœ” Will you be using JavaScript or TypeScript?
ยท TypeScript
โœ” Will you be using a CMS?
ยท Choose whatever you want
โœ” Would you like to install a styling system?
ยท Tailwind CSS
โœ” Would you like to install additional features with other plugins?
ยท Choose whatever you want
โœ” Shall we do this? (Y/n) ยท Yes

Edit tsconfig.json file

Add the following code to the tsconfig.json file to resolve paths:

{
  "compilerOptions": {
    // ...
    "baseUrl": ".",
    "paths": {
      "~/*": [
        "./src/*"
      ]
    }
    // ...
  }
}

Create gatsby-node.ts file

Create a gatsby-node.ts file at the root of your project if it doesnโ€™t already exist, and add the code below to the gatsby-node file so your app can resolve paths:

import * as path from "path"
 
export const onCreateWebpackConfig = ({ actions }) => {
  actions.setWebpackConfig({
    resolve: {
      alias: {
        "~/components": path.resolve(__dirname, "src/components"),
        "~/lib/utils": path.resolve(__dirname, "src/lib/utils"),
      },
    },
  })
}

Run the CLI

Run the nyxbui init command to setup your project:

npx nyxbui@latest init

Configure nyxbui.json

You will be asked a few questions to configure nyxbui.json:

Would you like to use TypeScript (recommended)? no / yes
Which style would you like to use? โ€บ Default
Which color would you like to use as base color? โ€บ Slate
Where is your global CSS file? โ€บ โ€บ ./src/styles/globals.css
Do you want to use CSS variables for colors? โ€บ no / yes
Where is your tailwind.config.js located? โ€บ tailwind.config.js
Configure the import alias for components: โ€บ ~/components
Configure the import alias for utils: โ€บ ~/lib/utils
Are you using React Server Components? โ€บ no

That's it

You can now start adding components to your project.

npx nyxbui@latest add button

The command above will add the Button component to your project. You can then import it like this:

import { Button } from "~/components/ui/button"
 
export default function Home() {
  return (
    <div>
      <Button>Click me</Button>
    </div>
  )
}