Astro Svelte Source Base

Modern web application built with Svelte, Astro, and TailwindCSS.

šŸš€ Tech Stack

  • Framework: Astro + Svelte
  • Styling: TailwindCSS + shadcn-svelte
  • State Management: TanStack Query (formerly React Query)
  • Form Handling: React Hook Form + Zod
  • HTTP Client: Axios

šŸ“ Project Structure

src/ ā”œā”€ā”€ assets/ # Static assets ā”œā”€ā”€ components/ # UI components ā”‚ ā”œā”€ā”€ ui/ # shadcn components ā”‚ ā”œā”€ā”€ common/ # Shared components ā”‚ ā””ā”€ā”€ features/ # Feature-specific components ā”œā”€ā”€ config/ # App configuration ā”œā”€ā”€ hooks/ # Custom hooks ā”‚ ā””ā”€ā”€ queries/ # TanStack Query hooks ā”œā”€ā”€ layouts/ # Page layouts ā”œā”€ā”€ lib/ ā”‚ ā”œā”€ā”€ api/ # API configuration ā”‚ ā”œā”€ā”€ utils/ # Utility functions ā”‚ ā””ā”€ā”€ types/ # TypeScript types ā”œā”€ā”€ pages/ # Astro pages ā”œā”€ā”€ services/ # API services ā””ā”€ā”€ styles/ # Global styles

šŸ› ļø Development

Prerequisites

  • Node.js 18+
  • npm/pnpm/yarn

Environment Variables

Copy .env.example to .env:

bash cp .env.example .env

Required environment variables:

  • PUBLIC_APP_NAME: Application name
  • PUBLIC_API_URL: Backend API URL
  • PUBLIC_APP_ENV: Environment (development/staging/production)

See .env.example for all available options.

Installation

Install dependencies npm install Start development server npm run dev Build for production npm run build Preview production build npm run preview

šŸ”‘ Key Features

  • šŸŽØ Modern UI with shadcn components
  • šŸ”„ Efficient state management with TanStack Query
  • šŸ“ Type-safe forms with Zod validation
  • šŸŒ API integration with Axios
  • šŸŽÆ Clean Architecture principles
  • šŸ“± Responsive design
  • šŸ”’ Type-safe environment variables

šŸ“š Documentation

Component Usage

svelte

API Services

Services follow a repository pattern with TypeScript interfaces:

typescript interface IUserService { getUsers(): Promise<User[]>; getUserById(id: string): Promise; // ... }

Environment Types

Environment variables are type-safe and validated with Zod. See src/config/index.ts.

The build output will be in the dist/ directory.

šŸ¤ Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

šŸ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

šŸ‘„ Authors

  • DevDuck - Initial work

šŸ™ Acknowledgments

Top categories

svelte logo

Need a Svelte website built?

Hire a professional Svelte developer today.
Loading Svelte Themes