Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/captaincodeman/svelte-transition
Svelte Transition Component
https://github.com/captaincodeman/svelte-transition
animation svelte tailwind transition
Last synced: 7 days ago
JSON representation
Svelte Transition Component
- Host: GitHub
- URL: https://github.com/captaincodeman/svelte-transition
- Owner: CaptainCodeman
- License: mit
- Created: 2022-01-18T19:12:15.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2024-08-28T21:30:04.000Z (5 months ago)
- Last Synced: 2025-01-13T01:05:30.419Z (14 days ago)
- Topics: animation, svelte, tailwind, transition
- Language: Svelte
- Homepage: https://captaincodeman.github.io/svelte-transition/
- Size: 227 KB
- Stars: 56
- Watchers: 4
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# svelte-transition
Svelte component to make using CSS class based transitions easier - ideally suited for use with [TailwindCSS](https://tailwindcss.com/)
Loosely modeled on the [HeadlessUI Transition](https://headlessui.dev/react/transition).
About 3Kb / 1.5Kb gzipped
## Installation
Install using your package manager of choice:
```bash
pnpm i svelte-transition
```## Usage
Import into your component and use a flag to control whether to show or hide an HTML Element.
```ts
import Transition from 'svelte-transition'let show = false
```Wrap the HTML Element with the `` component, setting the flag to toggle visibility and the classes to apply when transitioning:
```html
```
## Shortcut
If the leave transition is the opposite of the enter transition it can be omitted to save bytes. This is identical to the previous example:
```html
```
i.e. `leave` will equal `enter`, `leaveFrom` will equal `enterTo`, and `leaveTo` will equal `enterFrom` unless you override them.
## Appear
Set `appear` to have the transition play on initial mount.
Default `false`.
## Unmount
Set `unmount` to have the transitioned element removed from the DOM when not shown (instead of just hidden).
Default `false`.
## Co-ordinating Transitions
If the `show` property is ommitted then the transition is treated as a child and will receive it's state from it's parent. The parent will automatically wait for it's children to finish transitioning before they are unmounted or hidden, so the animations can complete.
## Events
The component raises events to indicate when any transition is running:
- `before-enter` runs before the enter transition happens
- `after-enter` runs after the enter transition happens
- `before-leave` runs before the leave transition happens
- `after-leave` runs after the leave transition happens## TailwindUI
If you're converting from TailwindUI markup, you can use this [handy converter](https://captaincodeman.github.io/svelte-transition/) to convert the comments into `` markup and classes.