Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mathiasoxholm/humblescroll-nuxt
Nuxt 3 animate on scroll
https://github.com/mathiasoxholm/humblescroll-nuxt
animate-on-scroll nuxt scroll-animations vue
Last synced: 3 months ago
JSON representation
Nuxt 3 animate on scroll
- Host: GitHub
- URL: https://github.com/mathiasoxholm/humblescroll-nuxt
- Owner: MathiasOxholm
- Created: 2023-08-28T20:45:53.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-08T18:26:42.000Z (about 1 year ago)
- Last Synced: 2024-10-02T01:56:24.290Z (4 months ago)
- Topics: animate-on-scroll, nuxt, scroll-animations, vue
- Language: Vue
- Homepage: https://humblescroll-docs.oxholm.dev/
- Size: 332 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
# HumbleScroll Nuxt
[![npm version][npm-version-src]][npm-version-href]
[![npm downloads][npm-downloads-src]][npm-downloads-href]
[![License][license-src]][license-href]
[![Nuxt][nuxt-src]][nuxt-href]HumbleScroll is a lightweight and minimalistic animation on scroll Nuxt module. It's easy to use and has no dependencies. The library is based on Intersection Observer combined with CSS Custom Props for easy customization.
- [✨ Release Notes](/CHANGELOG.md)
## Includes
- Vue plugin (Nuxt module)
- TailwindCSS plugin
- HumbleScroll component## Features
- CSS animations
- Customize with CSS variables
- TailwindCSS utility classes
- Uses the Intersection Observer API## Quick Setup
### 1. Add `humblescroll-nuxt` dependency to your project
```bash
# Using pnpm
pnpm add -D humblescroll-nuxt# Using yarn
yarn add -D humblescroll-nuxt# Using npm
npm install -D humblescroll-nuxt
```### 2. Add `humblescroll-nuxt` to the `modules` section of `nuxt.config.ts`
```js
export default defineNuxtConfig({
modules: [
'humblescroll-nuxt'
]
})
```### 3. Install the TailwindCSS plugin
Import the TailwindCSS plugin in your `tailwind.config.js` file.
```js
// tailwind.config.jsimport { humbleScrollTailwindPlugin } from 'humblescroll-vue'
export default {
content: [],
theme: {},
plugins: [
humbleScrollTailwindPlugin
]
}
```### 4. Use the HumbleScroll component
Use the HumbleScroll component in your Vue components.
```html
HumbleScroll
```
## Customization
### CSS variables
Adjust global animation settings in your stylesheet
```css
:root {
--hs-duration: 800ms;
--hs-delay: 100ms;
--hs-translate-x-amount: 10rem;
--hs-translate-y-amount: 8rem;
--hs-rotate: -5deg;
--hs-easing: cubic-bezier(0.17, 0.67, 0.83, 0.67);
}
```All Custom properties that can be customized. The default values are shown below.
```css
:root {
--hs-delay: 0ms;
--hs-easing: var(--hs-ease-out);
--hs-duration: 600ms;
--hs-ease-in: cubic-bezier(0.4, 0, 1, 1);
--hs-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
--hs-ease-out: cubic-bezier(0, 0, 0.2, 1);
--hs-ease-out-back: cubic-bezier(0.34, 1.56, 0.64, 1);
--hs-opacity: 1;
--hs-translate-y: 0;
--hs-translate-x: 0;
--hs-scale: 1;
--hs-rotate: 0deg;
--hs-perspective: 0;
--hs-rotate-x: 0deg;
--hs-rotate-y: 0deg;
--hs-skew-x: 0deg;
--hs-skew-y: 0deg;
--hs-translate-ratio: 1;
--hs-scale-ratio: 0.2;
--hs-duration-ratio: 1;
--hs-translate-x-amount: 2rem;
--hs-translate-y-amount: 3rem;
--hs-flip-x-amount: 100deg;
--hs-flip-y-amount: -100deg;
--hs-perspective-amount: 2000px;
--hs-stagger-amount: 100ms;
--hs-skew-amount: 20deg;
--hs-reveal-amount: 100%;
--hs-blur: 0;
--hs-blur-amount: 8px;
}
```#### Responsive values in CSS
```css
:root {
--hs-duration: 0.4s;
--hs-easing: ease-in-out;
--hs-translate-x-amount: 2.5rem;
}@media (min-width: 768px) {
:root {
--hs-duration: 0.6s;
--hs-easing: ease-in;
--hs-translate-x-amount: 4rem;
}
}
```## Plugin options
### Options overview
```js
// nuxt.config.js
export default defineNuxtConfig({
modules: [
'humblescroll-nuxt'
],
humbleScroll: {
repeat: true,
mirror: true,
offset: {
bottom: -100, // 100px away from bottom of the screen
top: 0,
left: 0,
right: 0
}
}
})
```| Option | Type | Default | Description |
| ---------------- | --------- | ------------------------------------------ | --------------------------------------------------------------------------- |
| `root` | `string` | `null` | Root container to observe |
| `repeat` | `boolean` | `false` | Repeat the animation when scrolling from top |
| `mirror` | `boolean` | `false` | Mirror the animation on leave |
| `threshold` | `number` | `0.1` | Intersection threshold where 0.1 is 10% of the element |
| `offset` | `Offset` | `{top: 0, right: 0, bottom: -40, left: 0}` | Intersection offset. Use negative numbers to make the observed area smaller |## Animations
### 1. Fade animation
Fades in the element.
```html
```
### 2. Directional
Customize by overriding `--hs-translate-y-amount` or `--hs-translate-x-amount` in your css or directly on the element with the variables prop. Works like a slide without `fade` applied.
```html
```
### 3. Zoom
Customize by overriding `--hs-scale-ratio` in your css or directly on the element as inline-style.
```html
```
### 4. Flip
Flip in any direction. Customize by overriding `--hs-flip-x-amount` and `--hs-flip-y-amount`.
```html
```
### 5. Skew
Combine with blur to make them feel blazingly fast. Customize by overriding `--hs-skew-amount`.
```html
```
### 6. Reveal
Parent has overflow hidden and child slides from 100% to 0. Cusomize by overriding `--hs-reveal-amount`.
```html
```
### 7. Blur
Who doesn't like motion blur? Customize by overriding `--hs-blur` on an element.
```html
```
### 8. Easings
Customize by overriding `--hs-ease`, `--hs-ease-in`, `--hs-ease-out` or `--hs-ease-out-back` or just create your own.
```html
```
### 9. Size variations
Default variation for the translation amount on directional animations (up, down, left, right).
Customize by overriding `--hs-translate-ratio`.```html
```
### 10. Speed variations
Default variation for animation durations (scales from `--hs-duration`).
```html
```
### 11. Run once
Ensure the animation only runs once - even with `repeat` and `mirror` enabled.
```html
```
### 12. Responsive animations
In this responsive age developers need the ability to animate differently based on screen sizes. Use the tailwind prefix before animations to apply a media query.
```html
```
### 13. Combine them
Combine animations inside the `animation` prop (space seperated).
```html
```## Vue state
Use the `v-slot` directive to access the `isIntersecting` state.
```html
{{ isIntersecting ? 'Intersecting' : 'Not intersecting' }}
```
Use the `@intersecting` event to access the `isIntersecting` state.
```html
Run your functionality when in screen
```
[npm-version-src]: https://img.shields.io/npm/v/humblescroll-nuxt/latest.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-version-href]: https://npmjs.com/package/humblescroll-nuxt[npm-downloads-src]: https://img.shields.io/npm/dm/humblescroll-nuxt.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-downloads-href]: https://npmjs.com/package/humblescroll-nuxt[license-src]: https://img.shields.io/npm/l/humblescroll-nuxt.svg?style=flat&colorA=18181B&colorB=28CF8D
[license-href]: https://npmjs.com/package/humblescroll-nuxt[nuxt-src]: https://img.shields.io/badge/Nuxt-18181B?logo=nuxt.js
[nuxt-href]: https://nuxt.com