scroll-dynamics-pro 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 James
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,120 @@
1
+ # scroll-dynamics-pro
2
+
3
+ A lightweight, production-ready React library for mixed vertical and horizontal scrolling.
4
+ Zero dependencies, 60FPS performance, and native sticky positioning.
5
+
6
+ ## Features
7
+
8
+ - **Mixed Scrolling:** Seamlessly switch between vertical and horizontal scrolling sections.
9
+ - **Scroll Restore:** Maintains correct horizontal position on page reload (no jumps).
10
+ - **High Performance:** Uses `requestAnimationFrame` and direct DOM manipulation (no React state thrashing).
11
+ - **Optimization:** Uses `IntersectionObserver` to only run logic when sections are in view.
12
+ - **Lightweight:** No heavy animation libraries (GSAP/Framer Motion).
13
+
14
+ ## Installation
15
+
16
+ ```bash
17
+ npm install scroll-dynamics-pro
18
+ # or
19
+ yarn add scroll-dynamics-pro
20
+ ```
21
+
22
+ ## Usage
23
+
24
+ Wrap your application (or just the scrolling area) in `ScrollProvider`, then use `ScrollSection` to create scrollable areas.
25
+
26
+ ```tsx
27
+ import React from "react";
28
+ import {
29
+ ScrollProvider,
30
+ ScrollSection,
31
+ ScrollTransform,
32
+ } from "scroll-dynamics-pro";
33
+
34
+ const App = () => {
35
+ return (
36
+ <ScrollProvider>
37
+ {/* Normal Vertical Content */}
38
+ <ScrollSection direction="vertical">
39
+ <div
40
+ style={{ height: "100vh", background: "#f0f0f0", padding: "50px" }}
41
+ >
42
+ <h1>Welcome to the Scroll Experience</h1>
43
+
44
+ <ScrollTransform effect="fade">
45
+ <h2>I fade in as I scroll up!</h2>
46
+ </ScrollTransform>
47
+
48
+ <ScrollTransform effect="parallax" speed={0.5}>
49
+ <div
50
+ className="parallax-box"
51
+ style={{
52
+ background: "purple",
53
+ padding: "20px",
54
+ marginTop: "50px",
55
+ color: "white",
56
+ }}
57
+ >
58
+ I move slower than the scroll!
59
+ </div>
60
+ </ScrollTransform>
61
+ </div>
62
+ </ScrollSection>
63
+
64
+ {/* Horizontal Scroll Section */}
65
+ {/* trackLength="300vw" means the user needs to scroll 2 viewport heights
66
+ to move through the 3 viewports worth of content. */}
67
+ <ScrollSection direction="horizontal" trackLength="300vw">
68
+ <div className="card" style={{ width: "100vw", background: "red" }}>
69
+ Slide 1
70
+ </div>
71
+ <div className="card" style={{ width: "100vw", background: "blue" }}>
72
+ Slide 2
73
+ </div>
74
+ <div className="card" style={{ width: "100vw", background: "green" }}>
75
+ Slide 3
76
+ </div>
77
+ </ScrollSection>
78
+
79
+ {/* More Vertical Content */}
80
+ <ScrollSection direction="vertical">
81
+ <div style={{ height: "100vh", background: "#e0e0e0" }}>
82
+ <h2>The End</h2>
83
+ </div>
84
+ </ScrollSection>
85
+ </ScrollProvider>
86
+ );
87
+ };
88
+
89
+ export default App;
90
+ ```
91
+
92
+ ## API
93
+
94
+ ### `<ScrollProvider>`
95
+
96
+ Tracks global scroll position. Must wrap all `ScrollSection` components.
97
+
98
+ ### `<ScrollSection>`
99
+
100
+ | Prop | Type | Default | Description |
101
+ | ------------- | ---------------------------- | ------------ | ----------------------------------------------------------------------------------------------- |
102
+ | `direction` | `'vertical' \| 'horizontal'` | `'vertical'` | The scroll direction. |
103
+ | `trackLength` | `string` | `'300vw'` | Total height of the scroll track (only for horizontal). Determines how long the scroll "lasts". |
104
+ | `className` | `string` | | CSS class for the section container. |
105
+ | `style` | `object` | | Inline styles for the section container. |
106
+
107
+ ### `<ScrollTransform>`
108
+
109
+ Animates children based on scroll position.
110
+
111
+ | Prop | Type | Default | Description |
112
+ | ----------- | --------------------------------------------- | ------------ | ----------------------------------------------------------------- |
113
+ | `effect` | `'parallax' \| 'fade' \| 'scale' \| 'custom'` | `'parallax'` | The animation effect to apply. |
114
+ | `speed` | `number` | `0.2` | (Parallax only) Speed factor relative to scroll. |
115
+ | `range` | `[number, number]` | `[0, 1]` | Range of viewport traversal [0=enter, 1=leave] for interpolation. |
116
+ | `transform` | `function` | | Custom transform function `(element, progress, scrollY) => void`. |
117
+
118
+ ## License
119
+
120
+ MIT
@@ -0,0 +1,21 @@
1
+ import React from "react";
2
+ interface ScrollSectionProps {
3
+ /**
4
+ * Direction of scrolling effect.
5
+ * 'horizontal': The content inside will scroll horizontally as the user scrolls down.
6
+ * 'vertical': Standard vertical scrolling (pass-through mostly, or parallax hook).
7
+ * Currently optimized for 'horizontal' (mixed) flow.
8
+ */
9
+ direction?: "horizontal" | "vertical";
10
+ children: React.ReactNode;
11
+ className?: string;
12
+ style?: React.CSSProperties;
13
+ /**
14
+ * Only for horizontal direction:
15
+ * The width of the track relative to viewport width.
16
+ * e.g., '300vw' means the section will take 3 viewports to scroll through.
17
+ */
18
+ trackLength?: string;
19
+ }
20
+ export declare const ScrollSection: React.FC<ScrollSectionProps>;
21
+ export {};
@@ -0,0 +1,52 @@
1
+ import React from "react";
2
+ interface ScrollTransformProps {
3
+ children: React.ReactNode;
4
+ /**
5
+ * The effect to apply.
6
+ * 'parallax': Moves the element at a different speed than scroll.
7
+ * 'fade': Changes opacity from 0 to 1 based on entry.
8
+ * 'scale': Scales element from start scale to end scale.
9
+ * 'skew-velocity': Skews the element based on global scroll velocity.
10
+ * 'rotate': Rotates the element based on scroll progress.
11
+ * 'slide-in': Slides the element in from a direction.
12
+ * 'custom': Use the `transform` prop function.
13
+ */
14
+ effect?: "parallax" | "fade" | "scale" | "skew-velocity" | "rotate" | "rotate-x" | "rotate-y" | "slide-in" | "blur" | "hue-rotate" | "custom";
15
+ /**
16
+ * For parallax: speed factor.
17
+ * 0.5 = moves at half speed.
18
+ * -0.5 = moves in reverse.
19
+ */
20
+ speed?: number;
21
+ /**
22
+ * Multiplier for effect intensity (e.g. max skew angle, rotation degrees, slide distance).
23
+ * Default: 1
24
+ */
25
+ intensity?: number;
26
+ /**
27
+ * Direction for slide-in or other directional effects.
28
+ */
29
+ direction?: "up" | "down" | "left" | "right";
30
+ /**
31
+ * For fade/scale: input range [start, end] as generic progress 0..1 (viewport relative).
32
+ * default: [0, 1] meaning full viewport traversal.
33
+ */
34
+ range?: [number, number];
35
+ /**
36
+ * For custom effect: A function that receives progress (0..1) or scrollY and applies style.
37
+ * Warning: Keep this performant. direct DOM manipulation recommended.
38
+ */
39
+ transform?: (element: HTMLElement, progress: number, scrollY: number, velocity: number) => void;
40
+ /**
41
+ * Callback fired when element enters the viewport.
42
+ */
43
+ onEnter?: () => void;
44
+ /**
45
+ * Callback fired when element leaves the viewport.
46
+ */
47
+ onLeave?: () => void;
48
+ className?: string;
49
+ style?: React.CSSProperties;
50
+ }
51
+ export declare const ScrollTransform: React.FC<ScrollTransformProps>;
52
+ export {};
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ interface ScrollytellingProps {
3
+ /**
4
+ * Total height of the scrollable track (e.g. '300vh').
5
+ */
6
+ height?: string | number;
7
+ /**
8
+ * Render prop function receiving progress (0 to 1).
9
+ */
10
+ children: (progress: number) => React.ReactNode;
11
+ className?: string;
12
+ style?: React.CSSProperties;
13
+ }
14
+ export declare const Scrollytelling: React.FC<ScrollytellingProps>;
15
+ export {};
@@ -0,0 +1,12 @@
1
+ import React from "react";
2
+ type ScrollCallback = (scrollY: number, velocity: number) => void;
3
+ interface ScrollContextValue {
4
+ subscribe: (callback: ScrollCallback) => () => void;
5
+ getScrollY: () => number;
6
+ }
7
+ export declare const ScrollProvider: React.FC<{
8
+ children: React.ReactNode;
9
+ containerRef?: React.RefObject<HTMLElement>;
10
+ }>;
11
+ export declare const useScroll: () => ScrollContextValue;
12
+ export {};
@@ -0,0 +1,2 @@
1
+ import { RefObject } from 'react';
2
+ export declare const useScrollProgress: (ref: RefObject<HTMLElement>) => number;
@@ -0,0 +1,6 @@
1
+ export { ScrollProvider, useScroll } from "./context/ScrollContext";
2
+ export { ScrollSection } from "./components/ScrollSection";
3
+ export { ScrollTransform } from "./components/ScrollTransform";
4
+ export { Scrollytelling } from "./components/Scrollytelling";
5
+ export { useScrollProgress } from "./hooks/useScrollProgress";
6
+ export { ScrollUtils } from "./utils/math";
@@ -0,0 +1,2 @@
1
+ import t,{createContext as e,useRef as r,useEffect as n,useContext as i,useLayoutEffect as o,useState as c}from"react";var a=e(null),s=function(e){var i=e.children,o=e.containerRef,c=r(new Set),s=r(0),l=r(!1),u=r(0);n(function(){var t=(null==o?void 0:o.current)||("undefined"!=typeof window?window:null);if(t){var e=function(){return t instanceof Window?t.scrollY:t.scrollTop},r=e();s.current=r,u.current=r;var n=function(){var t=e(),r=t-u.current;s.current=t,u.current=t,c.current.forEach(function(t){return t(s.current,r)}),l.current=!1},i=function(){l.current||(requestAnimationFrame(n),l.current=!0)};return t.addEventListener("scroll",i,{passive:!0}),t instanceof Window&&t.addEventListener("resize",i,{passive:!0}),function(){t.removeEventListener("scroll",i),t instanceof Window&&t.removeEventListener("resize",i)}}},[o]);return t.createElement(a.Provider,{value:{subscribe:function(t){return c.current.add(t),t(s.current,0),function(){c.current.delete(t)}},getScrollY:function(){return s.current}}},i)},l=function(){var t=i(a);if(!t)throw new Error("useScroll must be used within a ScrollProvider");return t},u=function(){return u=Object.assign||function(t){for(var e,r=1,n=arguments.length;r<n;r++)for(var i in e=arguments[r])Object.prototype.hasOwnProperty.call(e,i)&&(t[i]=e[i]);return t},u.apply(this,arguments)};"function"==typeof SuppressedError&&SuppressedError;var f={clamp:function(t,e,r){return Math.min(r,Math.max(e,t))},mapRange:function(t,e,r,n,i){return n+(t-e)/(r-e)*(i-n)},lerp:function(t,e,r){return t*(1-r)+e*r},abs:function(t){return Math.abs(t)},min:function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];return Math.min.apply(Math,t)},max:function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];return Math.max.apply(Math,t)},floor:function(t){return Math.floor(t)},cos:function(t){return Math.cos(t)},sin:function(t){return Math.sin(t)},PI:Math.PI},d=function(e){var i=e.direction,c=void 0===i?"vertical":i,a=e.children,s=e.className,d=e.style,h=e.trackLength,v=void 0===h?"300vw":h,p=l().subscribe,w=r(null),g=r(null),m=r(!1);n(function(){var t=new IntersectionObserver(function(t){var e=t[0];m.current=e.isIntersecting},{threshold:0});return w.current&&t.observe(w.current),function(){return t.disconnect()}},[]);var y=r({offsetTop:0,trackHeight:0,windowHeight:0,scrollWidth:0,windowWidth:0});return n(function(){if("horizontal"===c){var t=function(){if(w.current&&g.current){var t=w.current.getBoundingClientRect(),e=window.scrollY||window.pageYOffset;y.current={offsetTop:t.top+e,trackHeight:t.height,windowHeight:window.innerHeight,scrollWidth:g.current.scrollWidth,windowWidth:window.innerWidth}}};return t(),window.addEventListener("resize",t),function(){return window.removeEventListener("resize",t)}}},[c,a]),n(function(){if("horizontal"===c)return p(function(t){if(m.current&&w.current&&g.current){var e=y.current,r=e.offsetTop,n=e.trackHeight,i=e.windowHeight,o=e.scrollWidth,c=e.windowWidth,a=n-i;if(!(a<=0)){var s=f.clamp(-(r-t)/a,0,1),l=o-c;if(l>0){var u=s*l;g.current.style.transform="translateX(-".concat(u,"px)")}}}})},[c,p]),o(function(){if("horizontal"===c&&w.current&&g.current){var t=w.current.getBoundingClientRect(),e=-t.top/(t.height-window.innerHeight),r=f.clamp(e,0,1),n=g.current,i=n.scrollWidth-window.innerWidth;i>0&&(n.style.transform="translateX(-".concat(r*i,"px)"))}},[c]),"vertical"===c?t.createElement("div",{className:s,style:d},a):t.createElement("div",{ref:w,className:s,style:u({position:"relative",height:v},d)},t.createElement("div",{style:{position:"sticky",top:0,height:"100vh",width:"100%",overflow:"hidden"}},t.createElement("div",{ref:g,style:{height:"100%",display:"flex",willChange:"transform"}},a)))},h=function(e){var i=e.children,o=e.effect,c=void 0===o?"parallax":o,a=e.speed,s=void 0===a?.2:a,d=e.intensity,h=void 0===d?1:d,v=e.direction,p=void 0===v?"up":v,w=e.range,g=void 0===w?[0,1]:w,m=e.transform,y=e.onEnter,b=e.onLeave,x=e.className,E=e.style,Y=l().subscribe,H=r(null),W=r(!1),M=r(0);return n(function(){var t=new IntersectionObserver(function(t){var e=t[0],r=W.current;if(W.current=e.isIntersecting,e.isIntersecting){if(!r&&y&&y(),H.current){var n=H.current.getBoundingClientRect();M.current=n.top+window.scrollY}}else r&&b&&b()},{threshold:0});return H.current&&t.observe(H.current),function(){return t.disconnect()}},[]),n(function(){return Y(function(t,e){if(W.current&&H.current){var r=H.current,n=r.getBoundingClientRect(),i=window.innerHeight,o=i+n.height,a=(i-n.top)/o,l=g[0],u=g[1],d=0;if(d=l===u?a>=l?1:0:f.clamp((a-l)/(u-l),0,1),"parallax"===c){var v=(n.top-i/2)*s;r.style.transform="translateY(".concat(v,"px)")}else if("fade"===c)r.style.opacity=d.toString(),h>0&&(r.style.transform="translateY(".concat(20*(1-d)*h,"px)"));else if("scale"===c){var w=.8+.2*f.clamp(d,0,1)*h;r.style.transform="scale(".concat(w,")")}else if("skew-velocity"===c){var y=15*h,b=f.max(-y,f.min(y,.1*e)),x=1+f.min(.2,f.abs(5e-4*e)*h);r.style.transform="skewY(".concat(b,"deg) scaleY(").concat(x,")")}else if("rotate"===c){var E=2*(d-.5)*(45*h);r.style.transform="rotate(".concat(E,"deg)")}else if("rotate-x"===c){E=2*(.5-d)*(45*h);r.style.transform="perspective(1000px) rotateX(".concat(E,"deg)")}else if("rotate-y"===c){E=2*(d-.5)*(45*h);r.style.transform="perspective(1000px) rotateY(".concat(E,"deg)")}else if("slide-in"===c)if(d>=1)r.style.transform="none",r.style.opacity="1";else{var Y=(1-d)*(100*h);r.style.opacity=d.toString(),"up"===p?r.style.transform="translateY(".concat(Y,"px)"):"down"===p?r.style.transform="translateY(".concat(-Y,"px)"):"left"===p?r.style.transform="translateX(".concat(Y,"px)"):"right"===p&&(r.style.transform="translateX(".concat(-Y,"px)"))}else if("blur"===c){var M=10*(1-d)*h;r.style.filter="blur(".concat(M,"px)"),r.style.opacity=d.toString()}else if("hue-rotate"===c){E=360*d*h;r.style.filter="hue-rotate(".concat(E,"deg)")}else"custom"===c&&m&&m(r,d,t,e)}})},[c,s,h,p,g,m,Y]),t.createElement("div",{ref:H,className:x,style:u({willChange:"transform, opacity"},E)},i)},v=function(t){var e=c(0),r=e[0],i=e[1],o=l().subscribe;return n(function(){var e=t.current;if(e){var r=!1,n={top:0,height:0,windowHeight:0},c=new IntersectionObserver(function(t){var i=t[0];if(r=i.isIntersecting){var o=e.getBoundingClientRect(),c=window.scrollY||window.pageYOffset;n={top:o.top+c,height:o.height,windowHeight:window.innerHeight}}},{threshold:0});c.observe(e);var a=o(function(t){if(r){var e=n.top,o=n.height-n.windowHeight;if(!(o<=0)){var c=(t-e)/o;c=f.clamp(c,0,1),i(c)}}});return function(){c.disconnect(),a()}}},[t,o]),r},p=function(e){var n=e.height,i=void 0===n?"300vh":n,o=e.children,c=e.className,a=e.style,s=r(null),l=v(s);return t.createElement("div",{ref:s,className:c,style:u({height:i,position:"relative"},a)},t.createElement("div",{style:{position:"sticky",top:0,height:"100vh",width:"100%",overflow:"hidden"}},o(l)))};export{s as ScrollProvider,d as ScrollSection,h as ScrollTransform,f as ScrollUtils,p as Scrollytelling,l as useScroll,v as useScrollProgress};
2
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.js","sources":["../src/context/ScrollContext.tsx","../node_modules/tslib/tslib.es6.js","../src/utils/math.ts","../src/components/ScrollSection.tsx","../src/components/ScrollTransform.tsx","../src/hooks/useScrollProgress.ts","../src/components/Scrollytelling.tsx"],"sourcesContent":[null,"/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n",null,null,null,null,null],"names":["ScrollContext","createContext","ScrollProvider","_a","children","containerRef","listenersRef","useRef","Set","scrollYRef","tickingRef","previousScrollYRef","useEffect","target","current","window","getScrollPosition","Window","scrollY","scrollTop","initialScroll","update","currentScroll","velocity","forEach","cb","requestTick","requestAnimationFrame","addEventListener","passive","removeEventListener","React","createElement","Provider","value","subscribe","callback","add","delete","getScrollY","useScroll","context","useContext","Error","__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","SuppressedError","ScrollUtils","clamp","min","max","Math","mapRange","inMin","inMax","outMin","outMax","lerp","start","end","abs","values","_i","floor","cos","angle","sin","PI","ScrollSection","_b","direction","className","style","_c","trackLength","trackRef","isVisibleRef","observer","IntersectionObserver","entry","isIntersecting","threshold","observe","disconnect","metricsRef","offsetTop","trackHeight","windowHeight","scrollWidth","windowWidth","updateMetrics","rect","getBoundingClientRect","pageYOffset","top","height","innerHeight","innerWidth","scrollableDistance","clampedProgress","maxTranslate","x","transform","concat","useLayoutEffect","progress","track","ref","position","width","overflow","display","willChange","ScrollTransform","effect","speed","_d","intensity","_e","_f","range","onEnter","onLeave","elementRef","initialTopRef","wasVisible","element","viewportHeight","totalTravel","rawProgress","rStart","rEnd","offset","opacity","toString","scale","maxSkew","skew","scaleY","deg","val","px","filter","useScrollProgress","useState","setProgress","isActive","rectCache","unsubscribe","distance","Scrollytelling"],"mappings":"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","x_google_ignoreList":[1]}
package/dist/index.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";var e=require("react"),t=e.createContext(null),r=function(){var r=e.useContext(t);if(!r)throw new Error("useScroll must be used within a ScrollProvider");return r},n=function(){return n=Object.assign||function(e){for(var t,r=1,n=arguments.length;r<n;r++)for(var i in t=arguments[r])Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i]);return e},n.apply(this,arguments)};"function"==typeof SuppressedError&&SuppressedError;var i={clamp:function(e,t,r){return Math.min(r,Math.max(t,e))},mapRange:function(e,t,r,n,i){return n+(e-t)/(r-t)*(i-n)},lerp:function(e,t,r){return e*(1-r)+t*r},abs:function(e){return Math.abs(e)},min:function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return Math.min.apply(Math,e)},max:function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return Math.max.apply(Math,e)},floor:function(e){return Math.floor(e)},cos:function(e){return Math.cos(e)},sin:function(e){return Math.sin(e)},PI:Math.PI},o=function(t){var n=e.useState(0),o=n[0],c=n[1],s=r().subscribe;return e.useEffect(function(){var e=t.current;if(e){var r=!1,n={top:0,height:0,windowHeight:0},o=new IntersectionObserver(function(t){var i=t[0];if(r=i.isIntersecting){var o=e.getBoundingClientRect(),c=window.scrollY||window.pageYOffset;n={top:o.top+c,height:o.height,windowHeight:window.innerHeight}}},{threshold:0});o.observe(e);var a=s(function(e){if(r){var t=n.top,o=n.height-n.windowHeight;if(!(o<=0)){var s=(e-t)/o;s=i.clamp(s,0,1),c(s)}}});return function(){o.disconnect(),a()}}},[t,s]),o};exports.ScrollProvider=function(r){var n=r.children,i=r.containerRef,o=e.useRef(new Set),c=e.useRef(0),s=e.useRef(!1),a=e.useRef(0);e.useEffect(function(){var e=(null==i?void 0:i.current)||("undefined"!=typeof window?window:null);if(e){var t=function(){return e instanceof Window?e.scrollY:e.scrollTop},r=t();c.current=r,a.current=r;var n=function(){var e=t(),r=e-a.current;c.current=e,a.current=e,o.current.forEach(function(e){return e(c.current,r)}),s.current=!1},l=function(){s.current||(requestAnimationFrame(n),s.current=!0)};return e.addEventListener("scroll",l,{passive:!0}),e instanceof Window&&e.addEventListener("resize",l,{passive:!0}),function(){e.removeEventListener("scroll",l),e instanceof Window&&e.removeEventListener("resize",l)}}},[i]);return e.createElement(t.Provider,{value:{subscribe:function(e){return o.current.add(e),e(c.current,0),function(){o.current.delete(e)}},getScrollY:function(){return c.current}}},n)},exports.ScrollSection=function(t){var o=t.direction,c=void 0===o?"vertical":o,s=t.children,a=t.className,l=t.style,u=t.trackLength,f=void 0===u?"300vw":u,d=r().subscribe,h=e.useRef(null),v=e.useRef(null),p=e.useRef(!1);e.useEffect(function(){var e=new IntersectionObserver(function(e){var t=e[0];p.current=t.isIntersecting},{threshold:0});return h.current&&e.observe(h.current),function(){return e.disconnect()}},[]);var w=e.useRef({offsetTop:0,trackHeight:0,windowHeight:0,scrollWidth:0,windowWidth:0});return e.useEffect(function(){if("horizontal"===c){var e=function(){if(h.current&&v.current){var e=h.current.getBoundingClientRect(),t=window.scrollY||window.pageYOffset;w.current={offsetTop:e.top+t,trackHeight:e.height,windowHeight:window.innerHeight,scrollWidth:v.current.scrollWidth,windowWidth:window.innerWidth}}};return e(),window.addEventListener("resize",e),function(){return window.removeEventListener("resize",e)}}},[c,s]),e.useEffect(function(){if("horizontal"===c)return d(function(e){if(p.current&&h.current&&v.current){var t=w.current,r=t.offsetTop,n=t.trackHeight,o=t.windowHeight,c=t.scrollWidth,s=t.windowWidth,a=n-o;if(!(a<=0)){var l=i.clamp(-(r-e)/a,0,1),u=c-s;if(u>0){var f=l*u;v.current.style.transform="translateX(-".concat(f,"px)")}}}})},[c,d]),e.useLayoutEffect(function(){if("horizontal"===c&&h.current&&v.current){var e=h.current.getBoundingClientRect(),t=-e.top/(e.height-window.innerHeight),r=i.clamp(t,0,1),n=v.current,o=n.scrollWidth-window.innerWidth;o>0&&(n.style.transform="translateX(-".concat(r*o,"px)"))}},[c]),"vertical"===c?e.createElement("div",{className:a,style:l},s):e.createElement("div",{ref:h,className:a,style:n({position:"relative",height:f},l)},e.createElement("div",{style:{position:"sticky",top:0,height:"100vh",width:"100%",overflow:"hidden"}},e.createElement("div",{ref:v,style:{height:"100%",display:"flex",willChange:"transform"}},s)))},exports.ScrollTransform=function(t){var o=t.children,c=t.effect,s=void 0===c?"parallax":c,a=t.speed,l=void 0===a?.2:a,u=t.intensity,f=void 0===u?1:u,d=t.direction,h=void 0===d?"up":d,v=t.range,p=void 0===v?[0,1]:v,w=t.transform,g=t.onEnter,m=t.onLeave,y=t.className,x=t.style,E=r().subscribe,b=e.useRef(null),R=e.useRef(!1),S=e.useRef(0);return e.useEffect(function(){var e=new IntersectionObserver(function(e){var t=e[0],r=R.current;if(R.current=t.isIntersecting,t.isIntersecting){if(!r&&g&&g(),b.current){var n=b.current.getBoundingClientRect();S.current=n.top+window.scrollY}}else r&&m&&m()},{threshold:0});return b.current&&e.observe(b.current),function(){return e.disconnect()}},[]),e.useEffect(function(){return E(function(e,t){if(R.current&&b.current){var r=b.current,n=r.getBoundingClientRect(),o=window.innerHeight,c=o+n.height,a=(o-n.top)/c,u=p[0],d=p[1],v=0;if(v=u===d?a>=u?1:0:i.clamp((a-u)/(d-u),0,1),"parallax"===s){var g=(n.top-o/2)*l;r.style.transform="translateY(".concat(g,"px)")}else if("fade"===s)r.style.opacity=v.toString(),f>0&&(r.style.transform="translateY(".concat(20*(1-v)*f,"px)"));else if("scale"===s){var m=.8+.2*i.clamp(v,0,1)*f;r.style.transform="scale(".concat(m,")")}else if("skew-velocity"===s){var y=15*f,x=i.max(-y,i.min(y,.1*t)),E=1+i.min(.2,i.abs(5e-4*t)*f);r.style.transform="skewY(".concat(x,"deg) scaleY(").concat(E,")")}else if("rotate"===s){var S=2*(v-.5)*(45*f);r.style.transform="rotate(".concat(S,"deg)")}else if("rotate-x"===s){S=2*(.5-v)*(45*f);r.style.transform="perspective(1000px) rotateX(".concat(S,"deg)")}else if("rotate-y"===s){S=2*(v-.5)*(45*f);r.style.transform="perspective(1000px) rotateY(".concat(S,"deg)")}else if("slide-in"===s)if(v>=1)r.style.transform="none",r.style.opacity="1";else{var Y=(1-v)*(100*f);r.style.opacity=v.toString(),"up"===h?r.style.transform="translateY(".concat(Y,"px)"):"down"===h?r.style.transform="translateY(".concat(-Y,"px)"):"left"===h?r.style.transform="translateX(".concat(Y,"px)"):"right"===h&&(r.style.transform="translateX(".concat(-Y,"px)"))}else if("blur"===s){var H=10*(1-v)*f;r.style.filter="blur(".concat(H,"px)"),r.style.opacity=v.toString()}else if("hue-rotate"===s){S=360*v*f;r.style.filter="hue-rotate(".concat(S,"deg)")}else"custom"===s&&w&&w(r,v,e,t)}})},[s,l,f,h,p,w,E]),e.createElement("div",{ref:b,className:y,style:n({willChange:"transform, opacity"},x)},o)},exports.ScrollUtils=i,exports.Scrollytelling=function(t){var r=t.height,i=void 0===r?"300vh":r,c=t.children,s=t.className,a=t.style,l=e.useRef(null),u=o(l);return e.createElement("div",{ref:l,className:s,style:n({height:i,position:"relative"},a)},e.createElement("div",{style:{position:"sticky",top:0,height:"100vh",width:"100%",overflow:"hidden"}},c(u)))},exports.useScroll=r,exports.useScrollProgress=o;
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/context/ScrollContext.tsx","../node_modules/tslib/tslib.es6.js","../src/utils/math.ts","../src/hooks/useScrollProgress.ts","../src/components/ScrollSection.tsx","../src/components/ScrollTransform.tsx","../src/components/Scrollytelling.tsx"],"sourcesContent":[null,"/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n",null,null,null,null,null],"names":["ScrollContext","createContext","useScroll","context","useContext","Error","__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","SuppressedError","ScrollUtils","clamp","value","min","max","Math","mapRange","inMin","inMax","outMin","outMax","lerp","start","end","abs","values","_i","floor","cos","angle","sin","PI","useScrollProgress","ref","_a","useState","progress","setProgress","subscribe","useEffect","element","current","isActive","rectCache","top","height","windowHeight","observer","IntersectionObserver","entry","isIntersecting","rect","getBoundingClientRect","scrollTop","window","scrollY","pageYOffset","innerHeight","threshold","observe","unsubscribe","distance","disconnect","children","containerRef","listenersRef","useRef","Set","scrollYRef","tickingRef","previousScrollYRef","target","getScrollPosition","Window","initialScroll","update","currentScroll","velocity","forEach","cb","requestTick","requestAnimationFrame","addEventListener","passive","removeEventListener","React","createElement","Provider","callback","add","delete","getScrollY","_b","direction","className","style","_c","trackLength","trackRef","isVisibleRef","metricsRef","offsetTop","trackHeight","scrollWidth","windowWidth","updateMetrics","innerWidth","scrollableDistance","clampedProgress","maxTranslate","x","transform","concat","useLayoutEffect","track","position","width","overflow","display","willChange","effect","speed","_d","intensity","_e","_f","range","onEnter","onLeave","elementRef","initialTopRef","wasVisible","viewportHeight","totalTravel","rawProgress","rStart","rEnd","offset","opacity","toString","scale","maxSkew","skew","scaleY","deg","val","px","filter"],"mappings":"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","x_google_ignoreList":[1]}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Collection of utility functions for scroll calculations.
3
+ */
4
+ export declare const ScrollUtils: {
5
+ /**
6
+ * Clamps a number between a minimum and maximum value.
7
+ */
8
+ clamp: (value: number, min: number, max: number) => number;
9
+ /**
10
+ * Maps a value from one range to another.
11
+ * @param value - The incoming value.
12
+ * @param inMin - Lower bound of the input range.
13
+ * @param inMax - Upper bound of the input range.
14
+ * @param outMin - Lower bound of the output range.
15
+ * @param outMax - Upper bound of the output range.
16
+ */
17
+ mapRange: (value: number, inMin: number, inMax: number, outMin: number, outMax: number) => number;
18
+ /**
19
+ * Linear interpolation between two values.
20
+ */
21
+ lerp: (start: number, end: number, t: number) => number;
22
+ abs: (value: number) => number;
23
+ min: (...values: number[]) => number;
24
+ max: (...values: number[]) => number;
25
+ /**
26
+ * Rounds down to the nearest integer.
27
+ */
28
+ floor: (value: number) => number;
29
+ /**
30
+ * Returns the cosine of an angle (in radians).
31
+ */
32
+ cos: (angle: number) => number;
33
+ /**
34
+ * Returns the sine of an angle (in radians).
35
+ */
36
+ sin: (angle: number) => number;
37
+ /**
38
+ * The mathematical constant PI (π).
39
+ */
40
+ PI: number;
41
+ };
package/package.json ADDED
@@ -0,0 +1,59 @@
1
+ {
2
+ "name": "scroll-dynamics-pro",
3
+ "version": "1.0.0",
4
+ "description": "A lightweight, production-ready React scrolling library with no dependencies.",
5
+ "main": "dist/index.js",
6
+ "module": "dist/index.esm.js",
7
+ "exports": {
8
+ ".": {
9
+ "import": "./dist/index.esm.js",
10
+ "require": "./dist/index.js"
11
+ }
12
+ },
13
+ "sideEffects": false,
14
+ "types": "dist/index.d.ts",
15
+ "files": [
16
+ "dist"
17
+ ],
18
+ "scripts": {
19
+ "build": "rollup -c && tsc --emitDeclarationOnly",
20
+ "watch": "rollup -c -w",
21
+ "prepublishOnly": "npm run build"
22
+ },
23
+ "keywords": [
24
+ "react",
25
+ "scrolling",
26
+ "horizontal-scroll",
27
+ "vertical-scroll",
28
+ "scroll",
29
+ "component"
30
+ ],
31
+ "author": "James Adewara <jamesadewara1@gmail.com> (https://github.com/jamesadewara)",
32
+ "repository": {
33
+ "type": "git",
34
+ "url": "https://github.com/jamesadewara/scroll-dynamics-pro"
35
+ },
36
+ "license": "MIT",
37
+ "peerDependencies": {
38
+ "react": ">=16.8.0",
39
+ "react-dom": ">=16.8.0"
40
+ },
41
+ "devDependencies": {
42
+ "@babel/cli": "^7.28.3",
43
+ "@babel/core": "^7.28.5",
44
+ "@babel/preset-react": "^7.28.5",
45
+ "@rollup/plugin-babel": "^6.1.0",
46
+ "@rollup/plugin-commonjs": "^25.0.8",
47
+ "@rollup/plugin-node-resolve": "^15.3.1",
48
+ "@rollup/plugin-terser": "^0.4.4",
49
+ "@rollup/plugin-typescript": "^11.0.0",
50
+ "@types/react": "^18.0.0",
51
+ "@types/react-dom": "^18.0.0",
52
+ "react": "^18.0.0",
53
+ "react-dom": "^18.0.0",
54
+ "rollup": "^3.29.5",
55
+ "rollup-plugin-peer-deps-external": "^2.2.0",
56
+ "tslib": "^2.0.0",
57
+ "typescript": "^5.0.0"
58
+ }
59
+ }