-
Notifications
You must be signed in to change notification settings - Fork 0
Home
riccoarntz edited this page Feb 22, 2019
·
36 revisions
The ScrollTrackerComponentManager is a class that tracks whether a component is within your viewport based on your scroll position. It will/can handle the following for you:
- trigger methods such as
enterView
orleaveView
, once you component enters/leaves your viewport. - update your component with a progress value between
0
and1
. This is the progress of you components visibility. - enable smooth-scroll if needed.
const components = [new DummyFoo(), new DummyFoo2()];
const scrollTrackerComponentManager = new ScrollTrackerComponentManager();
scrollTrackerComponentManager.addComponentsToScrollTracker(components);
Methods/properties of the component that are triggered which can be overwritten to add components with a different/custom interface.
const scrollTrackerComponentManager = new ScrollTrackerComponentManager({
container: window,
element: 'element',
enterView: 'enterView',
leaveView: 'leaveView',
beyondView: 'beyondView',
inViewProgress: 'inViewProgress',
inViewProgressThreshold: 'inViewProgressThreshold',
enterViewThreshold: 'enterViewThreshold',
componentId: 'componentId',
hasEntered: 'hasEntered',
currentViewProgress: 'currentViewProgress',
inViewProgressEnabled: false,
setDebugLabel: true,
debugBorderColor: 'red',
scrollThrottle: 100,
resizeDebounce: 100,
enableSmoothScroll: false,
smoothScrollOptions: {
damping: 0.1,
thumbMinSize: 20,
renderByPixels: true,
alwaysShowTracks: false,
continuousScrolling: true,
wheelEventTarget: null,
plugins: {},
},
});
-
container
- the container that will be the scroll-area, default is the window. -
element
- PropertyName of the component that contains the HTMLElement of the component. -
enterView
- MethodName of the component which is triggered when the component is within the viewport. -
leaveView
- MethodName of the component which is triggered when the component has left the viewport. -
beyondView
- MethodName of the component which is triggered everytime it is already scrolled passed a component, or when you would load a page while the scrollbar is already at the bottom or passed a component. -
inViewProgress
- Method name of the component which is triggered every time the scroll-position changes. This method will have the parameterprogress
which is a number between0-1
. -
enterViewThreshold
- PropertyName of the component that contains a number between 0 - 1. Setting this number to for example 0.5 will trigger the enterView method when the component is already visible for 50% within your viewport. -
inViewProgressThreshold
- same asenterViewThreshold
but then used as an offset from when your inViewProgress will start. -
hasEntered
- PropertyName of the component that should is by default set to false. Will be set to value if it has passed the viewport once already. -
currentViewProgress
- PropertyName of the component where we will store theprogress
of its visibility. -
inViewProgressEnabled
- When this is set totrue
we will call the methodinViewProgress(progress)
. By default this is set tofalse
. -
componentId
- PropertyName of the component that should contain a unique string for each added component. -
setDebugLabel
- Enable/Disable visible scroll-tracker-points for each component, this will allow to you see when the transitionIn/Out is called. -
debugBorderColor
- Color of the scroll-tracker-points (top/bottom line). -
resizeDebounce
- Number in milliseconds to update the scroll-tracker-points with a debounce if the window is being resized. -
scrollThrottle
- Number in milliseconds used to throttle the scroll event. -
enableSmoothScroll
- Enable/Disable smooth-scroll, see documentation below. By default this is set tofalse
-
smoothScrollOptions
- See documentation below.
Smoothscroll ( EXAMPLE )
In case you want to enable smooth-scroll, read their documentation for all the possibilities.
scrollTrackerComponentManager.removeComponentsFromScrollTracker(components);
scrollTrackerComponentManager.dispose();