Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F124559704
useScrollTrigger.js
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sun, Aug 3, 06:47
Size
1 KB
Mime Type
text/x-java
Expires
Tue, Aug 5, 06:47 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
27853246
Attached To
rOACCT Open Access Compliance Check Tool (OACCT)
useScrollTrigger.js
View Options
import
_extends
from
"@babel/runtime/helpers/esm/extends"
;
import
_objectWithoutPropertiesLoose
from
"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose"
;
const
_excluded
=
[
"getTrigger"
,
"target"
];
import
*
as
React
from
'react'
;
function
defaultTrigger
(
store
,
options
)
{
const
{
disableHysteresis
=
false
,
threshold
=
100
,
target
}
=
options
;
const
previous
=
store
.
current
;
if
(
target
)
{
// Get vertical scroll
store
.
current
=
target
.
pageYOffset
!==
undefined
?
target
.
pageYOffset
:
target
.
scrollTop
;
}
if
(
!
disableHysteresis
&&
previous
!==
undefined
)
{
if
(
store
.
current
<
previous
)
{
return
false
;
}
}
return
store
.
current
>
threshold
;
}
const
defaultTarget
=
typeof
window
!==
'undefined'
?
window
:
null
;
export
default
function
useScrollTrigger
(
options
=
{})
{
const
{
getTrigger
=
defaultTrigger
,
target
=
defaultTarget
}
=
options
,
other
=
_objectWithoutPropertiesLoose
(
options
,
_excluded
);
const
store
=
React
.
useRef
();
const
[
trigger
,
setTrigger
]
=
React
.
useState
(()
=>
getTrigger
(
store
,
other
));
React
.
useEffect
(()
=>
{
const
handleScroll
=
()
=>
{
setTrigger
(
getTrigger
(
store
,
_extends
({
target
},
other
)));
};
handleScroll
();
// Re-evaluate trigger when dependencies change
target
.
addEventListener
(
'scroll'
,
handleScroll
,
{
passive
:
true
});
return
()
=>
{
target
.
removeEventListener
(
'scroll'
,
handleScroll
,
{
passive
:
true
});
};
// See Option 3. https://github.com/facebook/react/issues/14476#issuecomment-471199055
// eslint-disable-next-line react-hooks/exhaustive-deps
},
[
target
,
getTrigger
,
JSON
.
stringify
(
other
)]);
return
trigger
;
}
Event Timeline
Log In to Comment