Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@hypernym/nuxt-gsap

Package Overview
Dependencies
Maintainers
2
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@hypernym/nuxt-gsap

GSAP module for Nuxt.

  • 2.4.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
1.6K
increased by11.31%
Maintainers
2
Weekly downloads
 
Created
Source

Nuxt Gsap Module

GSAP module for Nuxt.

Features

  • Helps you integrate the GSAP animation library
  • Provides a solution for global use
  • Supports custom composables
  • Automatically registers plugins after activation
  • Allows you to easily register global effects & eases
  • Supports Club GreenSock premium plugins
  • Zero-config setup ready to go
  • TypeScript friendly
  • Super easy to use

Quick Start

  1. Install @hypernym/nuxt-gsap to your project
npm i -D @hypernym/nuxt-gsap
  1. Enable the module in the main config file
// nuxt.config.ts

{
  modules: ['@hypernym/nuxt-gsap']
}

That's it!

Module

The module comes with a zero-config setup so after activation it automatically adds the GSAP core and it is globally available without additional settings.

<!-- layout.vue | page.vue | component.vue -->

<template>
  <div>
    <h1 class="title">Nuxt Gsap</h1>
  </div>
</template>

<script setup lang="ts">
  const { $gsap } = useNuxtApp()

  onMounted(() => {
    $gsap.to('.title', { rotation: 3, x: 100, duration: 1 })
  })
</script>

Options

Nuxt Gsap Module is completely rewritten in TypeScript. It also improves the development experience with detailed descriptions, examples and code auto-completion.

After plugin activation, it is immediately available globally, so there is no need to manually import or register.

// nuxt.config.ts

{
  modules: ['@hypernym/nuxt-gsap'],

  gsap: {
    // Module options
  }
}

GSAP Core

It can be used via a provide helper that will be available globally or via a custom composable that you can import where you need it.

Provide

GSAP core is enabled by default on module activation.

// nuxt.config.ts

{
  modules: ['@hypernym/nuxt-gsap'],
}

Available globally

<script setup lang="ts">
  const { $gsap } = useNuxtApp()

  onMounted(() => {
    $gsap.to('.title', { rotation: 3, x: 100, duration: 1 })
  })
</script>

To disable the provide helper completely, set it to false.

// nuxt.config.ts

{
  gsap: {
    provide: false
  }
}

Composable

Imports the main gsap core as custom composable.

To enable custom composables, set it to true:

// nuxt.config.ts

{
  gsap: {
    composables: true
  }
}
useGsap
  • Custom composable
<!-- layout.vue | page.vue | component.vue -->

<template>
  <h1 class="title">Nuxt Gsap Module</h1>
</template>

<script setup lang="ts">
  useGsap.to('.title', { rotation: 3, x: 100, duration: 1 })
</script>
// Explicit import (optional)
import { useGsap } from '#gsap'

Provide

  • Type: boolean
  • Default: true

Provides the main $gsap core with plugins globally.

// nuxt.config.ts

{
  gsap: {
    provide: true
  }
}

Available globally

const { $gsap } = useNuxtApp()

$gsap.to('.class', { rotation: 3, x: 100, duration: 1 })

Composables

  • Type: boolean
  • Default: undefined

Specifies custom composables.

If enabled, allows the use of custom composables.

// nuxt.config.ts

{
  gsap: {
    composables: true
  }
}

It is possible to use provide helper and composables in combination or separately, depending on preference.

When using only composables, it is recommended to disable global import.

// nuxt.config.ts

{
  gsap: {
    composables: true
    provide: false // global import
  }
}

Auto Import

  • Type: boolean
  • Default: true

Specifies the auto-import feature.

If enabled, the composables will be available globally so there is no need to import them manually.

Since this is an opinionated feature, you can disable global auto-import and use explicit import only where you need it.

[!NOTE]
Works only if the option composables: true is enabled.

// nuxt.config.ts

{
  gsap: {
    autoImport: false
  }
}

Register Effects

  • Type: object[]
  • Default: undefined

Provides an easy way to register global effects.

Once the effect is registered, it can be accessed directly on the gsap.effects object.

To avoid possible linting warnings, use // eslint-disable-next-line and // @ts-ignore comments.

// nuxt.config.ts

{
  gsap: {
    registerEffects: [
      {
        name: 'fade',
        defaults: {
          y: -100,
          opacity: 0,
          duration: 2,
        },
        // eslint-disable-next-line
        // @ts-ignore
        effect: (targets, config) => {
          return gsap.to(targets, {
            y: config.y,
            opacity: config.opacity,
            duration: config.duration,
          })
        },
      },
      {
        name: 'slideIn',
        // ...
      },
    ]
  }
}

