Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/olliejt/create-sva
https://github.com/olliejt/create-sva
Last synced: 18 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/olliejt/create-sva
- Owner: OllieJT
- License: mit
- Created: 2024-06-22T11:56:54.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-07T16:35:26.000Z (6 months ago)
- Last Synced: 2024-12-08T12:49:24.971Z (about 1 month ago)
- Language: TypeScript
- Size: 2.35 MB
- Stars: 24
- Watchers: 2
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
create-sva
SVA reduces time spent on boilerplate and project setup.
It aims to be the fastest way to build interactive typesafe Svelte applications.Get started by running
npm create sva@latest
[![NPM version][npm-image]][npm-url] [![Downloads][downloads-image]][npm-url] ![GitHub Repo stars][github-image]
## Table of contents
- About
- Axioms
- Getting Started
- Feature RequestThe SVA Stack
The _"SVA Stack"_ is a web development stack focused on **simplicity**, **consistency**, and **full-stack typesafety**. It combines a collection of tools for interactive full-stack applications, and provides you with a CLI to scaffold your own project.
| Package | Usecase | Options |
| --------------------------------------------- | ---------------- | -------------- |
| [Svelte V5](https://svelte.dev/) | Framework | 🚫 _Required_ |
| [SvelteKit](https://kit.svelte.dev/) | Meta-Framework | 🚫 _Required_ |
| [Typescript](https://www.typescriptlang.org/) | Type-Safety | 🚫 _Required_ |
| [Prettier](https://prettier.io/) | Code Formatter | 🚧 _Removable_ |
| [ESLint](https://eslint.org/) | Code Linter | 🚧 _Removable_ |
| [Tailwind CSS](https://tailwindcss.com) | Styling | 💠Recommended |
| [Lucia](https://lucia-auth.com/) | Auth | 💠Recommended |
| [Drizzle](https://orm.drizzle.team/) | Database Adapter | 💠Recommended |
| [Husky](https://typicode.github.io/husky/) | Git Hooks | 💠Optional |> [!NOTE]
> create-sva is heavily inspired by the [t3stack](https://github.com/t3-oss/create-t3-app/), both in the methodology, and the CLI. The first version of this project used or learnt from many aspects of the t3 codebase, and we owe a lot to it's [contributors](https://github.com/t3-oss/create-t3-app/graphs/contributors).### What exactly is `create-sva`?
`create-sva` is an interactive CLI designed to quickly scaffold a Svelte application with **sensible defaults** tailored for **interactive applications**. Unlike the standard Svelte CLI (which is fantastic for basic websites) create-sva focuses on getting setup with more complex functionality like authentication and databases.
The goal of `create-sva` is to streamline the setup process, providing you with a modular structure that fits your specific needs. Each piece is optional, and the project is generated based on your choices during setup.
SVA aims to be as leightweight as possible while scaffolding projects that get you through boilerplate code as fast as possible. This means we may omit beloved packages like [superforms](https://superforms.rocks/) as it does not require project configuration.
| CLI Prompt | Type | Options | Default |
| ----------------- | ------------ | ------------------------------------------- | -------------- |
| Project Name | Text | Text Input | new-svelte-app |
| Styling Solution | Select | Post CSS / **Tailwind** | Tailwind |
| Auth Solution | Select | None / Lucia | Lucia |
| SvelteKit Adapter | Select | Auto / Node / Vercel / Netlify / Cloudflare | Auto |
| Dev Tools | Multi-Select | Husky / CS Code Config | [ ] |---
Axioms
This is an _opinionated project_ inspired by the axioms of [t3 stack](https://github.com/t3-oss/create-t3-app/), and the methodologies of [Rich Harris](https://github.com/Rich-Harris).
### 1. Solve Problems
It's easy to fall into the trap of "adding everything" - we explicitly _don't_ want to do that.
Everything added to `create-sva` should both address the mission, and benefit from pre-configuration. This means we **won't** add beloved packages like [superforms](https://superforms.rocks/) as it does not require much setup... but we **will** add things like [Lucia](https://lucia-auth.com/) and integrate it into [Drizzle](https://orm.drizzle.team/) for you.
### 2. Embrace Web Standards
We believe in making the most of native web features to reduce unnecessary complexity and improve performance. Modern web standards offer powerful capabilities that can simplify development and enhance the user experience. By using native browser APIs and built-in features, we minimize dependencies and overhead, resulting in faster, more efficient applications. This means we look forward to deleting code, and removing dependencies in favour of native capabilities.
### 3. Typesafety Isn't Optional
The stated goal of `create-sva` is to provide the quickest way to start a new full-stack, typesafe web application. We take typesafety seriously in these parts as it improves our productivity and helps us ship fewer bugs. Any decision that compromises the typesafe nature of `create-sva` is a decision that should be made in a different project.
Getting Started
To scaffold an app using `create-sva`, run any of the following four commands and answer the command prompt questions:
### npm
```bash
npm create sva@latest
```### yarn
```bash
yarn create sva
```### pnpm
```bash
pnpm create sva@latest
```### bun
```bash
bun create sva@latest
```[downloads-image]: https://img.shields.io/npm/dm/create-sva?color=364fc7&logoColor=364fc7
[npm-url]: https://www.npmjs.com/package/create-sva
[npm-image]: https://img.shields.io/npm/v/create-sva?color=0b7285&logoColor=0b7285
[contribute-url]: https://github.com/olliejt/create-sva/blob/main/CONTRIBUTING.md
[contribute-image]: https://img.shields.io/badge/PRs-welcome-blue.svg
[github-image]: https://img.shields.io/github/stars/olliejt/create-svaMade with [contrib.rocks](https://contrib.rocks).