Very simple component library made in Svelte v5 and Tailwind v4. The point of this for me was to test out what each update is bringing to the table. But now, has turned into what I consider to be a very useful component starter-pack for my projects.
I tried keeping a consistent design language across all components, primarily ones that are interactable (form components).
- All Components
- Light border (white with 25% opacity), which allows it to play off the backgroud color and is therefore widely applicable
- The border becomes lighter (50% opacity) when the user is only one step away from using a component
- Compact in size, allowing for easier scaling
- Light border (white with 25% opacity), which allows it to play off the backgroud color and is therefore widely applicable
- Disabled Components
- Borders disappear, which let's them blend into the background
- Their color is set to
transparent
so they don't shrink in size
- Their color is set to
- Cursor is
not-allowed
- Text color should be 50% less opaque
- Borders disappear, which let's them blend into the background
I have tried to make it so components make use of Svelte v5's new feature, Snippets, wherever they can. These effectively allow for passing Svelte code as arguments, but I avoided that where I could.
In some component's cases, they accept children in place of the label
attribute.
<!-- This is valid -->
<MockButton>Label</MockButton>
<!-- But I prefer this way unless you need HTML -->
<MockButton label="Label" />
If you need to pass in some fancily styled elements it's worth noting that all components that render children have the group/<component>
Tailwind class on them. In MockButton
's case, it is group/button
.
MockInput
allows you to pass snippets to render buttons or icons on the left or right side of the input field.
{#snippet right()}
<Icon
class="size-6"
data={faX}
/>
{/snippet}
<MockInput {right} />
All components primarily make use of var(--color-component)
for their coloring. Through the power of Tailwind, it's now very easy to change the color of a component or a group of components.
<!-- this makes the button turn red -->
<MockButton
class="component-red-500"
label="Hello world"
/>
The format is component-<color>
where <color>
is any Tailwind color. This also trickles down to child elements, so you can easily change the color of a group of components.
<!-- makes both buttons red -->
<div class="component-red-500">
<MockButton label="Hello world" />
<MockButton label="Hey world" />
</div>
<!-- remains the default primary color -->
<MockButton label="Hi world" />
The primary color is also configurable in the Tailwind config.
All unknown props passed to a component are passed to the target component element. Which means, aside from wrapper elements, you aren't missing access to any attributes on mock components.
All classes passed into class
on all components are merged with tailwind-merge
on the primary visual element of the component.
All components are designed to be keyboard accessible, by keeping them as simple and as close to their original counterparts as possible. All components work with plain <form>
tags.
Things I'd like to accomplish in this component library in order for me to consider it complete.
-
MockFileSelect
- Make inner
MockButton
not require an onclick handler, likely the solution will be replacing the button with a different element
- Make inner
-
MockSelect
- Fix default appearance in Safari to not be glossy
-
MockSlider
- Add track fill, preferably without the need for JavaScript
- Consistently use CSS variables for coloring, this way setting a variable can trickle down to child elements and overall feel more natural to change (a lot like what's done in
MockInput
forghost
)- This is achieved now by using the custom written
component-<color>
Tailwind utility. This utility sets the--color-component
CSS variable on the element it is applied to. This means now changing the color of a component, or even a group of components, is as simple as usingcomponent-blue-600
as a CSS class.
- This is achieved now by using the custom written
-
shadcn/ui
-like CLI for installing components - For components where they are comprised of several HTML elements, it's not immediately clear where the rest of the
$props()
go. Furthermore, it's annoying you have to even choose where they go, a prop grouping API where other elements can be specified with a prefix (e.g.<el>-<prop>
,label-class="max-w-36"
makesclass
apply tolabel
,svg-class="size-24"
appliesclass
to a givensvg
, etc.)
- I have not set this up to be used as a library, but more as a boilerplate repository
- The current set of components currently are focused around being form compatible