react-abohook-fullpage 1.1.5 → 1.1.7

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/README.md CHANGED
@@ -150,8 +150,9 @@ export default function App() {
150
150
  | `onChange` | `(index: number) => void` | `undefined` | Triggered when section changes |
151
151
  | `duration` | `number` | `700` | Transition duration in milliseconds |
152
152
  | `directionDots` | `"left" \| "right" \| "bottom"` | `"right"` | Position of navigation dots |
153
- | `enableContextMenu` | `boolean` | `false` | Enable right-click context menu |
153
+ | `enableContextMenu` | `boolean` | `true` | Enable right-click context menu |
154
154
  | `closeOutside` | `boolean` | `false` | Close When click outside |
155
+ | `disable` | `boolean` | `false` | Disable Scroll for fullPage |
155
156
 
156
157
  ---
157
158
 
package/dist/index.cjs.js CHANGED
@@ -1,6 +1,6 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u=require("react");var C={exports:{}},O={};var H;function oe(){if(H)return O;H=1;var r=Symbol.for("react.transitional.element"),n=Symbol.for("react.fragment");function l(d,s,o){var a=null;if(o!==void 0&&(a=""+o),s.key!==void 0&&(a=""+s.key),"key"in s){o={};for(var m in s)m!=="key"&&(o[m]=s[m])}else o=s;return s=o.ref,{$$typeof:r,type:d,key:a,ref:s!==void 0?s:null,props:o}}return O.Fragment=n,O.jsx=l,O.jsxs=l,O}var j={};var X;function ae(){return X||(X=1,process.env.NODE_ENV!=="production"&&(function(){function r(e){if(e==null)return null;if(typeof e=="function")return e.$$typeof===te?null:e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case p:return"Fragment";case v:return"Profiler";case h:return"StrictMode";case N:return"Suspense";case E:return"SuspenseList";case ee:return"Activity"}if(typeof e=="object")switch(typeof e.tag=="number"&&console.error("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),e.$$typeof){case P:return"Portal";case T:return e.displayName||"Context";case y:return(e._context.displayName||"Context")+".Consumer";case F:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case K:return t=e.displayName||null,t!==null?t:r(e.type)||"Memo";case Y:t=e._payload,e=e._init;try{return r(e(t))}catch{}}return null}function n(e){return""+e}function l(e){try{n(e);var t=!1}catch{t=!0}if(t){t=console;var i=t.error,c=typeof Symbol=="function"&&Symbol.toStringTag&&e[Symbol.toStringTag]||e.constructor.name||"Object";return i.call(t,"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",c),n(e)}}function d(e){if(e===p)return"<>";if(typeof e=="object"&&e!==null&&e.$$typeof===Y)return"<...>";try{var t=r(e);return t?"<"+t+">":"<...>"}catch{return"<...>"}}function s(){var e=I.A;return e===null?null:e.getOwner()}function o(){return Error("react-stack-top-frame")}function a(e){if(W.call(e,"key")){var t=Object.getOwnPropertyDescriptor(e,"key").get;if(t&&t.isReactWarning)return!1}return e.key!==void 0}function m(e,t){function i(){z||(z=!0,console.error("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",t))}i.isReactWarning=!0,Object.defineProperty(e,"key",{get:i,configurable:!0})}function g(){var e=r(this.type);return G[e]||(G[e]=!0,console.error("Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release.")),e=this.props.ref,e!==void 0?e:null}function b(e,t,i,c,L,D){var f=i.ref;return e={$$typeof:x,type:e,key:t,props:i,_owner:c},(f!==void 0?f:null)!==null?Object.defineProperty(e,"ref",{enumerable:!1,get:g}):Object.defineProperty(e,"ref",{enumerable:!1,value:null}),e._store={},Object.defineProperty(e._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:0}),Object.defineProperty(e,"_debugInfo",{configurable:!1,enumerable:!1,writable:!0,value:null}),Object.defineProperty(e,"_debugStack",{configurable:!1,enumerable:!1,writable:!0,value:L}),Object.defineProperty(e,"_debugTask",{configurable:!1,enumerable:!1,writable:!0,value:D}),Object.freeze&&(Object.freeze(e.props),Object.freeze(e)),e}function w(e,t,i,c,L,D){var f=t.children;if(f!==void 0)if(c)if(re(f)){for(c=0;c<f.length;c++)S(f[c]);Object.freeze&&Object.freeze(f)}else console.error("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else S(f);if(W.call(t,"key")){f=r(e);var A=Object.keys(t).filter(function(ne){return ne!=="key"});c=0<A.length?"{key: someKey, "+A.join(": ..., ")+": ...}":"{key: someKey}",J[f+c]||(A=0<A.length?"{"+A.join(": ..., ")+": ...}":"{}",console.error(`A props object containing a "key" prop is being spread into JSX:
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u=require("react");var Y={exports:{}},j={};var X;function oe(){if(X)return j;X=1;var r=Symbol.for("react.transitional.element"),n=Symbol.for("react.fragment");function i(d,a,l){var o=null;if(l!==void 0&&(o=""+l),a.key!==void 0&&(o=""+a.key),"key"in a){l={};for(var m in a)m!=="key"&&(l[m]=a[m])}else l=a;return a=l.ref,{$$typeof:r,type:d,key:o,ref:a!==void 0?a:null,props:l}}return j.Fragment=n,j.jsx=i,j.jsxs=i,j}var F={};var B;function ae(){return B||(B=1,process.env.NODE_ENV!=="production"&&(function(){function r(e){if(e==null)return null;if(typeof e=="function")return e.$$typeof===te?null:e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case S:return"Fragment";case w:return"Profiler";case R:return"StrictMode";case N:return"Suspense";case L:return"SuspenseList";case ee:return"Activity"}if(typeof e=="object")switch(typeof e.tag=="number"&&console.error("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),e.$$typeof){case A:return"Portal";case k:return e.displayName||"Context";case v:return(e._context.displayName||"Context")+".Consumer";case y:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case E:return t=e.displayName||null,t!==null?t:r(e.type)||"Memo";case I:t=e._payload,e=e._init;try{return r(e(t))}catch{}}return null}function n(e){return""+e}function i(e){try{n(e);var t=!1}catch{t=!0}if(t){t=console;var s=t.error,c=typeof Symbol=="function"&&Symbol.toStringTag&&e[Symbol.toStringTag]||e.constructor.name||"Object";return s.call(t,"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",c),n(e)}}function d(e){if(e===S)return"<>";if(typeof e=="object"&&e!==null&&e.$$typeof===I)return"<...>";try{var t=r(e);return t?"<"+t+">":"<...>"}catch{return"<...>"}}function a(){var e=$.A;return e===null?null:e.getOwner()}function l(){return Error("react-stack-top-frame")}function o(e){if(z.call(e,"key")){var t=Object.getOwnPropertyDescriptor(e,"key").get;if(t&&t.isReactWarning)return!1}return e.key!==void 0}function m(e,t){function s(){G||(G=!0,console.error("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",t))}s.isReactWarning=!0,Object.defineProperty(e,"key",{get:s,configurable:!0})}function p(){var e=r(this.type);return V[e]||(V[e]=!0,console.error("Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release.")),e=this.props.ref,e!==void 0?e:null}function g(e,t,s,c,C,M){var f=s.ref;return e={$$typeof:T,type:e,key:t,props:s,_owner:c},(f!==void 0?f:null)!==null?Object.defineProperty(e,"ref",{enumerable:!1,get:p}):Object.defineProperty(e,"ref",{enumerable:!1,value:null}),e._store={},Object.defineProperty(e._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:0}),Object.defineProperty(e,"_debugInfo",{configurable:!1,enumerable:!1,writable:!0,value:null}),Object.defineProperty(e,"_debugStack",{configurable:!1,enumerable:!1,writable:!0,value:C}),Object.defineProperty(e,"_debugTask",{configurable:!1,enumerable:!1,writable:!0,value:M}),Object.freeze&&(Object.freeze(e.props),Object.freeze(e)),e}function h(e,t,s,c,C,M){var f=t.children;if(f!==void 0)if(c)if(re(f)){for(c=0;c<f.length;c++)b(f[c]);Object.freeze&&Object.freeze(f)}else console.error("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else b(f);if(z.call(t,"key")){f=r(e);var O=Object.keys(t).filter(function(ne){return ne!=="key"});c=0<O.length?"{key: someKey, "+O.join(": ..., ")+": ...}":"{key: someKey}",H[f+c]||(O=0<O.length?"{"+O.join(": ..., ")+": ...}":"{}",console.error(`A props object containing a "key" prop is being spread into JSX:
2
2
  let props = %s;
3
3
  <%s {...props} />
4
4
  React keys must be passed directly to JSX without using spread:
5
5
  let props = %s;
6
- <%s key={someKey} {...props} />`,c,f,A,f),J[f+c]=!0)}if(f=null,i!==void 0&&(l(i),f=""+i),a(t)&&(l(t.key),f=""+t.key),"key"in t){i={};for(var M in t)M!=="key"&&(i[M]=t[M])}else i=t;return f&&m(i,typeof e=="function"?e.displayName||e.name||"Unknown":e),b(e,f,i,s(),L,D)}function S(e){k(e)?e._store&&(e._store.validated=1):typeof e=="object"&&e!==null&&e.$$typeof===Y&&(e._payload.status==="fulfilled"?k(e._payload.value)&&e._payload.value._store&&(e._payload.value._store.validated=1):e._store&&(e._store.validated=1))}function k(e){return typeof e=="object"&&e!==null&&e.$$typeof===x}var R=u,x=Symbol.for("react.transitional.element"),P=Symbol.for("react.portal"),p=Symbol.for("react.fragment"),h=Symbol.for("react.strict_mode"),v=Symbol.for("react.profiler"),y=Symbol.for("react.consumer"),T=Symbol.for("react.context"),F=Symbol.for("react.forward_ref"),N=Symbol.for("react.suspense"),E=Symbol.for("react.suspense_list"),K=Symbol.for("react.memo"),Y=Symbol.for("react.lazy"),ee=Symbol.for("react.activity"),te=Symbol.for("react.client.reference"),I=R.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,W=Object.prototype.hasOwnProperty,re=Array.isArray,$=console.createTask?console.createTask:function(){return null};R={react_stack_bottom_frame:function(e){return e()}};var z,G={},V=R.react_stack_bottom_frame.bind(R,o)(),q=$(d(o)),J={};j.Fragment=p,j.jsx=function(e,t,i){var c=1e4>I.recentlyCreatedOwnerStacks++;return w(e,t,i,!1,c?Error("react-stack-top-frame"):V,c?$(d(e)):q)},j.jsxs=function(e,t,i){var c=1e4>I.recentlyCreatedOwnerStacks++;return w(e,t,i,!0,c?Error("react-stack-top-frame"):V,c?$(d(e)):q)}})()),j}var B;function se(){return B||(B=1,process.env.NODE_ENV==="production"?C.exports=oe():C.exports=ae()),C.exports}var _=se();const ie=50,le=(r,n,l,d=700,s)=>{const[o,a]=u.useState(0),[m,g]=u.useState(!0),b=u.useRef(!1),[w,S]=u.useState(0),k=n&&o+1===r,R=u.useRef(0),x=u.useRef(0),P=u.useRef(!1),p=u.useRef(null),h=(v,y)=>{if(v<0||v>=r||b.current)return;const T=y===2;b.current=!0,S(o),a(v),k?v===3||o===r-1?a(T?w:v):a(w):a(v),n&&r===v+1?g(!1):g(!0),setTimeout(()=>{b.current=!1},d)};return u.useEffect(()=>{l&&l(o);const v=E=>{if(b.current)return E.preventDefault();E.deltaY>0?h(o+1,2):h(o-1,2)},y=E=>{b.current||(E.key==="ArrowDown"&&h(o+1,2),E.key==="ArrowUp"&&h(o-1,2))},T=E=>{R.current=E.touches[0].clientY,P.current=!1},F=E=>{x.current=E.touches[0].clientY,P.current=!0},N=()=>{if(!P.current)return;const E=R.current-x.current;Math.abs(E)>=ie&&(E>0?h(o+1,2):h(o-1,2))};return window.addEventListener("wheel",v,{passive:!1}),window.addEventListener("keydown",y),window.addEventListener("touchstart",T,{passive:!0}),window.addEventListener("touchmove",F,{passive:!0}),window.addEventListener("touchend",N),()=>{window.removeEventListener("wheel",v),window.removeEventListener("keydown",y),window.removeEventListener("touchstart",T),window.removeEventListener("touchmove",F),window.removeEventListener("touchend",N)}},[o,r,n,l]),u.useEffect(()=>{if(!s)return;const v=y=>{if(b.current&&m)return;const T=y.target;p.current&&!p.current.contains(T)&&!m&&(a(w),g(!0))};return setTimeout(()=>{document.addEventListener("click",v)},300),()=>{document.removeEventListener("click",v)}},[w,m,s]),{active:o,goToSection:h,isHiddenFooter:m,footerRef:p}},ue=(r=!1)=>{u.useEffect(()=>{if(r)return;const n=l=>l.preventDefault();return window.addEventListener("contextmenu",n),()=>{window.removeEventListener("contextmenu",n)}},[r])};function ce({children:r,index:n,active:l,isHiddenFooter:d}){return _.jsx("section",{style:{position:"relative",width:"100%",height:"100vh",overflow:"hidden",filter:n===l||d?"blur(0px)":"blur(6px)"},children:r})}const fe=u.memo(ce);function de({sectionsLen:r,active:n,goToSection:l,direction:d="right"}){const s=d==="bottom";return _.jsx("div",{style:{position:"fixed",right:d==="right"?24:d==="bottom"?"50%":void 0,left:d==="left"?24:void 0,top:s?void 0:"50%",bottom:s?"5%":void 0,transform:"translateY(-50%)",display:"flex",flexDirection:s?"row":"column",gap:"16px",zIndex:50},children:Array.from({length:r}).map((o,a)=>_.jsx("button",{disabled:a===n,"aria-label":"navigation dot",onClick:()=>l(a,1),style:{width:"16px",height:"16px",display:"flex",alignItems:"center",justifyContent:"center",padding:0,border:"none",background:"none",cursor:"pointer",userSelect:"none"},children:_.jsx("span",{style:{width:"10px",height:"10px",borderRadius:"50%",backgroundColor:n===a?"white":"rgba(255,255,255,0.4)",transform:n===a?"scale(1.25)":"scale(1)",transition:"all 0.3s ease"}})},a))})}const me=u.memo(de);function ve({children:r}){return _.jsx("div",{style:{position:"relative",width:"100%",height:"100vh",overflow:"hidden",background:"transparent"},children:r})}const Z=u.memo(ve);Z.__FULLPAGE_SECTION__=!0;function Ee({children:r,styles:n,height:l="30%",backgroundColor:d="yellow",footerRef:s}){return _.jsx("div",{ref:s,style:{position:"absolute",width:"100%",height:l,backgroundColor:d,bottom:0,zIndex:50,...n},children:r},"fullpage-footer")}const Q=u.memo(Ee);Q.__FULLPAGE_FOOTER__=!0;function _e(r){process.env.NODE_ENV!=="production"&&r.forEach(n=>{if(u.isValidElement(n)&&!n.type.__FULLPAGE_SECTION__)throw console.warn("[FullPage] You must wrap content inside <FullPage.Section />"),new Error("[FullPage] You must wrap content inside <FullPage.Section />")})}function pe({children:r,isHiddenFooter:n}){const l=n?2500:600;return _.jsx("div",{style:{position:"absolute",left:0,bottom:0,width:"100%",height:"100vh",zIndex:50,transform:n?"translateY(100%)":"translateY(0)",transition:`transform ${l}ms cubic-bezier(0.22,1,0.36,1)`,willChange:"transform",pointerEvents:n?"none":"auto"},children:r})}const he=u.memo(pe);function U({children:r,onChange:n,directionDots:l="right",enableContextMenu:d=!1,duration:s=700,closeOutside:o=!1}){const a=u.Children.toArray(r),m=a.filter(p=>p.type.__FULLPAGE_SECTION__),g=a.find(p=>p.type.__FULLPAGE_FOOTER__);ue(d),u.useEffect(()=>(_e(m),()=>{}),[m]);const b=!!g,w=m.length+(b?1:0),{active:S,goToSection:k,isHiddenFooter:R,footerRef:x}=le(w,b,n,s,o),P=g?u.cloneElement(g,{footerRef:x}):null;return _.jsxs(_.Fragment,{children:[_.jsxs("div",{style:{position:"relative",height:"100vh",width:"100%",overflow:"hidden"},children:[_.jsx("div",{style:{height:`${m.length*100}vh`,transform:R?`translateY(-${S*100}vh)`:`translateY(-${m.length-100}vh)`,transition:"transform 700ms cubic-bezier(0.22,1,0.36,1)"},children:m.map((p,h)=>_.jsx(fe,{index:h,active:S,isHiddenFooter:R,children:p},h))}),g&&_.jsx(he,{isHiddenFooter:R,children:P})]}),_.jsx(me,{sectionsLen:w,active:S,goToSection:k,direction:l})]})}U.Section=Z;U.Footer=Q;exports.FullPage=U;
6
+ <%s key={someKey} {...props} />`,c,f,O,f),H[f+c]=!0)}if(f=null,s!==void 0&&(i(s),f=""+s),o(t)&&(i(t.key),f=""+t.key),"key"in t){s={};for(var U in t)U!=="key"&&(s[U]=t[U])}else s=t;return f&&m(s,typeof e=="function"?e.displayName||e.name||"Unknown":e),g(e,f,s,a(),C,M)}function b(e){x(e)?e._store&&(e._store.validated=1):typeof e=="object"&&e!==null&&e.$$typeof===I&&(e._payload.status==="fulfilled"?x(e._payload.value)&&e._payload.value._store&&(e._payload.value._store.validated=1):e._store&&(e._store.validated=1))}function x(e){return typeof e=="object"&&e!==null&&e.$$typeof===T}var P=u,T=Symbol.for("react.transitional.element"),A=Symbol.for("react.portal"),S=Symbol.for("react.fragment"),R=Symbol.for("react.strict_mode"),w=Symbol.for("react.profiler"),v=Symbol.for("react.consumer"),k=Symbol.for("react.context"),y=Symbol.for("react.forward_ref"),N=Symbol.for("react.suspense"),L=Symbol.for("react.suspense_list"),E=Symbol.for("react.memo"),I=Symbol.for("react.lazy"),ee=Symbol.for("react.activity"),te=Symbol.for("react.client.reference"),$=P.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,z=Object.prototype.hasOwnProperty,re=Array.isArray,D=console.createTask?console.createTask:function(){return null};P={react_stack_bottom_frame:function(e){return e()}};var G,V={},q=P.react_stack_bottom_frame.bind(P,l)(),J=D(d(l)),H={};F.Fragment=S,F.jsx=function(e,t,s){var c=1e4>$.recentlyCreatedOwnerStacks++;return h(e,t,s,!1,c?Error("react-stack-top-frame"):q,c?D(d(e)):J)},F.jsxs=function(e,t,s){var c=1e4>$.recentlyCreatedOwnerStacks++;return h(e,t,s,!0,c?Error("react-stack-top-frame"):q,c?D(d(e)):J)}})()),F}var Z;function se(){return Z||(Z=1,process.env.NODE_ENV==="production"?Y.exports=oe():Y.exports=ae()),Y.exports}var _=se();const ie=50,ue=(r,n,i,d=700,a,l)=>{const[o,m]=u.useState(0),[p,g]=u.useState(!0),h=u.useRef(!1),[b,x]=u.useState(0),P=n&&o+1===r,T=u.useRef(0),A=u.useRef(0),S=u.useRef(!1),R=u.useRef(null),w=(v,k)=>{if(v<0||v>=r||h.current)return;const y=k===2;h.current=!0,x(o),m(v),P?v===3||o===r-1?m(y?b:v):m(b):m(v),n&&r===v+1?g(!1):g(!0),setTimeout(()=>{h.current=!1},d)};return u.useEffect(()=>{i&&i(o);const v=E=>{if(!l){if(h.current)return E.preventDefault();E.deltaY>0?w(o+1,2):w(o-1,2)}},k=E=>{l||h.current||(E.key==="ArrowDown"&&w(o+1,2),E.key==="ArrowUp"&&w(o-1,2))},y=E=>{l||(T.current=E.touches[0].clientY,S.current=!1)},N=E=>{l||(A.current=E.touches[0].clientY,S.current=!0)},L=()=>{if(l||!S.current)return;const E=T.current-A.current;Math.abs(E)>=ie&&(E>0?w(o+1,2):w(o-1,2))};return window.addEventListener("wheel",v,{passive:!1}),window.addEventListener("keydown",k),window.addEventListener("touchstart",y,{passive:!0}),window.addEventListener("touchmove",N,{passive:!0}),window.addEventListener("touchend",L),()=>{window.removeEventListener("wheel",v),window.removeEventListener("keydown",k),window.removeEventListener("touchstart",y),window.removeEventListener("touchmove",N),window.removeEventListener("touchend",L)}},[o,r,n,i]),u.useEffect(()=>{if(!a)return;const v=k=>{if(h.current&&p)return;const y=k.target;R.current&&!R.current.contains(y)&&!p&&(m(b),g(!0))};return setTimeout(()=>{document.addEventListener("click",v)},300),()=>{document.removeEventListener("click",v)}},[b,p,a]),{active:o,goToSection:w,isHiddenFooter:p,footerRef:R}},le=(r=!1)=>{u.useEffect(()=>{if(r)return;const n=i=>i.preventDefault();return window.addEventListener("contextmenu",n),()=>{window.removeEventListener("contextmenu",n)}},[r])};function ce({children:r,index:n,active:i,isHiddenFooter:d}){return _.jsx("section",{style:{position:"relative",width:"100%",height:"100vh",overflow:"hidden",filter:n===i||d?"blur(0px)":"blur(6px)"},children:r})}const fe=u.memo(ce);function de({sectionsLen:r,active:n,goToSection:i,direction:d="right"}){const a=d==="bottom";return _.jsx("div",{style:{position:"fixed",right:d==="right"?24:d==="bottom"?"50%":void 0,left:d==="left"?24:void 0,top:a?void 0:"50%",bottom:a?"5%":void 0,transform:"translateY(-50%)",display:"flex",flexDirection:a?"row":"column",gap:"16px",zIndex:50},children:Array.from({length:r}).map((l,o)=>_.jsx("button",{disabled:o===n,"aria-label":"navigation dot",onClick:()=>i(o,1),style:{width:"16px",height:"16px",display:"flex",alignItems:"center",justifyContent:"center",padding:0,border:"none",background:"none",cursor:"pointer",userSelect:"none"},children:_.jsx("span",{style:{width:"10px",height:"10px",borderRadius:"50%",backgroundColor:n===o?"white":"rgba(255,255,255,0.4)",transform:n===o?"scale(1.25)":"scale(1)",transition:"all 0.3s ease"}})},o))})}const me=u.memo(de);function ve({children:r}){return _.jsx("div",{style:{position:"relative",width:"100%",height:"100vh",overflow:"hidden",background:"transparent"},children:r})}const Q=u.memo(ve);Q.__FULLPAGE_SECTION__=!0;function Ee({children:r,styles:n,height:i="30%",backgroundColor:d="yellow",footerRef:a}){return _.jsx("div",{ref:a,style:{position:"absolute",width:"100%",height:i,backgroundColor:d,bottom:0,zIndex:50,...n},children:r},"fullpage-footer")}const K=u.memo(Ee);K.__FULLPAGE_FOOTER__=!0;function _e(r){process.env.NODE_ENV!=="production"&&r.forEach(n=>{if(u.isValidElement(n)&&!n.type.__FULLPAGE_SECTION__)throw console.warn("[FullPage] You must wrap content inside <FullPage.Section />"),new Error("[FullPage] You must wrap content inside <FullPage.Section />")})}function pe({children:r,isHiddenFooter:n}){const i=n?2500:600;return _.jsx("div",{style:{position:"absolute",left:0,bottom:0,width:"100%",height:"100vh",zIndex:50,transform:n?"translateY(100%)":"translateY(0)",transition:`transform ${i}ms cubic-bezier(0.22,1,0.36,1)`,willChange:"transform",pointerEvents:n?"none":"auto"},children:r})}const he=u.memo(pe);function W({children:r,onChange:n,directionDots:i="right",enableContextMenu:d=!0,duration:a=700,closeOutside:l=!1,disable:o=!1}){const m=u.Children.toArray(r),p=m.filter(R=>R.type.__FULLPAGE_SECTION__),g=m.find(R=>R.type.__FULLPAGE_FOOTER__);le(d),u.useEffect(()=>(_e(p),()=>{}),[p]);const h=!!g,b=p.length+(h?1:0),{active:x,goToSection:P,isHiddenFooter:T,footerRef:A}=ue(b,h,n,a,l,o),S=g?u.cloneElement(g,{footerRef:A}):null;return _.jsxs(_.Fragment,{children:[_.jsxs("div",{style:{position:"relative",height:"100vh",width:"100%",overflow:"hidden"},children:[_.jsx("div",{style:{height:`${p.length*100}vh`,transform:T?`translateY(-${x*100}vh)`:`translateY(-${p.length-100}vh)`,transition:"transform 700ms cubic-bezier(0.22,1,0.36,1)"},children:p.map((R,w)=>_.jsx(fe,{index:w,active:x,isHiddenFooter:T,children:R},w))}),g&&_.jsx(he,{isHiddenFooter:T,children:S})]}),_.jsx(me,{sectionsLen:b,active:x,goToSection:P,direction:i})]})}W.Section=Q;W.Footer=K;exports.FullPage=W;
package/dist/index.d.ts CHANGED
@@ -3,7 +3,7 @@ import { JSX as JSX_2 } from 'react/jsx-runtime';
3
3
 
4
4
  declare type DirectionDotsType = "left" | "right" | "bottom";
5
5
 
6
- export declare function FullPage({ children, onChange, directionDots, enableContextMenu, duration, closeOutside, }: FullPageProps): JSX_2.Element;
6
+ export declare function FullPage({ children, onChange, directionDots, enableContextMenu, duration, closeOutside, disable, }: FullPageProps): JSX_2.Element;
7
7
 
8
8
  export declare namespace FullPage {
9
9
  var Section: default_2.FC<FullPageSectionProps>;
@@ -25,6 +25,7 @@ declare interface FullPageProps {
25
25
  closeOutside?: boolean;
26
26
  enableContextMenu?: boolean;
27
27
  duration: number;
28
+ disable?: boolean;
28
29
  }
29
30
 
30
31
  declare interface FullPageSectionProps {
package/dist/index.es.js CHANGED
@@ -1,46 +1,46 @@
1
- import I, { useEffect as $, useState as G, useRef as A, memo as N } from "react";
2
- var Y = { exports: {} }, O = {};
3
- var Z;
1
+ import $, { useEffect as D, useState as V, useRef as O, memo as F } from "react";
2
+ var I = { exports: {} }, j = {};
3
+ var Q;
4
4
  function le() {
5
- if (Z) return O;
6
- Z = 1;
5
+ if (Q) return j;
6
+ Q = 1;
7
7
  var r = /* @__PURE__ */ Symbol.for("react.transitional.element"), n = /* @__PURE__ */ Symbol.for("react.fragment");
8
- function l(f, s, o) {
9
- var a = null;
10
- if (o !== void 0 && (a = "" + o), s.key !== void 0 && (a = "" + s.key), "key" in s) {
11
- o = {};
12
- for (var d in s)
13
- d !== "key" && (o[d] = s[d]);
14
- } else o = s;
15
- return s = o.ref, {
8
+ function i(f, a, l) {
9
+ var o = null;
10
+ if (l !== void 0 && (o = "" + l), a.key !== void 0 && (o = "" + a.key), "key" in a) {
11
+ l = {};
12
+ for (var d in a)
13
+ d !== "key" && (l[d] = a[d]);
14
+ } else l = a;
15
+ return a = l.ref, {
16
16
  $$typeof: r,
17
17
  type: f,
18
- key: a,
19
- ref: s !== void 0 ? s : null,
20
- props: o
18
+ key: o,
19
+ ref: a !== void 0 ? a : null,
20
+ props: l
21
21
  };
22
22
  }
23
- return O.Fragment = n, O.jsx = l, O.jsxs = l, O;
23
+ return j.Fragment = n, j.jsx = i, j.jsxs = i, j;
24
24
  }
25
- var j = {};
26
- var Q;
25
+ var N = {};
26
+ var K;
27
27
  function ue() {
28
- return Q || (Q = 1, process.env.NODE_ENV !== "production" && (function() {
28
+ return K || (K = 1, process.env.NODE_ENV !== "production" && (function() {
29
29
  function r(e) {
30
30
  if (e == null) return null;
31
31
  if (typeof e == "function")
32
32
  return e.$$typeof === ae ? null : e.displayName || e.name || null;
33
33
  if (typeof e == "string") return e;
34
34
  switch (e) {
35
- case _:
35
+ case T:
36
36
  return "Fragment";
37
- case m:
37
+ case h:
38
38
  return "Profiler";
39
- case p:
39
+ case b:
40
40
  return "StrictMode";
41
41
  case L:
42
42
  return "Suspense";
43
- case v:
43
+ case C:
44
44
  return "SuspenseList";
45
45
  case oe:
46
46
  return "Activity";
@@ -49,18 +49,18 @@ function ue() {
49
49
  switch (typeof e.tag == "number" && console.error(
50
50
  "Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."
51
51
  ), e.$$typeof) {
52
- case S:
52
+ case P:
53
53
  return "Portal";
54
- case g:
54
+ case k:
55
55
  return e.displayName || "Context";
56
- case x:
56
+ case m:
57
57
  return (e._context.displayName || "Context") + ".Consumer";
58
- case F:
58
+ case x:
59
59
  var t = e.render;
60
60
  return e = e.displayName, e || (e = t.displayName || t.name || "", e = e !== "" ? "ForwardRef(" + e + ")" : "ForwardRef"), e;
61
- case ne:
61
+ case v:
62
62
  return t = e.displayName || null, t !== null ? t : r(e.type) || "Memo";
63
- case D:
63
+ case M:
64
64
  t = e._payload, e = e._init;
65
65
  try {
66
66
  return r(e(t));
@@ -72,7 +72,7 @@ function ue() {
72
72
  function n(e) {
73
73
  return "" + e;
74
74
  }
75
- function l(e) {
75
+ function i(e) {
76
76
  try {
77
77
  n(e);
78
78
  var t = !1;
@@ -81,8 +81,8 @@ function ue() {
81
81
  }
82
82
  if (t) {
83
83
  t = console;
84
- var i = t.error, u = typeof Symbol == "function" && Symbol.toStringTag && e[Symbol.toStringTag] || e.constructor.name || "Object";
85
- return i.call(
84
+ var s = t.error, u = typeof Symbol == "function" && Symbol.toStringTag && e[Symbol.toStringTag] || e.constructor.name || "Object";
85
+ return s.call(
86
86
  t,
87
87
  "The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",
88
88
  u
@@ -90,8 +90,8 @@ function ue() {
90
90
  }
91
91
  }
92
92
  function f(e) {
93
- if (e === _) return "<>";
94
- if (typeof e == "object" && e !== null && e.$$typeof === D)
93
+ if (e === T) return "<>";
94
+ if (typeof e == "object" && e !== null && e.$$typeof === M)
95
95
  return "<...>";
96
96
  try {
97
97
  var t = r(e);
@@ -100,49 +100,49 @@ function ue() {
100
100
  return "<...>";
101
101
  }
102
102
  }
103
- function s() {
104
- var e = M.A;
103
+ function a() {
104
+ var e = U.A;
105
105
  return e === null ? null : e.getOwner();
106
106
  }
107
- function o() {
107
+ function l() {
108
108
  return Error("react-stack-top-frame");
109
109
  }
110
- function a(e) {
111
- if (V.call(e, "key")) {
110
+ function o(e) {
111
+ if (J.call(e, "key")) {
112
112
  var t = Object.getOwnPropertyDescriptor(e, "key").get;
113
113
  if (t && t.isReactWarning) return !1;
114
114
  }
115
115
  return e.key !== void 0;
116
116
  }
117
117
  function d(e, t) {
118
- function i() {
119
- J || (J = !0, console.error(
118
+ function s() {
119
+ q || (q = !0, console.error(
120
120
  "%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",
121
121
  t
122
122
  ));
123
123
  }
124
- i.isReactWarning = !0, Object.defineProperty(e, "key", {
125
- get: i,
124
+ s.isReactWarning = !0, Object.defineProperty(e, "key", {
125
+ get: s,
126
126
  configurable: !0
127
127
  });
128
128
  }
129
- function R() {
129
+ function _() {
130
130
  var e = r(this.type);
131
- return q[e] || (q[e] = !0, console.error(
131
+ return H[e] || (H[e] = !0, console.error(
132
132
  "Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release."
133
133
  )), e = this.props.ref, e !== void 0 ? e : null;
134
134
  }
135
- function h(e, t, i, u, C, W) {
136
- var c = i.ref;
135
+ function R(e, t, s, u, Y, z) {
136
+ var c = s.ref;
137
137
  return e = {
138
- $$typeof: y,
138
+ $$typeof: g,
139
139
  type: e,
140
140
  key: t,
141
- props: i,
141
+ props: s,
142
142
  _owner: u
143
143
  }, (c !== void 0 ? c : null) !== null ? Object.defineProperty(e, "ref", {
144
144
  enumerable: !1,
145
- get: R
145
+ get: _
146
146
  }) : Object.defineProperty(e, "ref", { enumerable: !1, value: null }), e._store = {}, Object.defineProperty(e._store, "validated", {
147
147
  configurable: !1,
148
148
  enumerable: !1,
@@ -157,33 +157,33 @@ function ue() {
157
157
  configurable: !1,
158
158
  enumerable: !1,
159
159
  writable: !0,
160
- value: C
160
+ value: Y
161
161
  }), Object.defineProperty(e, "_debugTask", {
162
162
  configurable: !1,
163
163
  enumerable: !1,
164
164
  writable: !0,
165
- value: W
165
+ value: z
166
166
  }), Object.freeze && (Object.freeze(e.props), Object.freeze(e)), e;
167
167
  }
168
- function b(e, t, i, u, C, W) {
168
+ function p(e, t, s, u, Y, z) {
169
169
  var c = t.children;
170
170
  if (c !== void 0)
171
171
  if (u)
172
172
  if (se(c)) {
173
173
  for (u = 0; u < c.length; u++)
174
- T(c[u]);
174
+ w(c[u]);
175
175
  Object.freeze && Object.freeze(c);
176
176
  } else
177
177
  console.error(
178
178
  "React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead."
179
179
  );
180
- else T(c);
181
- if (V.call(t, "key")) {
180
+ else w(c);
181
+ if (J.call(t, "key")) {
182
182
  c = r(e);
183
- var P = Object.keys(t).filter(function(ie) {
183
+ var A = Object.keys(t).filter(function(ie) {
184
184
  return ie !== "key";
185
185
  });
186
- u = 0 < P.length ? "{key: someKey, " + P.join(": ..., ") + ": ...}" : "{key: someKey}", B[c + u] || (P = 0 < P.length ? "{" + P.join(": ..., ") + ": ...}" : "{}", console.error(
186
+ u = 0 < A.length ? "{key: someKey, " + A.join(": ..., ") + ": ...}" : "{key: someKey}", Z[c + u] || (A = 0 < A.length ? "{" + A.join(": ..., ") + ": ...}" : "{}", console.error(
187
187
  `A props object containing a "key" prop is being spread into JSX:
188
188
  let props = %s;
189
189
  <%s {...props} />
@@ -192,117 +192,119 @@ React keys must be passed directly to JSX without using spread:
192
192
  <%s key={someKey} {...props} />`,
193
193
  u,
194
194
  c,
195
- P,
195
+ A,
196
196
  c
197
- ), B[c + u] = !0);
197
+ ), Z[c + u] = !0);
198
198
  }
199
- if (c = null, i !== void 0 && (l(i), c = "" + i), a(t) && (l(t.key), c = "" + t.key), "key" in t) {
200
- i = {};
201
- for (var z in t)
202
- z !== "key" && (i[z] = t[z]);
203
- } else i = t;
199
+ if (c = null, s !== void 0 && (i(s), c = "" + s), o(t) && (i(t.key), c = "" + t.key), "key" in t) {
200
+ s = {};
201
+ for (var G in t)
202
+ G !== "key" && (s[G] = t[G]);
203
+ } else s = t;
204
204
  return c && d(
205
- i,
205
+ s,
206
206
  typeof e == "function" ? e.displayName || e.name || "Unknown" : e
207
- ), h(
207
+ ), R(
208
208
  e,
209
209
  c,
210
- i,
211
- s(),
212
- C,
213
- W
210
+ s,
211
+ a(),
212
+ Y,
213
+ z
214
214
  );
215
215
  }
216
- function T(e) {
217
- k(e) ? e._store && (e._store.validated = 1) : typeof e == "object" && e !== null && e.$$typeof === D && (e._payload.status === "fulfilled" ? k(e._payload.value) && e._payload.value._store && (e._payload.value._store.validated = 1) : e._store && (e._store.validated = 1));
216
+ function w(e) {
217
+ y(e) ? e._store && (e._store.validated = 1) : typeof e == "object" && e !== null && e.$$typeof === M && (e._payload.status === "fulfilled" ? y(e._payload.value) && e._payload.value._store && (e._payload.value._store.validated = 1) : e._store && (e._store.validated = 1));
218
218
  }
219
- function k(e) {
220
- return typeof e == "object" && e !== null && e.$$typeof === y;
219
+ function y(e) {
220
+ return typeof e == "object" && e !== null && e.$$typeof === g;
221
221
  }
222
- var w = I, y = /* @__PURE__ */ Symbol.for("react.transitional.element"), S = /* @__PURE__ */ Symbol.for("react.portal"), _ = /* @__PURE__ */ Symbol.for("react.fragment"), p = /* @__PURE__ */ Symbol.for("react.strict_mode"), m = /* @__PURE__ */ Symbol.for("react.profiler"), x = /* @__PURE__ */ Symbol.for("react.consumer"), g = /* @__PURE__ */ Symbol.for("react.context"), F = /* @__PURE__ */ Symbol.for("react.forward_ref"), L = /* @__PURE__ */ Symbol.for("react.suspense"), v = /* @__PURE__ */ Symbol.for("react.suspense_list"), ne = /* @__PURE__ */ Symbol.for("react.memo"), D = /* @__PURE__ */ Symbol.for("react.lazy"), oe = /* @__PURE__ */ Symbol.for("react.activity"), ae = /* @__PURE__ */ Symbol.for("react.client.reference"), M = w.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, V = Object.prototype.hasOwnProperty, se = Array.isArray, U = console.createTask ? console.createTask : function() {
222
+ var S = $, g = /* @__PURE__ */ Symbol.for("react.transitional.element"), P = /* @__PURE__ */ Symbol.for("react.portal"), T = /* @__PURE__ */ Symbol.for("react.fragment"), b = /* @__PURE__ */ Symbol.for("react.strict_mode"), h = /* @__PURE__ */ Symbol.for("react.profiler"), m = /* @__PURE__ */ Symbol.for("react.consumer"), k = /* @__PURE__ */ Symbol.for("react.context"), x = /* @__PURE__ */ Symbol.for("react.forward_ref"), L = /* @__PURE__ */ Symbol.for("react.suspense"), C = /* @__PURE__ */ Symbol.for("react.suspense_list"), v = /* @__PURE__ */ Symbol.for("react.memo"), M = /* @__PURE__ */ Symbol.for("react.lazy"), oe = /* @__PURE__ */ Symbol.for("react.activity"), ae = /* @__PURE__ */ Symbol.for("react.client.reference"), U = S.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, J = Object.prototype.hasOwnProperty, se = Array.isArray, W = console.createTask ? console.createTask : function() {
223
223
  return null;
224
224
  };
225
- w = {
225
+ S = {
226
226
  react_stack_bottom_frame: function(e) {
227
227
  return e();
228
228
  }
229
229
  };
230
- var J, q = {}, H = w.react_stack_bottom_frame.bind(
231
- w,
232
- o
233
- )(), X = U(f(o)), B = {};
234
- j.Fragment = _, j.jsx = function(e, t, i) {
235
- var u = 1e4 > M.recentlyCreatedOwnerStacks++;
236
- return b(
230
+ var q, H = {}, X = S.react_stack_bottom_frame.bind(
231
+ S,
232
+ l
233
+ )(), B = W(f(l)), Z = {};
234
+ N.Fragment = T, N.jsx = function(e, t, s) {
235
+ var u = 1e4 > U.recentlyCreatedOwnerStacks++;
236
+ return p(
237
237
  e,
238
238
  t,
239
- i,
239
+ s,
240
240
  !1,
241
- u ? Error("react-stack-top-frame") : H,
242
- u ? U(f(e)) : X
241
+ u ? Error("react-stack-top-frame") : X,
242
+ u ? W(f(e)) : B
243
243
  );
244
- }, j.jsxs = function(e, t, i) {
245
- var u = 1e4 > M.recentlyCreatedOwnerStacks++;
246
- return b(
244
+ }, N.jsxs = function(e, t, s) {
245
+ var u = 1e4 > U.recentlyCreatedOwnerStacks++;
246
+ return p(
247
247
  e,
248
248
  t,
249
- i,
249
+ s,
250
250
  !0,
251
- u ? Error("react-stack-top-frame") : H,
252
- u ? U(f(e)) : X
251
+ u ? Error("react-stack-top-frame") : X,
252
+ u ? W(f(e)) : B
253
253
  );
254
254
  };
255
- })()), j;
255
+ })()), N;
256
256
  }
257
- var K;
257
+ var ee;
258
258
  function ce() {
259
- return K || (K = 1, process.env.NODE_ENV === "production" ? Y.exports = le() : Y.exports = ue()), Y.exports;
259
+ return ee || (ee = 1, process.env.NODE_ENV === "production" ? I.exports = le() : I.exports = ue()), I.exports;
260
260
  }
261
261
  var E = ce();
262
- const fe = 50, de = (r, n, l, f = 700, s) => {
263
- const [o, a] = G(0), [d, R] = G(!0), h = A(!1), [b, T] = G(0), k = n && o + 1 === r, w = A(0), y = A(0), S = A(!1), _ = A(null), p = (m, x) => {
264
- if (m < 0 || m >= r || h.current) return;
265
- const g = x === 2;
266
- h.current = !0, T(o), a(m), k ? m === 3 || o === r - 1 ? a(g ? b : m) : a(b) : a(m), n && r === m + 1 ? R(!1) : R(!0), setTimeout(() => {
267
- h.current = !1;
262
+ const fe = 50, de = (r, n, i, f = 700, a, l) => {
263
+ const [o, d] = V(0), [_, R] = V(!0), p = O(!1), [w, y] = V(0), S = n && o + 1 === r, g = O(0), P = O(0), T = O(!1), b = O(null), h = (m, k) => {
264
+ if (m < 0 || m >= r || p.current) return;
265
+ const x = k === 2;
266
+ p.current = !0, y(o), d(m), S ? m === 3 || o === r - 1 ? d(x ? w : m) : d(w) : d(m), n && r === m + 1 ? R(!1) : R(!0), setTimeout(() => {
267
+ p.current = !1;
268
268
  }, f);
269
269
  };
270
- return $(() => {
271
- l && l(o);
270
+ return D(() => {
271
+ i && i(o);
272
272
  const m = (v) => {
273
- if (h.current) return v.preventDefault();
274
- v.deltaY > 0 ? p(o + 1, 2) : p(o - 1, 2);
273
+ if (!l) {
274
+ if (p.current) return v.preventDefault();
275
+ v.deltaY > 0 ? h(o + 1, 2) : h(o - 1, 2);
276
+ }
277
+ }, k = (v) => {
278
+ l || p.current || (v.key === "ArrowDown" && h(o + 1, 2), v.key === "ArrowUp" && h(o - 1, 2));
275
279
  }, x = (v) => {
276
- h.current || (v.key === "ArrowDown" && p(o + 1, 2), v.key === "ArrowUp" && p(o - 1, 2));
277
- }, g = (v) => {
278
- w.current = v.touches[0].clientY, S.current = !1;
279
- }, F = (v) => {
280
- y.current = v.touches[0].clientY, S.current = !0;
281
- }, L = () => {
282
- if (!S.current) return;
283
- const v = w.current - y.current;
284
- Math.abs(v) >= fe && (v > 0 ? p(o + 1, 2) : p(o - 1, 2));
280
+ l || (g.current = v.touches[0].clientY, T.current = !1);
281
+ }, L = (v) => {
282
+ l || (P.current = v.touches[0].clientY, T.current = !0);
283
+ }, C = () => {
284
+ if (l || !T.current) return;
285
+ const v = g.current - P.current;
286
+ Math.abs(v) >= fe && (v > 0 ? h(o + 1, 2) : h(o - 1, 2));
285
287
  };
286
- return window.addEventListener("wheel", m, { passive: !1 }), window.addEventListener("keydown", x), window.addEventListener("touchstart", g, { passive: !0 }), window.addEventListener("touchmove", F, { passive: !0 }), window.addEventListener("touchend", L), () => {
287
- window.removeEventListener("wheel", m), window.removeEventListener("keydown", x), window.removeEventListener("touchstart", g), window.removeEventListener("touchmove", F), window.removeEventListener("touchend", L);
288
+ return window.addEventListener("wheel", m, { passive: !1 }), window.addEventListener("keydown", k), window.addEventListener("touchstart", x, { passive: !0 }), window.addEventListener("touchmove", L, { passive: !0 }), window.addEventListener("touchend", C), () => {
289
+ window.removeEventListener("wheel", m), window.removeEventListener("keydown", k), window.removeEventListener("touchstart", x), window.removeEventListener("touchmove", L), window.removeEventListener("touchend", C);
288
290
  };
289
- }, [o, r, n, l]), $(() => {
290
- if (!s) return;
291
- const m = (x) => {
292
- if (h.current && d) return;
293
- const g = x.target;
294
- _.current && !_.current.contains(g) && !d && (a(b), R(!0));
291
+ }, [o, r, n, i]), D(() => {
292
+ if (!a) return;
293
+ const m = (k) => {
294
+ if (p.current && _) return;
295
+ const x = k.target;
296
+ b.current && !b.current.contains(x) && !_ && (d(w), R(!0));
295
297
  };
296
298
  return setTimeout(() => {
297
299
  document.addEventListener("click", m);
298
300
  }, 300), () => {
299
301
  document.removeEventListener("click", m);
300
302
  };
301
- }, [b, d, s]), { active: o, goToSection: p, isHiddenFooter: d, footerRef: _ };
303
+ }, [w, _, a]), { active: o, goToSection: h, isHiddenFooter: _, footerRef: b };
302
304
  }, me = (r = !1) => {
303
- $(() => {
305
+ D(() => {
304
306
  if (r) return;
305
- const n = (l) => l.preventDefault();
307
+ const n = (i) => i.preventDefault();
306
308
  return window.addEventListener("contextmenu", n), () => {
307
309
  window.removeEventListener("contextmenu", n);
308
310
  };
@@ -311,7 +313,7 @@ const fe = 50, de = (r, n, l, f = 700, s) => {
311
313
  function ve({
312
314
  children: r,
313
315
  index: n,
314
- active: l,
316
+ active: i,
315
317
  isHiddenFooter: f
316
318
  }) {
317
319
  return /* @__PURE__ */ E.jsx(
@@ -322,20 +324,20 @@ function ve({
322
324
  width: "100%",
323
325
  height: "100vh",
324
326
  overflow: "hidden",
325
- filter: n === l || f ? "blur(0px)" : "blur(6px)"
327
+ filter: n === i || f ? "blur(0px)" : "blur(6px)"
326
328
  },
327
329
  children: r
328
330
  }
329
331
  );
330
332
  }
331
- const Ee = N(ve);
333
+ const Ee = F(ve);
332
334
  function _e({
333
335
  sectionsLen: r,
334
336
  active: n,
335
- goToSection: l,
337
+ goToSection: i,
336
338
  direction: f = "right"
337
339
  }) {
338
- const s = f === "bottom";
340
+ const a = f === "bottom";
339
341
  return /* @__PURE__ */ E.jsx(
340
342
  "div",
341
343
  {
@@ -343,20 +345,20 @@ function _e({
343
345
  position: "fixed",
344
346
  right: f === "right" ? 24 : f === "bottom" ? "50%" : void 0,
345
347
  left: f === "left" ? 24 : void 0,
346
- top: s ? void 0 : "50%",
347
- bottom: s ? "5%" : void 0,
348
+ top: a ? void 0 : "50%",
349
+ bottom: a ? "5%" : void 0,
348
350
  transform: "translateY(-50%)",
349
351
  display: "flex",
350
- flexDirection: s ? "row" : "column",
352
+ flexDirection: a ? "row" : "column",
351
353
  gap: "16px",
352
354
  zIndex: 50
353
355
  },
354
- children: Array.from({ length: r }).map((o, a) => /* @__PURE__ */ E.jsx(
356
+ children: Array.from({ length: r }).map((l, o) => /* @__PURE__ */ E.jsx(
355
357
  "button",
356
358
  {
357
- disabled: a === n,
359
+ disabled: o === n,
358
360
  "aria-label": "navigation dot",
359
- onClick: () => l(a, 1),
361
+ onClick: () => i(o, 1),
360
362
  style: {
361
363
  width: "16px",
362
364
  height: "16px",
@@ -376,19 +378,19 @@ function _e({
376
378
  width: "10px",
377
379
  height: "10px",
378
380
  borderRadius: "50%",
379
- backgroundColor: n === a ? "white" : "rgba(255,255,255,0.4)",
380
- transform: n === a ? "scale(1.25)" : "scale(1)",
381
+ backgroundColor: n === o ? "white" : "rgba(255,255,255,0.4)",
382
+ transform: n === o ? "scale(1.25)" : "scale(1)",
381
383
  transition: "all 0.3s ease"
382
384
  }
383
385
  }
384
386
  )
385
387
  },
386
- a
388
+ o
387
389
  ))
388
390
  }
389
391
  );
390
392
  }
391
- const pe = N(_e);
393
+ const pe = F(_e);
392
394
  function he({ children: r }) {
393
395
  return /* @__PURE__ */ E.jsx(
394
396
  "div",
@@ -404,23 +406,23 @@ function he({ children: r }) {
404
406
  }
405
407
  );
406
408
  }
407
- const ee = N(he);
408
- ee.__FULLPAGE_SECTION__ = !0;
409
- function be({
409
+ const te = F(he);
410
+ te.__FULLPAGE_SECTION__ = !0;
411
+ function we({
410
412
  children: r,
411
413
  styles: n,
412
- height: l = "30%",
414
+ height: i = "30%",
413
415
  backgroundColor: f = "yellow",
414
- footerRef: s
416
+ footerRef: a
415
417
  }) {
416
418
  return /* @__PURE__ */ E.jsx(
417
419
  "div",
418
420
  {
419
- ref: s,
421
+ ref: a,
420
422
  style: {
421
423
  position: "absolute",
422
424
  width: "100%",
423
- height: l,
425
+ height: i,
424
426
  backgroundColor: f,
425
427
  bottom: 0,
426
428
  zIndex: 50,
@@ -431,11 +433,11 @@ function be({
431
433
  "fullpage-footer"
432
434
  );
433
435
  }
434
- const te = N(be);
435
- te.__FULLPAGE_FOOTER__ = !0;
436
- function we(r) {
436
+ const re = F(we);
437
+ re.__FULLPAGE_FOOTER__ = !0;
438
+ function be(r) {
437
439
  process.env.NODE_ENV !== "production" && r.forEach((n) => {
438
- if (I.isValidElement(n) && !n.type.__FULLPAGE_SECTION__)
440
+ if ($.isValidElement(n) && !n.type.__FULLPAGE_SECTION__)
439
441
  throw console.warn(
440
442
  "[FullPage] You must wrap content inside <FullPage.Section />"
441
443
  ), new Error(
@@ -444,7 +446,7 @@ function we(r) {
444
446
  });
445
447
  }
446
448
  function Re({ children: r, isHiddenFooter: n }) {
447
- const l = n ? 2500 : 600;
449
+ const i = n ? 2500 : 600;
448
450
  return /* @__PURE__ */ E.jsx(
449
451
  "div",
450
452
  {
@@ -456,7 +458,7 @@ function Re({ children: r, isHiddenFooter: n }) {
456
458
  height: "100vh",
457
459
  zIndex: 50,
458
460
  transform: n ? "translateY(100%)" : "translateY(0)",
459
- transition: `transform ${l}ms cubic-bezier(0.22,1,0.36,1)`,
461
+ transition: `transform ${i}ms cubic-bezier(0.22,1,0.36,1)`,
460
462
  willChange: "transform",
461
463
  pointerEvents: n ? "none" : "auto"
462
464
  },
@@ -464,29 +466,31 @@ function Re({ children: r, isHiddenFooter: n }) {
464
466
  }
465
467
  );
466
468
  }
467
- const ge = N(Re);
468
- function re({
469
+ const ge = F(Re);
470
+ function ne({
469
471
  children: r,
470
472
  onChange: n,
471
- directionDots: l = "right",
472
- enableContextMenu: f = !1,
473
- duration: s = 700,
474
- closeOutside: o = !1
473
+ directionDots: i = "right",
474
+ enableContextMenu: f = !0,
475
+ duration: a = 700,
476
+ closeOutside: l = !1,
477
+ disable: o = !1
475
478
  }) {
476
- const a = I.Children.toArray(r), d = a.filter(
477
- (_) => _.type.__FULLPAGE_SECTION__
478
- ), R = a.find(
479
- (_) => _.type.__FULLPAGE_FOOTER__
479
+ const d = $.Children.toArray(r), _ = d.filter(
480
+ (b) => b.type.__FULLPAGE_SECTION__
481
+ ), R = d.find(
482
+ (b) => b.type.__FULLPAGE_FOOTER__
480
483
  );
481
- me(f), $(() => (we(d), () => {
482
- }), [d]);
483
- const h = !!R, b = d.length + (h ? 1 : 0), { active: T, goToSection: k, isHiddenFooter: w, footerRef: y } = de(
484
- b,
485
- h,
484
+ me(f), D(() => (be(_), () => {
485
+ }), [_]);
486
+ const p = !!R, w = _.length + (p ? 1 : 0), { active: y, goToSection: S, isHiddenFooter: g, footerRef: P } = de(
487
+ w,
488
+ p,
486
489
  n,
487
- s,
490
+ a,
491
+ l,
488
492
  o
489
- ), S = R ? I.cloneElement(R, { footerRef: y }) : null;
493
+ ), T = R ? $.cloneElement(R, { footerRef: P }) : null;
490
494
  return /* @__PURE__ */ E.jsxs(E.Fragment, { children: [
491
495
  /* @__PURE__ */ E.jsxs(
492
496
  "div",
@@ -502,39 +506,39 @@ function re({
502
506
  "div",
503
507
  {
504
508
  style: {
505
- height: `${d.length * 100}vh`,
506
- transform: w ? `translateY(-${T * 100}vh)` : `translateY(-${d.length - 100}vh)`,
509
+ height: `${_.length * 100}vh`,
510
+ transform: g ? `translateY(-${y * 100}vh)` : `translateY(-${_.length - 100}vh)`,
507
511
  transition: "transform 700ms cubic-bezier(0.22,1,0.36,1)"
508
512
  },
509
- children: d.map((_, p) => /* @__PURE__ */ E.jsx(
513
+ children: _.map((b, h) => /* @__PURE__ */ E.jsx(
510
514
  Ee,
511
515
  {
512
- index: p,
513
- active: T,
514
- isHiddenFooter: w,
515
- children: _
516
+ index: h,
517
+ active: y,
518
+ isHiddenFooter: g,
519
+ children: b
516
520
  },
517
- p
521
+ h
518
522
  ))
519
523
  }
520
524
  ),
521
- R && /* @__PURE__ */ E.jsx(ge, { isHiddenFooter: w, children: S })
525
+ R && /* @__PURE__ */ E.jsx(ge, { isHiddenFooter: g, children: T })
522
526
  ]
523
527
  }
524
528
  ),
525
529
  /* @__PURE__ */ E.jsx(
526
530
  pe,
527
531
  {
528
- sectionsLen: b,
529
- active: T,
530
- goToSection: k,
531
- direction: l
532
+ sectionsLen: w,
533
+ active: y,
534
+ goToSection: S,
535
+ direction: i
532
536
  }
533
537
  )
534
538
  ] });
535
539
  }
536
- re.Section = ee;
537
- re.Footer = te;
540
+ ne.Section = te;
541
+ ne.Footer = re;
538
542
  export {
539
- re as FullPage
543
+ ne as FullPage
540
544
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-abohook-fullpage",
3
- "version": "1.1.5",
3
+ "version": "1.1.7",
4
4
  "description": "React FullPage scroll component with parallax and navigation dots",
5
5
  "author": "Mostafa Ahmed",
6
6
  "license": "MIT",