Skip to content

syfrtech/svelte-grip

Repository files navigation

Svelte Grip 🤝 (UI Toolset)

A library of UI tools that help you build totally-custom and accessible accordions, dialogs, modals, tooltips, and more with Svelte. Written exclusively in Typescript with extensive documentation and references.

<script lang="ts">
  let [dialog$, dialog] = useDisclosure();
</script>

<dialog open use:dialog1.content="{$dialog$}">here is some content!</dialog>
<button use:dialog1.button="{$dialog$}" on:click="{dialog.toggle}">
  click to open modal
</button>

Install

Add it to your Svelte / Svelte Kit project:

npm install git+https://github.com/syfrtech/svelte-grip.git

Note: (alpha/beta releases may have breaking changes without warning)

How it works

  1. You import an action you want to use. ex: let [tooltip$, tooltip] = useTooltip();
  2. You add the action to the element(s) that will use that action. ex: <span use:tooltip.trigger="{$tooltip$}">hover for info</span>
  3. The action injects the necessary functionality into your element. For example, the span above, would register the events to track mouseover and focus to toggle the tooltip content.

Note: reactive values have a $ suffix to indicate their reactiveness (ex: dialog1$). You can subscribe to them with the $ prefix, so they end up looking like $dialog1$

Transitions / Animations

It's actually quite easy! Although may a11y patterns do not account for transition animations, we can add this behavior with Svelte. For example:

{#if $dialog1$.isOpen}
<dialog
  transition:fade="{{delay: 250, duration: 300}}"
  open
  use:dialog1.content="{$dialog1$}"
>
  here is some content!
</dialog>
{/if}

The nice thing here is that svelte-grip does not interfere with Svelte. You can customize styling and animation transitions however you like using native Svelte syntax... which boils down to native HTML + JS 🤩!

Details

What is a Grip?

Grip on car tires helps cars climb mountains of sand and mud. Grip on UI lets developers build apps quickly and funly🍻. This is possible with just a few simple rules for Grip:

  1. MUST be composible (allowing others to remix as they please)
  2. MUST be typed (for linting)
  3. MUST NOT impose any styling
  4. SHOULD provide robust support for a11y practices
  5. SHOULD provide documentation and links to applicable specifications

Why headless / unstyled?

This allows you to get the functionality you want without being constrained to a particular design style. This library can be used with any design framework:

  • Material UI
  • Bootstrap
  • Tailwind
  • Carbon
  • plain-ole CSS
  • whatever you want!

Svelte

It can be tempting to create wrapper functionality (like React), but we resist the temptation! Instead, the use:actions to provide tool access without .svelte files. From there, you are welcome to extend your elements as Svelte components or additional actions as you see fit.

Accessibility

This library is intended to fulfill accessibility / a11y with documentation and references, but without the headache. Even if you think you don't want/need accessibility, you still probably want it. For example:

  1. Accessible content is easier for machine processing: that means better SEO, better automation, better device compatibility, etc
  2. Your interface is keyboard friendly🎉. This makes your application more appealing to advanced users who are annoyed when having to drag their mouse all over a screen for no reason.
  3. You get thoroughly vetted patterns: no need to reinvent the wheel.
  4. You can focus on features instead of naming (ex: no need to debate class="modal" id="modal1" vs class="modal1")
  5. Your application is accessible to those with impairments.

See also:

About

Unstyled, headless, component-less, accessible UI system for Svelte

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published