Skip to content

Latest commit

 

History

History
98 lines (68 loc) · 2.68 KB

README.md

File metadata and controls

98 lines (68 loc) · 2.68 KB

Astro + Shadcn Starter

Welcome to the Astro + Shadcn Starter Template! This project is designed to help you get started quickly with Astro and Shadcn UI. It includes Tailwind CSS for styling and React for building interactive components.

astroxshadcn

Table of Contents

Features

  • 🚀 Astro - Modern static site generator.
  • 🎨 Shadcn UI - Beautifully designed components built with Radix UI and Tailwind CSS.
  • 📦 Tailwind CSS - Utility-first CSS framework.
  • 🔥 React - Library for building user interfaces.

Getting Started

Follow these instructions to set up the project locally.

Prerequisites

Ensure you have the following installed:

Installation

  1. Clone the repository:

    git clone https://github.com/your-username/astro-shadcn-starter.git
    cd astro-shadcn-starter
  2. Install dependencies:

    npm install
  3. Start the development server:

    npm run dev

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

Project Structure

├── public # Static assets
├── src
│ ├── components # React components
│ ├────ui # Shadcn installed components
│ ├── layouts # Layout components
│ ├── pages # Astro pages
│ ├── styles # Global styles
│ └── utils # Utility functions
├── astro.config.mjs # Astro configuration
├── tailwind.config.mjs # Tailwind CSS configuration
└── package.json # Project metadata and dependencies

Usage

Adding a New Page

To add a new page, create a new .astro file in the src/pages directory.

Example:

---
import Layout from '../layouts/Layout.astro';
---

<Layout title="New Page">
  <h1>New Page</h1>
  <p>This is a new page.</p>
</Layout>

Important

Due to the static and island based nature of Astro, a lot of Shadcn components won't work out of the box, some components such as the Avatar require more work on your side to enable them to work (see src/components/Avatar.tsx).

You can find useful information on this from the following links: