This is a Svelte implementation of the Geist Design System by Vercel.
Notes
- Work in progress.
- Not affiliated with Vercel.
- Not a component library.
- Will try and keep the API's as close to the original as possible.
- Built with shadcn-svelte
Setup
pnpm dlx sv create
# add tailwind, prettier, eslintCopy app.css to src/app.css
Copy tailwind.config.ts to tailwind.config.ts
Install tailwind plugins:
pnpm add -D @pyncz/tailwind-mask-image @tailwindcss/typography tailwindcss-animateInstall plugin:
pnpm add -D @poppanator/sveltekit-svgAdd plugin in vite.config.ts:
+import svg from '@poppanator/sveltekit-svg';
import { sveltekit } from '@sveltejs/kit/vite';
import { defineConfig } from 'vite';
export default defineConfig({
	plugins: [
		sveltekit(),
+		svg()
	]
});💡 Tip
For Typescript support of
file.svg?component, add this import to any.d.tsfile in your project path:
+ import '@poppanator/sveltekit-svg/dist/svg';pnpm add -D @fontsource/geist-sans @fontsource/geist-monopnpm add -D mode-watcherAdd <ModeWatcher/> to src/routes/+layout.svelte
<script lang="ts">
+	import { ModeWatcher } from 'mode-watcher';
	import '../app.css';
	let { children } = $props();
</script>
+<ModeWatcher/>
{@render children()}Add components with jsrepo
We have set up jsrepo so that you can install our components just like shadcn/ui.
Setup jsrepo:
pnpm dlx jsrepo init --project --repos github/shyakadavis/geistConfigure paths in jsrepo.json:
{
	"$schema": "https://unpkg.com/[email protected]/schemas/project-config.json",
	"repos": ["github/shyakadavis/geist"],
	"includeTests": false,
	"watermark": true,
	"formatter": "prettier",
	"paths": {
		"*": "./src/lib/ts/blocks",
+       "ui": "$lib/components/ui",
+       "icons": "$lib/assets/icons",
+       "lib": "$lib/"
	}
}Add components:
# list components
pnpm dlx jsrepo add
# add specific component
pnpm dlx jsrepo add ui/avatarContributing
If you would like to contribute, please read the CONTRIBUTING.md file to get started.