201 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			201 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
/**
 | 
						|
 * simplebar - v6.2.5
 | 
						|
 * Scrollbars, simpler.
 | 
						|
 * https://grsmto.github.io/simplebar/
 | 
						|
 *
 | 
						|
 * Made by Adrien Denat from a fork by Jonathan Nicol
 | 
						|
 * Under MIT License
 | 
						|
 */
 | 
						|
 | 
						|
import canUseDOM from 'can-use-dom';
 | 
						|
import SimpleBarCore from 'simplebar-core';
 | 
						|
 | 
						|
/******************************************************************************
 | 
						|
Copyright (c) Microsoft Corporation.
 | 
						|
 | 
						|
Permission to use, copy, modify, and/or distribute this software for any
 | 
						|
purpose with or without fee is hereby granted.
 | 
						|
 | 
						|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
 | 
						|
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
 | 
						|
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
 | 
						|
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
 | 
						|
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
 | 
						|
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
 | 
						|
PERFORMANCE OF THIS SOFTWARE.
 | 
						|
***************************************************************************** */
 | 
						|
/* global Reflect, Promise */
 | 
						|
 | 
						|
var extendStatics = function(d, b) {
 | 
						|
    extendStatics = Object.setPrototypeOf ||
 | 
						|
        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
 | 
						|
        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
 | 
						|
    return extendStatics(d, b);
 | 
						|
};
 | 
						|
 | 
						|
function __extends(d, b) {
 | 
						|
    if (typeof b !== "function" && b !== null)
 | 
						|
        throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
 | 
						|
    extendStatics(d, b);
 | 
						|
    function __() { this.constructor = d; }
 | 
						|
    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
 | 
						|
}
 | 
						|
 | 
						|
var _a = SimpleBarCore.helpers, getOptions = _a.getOptions, addClasses = _a.addClasses;
 | 
						|
