New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

scrollscene

Package Overview
Dependencies
Maintainers
1
Versions
24
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

scrollscene - npm Package Compare versions

Comparing version

to
0.0.16

9

dist/commonjs/ScrollScene.js

@@ -148,4 +148,3 @@ "use strict";

gsap = _ref.gsap,
_ref$offset = _ref.offset,
offset = _ref$offset === void 0 ? 0 : _ref$offset,
offset = _ref.offset,
_ref$scene = _ref.scene,

@@ -171,4 +170,4 @@ scene = _ref$scene === void 0 ? {} : _ref$scene,

if (!triggerElement) {
(0, _helpers.errorLog)(nameSpace, "Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ".concat(nameSpace, "({ triggerElement: triggerElement })"));
if (!triggerElement && offset === undefined) {
(0, _helpers.errorLog)(nameSpace, "Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ".concat(nameSpace, "({ triggerElement: triggerElement }) or set an offset."));
}

@@ -208,2 +207,2 @@

exports.ScrollScene = ScrollScene;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ScrollScene.ts"],"names":["nameSpace","updateTweenProgress","Scene","Tween","gsapForwardSpeed","gsapReverseSpeed","progress","state","repeat","paused","timeScale","play","pause","duration","reverse","removeTween","kill","setDuration","keys","Object","fn","index","length","breakpoint","parseFloat","window","innerWidth","addEventListener","setClassName","options","toggle","className","element","addClassName","classList","contains","add","removeClassName","remove","on","event","scrollDirection","setTween","gsap","forwardSpeed","reverseSpeed","timeline","globalController","ScrollScene","breakpoints","controller","offset","scene","triggerElement","triggerHook","useGlobalController","localController","ScrollMagic","Controller","controllerIsUse","init","addTo","destroy"],"mappings":"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","sourcesContent":["import ScrollMagic from './scrollmagic-with-ssr'\nimport throttle from 'lodash.throttle'\nimport { errorLog, isObject, scrollAnimationInit } from './helpers'\nimport { IScrollObserverToggle, IScrollObserverGsap } from './ScrollObserver'\n\nconst nameSpace = 'ScrollScene'\n\nconst updateTweenProgress = function(Scene, Tween, gsapForwardSpeed, gsapReverseSpeed) {\n  if (Tween) {\n    const progress = Scene.progress()\n    const state = Scene.state()\n    if (Tween.repeat && Tween.repeat() === -1) {\n      // infinite loop, so not in relation to progress\n      if (state === 'DURING' && Tween.paused()) {\n        Tween.timeScale(gsapForwardSpeed).play()\n      } else if (state !== 'DURING' && !Tween.paused()) {\n        Tween.pause()\n      }\n    } else if (progress != Tween.progress()) {\n      // do we even need to update the progress?\n      // no infinite loop - so should we just play or go to a specific point in time?\n      if (Scene.duration() === 0) {\n        // play the animation\n        if (progress > 0) {\n          // play from 0 to 1\n          Tween.timeScale(gsapForwardSpeed).play()\n        } else {\n          // play from 1 to 0\n          Tween.timeScale(gsapReverseSpeed).reverse()\n        }\n      } else {\n        // go to a specific point in time\n        // just hard set it\n        Tween.progress(progress).pause()\n      }\n    }\n  }\n}\n\nconst removeTween = function(Tween) {\n  if (Tween) {\n    Tween.pause(0)\n    Tween.kill()\n  }\n}\n\nconst setDuration = (Scene, duration) => {\n  if (isObject(duration)) {\n    const keys = Object.keys(duration).reverse()\n\n    const fn = () => {\n      for (let index = 0; index < keys.length; index++) {\n        const breakpoint = parseFloat(keys[index])\n\n        if (breakpoint <= window.innerWidth) {\n          Scene.duration(duration[breakpoint])\n          break\n        }\n      }\n    }\n\n    fn()\n\n    window.addEventListener('resize', throttle(fn, 700))\n  } else {\n    Scene.duration(duration)\n  }\n}\n\nconst setClassName = (Scene, options, duration) => {\n  const toggle = {\n    className: null,\n    element: null,\n    reverse: false,\n    ...options,\n  }\n\n  if (!toggle.className) {\n    errorLog(nameSpace, `Be sure to set a className in the new ${nameSpace}({ toggle: { className: \"my-class\" } })`)\n  }\n\n  if (!toggle.element) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const toggleElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ toggle: { element: toggleElement } })`,\n    )\n  }\n\n  const addClassName = () =>\n    !toggle.element.classList.contains(toggle.className) && toggle.element.classList.add(toggle.className)\n\n  const removeClassName = () =>\n    toggle.element.classList.contains(toggle.className) && toggle.element.classList.remove(toggle.className)\n\n  Scene.on('enter', function() {\n    addClassName()\n  })\n\n  Scene.on('add', function() {\n    if (Scene.state() === 'DURING') {\n      addClassName()\n    }\n  })\n\n  Scene.on('leave', function(event) {\n    if (!toggle.reverse && duration) {\n      // needs to be based on whether or not we have a duration\n      event.scrollDirection === 'REVERSE' && removeClassName()\n    } else {\n      removeClassName()\n    }\n  })\n\n  Scene.on('remove', function() {\n    removeClassName()\n  })\n}\n\nconst setTween = (Scene, options) => {\n  const gsap = {\n    forwardSpeed: 1,\n    reverseSpeed: 1,\n    timeline: null,\n    ...options,\n  }\n\n  if (!gsap.timeline) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const tl = gsap.timeline({ paused: true }) in the new ${nameSpace}({ gsap: { timeline: tl } })`,\n    )\n  }\n\n  Scene.on('progress', function() {\n    updateTweenProgress(Scene, gsap.timeline, gsap.forwardSpeed, gsap.reverseSpeed)\n  })\n\n  Scene.on('remove', function() {\n    removeTween(gsap.timeline)\n  })\n}\n\ninterface IScrollSceneToggle extends IScrollObserverToggle {\n  /**\n   * reverse\n   * @desc Specify the className should be removed after the duration of scene is met. Only applies if scene has duration.\n   * @type boolean\n   * @default false\n   * @example\n   * toggle: { reverse: true }\n   */\n  reverse?: boolean\n}\n\ninterface IScrollScene {\n  /**\n   * breakpoints\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first\n   * @type object\n   * @example\n   * breakpoints: { 0: false, 768: true }\n   */\n  breakpoints?: object\n\n  /**\n   * controller\n   * @desc Extra options to pass the new ScrollMagic.Controller, like vertical, etc.\n   * @type object\n   * @example\n   * controller: { vertical: false }\n   */\n  controller?: object\n\n  /**\n   * duration\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first (if setting breakpoints)\n   * Must be string for percentage, and number for pixel.\n   * @type object\n   * @example\n   * duration: '100%' = 100vh\n   * duration: 100 = 100px\n   * duration: { 0: '50%', 768: '100% } // = ScrollScene lasts 50vh on mobile, 100% after\n   */\n  duration?: string | number | object\n\n  /**\n   * gsap\n   * @desc Use to set options for the gsap animation of the ScrollObserver.\n   * @type object\n   * @example\n   * gsap: { timeline: myTimeline, yoyo: true, reverseSpeed: 2 }\n   */\n  gsap?: IScrollObserverGsap\n\n  /**\n   * triggerHook\n   * @desc Set the offset of the ScrollMagic scene.\n   * @type  number | string\n   * @defaultvalue 0\n   * @example\n   * offset: 100\n   * offset: '10%'\n   */\n  offset?: number | string\n\n  /**\n   * scene\n   * @desc Extra options to pass the new ScrollMagic.Scene, like logLevel, etc.\n   * @type object\n   * @example\n   * scene: { logLevel: 2 }\n   */\n  scene?: object\n\n  /**\n   * toggle\n   * @desc Use to set the options for the toggling of a className\n   * @type object\n   * @example\n   * toggle: { element: containerRef.current, className: 'lets-do-this' }\n   */\n  toggle?: IScrollSceneToggle\n\n  /**\n   * triggerElement\n   * @desc Set the element you wish to trigger events based upon, the observed element.\n   * @type  HTMLElement | any\n   * @example\n   * triggerElement: triggerRef.current\n   */\n  triggerElement: HTMLElement | any\n\n  /**\n   * triggerHook\n   * @desc Set the triggerHook of the ScrollMagic scene.\n   * @type  number\n   * @defaultvalue 'onEnter'\n   * @example\n   * triggerHook: 0.5\n   */\n  triggerHook?: number | string\n\n  /**\n   * useGlobalController\n   * @desc Chose whether or not to use the globalController provided for you, or a fresh new ScrollMagic.Controller instance.\n   * @type boolean\n   * @defaultValue true\n   * @example\n   * useGlobalController: false\n   */\n  useGlobalController?: boolean\n}\n\n// add controller var\nlet globalController\n\nconst ScrollScene = function(\n  this: any,\n  {\n    breakpoints,\n    controller = {},\n    duration,\n    gsap,\n    offset = 0,\n    scene = {},\n    toggle,\n    triggerElement,\n    triggerHook = 'onEnter',\n    useGlobalController = true,\n  }: IScrollScene,\n) {\n  let localController\n\n  // check if using a local controller\n  if (!useGlobalController) {\n    localController = new ScrollMagic.Controller(controller)\n  }\n\n  // mount controller\n  if (!globalController && useGlobalController) {\n    globalController = new ScrollMagic.Controller(controller)\n  }\n\n  const controllerIsUse = localController ? localController : globalController\n\n  if (!triggerElement) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ triggerElement: triggerElement })`,\n    )\n  }\n\n  const Scene = new ScrollMagic.Scene({\n    triggerElement,\n    triggerHook,\n    offset,\n    ...scene,\n  })\n\n  if (duration) {\n    setDuration(Scene, duration)\n  }\n\n  if (toggle && isObject(toggle)) {\n    setClassName(Scene, toggle, duration)\n  }\n\n  if (gsap && isObject(gsap)) {\n    setTween(Scene, gsap)\n  }\n\n  this.init = function() {\n    controllerIsUse && Scene.addTo(controllerIsUse)\n  }\n\n  this.destroy = function() {\n    Scene.remove()\n  }\n\n  this.Scene = Scene\n  this.Controller = controllerIsUse\n\n  scrollAnimationInit(breakpoints, this.init, this.destroy)\n}\n\nexport { ScrollScene }\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ScrollScene.ts"],"names":["nameSpace","updateTweenProgress","Scene","Tween","gsapForwardSpeed","gsapReverseSpeed","progress","state","repeat","paused","timeScale","play","pause","duration","reverse","removeTween","kill","setDuration","keys","Object","fn","index","length","breakpoint","parseFloat","window","innerWidth","addEventListener","setClassName","options","toggle","className","element","addClassName","classList","contains","add","removeClassName","remove","on","event","scrollDirection","setTween","gsap","forwardSpeed","reverseSpeed","timeline","globalController","ScrollScene","breakpoints","controller","offset","scene","triggerElement","triggerHook","useGlobalController","localController","ScrollMagic","Controller","controllerIsUse","undefined","init","addTo","destroy"],"mappings":"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","sourcesContent":["import ScrollMagic from './scrollmagic-with-ssr'\nimport throttle from 'lodash.throttle'\nimport { errorLog, isObject, scrollAnimationInit } from './helpers'\nimport { IScrollObserverToggle, IScrollObserverGsap } from './ScrollObserver'\n\nconst nameSpace = 'ScrollScene'\n\nconst updateTweenProgress = function(Scene, Tween, gsapForwardSpeed, gsapReverseSpeed) {\n  if (Tween) {\n    const progress = Scene.progress()\n    const state = Scene.state()\n    if (Tween.repeat && Tween.repeat() === -1) {\n      // infinite loop, so not in relation to progress\n      if (state === 'DURING' && Tween.paused()) {\n        Tween.timeScale(gsapForwardSpeed).play()\n      } else if (state !== 'DURING' && !Tween.paused()) {\n        Tween.pause()\n      }\n    } else if (progress != Tween.progress()) {\n      // do we even need to update the progress?\n      // no infinite loop - so should we just play or go to a specific point in time?\n      if (Scene.duration() === 0) {\n        // play the animation\n        if (progress > 0) {\n          // play from 0 to 1\n          Tween.timeScale(gsapForwardSpeed).play()\n        } else {\n          // play from 1 to 0\n          Tween.timeScale(gsapReverseSpeed).reverse()\n        }\n      } else {\n        // go to a specific point in time\n        // just hard set it\n        Tween.progress(progress).pause()\n      }\n    }\n  }\n}\n\nconst removeTween = function(Tween) {\n  if (Tween) {\n    Tween.pause(0)\n    Tween.kill()\n  }\n}\n\nconst setDuration = (Scene, duration) => {\n  if (isObject(duration)) {\n    const keys = Object.keys(duration).reverse()\n\n    const fn = () => {\n      for (let index = 0; index < keys.length; index++) {\n        const breakpoint = parseFloat(keys[index])\n\n        if (breakpoint <= window.innerWidth) {\n          Scene.duration(duration[breakpoint])\n          break\n        }\n      }\n    }\n\n    fn()\n\n    window.addEventListener('resize', throttle(fn, 700))\n  } else {\n    Scene.duration(duration)\n  }\n}\n\nconst setClassName = (Scene, options, duration) => {\n  const toggle = {\n    className: null,\n    element: null,\n    reverse: false,\n    ...options,\n  }\n\n  if (!toggle.className) {\n    errorLog(nameSpace, `Be sure to set a className in the new ${nameSpace}({ toggle: { className: \"my-class\" } })`)\n  }\n\n  if (!toggle.element) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const toggleElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ toggle: { element: toggleElement } })`,\n    )\n  }\n\n  const addClassName = () =>\n    !toggle.element.classList.contains(toggle.className) && toggle.element.classList.add(toggle.className)\n\n  const removeClassName = () =>\n    toggle.element.classList.contains(toggle.className) && toggle.element.classList.remove(toggle.className)\n\n  Scene.on('enter', function() {\n    addClassName()\n  })\n\n  Scene.on('add', function() {\n    if (Scene.state() === 'DURING') {\n      addClassName()\n    }\n  })\n\n  Scene.on('leave', function(event) {\n    if (!toggle.reverse && duration) {\n      // needs to be based on whether or not we have a duration\n      event.scrollDirection === 'REVERSE' && removeClassName()\n    } else {\n      removeClassName()\n    }\n  })\n\n  Scene.on('remove', function() {\n    removeClassName()\n  })\n}\n\nconst setTween = (Scene, options) => {\n  const gsap = {\n    forwardSpeed: 1,\n    reverseSpeed: 1,\n    timeline: null,\n    ...options,\n  }\n\n  if (!gsap.timeline) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const tl = gsap.timeline({ paused: true }) in the new ${nameSpace}({ gsap: { timeline: tl } })`,\n    )\n  }\n\n  Scene.on('progress', function() {\n    updateTweenProgress(Scene, gsap.timeline, gsap.forwardSpeed, gsap.reverseSpeed)\n  })\n\n  Scene.on('remove', function() {\n    removeTween(gsap.timeline)\n  })\n}\n\ninterface IScrollSceneToggle extends IScrollObserverToggle {\n  /**\n   * reverse\n   * @desc Specify the className should be removed after the duration of scene is met. Only applies if scene has duration.\n   * @type boolean\n   * @default false\n   * @example\n   * toggle: { reverse: true }\n   */\n  reverse?: boolean\n}\n\ninterface IScrollScene {\n  /**\n   * breakpoints\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first\n   * @type object\n   * @example\n   * breakpoints: { 0: false, 768: true }\n   */\n  breakpoints?: object\n\n  /**\n   * controller\n   * @desc Extra options to pass the new ScrollMagic.Controller, like vertical, etc.\n   * @type object\n   * @example\n   * controller: { vertical: false }\n   */\n  controller?: object\n\n  /**\n   * duration\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first (if setting breakpoints)\n   * Must be string for percentage, and number for pixel.\n   * @type object\n   * @example\n   * duration: '100%' = 100vh\n   * duration: 100 = 100px\n   * duration: { 0: '50%', 768: '100% } // = ScrollScene lasts 50vh on mobile, 100% after\n   */\n  duration?: string | number | object\n\n  /**\n   * gsap\n   * @desc Use to set options for the gsap animation of the ScrollObserver.\n   * @type object\n   * @example\n   * gsap: { timeline: myTimeline, yoyo: true, reverseSpeed: 2 }\n   */\n  gsap?: IScrollObserverGsap\n\n  /**\n   * triggerHook\n   * @desc Set the offset of the ScrollMagic scene.\n   * @type  number | string\n   * @defaultvalue 0\n   * @example\n   * offset: 100\n   * offset: '10%'\n   */\n  offset?: number | string\n\n  /**\n   * scene\n   * @desc Extra options to pass the new ScrollMagic.Scene, like logLevel, etc.\n   * @type object\n   * @example\n   * scene: { logLevel: 2 }\n   */\n  scene?: object\n\n  /**\n   * toggle\n   * @desc Use to set the options for the toggling of a className\n   * @type object\n   * @example\n   * toggle: { element: containerRef.current, className: 'lets-do-this' }\n   */\n  toggle?: IScrollSceneToggle\n\n  /**\n   * triggerElement\n   * @desc Set the element you wish to trigger events based upon, the observed element.\n   * @type  HTMLElement | any\n   * @example\n   * triggerElement: triggerRef.current\n   */\n  triggerElement: HTMLElement | any\n\n  /**\n   * triggerHook\n   * @desc Set the triggerHook of the ScrollMagic scene.\n   * @type  number\n   * @defaultvalue 'onEnter'\n   * @example\n   * triggerHook: 0.5\n   */\n  triggerHook?: number | string\n\n  /**\n   * useGlobalController\n   * @desc Chose whether or not to use the globalController provided for you, or a fresh new ScrollMagic.Controller instance.\n   * @type boolean\n   * @defaultValue true\n   * @example\n   * useGlobalController: false\n   */\n  useGlobalController?: boolean\n}\n\n// add controller var\nlet globalController\n\nconst ScrollScene = function(\n  this: any,\n  {\n    breakpoints,\n    controller = {},\n    duration,\n    gsap,\n    offset,\n    scene = {},\n    toggle,\n    triggerElement,\n    triggerHook = 'onEnter',\n    useGlobalController = true,\n  }: IScrollScene,\n) {\n  let localController\n\n  // check if using a local controller\n  if (!useGlobalController) {\n    localController = new ScrollMagic.Controller(controller)\n  }\n\n  // mount controller\n  if (!globalController && useGlobalController) {\n    globalController = new ScrollMagic.Controller(controller)\n  }\n\n  const controllerIsUse = localController ? localController : globalController\n\n  if (!triggerElement && offset === undefined) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ triggerElement: triggerElement }) or set an offset.`,\n    )\n  }\n\n  const Scene = new ScrollMagic.Scene({\n    triggerElement,\n    triggerHook,\n    offset,\n    ...scene,\n  })\n\n  if (duration) {\n    setDuration(Scene, duration)\n  }\n\n  if (toggle && isObject(toggle)) {\n    setClassName(Scene, toggle, duration)\n  }\n\n  if (gsap && isObject(gsap)) {\n    setTween(Scene, gsap)\n  }\n\n  this.init = function() {\n    controllerIsUse && Scene.addTo(controllerIsUse)\n  }\n\n  this.destroy = function() {\n    Scene.remove()\n  }\n\n  this.Scene = Scene\n  this.Controller = controllerIsUse\n\n  scrollAnimationInit(breakpoints, this.init, this.destroy)\n}\n\nexport { ScrollScene }\n"]}

@@ -136,4 +136,3 @@ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";

gsap = _ref.gsap,
_ref$offset = _ref.offset,
offset = _ref$offset === void 0 ? 0 : _ref$offset,
offset = _ref.offset,
_ref$scene = _ref.scene,

@@ -159,4 +158,4 @@ scene = _ref$scene === void 0 ? {} : _ref$scene,

if (!triggerElement) {
errorLog(nameSpace, "Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ".concat(nameSpace, "({ triggerElement: triggerElement })"));
if (!triggerElement && offset === undefined) {
errorLog(nameSpace, "Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ".concat(nameSpace, "({ triggerElement: triggerElement }) or set an offset."));
}

@@ -196,2 +195,2 @@

export { ScrollScene };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ScrollScene.ts"],"names":["ScrollMagic","throttle","errorLog","isObject","scrollAnimationInit","nameSpace","updateTweenProgress","Scene","Tween","gsapForwardSpeed","gsapReverseSpeed","progress","state","repeat","paused","timeScale","play","pause","duration","reverse","removeTween","kill","setDuration","keys","Object","fn","index","length","breakpoint","parseFloat","window","innerWidth","addEventListener","setClassName","options","toggle","className","element","addClassName","classList","contains","add","removeClassName","remove","on","event","scrollDirection","setTween","gsap","forwardSpeed","reverseSpeed","timeline","globalController","ScrollScene","breakpoints","controller","offset","scene","triggerElement","triggerHook","useGlobalController","localController","Controller","controllerIsUse","init","addTo","destroy"],"mappings":"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","sourcesContent":["import ScrollMagic from './scrollmagic-with-ssr'\nimport throttle from 'lodash.throttle'\nimport { errorLog, isObject, scrollAnimationInit } from './helpers'\nimport { IScrollObserverToggle, IScrollObserverGsap } from './ScrollObserver'\n\nconst nameSpace = 'ScrollScene'\n\nconst updateTweenProgress = function(Scene, Tween, gsapForwardSpeed, gsapReverseSpeed) {\n  if (Tween) {\n    const progress = Scene.progress()\n    const state = Scene.state()\n    if (Tween.repeat && Tween.repeat() === -1) {\n      // infinite loop, so not in relation to progress\n      if (state === 'DURING' && Tween.paused()) {\n        Tween.timeScale(gsapForwardSpeed).play()\n      } else if (state !== 'DURING' && !Tween.paused()) {\n        Tween.pause()\n      }\n    } else if (progress != Tween.progress()) {\n      // do we even need to update the progress?\n      // no infinite loop - so should we just play or go to a specific point in time?\n      if (Scene.duration() === 0) {\n        // play the animation\n        if (progress > 0) {\n          // play from 0 to 1\n          Tween.timeScale(gsapForwardSpeed).play()\n        } else {\n          // play from 1 to 0\n          Tween.timeScale(gsapReverseSpeed).reverse()\n        }\n      } else {\n        // go to a specific point in time\n        // just hard set it\n        Tween.progress(progress).pause()\n      }\n    }\n  }\n}\n\nconst removeTween = function(Tween) {\n  if (Tween) {\n    Tween.pause(0)\n    Tween.kill()\n  }\n}\n\nconst setDuration = (Scene, duration) => {\n  if (isObject(duration)) {\n    const keys = Object.keys(duration).reverse()\n\n    const fn = () => {\n      for (let index = 0; index < keys.length; index++) {\n        const breakpoint = parseFloat(keys[index])\n\n        if (breakpoint <= window.innerWidth) {\n          Scene.duration(duration[breakpoint])\n          break\n        }\n      }\n    }\n\n    fn()\n\n    window.addEventListener('resize', throttle(fn, 700))\n  } else {\n    Scene.duration(duration)\n  }\n}\n\nconst setClassName = (Scene, options, duration) => {\n  const toggle = {\n    className: null,\n    element: null,\n    reverse: false,\n    ...options,\n  }\n\n  if (!toggle.className) {\n    errorLog(nameSpace, `Be sure to set a className in the new ${nameSpace}({ toggle: { className: \"my-class\" } })`)\n  }\n\n  if (!toggle.element) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const toggleElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ toggle: { element: toggleElement } })`,\n    )\n  }\n\n  const addClassName = () =>\n    !toggle.element.classList.contains(toggle.className) && toggle.element.classList.add(toggle.className)\n\n  const removeClassName = () =>\n    toggle.element.classList.contains(toggle.className) && toggle.element.classList.remove(toggle.className)\n\n  Scene.on('enter', function() {\n    addClassName()\n  })\n\n  Scene.on('add', function() {\n    if (Scene.state() === 'DURING') {\n      addClassName()\n    }\n  })\n\n  Scene.on('leave', function(event) {\n    if (!toggle.reverse && duration) {\n      // needs to be based on whether or not we have a duration\n      event.scrollDirection === 'REVERSE' && removeClassName()\n    } else {\n      removeClassName()\n    }\n  })\n\n  Scene.on('remove', function() {\n    removeClassName()\n  })\n}\n\nconst setTween = (Scene, options) => {\n  const gsap = {\n    forwardSpeed: 1,\n    reverseSpeed: 1,\n    timeline: null,\n    ...options,\n  }\n\n  if (!gsap.timeline) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const tl = gsap.timeline({ paused: true }) in the new ${nameSpace}({ gsap: { timeline: tl } })`,\n    )\n  }\n\n  Scene.on('progress', function() {\n    updateTweenProgress(Scene, gsap.timeline, gsap.forwardSpeed, gsap.reverseSpeed)\n  })\n\n  Scene.on('remove', function() {\n    removeTween(gsap.timeline)\n  })\n}\n\ninterface IScrollSceneToggle extends IScrollObserverToggle {\n  /**\n   * reverse\n   * @desc Specify the className should be removed after the duration of scene is met. Only applies if scene has duration.\n   * @type boolean\n   * @default false\n   * @example\n   * toggle: { reverse: true }\n   */\n  reverse?: boolean\n}\n\ninterface IScrollScene {\n  /**\n   * breakpoints\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first\n   * @type object\n   * @example\n   * breakpoints: { 0: false, 768: true }\n   */\n  breakpoints?: object\n\n  /**\n   * controller\n   * @desc Extra options to pass the new ScrollMagic.Controller, like vertical, etc.\n   * @type object\n   * @example\n   * controller: { vertical: false }\n   */\n  controller?: object\n\n  /**\n   * duration\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first (if setting breakpoints)\n   * Must be string for percentage, and number for pixel.\n   * @type object\n   * @example\n   * duration: '100%' = 100vh\n   * duration: 100 = 100px\n   * duration: { 0: '50%', 768: '100% } // = ScrollScene lasts 50vh on mobile, 100% after\n   */\n  duration?: string | number | object\n\n  /**\n   * gsap\n   * @desc Use to set options for the gsap animation of the ScrollObserver.\n   * @type object\n   * @example\n   * gsap: { timeline: myTimeline, yoyo: true, reverseSpeed: 2 }\n   */\n  gsap?: IScrollObserverGsap\n\n  /**\n   * triggerHook\n   * @desc Set the offset of the ScrollMagic scene.\n   * @type  number | string\n   * @defaultvalue 0\n   * @example\n   * offset: 100\n   * offset: '10%'\n   */\n  offset?: number | string\n\n  /**\n   * scene\n   * @desc Extra options to pass the new ScrollMagic.Scene, like logLevel, etc.\n   * @type object\n   * @example\n   * scene: { logLevel: 2 }\n   */\n  scene?: object\n\n  /**\n   * toggle\n   * @desc Use to set the options for the toggling of a className\n   * @type object\n   * @example\n   * toggle: { element: containerRef.current, className: 'lets-do-this' }\n   */\n  toggle?: IScrollSceneToggle\n\n  /**\n   * triggerElement\n   * @desc Set the element you wish to trigger events based upon, the observed element.\n   * @type  HTMLElement | any\n   * @example\n   * triggerElement: triggerRef.current\n   */\n  triggerElement: HTMLElement | any\n\n  /**\n   * triggerHook\n   * @desc Set the triggerHook of the ScrollMagic scene.\n   * @type  number\n   * @defaultvalue 'onEnter'\n   * @example\n   * triggerHook: 0.5\n   */\n  triggerHook?: number | string\n\n  /**\n   * useGlobalController\n   * @desc Chose whether or not to use the globalController provided for you, or a fresh new ScrollMagic.Controller instance.\n   * @type boolean\n   * @defaultValue true\n   * @example\n   * useGlobalController: false\n   */\n  useGlobalController?: boolean\n}\n\n// add controller var\nlet globalController\n\nconst ScrollScene = function(\n  this: any,\n  {\n    breakpoints,\n    controller = {},\n    duration,\n    gsap,\n    offset = 0,\n    scene = {},\n    toggle,\n    triggerElement,\n    triggerHook = 'onEnter',\n    useGlobalController = true,\n  }: IScrollScene,\n) {\n  let localController\n\n  // check if using a local controller\n  if (!useGlobalController) {\n    localController = new ScrollMagic.Controller(controller)\n  }\n\n  // mount controller\n  if (!globalController && useGlobalController) {\n    globalController = new ScrollMagic.Controller(controller)\n  }\n\n  const controllerIsUse = localController ? localController : globalController\n\n  if (!triggerElement) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ triggerElement: triggerElement })`,\n    )\n  }\n\n  const Scene = new ScrollMagic.Scene({\n    triggerElement,\n    triggerHook,\n    offset,\n    ...scene,\n  })\n\n  if (duration) {\n    setDuration(Scene, duration)\n  }\n\n  if (toggle && isObject(toggle)) {\n    setClassName(Scene, toggle, duration)\n  }\n\n  if (gsap && isObject(gsap)) {\n    setTween(Scene, gsap)\n  }\n\n  this.init = function() {\n    controllerIsUse && Scene.addTo(controllerIsUse)\n  }\n\n  this.destroy = function() {\n    Scene.remove()\n  }\n\n  this.Scene = Scene\n  this.Controller = controllerIsUse\n\n  scrollAnimationInit(breakpoints, this.init, this.destroy)\n}\n\nexport { ScrollScene }\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ScrollScene.ts"],"names":["ScrollMagic","throttle","errorLog","isObject","scrollAnimationInit","nameSpace","updateTweenProgress","Scene","Tween","gsapForwardSpeed","gsapReverseSpeed","progress","state","repeat","paused","timeScale","play","pause","duration","reverse","removeTween","kill","setDuration","keys","Object","fn","index","length","breakpoint","parseFloat","window","innerWidth","addEventListener","setClassName","options","toggle","className","element","addClassName","classList","contains","add","removeClassName","remove","on","event","scrollDirection","setTween","gsap","forwardSpeed","reverseSpeed","timeline","globalController","ScrollScene","breakpoints","controller","offset","scene","triggerElement","triggerHook","useGlobalController","localController","Controller","controllerIsUse","undefined","init","addTo","destroy"],"mappings":"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","sourcesContent":["import ScrollMagic from './scrollmagic-with-ssr'\nimport throttle from 'lodash.throttle'\nimport { errorLog, isObject, scrollAnimationInit } from './helpers'\nimport { IScrollObserverToggle, IScrollObserverGsap } from './ScrollObserver'\n\nconst nameSpace = 'ScrollScene'\n\nconst updateTweenProgress = function(Scene, Tween, gsapForwardSpeed, gsapReverseSpeed) {\n  if (Tween) {\n    const progress = Scene.progress()\n    const state = Scene.state()\n    if (Tween.repeat && Tween.repeat() === -1) {\n      // infinite loop, so not in relation to progress\n      if (state === 'DURING' && Tween.paused()) {\n        Tween.timeScale(gsapForwardSpeed).play()\n      } else if (state !== 'DURING' && !Tween.paused()) {\n        Tween.pause()\n      }\n    } else if (progress != Tween.progress()) {\n      // do we even need to update the progress?\n      // no infinite loop - so should we just play or go to a specific point in time?\n      if (Scene.duration() === 0) {\n        // play the animation\n        if (progress > 0) {\n          // play from 0 to 1\n          Tween.timeScale(gsapForwardSpeed).play()\n        } else {\n          // play from 1 to 0\n          Tween.timeScale(gsapReverseSpeed).reverse()\n        }\n      } else {\n        // go to a specific point in time\n        // just hard set it\n        Tween.progress(progress).pause()\n      }\n    }\n  }\n}\n\nconst removeTween = function(Tween) {\n  if (Tween) {\n    Tween.pause(0)\n    Tween.kill()\n  }\n}\n\nconst setDuration = (Scene, duration) => {\n  if (isObject(duration)) {\n    const keys = Object.keys(duration).reverse()\n\n    const fn = () => {\n      for (let index = 0; index < keys.length; index++) {\n        const breakpoint = parseFloat(keys[index])\n\n        if (breakpoint <= window.innerWidth) {\n          Scene.duration(duration[breakpoint])\n          break\n        }\n      }\n    }\n\n    fn()\n\n    window.addEventListener('resize', throttle(fn, 700))\n  } else {\n    Scene.duration(duration)\n  }\n}\n\nconst setClassName = (Scene, options, duration) => {\n  const toggle = {\n    className: null,\n    element: null,\n    reverse: false,\n    ...options,\n  }\n\n  if (!toggle.className) {\n    errorLog(nameSpace, `Be sure to set a className in the new ${nameSpace}({ toggle: { className: \"my-class\" } })`)\n  }\n\n  if (!toggle.element) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const toggleElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ toggle: { element: toggleElement } })`,\n    )\n  }\n\n  const addClassName = () =>\n    !toggle.element.classList.contains(toggle.className) && toggle.element.classList.add(toggle.className)\n\n  const removeClassName = () =>\n    toggle.element.classList.contains(toggle.className) && toggle.element.classList.remove(toggle.className)\n\n  Scene.on('enter', function() {\n    addClassName()\n  })\n\n  Scene.on('add', function() {\n    if (Scene.state() === 'DURING') {\n      addClassName()\n    }\n  })\n\n  Scene.on('leave', function(event) {\n    if (!toggle.reverse && duration) {\n      // needs to be based on whether or not we have a duration\n      event.scrollDirection === 'REVERSE' && removeClassName()\n    } else {\n      removeClassName()\n    }\n  })\n\n  Scene.on('remove', function() {\n    removeClassName()\n  })\n}\n\nconst setTween = (Scene, options) => {\n  const gsap = {\n    forwardSpeed: 1,\n    reverseSpeed: 1,\n    timeline: null,\n    ...options,\n  }\n\n  if (!gsap.timeline) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const tl = gsap.timeline({ paused: true }) in the new ${nameSpace}({ gsap: { timeline: tl } })`,\n    )\n  }\n\n  Scene.on('progress', function() {\n    updateTweenProgress(Scene, gsap.timeline, gsap.forwardSpeed, gsap.reverseSpeed)\n  })\n\n  Scene.on('remove', function() {\n    removeTween(gsap.timeline)\n  })\n}\n\ninterface IScrollSceneToggle extends IScrollObserverToggle {\n  /**\n   * reverse\n   * @desc Specify the className should be removed after the duration of scene is met. Only applies if scene has duration.\n   * @type boolean\n   * @default false\n   * @example\n   * toggle: { reverse: true }\n   */\n  reverse?: boolean\n}\n\ninterface IScrollScene {\n  /**\n   * breakpoints\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first\n   * @type object\n   * @example\n   * breakpoints: { 0: false, 768: true }\n   */\n  breakpoints?: object\n\n  /**\n   * controller\n   * @desc Extra options to pass the new ScrollMagic.Controller, like vertical, etc.\n   * @type object\n   * @example\n   * controller: { vertical: false }\n   */\n  controller?: object\n\n  /**\n   * duration\n   * @desc Use to set responsiveness of the new ScrollMagic.Scene, mobile-first (if setting breakpoints)\n   * Must be string for percentage, and number for pixel.\n   * @type object\n   * @example\n   * duration: '100%' = 100vh\n   * duration: 100 = 100px\n   * duration: { 0: '50%', 768: '100% } // = ScrollScene lasts 50vh on mobile, 100% after\n   */\n  duration?: string | number | object\n\n  /**\n   * gsap\n   * @desc Use to set options for the gsap animation of the ScrollObserver.\n   * @type object\n   * @example\n   * gsap: { timeline: myTimeline, yoyo: true, reverseSpeed: 2 }\n   */\n  gsap?: IScrollObserverGsap\n\n  /**\n   * triggerHook\n   * @desc Set the offset of the ScrollMagic scene.\n   * @type  number | string\n   * @defaultvalue 0\n   * @example\n   * offset: 100\n   * offset: '10%'\n   */\n  offset?: number | string\n\n  /**\n   * scene\n   * @desc Extra options to pass the new ScrollMagic.Scene, like logLevel, etc.\n   * @type object\n   * @example\n   * scene: { logLevel: 2 }\n   */\n  scene?: object\n\n  /**\n   * toggle\n   * @desc Use to set the options for the toggling of a className\n   * @type object\n   * @example\n   * toggle: { element: containerRef.current, className: 'lets-do-this' }\n   */\n  toggle?: IScrollSceneToggle\n\n  /**\n   * triggerElement\n   * @desc Set the element you wish to trigger events based upon, the observed element.\n   * @type  HTMLElement | any\n   * @example\n   * triggerElement: triggerRef.current\n   */\n  triggerElement: HTMLElement | any\n\n  /**\n   * triggerHook\n   * @desc Set the triggerHook of the ScrollMagic scene.\n   * @type  number\n   * @defaultvalue 'onEnter'\n   * @example\n   * triggerHook: 0.5\n   */\n  triggerHook?: number | string\n\n  /**\n   * useGlobalController\n   * @desc Chose whether or not to use the globalController provided for you, or a fresh new ScrollMagic.Controller instance.\n   * @type boolean\n   * @defaultValue true\n   * @example\n   * useGlobalController: false\n   */\n  useGlobalController?: boolean\n}\n\n// add controller var\nlet globalController\n\nconst ScrollScene = function(\n  this: any,\n  {\n    breakpoints,\n    controller = {},\n    duration,\n    gsap,\n    offset,\n    scene = {},\n    toggle,\n    triggerElement,\n    triggerHook = 'onEnter',\n    useGlobalController = true,\n  }: IScrollScene,\n) {\n  let localController\n\n  // check if using a local controller\n  if (!useGlobalController) {\n    localController = new ScrollMagic.Controller(controller)\n  }\n\n  // mount controller\n  if (!globalController && useGlobalController) {\n    globalController = new ScrollMagic.Controller(controller)\n  }\n\n  const controllerIsUse = localController ? localController : globalController\n\n  if (!triggerElement && offset === undefined) {\n    errorLog(\n      nameSpace,\n      `Be sure to set a const triggerElement = (reactRef.current or document.querySelector) in the new ${nameSpace}({ triggerElement: triggerElement }) or set an offset.`,\n    )\n  }\n\n  const Scene = new ScrollMagic.Scene({\n    triggerElement,\n    triggerHook,\n    offset,\n    ...scene,\n  })\n\n  if (duration) {\n    setDuration(Scene, duration)\n  }\n\n  if (toggle && isObject(toggle)) {\n    setClassName(Scene, toggle, duration)\n  }\n\n  if (gsap && isObject(gsap)) {\n    setTween(Scene, gsap)\n  }\n\n  this.init = function() {\n    controllerIsUse && Scene.addTo(controllerIsUse)\n  }\n\n  this.destroy = function() {\n    Scene.remove()\n  }\n\n  this.Scene = Scene\n  this.Controller = controllerIsUse\n\n  scrollAnimationInit(breakpoints, this.init, this.destroy)\n}\n\nexport { ScrollScene }\n"]}
{
"name": "scrollscene",
"title": "ScrollScene",
"version": "0.0.15",
"version": "0.0.16",
"description": "ScrollScene is an extra layer on top of ScrollMagic as well as using IntersectionObserver to achieve similar effects.",

@@ -6,0 +6,0 @@ "author": "Jon K. Wheeler",