first commit
This commit is contained in:
@@ -0,0 +1,855 @@
|
||||
/**
|
||||
* SimpleBar.js - v4.2.3
|
||||
* Scrollbars, simpler.
|
||||
* https://grsmto.github.io/simplebar/
|
||||
*
|
||||
* Made by Adrien Denat from a fork by Jonathan Nicol
|
||||
* Under MIT License
|
||||
*/
|
||||
|
||||
import 'core-js/modules/es.array.filter';
|
||||
import 'core-js/modules/es.array.for-each';
|
||||
import 'core-js/modules/es.array.reduce';
|
||||
import 'core-js/modules/es.function.name';
|
||||
import 'core-js/modules/es.object.assign';
|
||||
import 'core-js/modules/es.parse-int';
|
||||
import 'core-js/modules/es.regexp.exec';
|
||||
import 'core-js/modules/es.string.match';
|
||||
import 'core-js/modules/es.string.replace';
|
||||
import 'core-js/modules/web.dom-collections.for-each';
|
||||
import throttle from 'lodash.throttle';
|
||||
import debounce from 'lodash.debounce';
|
||||
import memoize from 'lodash.memoize';
|
||||
import ResizeObserver from 'resize-observer-polyfill';
|
||||
import canUseDOM from 'can-use-dom';
|
||||
|
||||
function scrollbarWidth() {
|
||||
if (typeof document === 'undefined') {
|
||||
return 0;
|
||||
}
|
||||
|
||||
var body = document.body;
|
||||
var box = document.createElement('div');
|
||||
var boxStyle = box.style;
|
||||
boxStyle.position = 'fixed';
|
||||
boxStyle.left = 0;
|
||||
boxStyle.visibility = 'hidden';
|
||||
boxStyle.overflowY = 'scroll';
|
||||
body.appendChild(box);
|
||||
var width = box.getBoundingClientRect().right;
|
||||
body.removeChild(box);
|
||||
return width;
|
||||
}
|
||||
|
||||
var SimpleBar =
|
||||
/*#__PURE__*/
|
||||
function () {
|
||||
function SimpleBar(element, options) {
|
||||
var _this = this;
|
||||
|
||||
this.onScroll = function () {
|
||||
if (!_this.scrollXTicking) {
|
||||
window.requestAnimationFrame(_this.scrollX);
|
||||
_this.scrollXTicking = true;
|
||||
}
|
||||
|
||||
if (!_this.scrollYTicking) {
|
||||
window.requestAnimationFrame(_this.scrollY);
|
||||
_this.scrollYTicking = true;
|
||||
}
|
||||
};
|
||||
|
||||
this.scrollX = function () {
|
||||
if (_this.axis.x.isOverflowing) {
|
||||
_this.showScrollbar('x');
|
||||
|
||||
_this.positionScrollbar('x');
|
||||
}
|
||||
|
||||
_this.scrollXTicking = false;
|
||||
};
|
||||
|
||||
this.scrollY = function () {
|
||||
if (_this.axis.y.isOverflowing) {
|
||||
_this.showScrollbar('y');
|
||||
|
||||
_this.positionScrollbar('y');
|
||||
}
|
||||
|
||||
_this.scrollYTicking = false;
|
||||
};
|
||||
|
||||
this.onMouseEnter = function () {
|
||||
_this.showScrollbar('x');
|
||||
|
||||
_this.showScrollbar('y');
|
||||
};
|
||||
|
||||
this.onMouseMove = function (e) {
|
||||
_this.mouseX = e.clientX;
|
||||
_this.mouseY = e.clientY;
|
||||
|
||||
if (_this.axis.x.isOverflowing || _this.axis.x.forceVisible) {
|
||||
_this.onMouseMoveForAxis('x');
|
||||
}
|
||||
|
||||
if (_this.axis.y.isOverflowing || _this.axis.y.forceVisible) {
|
||||
_this.onMouseMoveForAxis('y');
|
||||
}
|
||||
};
|
||||
|
||||
this.onMouseLeave = function () {
|
||||
_this.onMouseMove.cancel();
|
||||
|
||||
if (_this.axis.x.isOverflowing || _this.axis.x.forceVisible) {
|
||||
_this.onMouseLeaveForAxis('x');
|
||||
}
|
||||
|
||||
if (_this.axis.y.isOverflowing || _this.axis.y.forceVisible) {
|
||||
_this.onMouseLeaveForAxis('y');
|
||||
}
|
||||
|
||||
_this.mouseX = -1;
|
||||
_this.mouseY = -1;
|
||||
};
|
||||
|
||||
this.onWindowResize = function () {
|
||||
// Recalculate scrollbarWidth in case it's a zoom
|
||||
_this.scrollbarWidth = scrollbarWidth();
|
||||
|
||||
_this.hideNativeScrollbar();
|
||||
};
|
||||
|
||||
this.hideScrollbars = function () {
|
||||
_this.axis.x.track.rect = _this.axis.x.track.el.getBoundingClientRect();
|
||||
_this.axis.y.track.rect = _this.axis.y.track.el.getBoundingClientRect();
|
||||
|
||||
if (!_this.isWithinBounds(_this.axis.y.track.rect)) {
|
||||
_this.axis.y.scrollbar.el.classList.remove(_this.classNames.visible);
|
||||
|
||||
_this.axis.y.isVisible = false;
|
||||
}
|
||||
|
||||
if (!_this.isWithinBounds(_this.axis.x.track.rect)) {
|
||||
_this.axis.x.scrollbar.el.classList.remove(_this.classNames.visible);
|
||||
|
||||
_this.axis.x.isVisible = false;
|
||||
}
|
||||
};
|
||||
|
||||
this.onPointerEvent = function (e) {
|
||||
var isWithinBoundsY, isWithinBoundsX;
|
||||
_this.axis.x.scrollbar.rect = _this.axis.x.scrollbar.el.getBoundingClientRect();
|
||||
_this.axis.y.scrollbar.rect = _this.axis.y.scrollbar.el.getBoundingClientRect();
|
||||
|
||||
if (_this.axis.x.isOverflowing || _this.axis.x.forceVisible) {
|
||||
isWithinBoundsX = _this.isWithinBounds(_this.axis.x.scrollbar.rect);
|
||||
}
|
||||
|
||||
if (_this.axis.y.isOverflowing || _this.axis.y.forceVisible) {
|
||||
isWithinBoundsY = _this.isWithinBounds(_this.axis.y.scrollbar.rect);
|
||||
} // If any pointer event is called on the scrollbar
|
||||
|
||||
|
||||
if (isWithinBoundsY || isWithinBoundsX) {
|
||||
// Preventing the event's default action stops text being
|
||||
// selectable during the drag.
|
||||
e.preventDefault(); // Prevent event leaking
|
||||
|
||||
e.stopPropagation();
|
||||
|
||||
if (e.type === 'mousedown') {
|
||||
if (isWithinBoundsY) {
|
||||
_this.onDragStart(e, 'y');
|
||||
}
|
||||
|
||||
if (isWithinBoundsX) {
|
||||
_this.onDragStart(e, 'x');
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
this.drag = function (e) {
|
||||
var eventOffset;
|
||||
var track = _this.axis[_this.draggedAxis].track;
|
||||
var trackSize = track.rect[_this.axis[_this.draggedAxis].sizeAttr];
|
||||
var scrollbar = _this.axis[_this.draggedAxis].scrollbar;
|
||||
var contentSize = _this.contentWrapperEl[_this.axis[_this.draggedAxis].scrollSizeAttr];
|
||||
var hostSize = parseInt(_this.elStyles[_this.axis[_this.draggedAxis].sizeAttr], 10);
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
|
||||
if (_this.draggedAxis === 'y') {
|
||||
eventOffset = e.pageY;
|
||||
} else {
|
||||
eventOffset = e.pageX;
|
||||
} // Calculate how far the user's mouse is from the top/left of the scrollbar (minus the dragOffset).
|
||||
|
||||
|
||||
var dragPos = eventOffset - track.rect[_this.axis[_this.draggedAxis].offsetAttr] - _this.axis[_this.draggedAxis].dragOffset; // Convert the mouse position into a percentage of the scrollbar height/width.
|
||||
|
||||
var dragPerc = dragPos / (trackSize - scrollbar.size); // Scroll the content by the same percentage.
|
||||
|
||||
var scrollPos = dragPerc * (contentSize - hostSize); // Fix browsers inconsistency on RTL
|
||||
|
||||
if (_this.draggedAxis === 'x') {
|
||||
scrollPos = _this.isRtl && SimpleBar.getRtlHelpers().isRtlScrollbarInverted ? scrollPos - (trackSize + scrollbar.size) : scrollPos;
|
||||
scrollPos = _this.isRtl && SimpleBar.getRtlHelpers().isRtlScrollingInverted ? -scrollPos : scrollPos;
|
||||
}
|
||||
|
||||
_this.contentWrapperEl[_this.axis[_this.draggedAxis].scrollOffsetAttr] = scrollPos;
|
||||
};
|
||||
|
||||
this.onEndDrag = function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
|
||||
_this.el.classList.remove(_this.classNames.dragging);
|
||||
|
||||
document.removeEventListener('mousemove', _this.drag, true);
|
||||
document.removeEventListener('mouseup', _this.onEndDrag, true);
|
||||
_this.removePreventClickId = window.setTimeout(function () {
|
||||
// Remove these asynchronously so we still suppress click events
|
||||
// generated simultaneously with mouseup.
|
||||
document.removeEventListener('click', _this.preventClick, true);
|
||||
document.removeEventListener('dblclick', _this.preventClick, true);
|
||||
_this.removePreventClickId = null;
|
||||
});
|
||||
};
|
||||
|
||||
this.preventClick = function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
};
|
||||
|
||||
this.el = element;
|
||||
this.flashTimeout;
|
||||
this.contentEl;
|
||||
this.contentWrapperEl;
|
||||
this.offsetEl;
|
||||
this.maskEl;
|
||||
this.globalObserver;
|
||||
this.mutationObserver;
|
||||
this.resizeObserver;
|
||||
this.scrollbarWidth;
|
||||
this.minScrollbarWidth = 20;
|
||||
this.options = Object.assign({}, SimpleBar.defaultOptions, options);
|
||||
this.classNames = Object.assign({}, SimpleBar.defaultOptions.classNames, this.options.classNames);
|
||||
this.isRtl;
|
||||
this.axis = {
|
||||
x: {
|
||||
scrollOffsetAttr: 'scrollLeft',
|
||||
sizeAttr: 'width',
|
||||
scrollSizeAttr: 'scrollWidth',
|
||||
offsetAttr: 'left',
|
||||
overflowAttr: 'overflowX',
|
||||
dragOffset: 0,
|
||||
isOverflowing: true,
|
||||
isVisible: false,
|
||||
forceVisible: false,
|
||||
track: {},
|
||||
scrollbar: {}
|
||||
},
|
||||
y: {
|
||||
scrollOffsetAttr: 'scrollTop',
|
||||
sizeAttr: 'height',
|
||||
scrollSizeAttr: 'scrollHeight',
|
||||
offsetAttr: 'top',
|
||||
overflowAttr: 'overflowY',
|
||||
dragOffset: 0,
|
||||
isOverflowing: true,
|
||||
isVisible: false,
|
||||
forceVisible: false,
|
||||
track: {},
|
||||
scrollbar: {}
|
||||
}
|
||||
};
|
||||
this.removePreventClickId = null; // Don't re-instantiate over an existing one
|
||||
|
||||
if (this.el.SimpleBar) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.recalculate = throttle(this.recalculate.bind(this), 64);
|
||||
this.onMouseMove = throttle(this.onMouseMove.bind(this), 64);
|
||||
this.hideScrollbars = debounce(this.hideScrollbars.bind(this), this.options.timeout);
|
||||
this.onWindowResize = debounce(this.onWindowResize.bind(this), 64, {
|
||||
leading: true
|
||||
});
|
||||
SimpleBar.getRtlHelpers = memoize(SimpleBar.getRtlHelpers);
|
||||
this.init();
|
||||
}
|
||||
/**
|
||||
* Static properties
|
||||
*/
|
||||
|
||||
/**
|
||||
* Helper to fix browsers inconsistency on RTL:
|
||||
* - Firefox inverts the scrollbar initial position
|
||||
* - IE11 inverts both scrollbar position and scrolling offset
|
||||
* Directly inspired by @KingSora's OverlayScrollbars https://github.com/KingSora/OverlayScrollbars/blob/master/js/OverlayScrollbars.js#L1634
|
||||
*/
|
||||
|
||||
|
||||
SimpleBar.getRtlHelpers = function getRtlHelpers() {
|
||||
var dummyDiv = document.createElement('div');
|
||||
dummyDiv.innerHTML = '<div class="hs-dummy-scrollbar-size"><div style="height: 200%; width: 200%; margin: 10px 0;"></div></div>';
|
||||
var scrollbarDummyEl = dummyDiv.firstElementChild;
|
||||
document.body.appendChild(scrollbarDummyEl);
|
||||
var dummyContainerChild = scrollbarDummyEl.firstElementChild;
|
||||
scrollbarDummyEl.scrollLeft = 0;
|
||||
var dummyContainerOffset = SimpleBar.getOffset(scrollbarDummyEl);
|
||||
var dummyContainerChildOffset = SimpleBar.getOffset(dummyContainerChild);
|
||||
scrollbarDummyEl.scrollLeft = 999;
|
||||
var dummyContainerScrollOffsetAfterScroll = SimpleBar.getOffset(dummyContainerChild);
|
||||
return {
|
||||
// determines if the scrolling is responding with negative values
|
||||
isRtlScrollingInverted: dummyContainerOffset.left !== dummyContainerChildOffset.left && dummyContainerChildOffset.left - dummyContainerScrollOffsetAfterScroll.left !== 0,
|
||||
// determines if the origin scrollbar position is inverted or not (positioned on left or right)
|
||||
isRtlScrollbarInverted: dummyContainerOffset.left !== dummyContainerChildOffset.left
|
||||
};
|
||||
};
|
||||
|
||||
SimpleBar.initHtmlApi = function initHtmlApi() {
|
||||
this.initDOMLoadedElements = this.initDOMLoadedElements.bind(this); // MutationObserver is IE11+
|
||||
|
||||
if (typeof MutationObserver !== 'undefined') {
|
||||
// Mutation observer to observe dynamically added elements
|
||||
this.globalObserver = new MutationObserver(function (mutations) {
|
||||
mutations.forEach(function (mutation) {
|
||||
Array.prototype.forEach.call(mutation.addedNodes, function (addedNode) {
|
||||
if (addedNode.nodeType === 1) {
|
||||
if (addedNode.hasAttribute('data-simplebar')) {
|
||||
!addedNode.SimpleBar && new SimpleBar(addedNode, SimpleBar.getElOptions(addedNode));
|
||||
} else {
|
||||
Array.prototype.forEach.call(addedNode.querySelectorAll('[data-simplebar]'), function (el) {
|
||||
!el.SimpleBar && new SimpleBar(el, SimpleBar.getElOptions(el));
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
Array.prototype.forEach.call(mutation.removedNodes, function (removedNode) {
|
||||
if (removedNode.nodeType === 1) {
|
||||
if (removedNode.hasAttribute('data-simplebar')) {
|
||||
removedNode.SimpleBar && removedNode.SimpleBar.unMount();
|
||||
} else {
|
||||
Array.prototype.forEach.call(removedNode.querySelectorAll('[data-simplebar]'), function (el) {
|
||||
el.SimpleBar && el.SimpleBar.unMount();
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
this.globalObserver.observe(document, {
|
||||
childList: true,
|
||||
subtree: true
|
||||
});
|
||||
} // Taken from jQuery `ready` function
|
||||
// Instantiate elements already present on the page
|
||||
|
||||
|
||||
if (document.readyState === 'complete' || document.readyState !== 'loading' && !document.documentElement.doScroll) {
|
||||
// Handle it asynchronously to allow scripts the opportunity to delay init
|
||||
window.setTimeout(this.initDOMLoadedElements);
|
||||
} else {
|
||||
document.addEventListener('DOMContentLoaded', this.initDOMLoadedElements);
|
||||
window.addEventListener('load', this.initDOMLoadedElements);
|
||||
}
|
||||
} // Helper function to retrieve options from element attributes
|
||||
;
|
||||
|
||||
SimpleBar.getElOptions = function getElOptions(el) {
|
||||
var options = Array.prototype.reduce.call(el.attributes, function (acc, attribute) {
|
||||
var option = attribute.name.match(/data-simplebar-(.+)/);
|
||||
|
||||
if (option) {
|
||||
var key = option[1].replace(/\W+(.)/g, function (x, chr) {
|
||||
return chr.toUpperCase();
|
||||
});
|
||||
|
||||
switch (attribute.value) {
|
||||
case 'true':
|
||||
acc[key] = true;
|
||||
break;
|
||||
|
||||
case 'false':
|
||||
acc[key] = false;
|
||||
break;
|
||||
|
||||
case undefined:
|
||||
acc[key] = true;
|
||||
break;
|
||||
|
||||
default:
|
||||
acc[key] = attribute.value;
|
||||
}
|
||||
}
|
||||
|
||||
return acc;
|
||||
}, {});
|
||||
return options;
|
||||
};
|
||||
|
||||
SimpleBar.removeObserver = function removeObserver() {
|
||||
this.globalObserver.disconnect();
|
||||
};
|
||||
|
||||
SimpleBar.initDOMLoadedElements = function initDOMLoadedElements() {
|
||||
document.removeEventListener('DOMContentLoaded', this.initDOMLoadedElements);
|
||||
window.removeEventListener('load', this.initDOMLoadedElements);
|
||||
Array.prototype.forEach.call(document.querySelectorAll('[data-simplebar]'), function (el) {
|
||||
if (!el.SimpleBar) new SimpleBar(el, SimpleBar.getElOptions(el));
|
||||
});
|
||||
};
|
||||
|
||||
SimpleBar.getOffset = function getOffset(el) {
|
||||
var rect = el.getBoundingClientRect();
|
||||
return {
|
||||
top: rect.top + (window.pageYOffset || document.documentElement.scrollTop),
|
||||
left: rect.left + (window.pageXOffset || document.documentElement.scrollLeft)
|
||||
};
|
||||
};
|
||||
|
||||
var _proto = SimpleBar.prototype;
|
||||
|
||||
_proto.init = function init() {
|
||||
// Save a reference to the instance, so we know this DOM node has already been instancied
|
||||
this.el.SimpleBar = this; // We stop here on server-side
|
||||
|
||||
if (canUseDOM) {
|
||||
this.initDOM();
|
||||
this.scrollbarWidth = scrollbarWidth();
|
||||
this.recalculate();
|
||||
this.initListeners();
|
||||
}
|
||||
};
|
||||
|
||||
_proto.initDOM = function initDOM() {
|
||||
var _this2 = this;
|
||||
|
||||
// make sure this element doesn't have the elements yet
|
||||
if (Array.prototype.filter.call(this.el.children, function (child) {
|
||||
return child.classList.contains(_this2.classNames.wrapper);
|
||||
}).length) {
|
||||
// assume that element has his DOM already initiated
|
||||
this.wrapperEl = this.el.querySelector("." + this.classNames.wrapper);
|
||||
this.contentWrapperEl = this.el.querySelector("." + this.classNames.contentWrapper);
|
||||
this.offsetEl = this.el.querySelector("." + this.classNames.offset);
|
||||
this.maskEl = this.el.querySelector("." + this.classNames.mask);
|
||||
this.contentEl = this.el.querySelector("." + this.classNames.contentEl);
|
||||
this.placeholderEl = this.el.querySelector("." + this.classNames.placeholder);
|
||||
this.heightAutoObserverWrapperEl = this.el.querySelector("." + this.classNames.heightAutoObserverWrapperEl);
|
||||
this.heightAutoObserverEl = this.el.querySelector("." + this.classNames.heightAutoObserverEl);
|
||||
this.axis.x.track.el = this.findChild(this.el, "." + this.classNames.track + "." + this.classNames.horizontal);
|
||||
this.axis.y.track.el = this.findChild(this.el, "." + this.classNames.track + "." + this.classNames.vertical);
|
||||
} else {
|
||||
// Prepare DOM
|
||||
this.wrapperEl = document.createElement('div');
|
||||
this.contentWrapperEl = document.createElement('div');
|
||||
this.offsetEl = document.createElement('div');
|
||||
this.maskEl = document.createElement('div');
|
||||
this.contentEl = document.createElement('div');
|
||||
this.placeholderEl = document.createElement('div');
|
||||
this.heightAutoObserverWrapperEl = document.createElement('div');
|
||||
this.heightAutoObserverEl = document.createElement('div');
|
||||
this.wrapperEl.classList.add(this.classNames.wrapper);
|
||||
this.contentWrapperEl.classList.add(this.classNames.contentWrapper);
|
||||
this.offsetEl.classList.add(this.classNames.offset);
|
||||
this.maskEl.classList.add(this.classNames.mask);
|
||||
this.contentEl.classList.add(this.classNames.contentEl);
|
||||
this.placeholderEl.classList.add(this.classNames.placeholder);
|
||||
this.heightAutoObserverWrapperEl.classList.add(this.classNames.heightAutoObserverWrapperEl);
|
||||
this.heightAutoObserverEl.classList.add(this.classNames.heightAutoObserverEl);
|
||||
|
||||
while (this.el.firstChild) {
|
||||
this.contentEl.appendChild(this.el.firstChild);
|
||||
}
|
||||
|
||||
this.contentWrapperEl.appendChild(this.contentEl);
|
||||
this.offsetEl.appendChild(this.contentWrapperEl);
|
||||
this.maskEl.appendChild(this.offsetEl);
|
||||
this.heightAutoObserverWrapperEl.appendChild(this.heightAutoObserverEl);
|
||||
this.wrapperEl.appendChild(this.heightAutoObserverWrapperEl);
|
||||
this.wrapperEl.appendChild(this.maskEl);
|
||||
this.wrapperEl.appendChild(this.placeholderEl);
|
||||
this.el.appendChild(this.wrapperEl);
|
||||
}
|
||||
|
||||
if (!this.axis.x.track.el || !this.axis.y.track.el) {
|
||||
var track = document.createElement('div');
|
||||
var scrollbar = document.createElement('div');
|
||||
track.classList.add(this.classNames.track);
|
||||
scrollbar.classList.add(this.classNames.scrollbar);
|
||||
track.appendChild(scrollbar);
|
||||
this.axis.x.track.el = track.cloneNode(true);
|
||||
this.axis.x.track.el.classList.add(this.classNames.horizontal);
|
||||
this.axis.y.track.el = track.cloneNode(true);
|
||||
this.axis.y.track.el.classList.add(this.classNames.vertical);
|
||||
this.el.appendChild(this.axis.x.track.el);
|
||||
this.el.appendChild(this.axis.y.track.el);
|
||||
}
|
||||
|
||||
this.axis.x.scrollbar.el = this.axis.x.track.el.querySelector("." + this.classNames.scrollbar);
|
||||
this.axis.y.scrollbar.el = this.axis.y.track.el.querySelector("." + this.classNames.scrollbar);
|
||||
|
||||
if (!this.options.autoHide) {
|
||||
this.axis.x.scrollbar.el.classList.add(this.classNames.visible);
|
||||
this.axis.y.scrollbar.el.classList.add(this.classNames.visible);
|
||||
}
|
||||
|
||||
this.el.setAttribute('data-simplebar', 'init');
|
||||
};
|
||||
|
||||
_proto.initListeners = function initListeners() {
|
||||
var _this3 = this;
|
||||
|
||||
// Event listeners
|
||||
if (this.options.autoHide) {
|
||||
this.el.addEventListener('mouseenter', this.onMouseEnter);
|
||||
}
|
||||
|
||||
['mousedown', 'click', 'dblclick'].forEach(function (e) {
|
||||
_this3.el.addEventListener(e, _this3.onPointerEvent, true);
|
||||
});
|
||||
['touchstart', 'touchend', 'touchmove'].forEach(function (e) {
|
||||
_this3.el.addEventListener(e, _this3.onPointerEvent, {
|
||||
capture: true,
|
||||
passive: true
|
||||
});
|
||||
});
|
||||
this.el.addEventListener('mousemove', this.onMouseMove);
|
||||
this.el.addEventListener('mouseleave', this.onMouseLeave);
|
||||
this.contentWrapperEl.addEventListener('scroll', this.onScroll); // Browser zoom triggers a window resize
|
||||
|
||||
window.addEventListener('resize', this.onWindowResize);
|
||||
this.resizeObserver = new ResizeObserver(this.recalculate);
|
||||
this.resizeObserver.observe(this.el);
|
||||
this.resizeObserver.observe(this.contentEl);
|
||||
};
|
||||
|
||||
_proto.recalculate = function recalculate() {
|
||||
var isHeightAuto = this.heightAutoObserverEl.offsetHeight <= 1;
|
||||
var isWidthAuto = this.heightAutoObserverEl.offsetWidth <= 1;
|
||||
this.elStyles = window.getComputedStyle(this.el);
|
||||
this.isRtl = this.elStyles.direction === 'rtl';
|
||||
this.contentEl.style.padding = this.elStyles.paddingTop + " " + this.elStyles.paddingRight + " " + this.elStyles.paddingBottom + " " + this.elStyles.paddingLeft;
|
||||
this.wrapperEl.style.margin = "-" + this.elStyles.paddingTop + " -" + this.elStyles.paddingRight + " -" + this.elStyles.paddingBottom + " -" + this.elStyles.paddingLeft;
|
||||
this.contentWrapperEl.style.height = isHeightAuto ? 'auto' : '100%'; // Determine placeholder size
|
||||
|
||||
this.placeholderEl.style.width = isWidthAuto ? this.contentEl.offsetWidth + "px" : 'auto';
|
||||
this.placeholderEl.style.height = this.contentEl.scrollHeight + "px"; // Set isOverflowing to false if scrollbar is not necessary (content is shorter than offset)
|
||||
|
||||
this.axis.x.isOverflowing = this.contentWrapperEl.scrollWidth > this.contentWrapperEl.offsetWidth;
|
||||
this.axis.y.isOverflowing = this.contentWrapperEl.scrollHeight > this.contentWrapperEl.offsetHeight; // Set isOverflowing to false if user explicitely set hidden overflow
|
||||
|
||||
this.axis.x.isOverflowing = this.elStyles.overflowX === 'hidden' ? false : this.axis.x.isOverflowing;
|
||||
this.axis.y.isOverflowing = this.elStyles.overflowY === 'hidden' ? false : this.axis.y.isOverflowing;
|
||||
this.axis.x.forceVisible = this.options.forceVisible === 'x' || this.options.forceVisible === true;
|
||||
this.axis.y.forceVisible = this.options.forceVisible === 'y' || this.options.forceVisible === true;
|
||||
this.hideNativeScrollbar();
|
||||
this.axis.x.track.rect = this.axis.x.track.el.getBoundingClientRect();
|
||||
this.axis.y.track.rect = this.axis.y.track.el.getBoundingClientRect();
|
||||
this.axis.x.scrollbar.size = this.getScrollbarSize('x');
|
||||
this.axis.y.scrollbar.size = this.getScrollbarSize('y');
|
||||
this.axis.x.scrollbar.el.style.width = this.axis.x.scrollbar.size + "px";
|
||||
this.axis.y.scrollbar.el.style.height = this.axis.y.scrollbar.size + "px";
|
||||
this.positionScrollbar('x');
|
||||
this.positionScrollbar('y');
|
||||
this.toggleTrackVisibility('x');
|
||||
this.toggleTrackVisibility('y');
|
||||
}
|
||||
/**
|
||||
* Calculate scrollbar size
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.getScrollbarSize = function getScrollbarSize(axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
var contentSize = this.scrollbarWidth ? this.contentWrapperEl[this.axis[axis].scrollSizeAttr] : this.contentWrapperEl[this.axis[axis].scrollSizeAttr] - this.minScrollbarWidth;
|
||||
var trackSize = this.axis[axis].track.rect[this.axis[axis].sizeAttr];
|
||||
var scrollbarSize;
|
||||
|
||||
if (!this.axis[axis].isOverflowing) {
|
||||
return;
|
||||
}
|
||||
|
||||
var scrollbarRatio = trackSize / contentSize; // Calculate new height/position of drag handle.
|
||||
|
||||
scrollbarSize = Math.max(~~(scrollbarRatio * trackSize), this.options.scrollbarMinSize);
|
||||
|
||||
if (this.options.scrollbarMaxSize) {
|
||||
scrollbarSize = Math.min(scrollbarSize, this.options.scrollbarMaxSize);
|
||||
}
|
||||
|
||||
return scrollbarSize;
|
||||
};
|
||||
|
||||
_proto.positionScrollbar = function positionScrollbar(axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
var contentSize = this.contentWrapperEl[this.axis[axis].scrollSizeAttr];
|
||||
var trackSize = this.axis[axis].track.rect[this.axis[axis].sizeAttr];
|
||||
var hostSize = parseInt(this.elStyles[this.axis[axis].sizeAttr], 10);
|
||||
var scrollbar = this.axis[axis].scrollbar;
|
||||
var scrollOffset = this.contentWrapperEl[this.axis[axis].scrollOffsetAttr];
|
||||
scrollOffset = axis === 'x' && this.isRtl && SimpleBar.getRtlHelpers().isRtlScrollingInverted ? -scrollOffset : scrollOffset;
|
||||
var scrollPourcent = scrollOffset / (contentSize - hostSize);
|
||||
var handleOffset = ~~((trackSize - scrollbar.size) * scrollPourcent);
|
||||
handleOffset = axis === 'x' && this.isRtl && SimpleBar.getRtlHelpers().isRtlScrollbarInverted ? handleOffset + (trackSize - scrollbar.size) : handleOffset;
|
||||
scrollbar.el.style.transform = axis === 'x' ? "translate3d(" + handleOffset + "px, 0, 0)" : "translate3d(0, " + handleOffset + "px, 0)";
|
||||
};
|
||||
|
||||
_proto.toggleTrackVisibility = function toggleTrackVisibility(axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
var track = this.axis[axis].track.el;
|
||||
var scrollbar = this.axis[axis].scrollbar.el;
|
||||
|
||||
if (this.axis[axis].isOverflowing || this.axis[axis].forceVisible) {
|
||||
track.style.visibility = 'visible';
|
||||
this.contentWrapperEl.style[this.axis[axis].overflowAttr] = 'scroll';
|
||||
} else {
|
||||
track.style.visibility = 'hidden';
|
||||
this.contentWrapperEl.style[this.axis[axis].overflowAttr] = 'hidden';
|
||||
} // Even if forceVisible is enabled, scrollbar itself should be hidden
|
||||
|
||||
|
||||
if (this.axis[axis].isOverflowing) {
|
||||
scrollbar.style.display = 'block';
|
||||
} else {
|
||||
scrollbar.style.display = 'none';
|
||||
}
|
||||
};
|
||||
|
||||
_proto.hideNativeScrollbar = function hideNativeScrollbar() {
|
||||
this.offsetEl.style[this.isRtl ? 'left' : 'right'] = this.axis.y.isOverflowing || this.axis.y.forceVisible ? "-" + (this.scrollbarWidth || this.minScrollbarWidth) + "px" : 0;
|
||||
this.offsetEl.style.bottom = this.axis.x.isOverflowing || this.axis.x.forceVisible ? "-" + (this.scrollbarWidth || this.minScrollbarWidth) + "px" : 0; // If floating scrollbar
|
||||
|
||||
if (!this.scrollbarWidth) {
|
||||
var paddingDirection = [this.isRtl ? 'paddingLeft' : 'paddingRight'];
|
||||
this.contentWrapperEl.style[paddingDirection] = this.axis.y.isOverflowing || this.axis.y.forceVisible ? this.minScrollbarWidth + "px" : 0;
|
||||
this.contentWrapperEl.style.paddingBottom = this.axis.x.isOverflowing || this.axis.x.forceVisible ? this.minScrollbarWidth + "px" : 0;
|
||||
}
|
||||
}
|
||||
/**
|
||||
* On scroll event handling
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.onMouseMoveForAxis = function onMouseMoveForAxis(axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
this.axis[axis].track.rect = this.axis[axis].track.el.getBoundingClientRect();
|
||||
this.axis[axis].scrollbar.rect = this.axis[axis].scrollbar.el.getBoundingClientRect();
|
||||
var isWithinScrollbarBoundsX = this.isWithinBounds(this.axis[axis].scrollbar.rect);
|
||||
|
||||
if (isWithinScrollbarBoundsX) {
|
||||
this.axis[axis].scrollbar.el.classList.add(this.classNames.hover);
|
||||
} else {
|
||||
this.axis[axis].scrollbar.el.classList.remove(this.classNames.hover);
|
||||
}
|
||||
|
||||
if (this.isWithinBounds(this.axis[axis].track.rect)) {
|
||||
this.showScrollbar(axis);
|
||||
this.axis[axis].track.el.classList.add(this.classNames.hover);
|
||||
} else {
|
||||
this.axis[axis].track.el.classList.remove(this.classNames.hover);
|
||||
}
|
||||
};
|
||||
|
||||
_proto.onMouseLeaveForAxis = function onMouseLeaveForAxis(axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
this.axis[axis].track.el.classList.remove(this.classNames.hover);
|
||||
this.axis[axis].scrollbar.el.classList.remove(this.classNames.hover);
|
||||
};
|
||||
|
||||
/**
|
||||
* Show scrollbar
|
||||
*/
|
||||
_proto.showScrollbar = function showScrollbar(axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
var scrollbar = this.axis[axis].scrollbar.el;
|
||||
|
||||
if (!this.axis[axis].isVisible) {
|
||||
scrollbar.classList.add(this.classNames.visible);
|
||||
this.axis[axis].isVisible = true;
|
||||
}
|
||||
|
||||
if (this.options.autoHide) {
|
||||
this.hideScrollbars();
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Hide Scrollbar
|
||||
*/
|
||||
;
|
||||
|
||||
/**
|
||||
* on scrollbar handle drag movement starts
|
||||
*/
|
||||
_proto.onDragStart = function onDragStart(e, axis) {
|
||||
if (axis === void 0) {
|
||||
axis = 'y';
|
||||
}
|
||||
|
||||
var scrollbar = this.axis[axis].scrollbar.el; // Measure how far the user's mouse is from the top of the scrollbar drag handle.
|
||||
|
||||
var eventOffset = axis === 'y' ? e.pageY : e.pageX;
|
||||
this.axis[axis].dragOffset = eventOffset - scrollbar.getBoundingClientRect()[this.axis[axis].offsetAttr];
|
||||
this.draggedAxis = axis;
|
||||
this.el.classList.add(this.classNames.dragging);
|
||||
document.addEventListener('mousemove', this.drag, true);
|
||||
document.addEventListener('mouseup', this.onEndDrag, true);
|
||||
|
||||
if (this.removePreventClickId === null) {
|
||||
document.addEventListener('click', this.preventClick, true);
|
||||
document.addEventListener('dblclick', this.preventClick, true);
|
||||
} else {
|
||||
window.clearTimeout(this.removePreventClickId);
|
||||
this.removePreventClickId = null;
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Drag scrollbar handle
|
||||
*/
|
||||
;
|
||||
|
||||
/**
|
||||
* Getter for content element
|
||||
*/
|
||||
_proto.getContentElement = function getContentElement() {
|
||||
return this.contentEl;
|
||||
}
|
||||
/**
|
||||
* Getter for original scrolling element
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.getScrollElement = function getScrollElement() {
|
||||
return this.contentWrapperEl;
|
||||
};
|
||||
|
||||
_proto.removeListeners = function removeListeners() {
|
||||
var _this4 = this;
|
||||
|
||||
// Event listeners
|
||||
if (this.options.autoHide) {
|
||||
this.el.removeEventListener('mouseenter', this.onMouseEnter);
|
||||
}
|
||||
|
||||
['mousedown', 'click', 'dblclick'].forEach(function (e) {
|
||||
_this4.el.removeEventListener(e, _this4.onPointerEvent, true);
|
||||
});
|
||||
['touchstart', 'touchend', 'touchmove'].forEach(function (e) {
|
||||
_this4.el.removeEventListener(e, _this4.onPointerEvent, {
|
||||
capture: true,
|
||||
passive: true
|
||||
});
|
||||
});
|
||||
this.el.removeEventListener('mousemove', this.onMouseMove);
|
||||
this.el.removeEventListener('mouseleave', this.onMouseLeave);
|
||||
this.contentWrapperEl.removeEventListener('scroll', this.onScroll);
|
||||
window.removeEventListener('resize', this.onWindowResize);
|
||||
this.mutationObserver && this.mutationObserver.disconnect();
|
||||
this.resizeObserver.disconnect(); // Cancel all debounced functions
|
||||
|
||||
this.recalculate.cancel();
|
||||
this.onMouseMove.cancel();
|
||||
this.hideScrollbars.cancel();
|
||||
this.onWindowResize.cancel();
|
||||
}
|
||||
/**
|
||||
* UnMount mutation observer and delete SimpleBar instance from DOM element
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.unMount = function unMount() {
|
||||
this.removeListeners();
|
||||
this.el.SimpleBar = null;
|
||||
}
|
||||
/**
|
||||
* Recursively walks up the parent nodes looking for this.el
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.isChildNode = function isChildNode(el) {
|
||||
if (el === null) return false;
|
||||
if (el === this.el) return true;
|
||||
return this.isChildNode(el.parentNode);
|
||||
}
|
||||
/**
|
||||
* Check if mouse is within bounds
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.isWithinBounds = function isWithinBounds(bbox) {
|
||||
return this.mouseX >= bbox.left && this.mouseX <= bbox.left + bbox.width && this.mouseY >= bbox.top && this.mouseY <= bbox.top + bbox.height;
|
||||
}
|
||||
/**
|
||||
* Find element children matches query
|
||||
*/
|
||||
;
|
||||
|
||||
_proto.findChild = function findChild(el, query) {
|
||||
var matches = el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector;
|
||||
return Array.prototype.filter.call(el.children, function (child) {
|
||||
return matches.call(child, query);
|
||||
})[0];
|
||||
};
|
||||
|
||||
return SimpleBar;
|
||||
}();
|
||||
/**
|
||||
* HTML API
|
||||
* Called only in a browser env.
|
||||
*/
|
||||
|
||||
|
||||
SimpleBar.defaultOptions = {
|
||||
autoHide: true,
|
||||
forceVisible: false,
|
||||
classNames: {
|
||||
contentEl: 'simplebar-content',
|
||||
contentWrapper: 'simplebar-content-wrapper',
|
||||
offset: 'simplebar-offset',
|
||||
mask: 'simplebar-mask',
|
||||
wrapper: 'simplebar-wrapper',
|
||||
placeholder: 'simplebar-placeholder',
|
||||
scrollbar: 'simplebar-scrollbar',
|
||||
track: 'simplebar-track',
|
||||
heightAutoObserverWrapperEl: 'simplebar-height-auto-observer-wrapper',
|
||||
heightAutoObserverEl: 'simplebar-height-auto-observer',
|
||||
visible: 'simplebar-visible',
|
||||
horizontal: 'simplebar-horizontal',
|
||||
vertical: 'simplebar-vertical',
|
||||
hover: 'simplebar-hover',
|
||||
dragging: 'simplebar-dragging'
|
||||
},
|
||||
scrollbarMinSize: 25,
|
||||
scrollbarMaxSize: 0,
|
||||
timeout: 1000
|
||||
};
|
||||
|
||||
if (canUseDOM) {
|
||||
SimpleBar.initHtmlApi();
|
||||
}
|
||||
|
||||
export default SimpleBar;
|
||||
//# sourceMappingURL=simplebar.esm.js.map
|
||||
@@ -0,0 +1 @@
|
||||
[data-simplebar]{position:relative;flex-direction:column;flex-wrap:wrap;justify-content:flex-start;align-content:flex-start;align-items:flex-start}.simplebar-wrapper{overflow:hidden;width:inherit;height:inherit;max-width:inherit;max-height:inherit}.simplebar-mask{direction:inherit;position:absolute;overflow:hidden;padding:0;margin:0;left:0;top:0;bottom:0;right:0;width:auto!important;height:auto!important;z-index:0}.simplebar-offset{direction:inherit!important;box-sizing:inherit!important;resize:none!important;position:absolute;top:0;left:0;bottom:0;right:0;padding:0;margin:0;-webkit-overflow-scrolling:touch}.simplebar-content-wrapper{direction:inherit;box-sizing:border-box!important;position:relative;display:block;height:100%;width:auto;visibility:visible;overflow:auto;max-width:100%;max-height:100%}.simplebar-content:after,.simplebar-content:before{content:' ';display:table}.simplebar-placeholder{max-height:100%;max-width:100%;width:100%;pointer-events:none}.simplebar-height-auto-observer-wrapper{box-sizing:inherit!important;height:100%;width:100%;max-width:1px;position:relative;float:left;max-height:1px;overflow:hidden;z-index:-1;padding:0;margin:0;pointer-events:none;flex-grow:inherit;flex-shrink:0;flex-basis:0}.simplebar-height-auto-observer{box-sizing:inherit;display:block;opacity:0;position:absolute;top:0;left:0;height:1000%;width:1000%;min-height:1px;min-width:1px;overflow:hidden;pointer-events:none;z-index:-1}.simplebar-track{z-index:1;position:absolute;right:0;bottom:0;pointer-events:none;overflow:hidden}[data-simplebar].simplebar-dragging .simplebar-content{pointer-events:none;user-select:none;-webkit-user-select:none}[data-simplebar].simplebar-dragging .simplebar-track{pointer-events:all}.simplebar-scrollbar{position:absolute;right:2px;width:7px;min-height:10px}.simplebar-scrollbar:before{position:absolute;content:'';background:#000;border-radius:7px;left:0;right:0;opacity:0;transition:opacity .2s linear}.simplebar-track .simplebar-scrollbar.simplebar-visible:before{opacity:.5;transition:opacity 0s linear}.simplebar-track.simplebar-vertical{top:0;width:11px}.simplebar-track.simplebar-vertical .simplebar-scrollbar:before{top:2px;bottom:2px}.simplebar-track.simplebar-horizontal{left:0;height:11px}.simplebar-track.simplebar-horizontal .simplebar-scrollbar:before{height:100%;left:2px;right:2px}.simplebar-track.simplebar-horizontal .simplebar-scrollbar{right:auto;left:0;top:2px;height:7px;min-height:0;min-width:10px;width:auto}[data-simplebar-direction=rtl] .simplebar-track.simplebar-vertical{right:auto;left:0}.hs-dummy-scrollbar-size{direction:rtl;position:fixed;opacity:0;visibility:hidden;height:500px;width:500px;overflow-y:hidden;overflow-x:scroll}
|
||||
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user