Create a Svelte Component Library
- components
- library
- npm
- svelte
svelte-package 2.0
This post was updated on Mar 22, 2023 to account for the changes in svelte-package 2.0. This update simplified the process for setting up a component library. See instructions on migrating an existing project here. You can also now find more information on svelte-package in the documentation.
Create a new SvelteKit project
If you frequently have components that you share between projects and want to keep a single repository of them, you can create a package on npm. Here’s how to create a Svelte component library with SvelteKit.
Setup
- Navigate to a directory in your terminal where you will create your project
- Run
npx sv@latest create
, configure your project with the CLI, select theSvelte library project
template, I’m going to use TypeScript in this tutorial - Update
README.md
with information about your project
Project information
Since this is a library project, it’s important to add in your relevant information to the package.json
file so it will appear on npm when the package is published. The template sets much of this up for us, but we will need to edit a few fields.
You can read more on this in the svelte-package documentation.
{
"name": "@rossrobino/components",
"version": "0.0.1",
"description": "A reusable Svelte component library",
"keywords": [
"components",
"documentation",
"Svelte",
"SvelteKit"
],
"homepage": "https://components.com",
"license": "MIT",
"author": {
"name": "Ross Robino",
"url": "https://robino.dev"
},
"repository": {
"type": "git",
"url": "git+https://github.com/rossrobino/components.git"
},
"sideEffects": false,
...
sideEffects
An important note if you are planning on including CSS in your components–set the sideEffects
field to false
, if you want bundlers like Vite to be more aggressive with tree-shaking. If this field is not set, all of the CSS for every one of your exported components will be included when one component is imported. If your package does include modules with side effects that occur upon importing, you can specify them with an array of paths to the modules.
Find the latest information on this setting on this pull request I made.
lib directory
The contents of the src/lib
directory are what will be packaged upon running npm run package
. This is where components can reside for the project as well as an index.ts
file that exports the components for the package.
Create a component
Create a component to export in your package, here’s my YouTube.svelte
component as an example.
<!-- src/lib/YouTube.svelte -->
<script lang="ts">
let { uid, title }: { uid: string; title: string } = $props();
</script>
<iframe
src="https://www.youtube.com/embed/{uid}"
{title}
frameborder="0"
allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture"
allowfullscreen
></iframe>
Export
Import and export the component from src/lib/index.ts
.
// src/lib/index.ts
import YouTube from "./YouTube.svelte";
export { YouTube };
Test locally
Do a quick test of your component on src/routes/+page.svelte
by importing it to the page and running npm run dev -- --open
.
<!-- src/routes/+page.svelte -->
<script lang="ts">
import YouTube from "$lib/YouTube.svelte";
</script>
<YouTube uid="gouiY85kD2o" title="Renegade - Kevin Olusola" />
Ensure that the component is working as expected, then you are ready to create a package.
Package
Now we can package the library and publish it on npm for anyone to use. Repeat these steps each time you want to update your package.
If you are looking to automate some of these steps, check out the changesets project.
- Update the
version
inpackage.json
, this will have to be bumped up each time you publish the package (major.minor.patch)–you can leave this at0.0.1
to start - Run
npm install
to sync yourpackage-lock.json
with the current version information - Run
npm run package
to execute thepackage
script inpackage.json
- You can verify the output of your build in the
dist
directory - Commit changes to your repository, it’s important to publish the same source code to both GitHub and npm to build trust in your package with users.
- Run
npm publish --access public
to publicly publish your package on npm (if you don’t have an account you will need to create one and log in)
Test in a separate project
After verifying on the npm website that your package has been published, you can now use your package in a separate project.
- Set up a new SvelteKit project or use a different existing one
- Run
npm install -D your-package-name
to install it as a dependency - Import in
src/routes/+page.svelte
like before, but edit the import path to point to your package instead - Lastly, run
npm run dev -- --open
to see your imported component in action
<!-- src/routes/+page.svelte -->
<script lang="ts">
import { YouTube } from "@rossrobino/components";
</script>
<YouTube uid="gouiY85kD2o" title="Renegade - Kevin Olusola" />
Conclusion
You have now built a Svelte component library you can access from any of your other SvelteKit projects to share code between them.
Thanks for reading!