1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- function getOffset(element, parent) {
- return {
- top: Math.round(element.getBoundingClientRect().top - parent.getBoundingClientRect().top),
- left: Math.round(element.getBoundingClientRect().left - parent.getBoundingClientRect().left)
- };
- }
- var locks = new Set();
- function lockBodyScrolling(lockingEl) {
- locks.add(lockingEl);
- document.body.classList.add("sl-scroll-lock");
- }
- function unlockBodyScrolling(lockingEl) {
- locks.delete(lockingEl);
- if (locks.size === 0) {
- document.body.classList.remove("sl-scroll-lock");
- }
- }
- function scrollIntoView(element, container, direction = "vertical", behavior = "smooth") {
- const offset = getOffset(element, container);
- const offsetTop = offset.top + container.scrollTop;
- const offsetLeft = offset.left + container.scrollLeft;
- const minX = container.scrollLeft;
- const maxX = container.scrollLeft + container.offsetWidth;
- const minY = container.scrollTop;
- const maxY = container.scrollTop + container.offsetHeight;
- if (direction === "horizontal" || direction === "both") {
- if (offsetLeft < minX) {
- container.scrollTo({ left: offsetLeft, behavior });
- } else if (offsetLeft + element.clientWidth > maxX) {
- container.scrollTo({ left: offsetLeft - container.offsetWidth + element.clientWidth, behavior });
- }
- }
- if (direction === "vertical" || direction === "both") {
- if (offsetTop < minY) {
- container.scrollTo({ top: offsetTop, behavior });
- } else if (offsetTop + element.clientHeight > maxY) {
- container.scrollTo({ top: offsetTop - container.offsetHeight + element.clientHeight, behavior });
- }
- }
- }
- export {
- getOffset,
- lockBodyScrolling,
- unlockBodyScrolling,
- scrollIntoView
- };
|