A headless mouse trail cursor for Svelte
You can install library from NPM using yarn or npm
yarn add svelte-cursor
Installing the package will add a global component called Cursor
to your project. You can use it like this:
<script>
import { Cursor } from 'svelte-cursor';
</script>
<Cursor>
<div class="cursor" />
</Cursor>
You can then style the cursor however you want. For example:
.cursor {
width: 20px;
aspect-ratio: 1;
background-color: white;
border-radius: 50%;
}
Cursor
has the ability to change states when hovering over objects. To enable this, you need to add the Interactive
component around the element you want the behavior to apply to. For example:
<Interactive>
<a href="/">A link element</a>
</Interactive>
By default, the Interactive
component will expose the hover state to the Cursor
component. You can change this by passing a state
prop to the Interactive
component. For example:
<Interactive state="drag"> ... </Interactive>
This will expose the drag state to the Cursor
component. You can then style the cursor based on the state like so:
<Cursor let:state>
<div class:draggable={state === 'drag'>
Drag me
</div>
</Cursor>
<style>
.draggable {
padding: 5px;
backdrop-filter: blur(5px);
background-color: rgba(255, 255, 255, 0.25);
border: 1px solid rgba(255, 255, 255, 0.5);
color: white;
}
</style>
MIT