Available globally

const { $gsap } = useNuxtApp()

$gsap.effects.fade('.class')
$gsap.effects.slideIn('#id')

Register Eases

  • Type: object[]
  • Default: undefined

Provides an easy way to register global eases.

Once the ease is registered, it can be accessed directly on the gsap animations.

// nuxt.config.ts

{
  gsap: {
    registerEases: [
      {
        name: 'customEase',
        ease: (progress) => {
          return progress // linear
        },
      },
      {
        name: 'customEase2',
        // ...
      },
    ]
  }
}

Available globally

const { $gsap } = useNuxtApp()

$gsap.to('.class', { x: 100, ease: 'customEase' })
$gsap.to('#id', { x: 200, ease: 'customEase2' })

Extra Plugins

  • Type: object
  • Default: undefined

Specifies GSAP extra plugins.

Flip

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      flip: true
    }
  }
}

Available globally

const { $Flip } = useNuxtApp()

useFlip

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      flip: true
    }
  }
}

Usage

useFlip
// Explicit import (optional)
import { useFlip } from '#gsap'

ScrollTrigger

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      scrollTrigger: true
    }
  }
}

Available globally

const { $ScrollTrigger } = useNuxtApp()

useScrollTrigger

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      scrollTrigger: true
    }
  }
}

Usage

useScrollTrigger
// Explicit import (optional)
import { useScrollTrigger } from '#gsap'

Observer

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      observer: true
    }
  }
}

Available globally

const { $Observer } = useNuxtApp()

useObserver

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      observer: true
    }
  }
}

Usage

useObserver
// Explicit import (optional)
import { useObserver } from '#gsap'

ScrollTo

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      scrollTo: true
    }
  }
}

Available globally

const { $ScrollToPlugin } = useNuxtApp()

useScrollToPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      scrollTo: true
    }
  }
}

Usage

useScrollToPlugin
// Explicit import (optional)
import { useScrollToPlugin } from '#gsap'

Draggable

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      draggable: true
    }
  }
}

Available globally

const { $Draggable } = useNuxtApp()

useDraggable

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      draggable: true
    }
  }
}

Usage

useDraggable
// Explicit import (optional)
import { useDraggable } from '#gsap'

Easel

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      easel: true
    }
  }
}

Available globally

const { $EaselPlugin } = useNuxtApp()

useEaselPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      easel: true
    }
  }
}

Usage

useEaselPlugin
// Explicit import (optional)
import { useEaselPlugin } from '#gsap'

MotionPath

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      motionPath: true
    }
  }
}

Available globally

const { $MotionPathPlugin } = useNuxtApp()

useMotionPathPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      motionPath: true
    }
  }
}

Usage

useMotionPathPlugin
// Explicit import (optional)
import { useMotionPathPlugin } from '#gsap'

Pixi

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      pixi: true
    }
  }
}

Available globally

const { $PixiPlugin } = useNuxtApp()

usePixiPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      pixi: true
    }
  }
}

Usage

usePixiPlugin
// Explicit import (optional)
import { usePixiPlugin } from '#gsap'

Text

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraPlugins: {
      text: true
    }
  }
}

Available globally

const { $TextPlugin } = useNuxtApp()

useTextPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraPlugins: {
      text: true
    }
  }
}

Usage

useTextPlugin
// Explicit import (optional)
import { useTextPlugin } from '#gsap'

Extra Eases

  • Type: object
  • Default: undefined

Specifies GSAP extra eases.

ExpoScale

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraEases: {
      expoScale: true
    }
  }
}

Available globally

const { $ExpoScaleEase } = useNuxtApp()

useExpoScaleEase

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraEases: {
      expoScale: true
    }
  }
}

Usage

useExpoScaleEase
// Explicit import (optional)
import { useExpoScaleEase } from '#gsap'

Rough

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraEases: {
      rough: true
    }
  }
}

Available globally

const { $RoughEase } = useNuxtApp()

useRoughEase

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraEases: {
      rough: true
    }
  }
}

Usage

useRoughEase
// Explicit import (optional)
import { useRoughEase } from '#gsap'

SlowMo

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraEases: {
      slowMo: true
    }
  }
}

Available globally

const { $SlowMo } = useNuxtApp()

useSlowMo

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraEases: {
      slowMo: true
    }
  }
}

Usage

useSlowMo
// Explicit import (optional)
import { useSlowMo } from '#gsap'

Custom

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    extraEases: {
      custom: true
    }
  }
}

Available globally

const { $CustomEase } = useNuxtApp()

useCustomEase

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    extraEases: {
      custom: true
    }
  }
}