var SimpleBar = /** @class */ (function (_super) {
 | 
						|
    __extends(SimpleBar, _super);
 | 
						|
    function SimpleBar() {
 | 
						|
        var args = [];
 | 
						|
        for (var _i = 0; _i < arguments.length; _i++) {
 | 
						|
            args[_i] = arguments[_i];
 | 
						|
        }
 | 
						|
        var _this = _super.apply(this, args) || this;
 | 
						|
        // // Save a reference to the instance, so we know this DOM node has already been instancied
 | 
						|
        SimpleBar.instances.set(args[0], _this);
 | 
						|
        return _this;
 | 
						|
    }
 | 
						|
    SimpleBar.initDOMLoadedElements = function () {
 | 
						|
        document.removeEventListener('DOMContentLoaded', this.initDOMLoadedElements);
 | 
						|
        window.removeEventListener('load', this.initDOMLoadedElements);
 | 
						|
        Array.prototype.forEach.call(document.querySelectorAll('[data-simplebar]'), function (el) {
 | 
						|
            if (el.getAttribute('data-simplebar') !== 'init' &&
 | 
						|
                !SimpleBar.instances.has(el))
 | 
						|
                new SimpleBar(el, getOptions(el.attributes));
 | 
						|
        });
 | 
						|
    };
 | 
						|
    SimpleBar.removeObserver = function () {
 | 
						|
        var _a;
 | 
						|
        (_a = SimpleBar.globalObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
 | 
						|
    };
 | 
						|
    SimpleBar.prototype.initDOM = function () {
 | 
						|
        var _this = this;
 | 
						|
        var _a, _b, _c;
 | 
						|
        // make sure this element doesn't have the elements yet
 | 
						|
        if (!Array.prototype.filter.call(this.el.children, function (child) {
 | 
						|
            return child.classList.contains(_this.classNames.wrapper);
 | 
						|
        }).length) {
 | 
						|
            // 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');
 | 
						|
            addClasses(this.wrapperEl, this.classNames.wrapper);
 | 
						|
            addClasses(this.contentWrapperEl, this.classNames.contentWrapper);
 | 
						|
            addClasses(this.offsetEl, this.classNames.offset);
 | 
						|
            addClasses(this.maskEl, this.classNames.mask);
 | 
						|
            addClasses(this.contentEl, this.classNames.contentEl);
 | 
						|
            addClasses(this.placeholderEl, this.classNames.placeholder);
 | 
						|
            addClasses(this.heightAutoObserverWrapperEl, this.classNames.heightAutoObserverWrapperEl);
 | 
						|
            addClasses(this.heightAutoObserverEl, 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);
 | 
						|
            (_a = this.contentWrapperEl) === null || _a === void 0 ? void 0 : _a.setAttribute('tabindex', '0');
 | 
						|
            (_b = this.contentWrapperEl) === null || _b === void 0 ? void 0 : _b.setAttribute('role', 'region');
 | 
						|
            (_c = this.contentWrapperEl) === null || _c === void 0 ? void 0 : _c.setAttribute('aria-label', this.options.ariaLabel);
 | 
						|
        }
 | 
						|
        if (!this.axis.x.track.el || !this.axis.y.track.el) {
 | 
						|
            var track = document.createElement('div');
 | 
						|
            var scrollbar = document.createElement('div');
 | 
						|
            addClasses(track, this.classNames.track);
 | 
						|
            addClasses(scrollbar, this.classNames.scrollbar);
 | 
						|
            track.appendChild(scrollbar);
 | 
						|
            this.axis.x.track.el = track.cloneNode(true);
 | 
						|
            addClasses(this.axis.x.track.el, this.classNames.horizontal);
 | 
						|
            this.axis.y.track.el = track.cloneNode(true);
 | 
						|
            addClasses(this.axis.y.track.el, this.classNames.vertical);
 | 
						|
            this.el.appendChild(this.axis.x.track.el);
 | 
						|
            this.el.appendChild(this.axis.y.track.el);
 | 
						|
        }
 | 
						|
        SimpleBarCore.prototype.initDOM.call(this);
 | 
						|
        this.el.setAttribute('data-simplebar', 'init');
 | 
						|
    };
 | 
						|
    SimpleBar.prototype.unMount = function () {
 | 
						|
        SimpleBarCore.prototype.unMount.call(this);
 | 
						|
        SimpleBar.instances["delete"](this.el);
 | 
						|
    };
 | 
						|
    SimpleBar.initHtmlApi = function () {
 | 
						|
        this.initDOMLoadedElements = this.initDOMLoadedElements.bind(this);
 | 
						|
        // MutationObserver is IE11+
 | 
						|
        if (typeof MutationObserver !== 'undefined') {
 | 
						|
            // Mutation observer to observe dynamically added elements
 | 
						|
            this.globalObserver = new MutationObserver(SimpleBar.handleMutations);
 | 
						|
            this.globalObserver.observe(document, { childList: true, subtree: true });
 | 
						|
        }
 | 
						|
        // Taken from jQuery `ready` function
 | 
						|
        // Instantiate elements already present on the page
 | 
						|
        if (document.readyState === 'complete' || // @ts-ignore: IE specific
 | 
						|
            (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);
 | 
						|
        }
 | 
						|
    };
 | 
						|
    SimpleBar.handleMutations = function (mutations) {
 | 
						|
        mutations.forEach(function (mutation) {
 | 
						|
            mutation.addedNodes.forEach(function (addedNode) {
 | 
						|
                if (addedNode.nodeType === 1) {
 | 
						|
                    if (addedNode.hasAttribute('data-simplebar')) {
 | 
						|
                        !SimpleBar.instances.has(addedNode) &&
 | 
						|
                            document.documentElement.contains(addedNode) &&
 | 
						|
                            new SimpleBar(addedNode, getOptions(addedNode.attributes));
 | 
						|
                    }
 | 
						|
                    else {
 | 
						|
                        addedNode
 | 
						|
                            .querySelectorAll('[data-simplebar]')
 | 
						|
                            .forEach(function (el) {
 | 
						|
                            if (el.getAttribute('data-simplebar') !== 'init' &&
 | 
						|
                                !SimpleBar.instances.has(el) &&
 | 
						|
                                document.documentElement.contains(el))
 | 
						|
                                new SimpleBar(el, getOptions(el.attributes));
 | 
						|
                        });
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            });
 | 
						|
            mutation.removedNodes.forEach(function (removedNode) {
 | 
						|
                if (removedNode.nodeType === 1) {
 | 
						|
                    if (removedNode.getAttribute('data-simplebar') === 'init') {
 | 
						|
                        SimpleBar.instances.has(removedNode) &&
 | 
						|
                            !document.documentElement.contains(removedNode) &&
 | 
						|
                            SimpleBar.instances.get(removedNode).unMount();
 | 
						|
                    }
 | 
						|
                    else {
 | 
						|
                        Array.prototype.forEach.call(removedNode.querySelectorAll('[data-simplebar="init"]'), function (el) {
 | 
						|
                            SimpleBar.instances.has(el) &&
 | 
						|
                                !document.documentElement.contains(el) &&
 | 
						|
                                SimpleBar.instances.get(el).unMount();
 | 
						|
                        });
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            });
 | 
						|
        });
 | 
						|
    };
 | 
						|
    SimpleBar.instances = new WeakMap();
 | 
						|
    return SimpleBar;
 | 
						|
}(SimpleBarCore));
 | 
						|
/**
 | 
						|
 * HTML API
 | 
						|
 * Called only in a browser env.
 | 
						|
 */
 | 
						|
if (canUseDOM) {
 | 
						|
    SimpleBar.initHtmlApi();
 | 
						|
}
 | 
						|
 | 
						|
export { SimpleBar as default };
 | 
						|
//# sourceMappingURL=index.mjs.map
 |