UNPKG

@fpxfd/next

Version:

A configurable component library for web built on React.

36 lines (33 loc) 1.37 kB
import raf from 'raf'; import { easeInOutCubic } from './easings'; import getScroll, { isWindow } from './getScroll'; export default function scrollTo(y, options) { var _options$getContainer = options.getContainer, getContainer = _options$getContainer === undefined ? function () { return window; } : _options$getContainer, callback = options.callback, _options$duration = options.duration, duration = _options$duration === undefined ? 450 : _options$duration; var container = getContainer(); var scrollTop = getScroll(container, true); var startTime = Date.now(); var frameFunc = function frameFunc() { var timestamp = Date.now(); var time = timestamp - startTime; var nextScrollTop = easeInOutCubic(time > duration ? duration : time, scrollTop, y, duration); if (isWindow(container)) { container.scrollTo(window.pageXOffset, nextScrollTop); } else if (container instanceof HTMLDocument || container.constructor.name === 'HTMLDocument') { container.documentElement.scrollTop = nextScrollTop; } else { container.scrollTop = nextScrollTop; } if (time < duration) { raf(frameFunc); } else if (typeof callback === 'function') { callback(); } }; raf(frameFunc); }