Usage

useCustomEase
// Explicit import (optional)
import { useCustomEase } from '#gsap'

Club Plugins

  • Type: object
  • Default: undefined

Specifies GSAP premium plugins.

This is only available to club members as it requires a paid license.

Keep in mind that premium plugins must be installed according to the official GSAP guidelines before use.

For more information about club plugins, check the official pages.

DrawSvg

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      drawSvg: true
    }
  }
}

Available globally

const { $DrawSVGPlugin } = useNuxtApp()

useDrawSVGPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      drawSvg: true
    }
  }
}

Usage

useDrawSVGPlugin
// Explicit import (optional)
import { useDrawSVGPlugin } from '#gsap'

ScrollSmoother

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      scrollSmoother: true
    }
  }
}

Available globally

const { $ScrollSmoother } = useNuxtApp()

useScrollSmoother

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      scrollSmoother: true
    }
  }
}

Usage

useScrollSmoother
// Explicit import (optional)
import { useScrollSmoother } from '#gsap'

GsDevTools

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      gsDevTools: true
    }
  }
}

Available globally

const { $GSDevTools } = useNuxtApp()

useGSDevTools

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      gsDevTools: true
    }
  }
}

Usage

useGSDevTools
// Explicit import (optional)
import { useGSDevTools } from '#gsap'

Inertia

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      inertia: true
    }
  }
}

Available globally

const { $InertiaPlugin } = useNuxtApp()

useInertiaPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      inertia: true
    }
  }
}

Usage

useInertiaPlugin
// Explicit import (optional)
import { useInertiaPlugin } from '#gsap'

MorphSvg

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      morphSvg: true
    }
  }
}

Available globally

const { $MorphSVGPlugin } = useNuxtApp()

useMorphSVGPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      morphSvg: true
    }
  }
}

Usage

useMorphSVGPlugin
// Explicit import (optional)
import { useMorphSVGPlugin } from '#gsap'

MotionPathHelper

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      motionPathHelper: true
    }
  }
}

Available globally

const { $MotionPathHelper } = useNuxtApp()

useMotionPathHelper

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      motionPathHelper: true
    }
  }
}

Usage

useMotionPathHelper
// Explicit import (optional)
import { useMotionPathHelper } from '#gsap'

Physics2d

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      physics2d: true
    }
  }
}

Available globally

const { $Physics2DPlugin } = useNuxtApp()

usePhysics2DPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      physics2d: true
    }
  }
}

Usage

usePhysics2DPlugin
// Explicit import (optional)
import { usePhysics2DPlugin } from '#gsap'

PhysicsProps

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      physicsProps: true
    }
  }
}

Available globally

const { $PhysicsPropsPlugin } = useNuxtApp()

usePhysicsPropsPlugin

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      physicsProps: true
    }
  }
}

Usage

usePhysicsPropsPlugin
// Explicit import (optional)
import { usePhysicsPropsPlugin } from '#gsap'

ScrambleText

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      scrambleText: true
    }
  }
}

Available globally

const { $ScrambleText } = useNuxtApp()

useScrambleText

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      scrambleText: true
    }
  }
}

Usage

useScrambleText
// Explicit import (optional)
import { useScrambleText } from '#gsap'

SplitText

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      splitText: true
    }
  }
}

Available globally

const { $SplitText } = useNuxtApp()

useSplitText

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      splitText: true
    }
  }
}

Usage

useSplitText
// Explicit import (optional)
import { useSplitText } from '#gsap'

CustomBounce

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      customBounce: true
    }
  }
}

Available globally

const { $CustomBounce } = useNuxtApp()

useCustomBounce

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      customBounce: true
    }
  }
}

Usage

useCustomBounce
// Explicit import (optional)
import { useCustomBounce } from '#gsap'

CustomWiggle

  • Type: boolean
  • Default: undefined
// nuxt.config.ts

{
  gsap: {
    clubPlugins: {
      customWiggle: true
    }
  }
}

Available globally

const { $CustomWiggle } = useNuxtApp()

useCustomWiggle

  • Custom composable
// nuxt.config.ts

{
  gsap: {
    composables: true,
    clubPlugins: {
      customWiggle: true
    }
  }
}

Usage

useCustomWiggle
// Explicit import (optional)
import { useCustomWiggle } from '#gsap'

Community

Feel free to use the official discussions for any additional questions.

License

Gsap Platform

More details about GSAP licenses can be found in the official repository.

Nuxt Gsap Module

Developed in 🇭🇷 Croatia

Released under the MIT license.

© Hypernym Studio

Keywords

FAQs

Package last updated on 16 Sep 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc