2018-11-13 08:41:12 +02:00
/ * !
2021-05-13 19:22:20 +03:00
* Bootstrap scrollspy . js v5 . 0.1 ( https : //getbootstrap.com/)
2021-02-10 18:14:51 +02:00
* Copyright 2011 - 2021 The Bootstrap Authors ( https : //github.com/twbs/bootstrap/graphs/contributors)
2020-06-16 21:50:01 +03:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
2018-11-13 08:41:12 +02:00
* /
2018-07-23 17:51:14 -07:00
( function ( global , factory ) {
2021-05-13 19:22:20 +03:00
typeof exports === 'object' && typeof module !== 'undefined' ? module . exports = factory ( require ( './dom/selector-engine.js' ) , require ( './dom/event-handler.js' ) , require ( './dom/manipulator.js' ) , require ( './base-component.js' ) ) :
typeof define === 'function' && define . amd ? define ( [ './dom/selector-engine' , './dom/event-handler' , './dom/manipulator' , './base-component' ] , factory ) :
( global = typeof globalThis !== 'undefined' ? globalThis : global || self , global . ScrollSpy = factory ( global . SelectorEngine , global . EventHandler , global . Manipulator , global . Base ) ) ;
} ( this , ( function ( SelectorEngine , EventHandler , Manipulator , BaseComponent ) { 'use strict' ;
2018-07-23 17:51:14 -07:00
2020-09-14 18:12:06 +03:00
function _interopDefaultLegacy ( e ) { return e && typeof e === 'object' && 'default' in e ? e : { 'default' : e } ; }
2021-05-13 19:22:20 +03:00
var SelectorEngine _ _default = /*#__PURE__*/ _interopDefaultLegacy ( SelectorEngine ) ;
2020-09-14 18:12:06 +03:00
var EventHandler _ _default = /*#__PURE__*/ _interopDefaultLegacy ( EventHandler ) ;
var Manipulator _ _default = /*#__PURE__*/ _interopDefaultLegacy ( Manipulator ) ;
2021-02-10 18:14:51 +02:00
var BaseComponent _ _default = /*#__PURE__*/ _interopDefaultLegacy ( BaseComponent ) ;
2019-03-01 18:31:34 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2021-05-13 19:22:20 +03:00
* Bootstrap ( v5 . 0.1 ) : util / index . js
2020-06-16 21:50:01 +03:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
2019-03-01 18:31:34 +02:00
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2021-05-13 19:22:20 +03:00
2021-03-23 18:26:54 +02:00
const MAX _UID = 1000000 ;
2019-03-01 18:31:34 +02:00
2021-03-23 18:26:54 +02:00
const toType = obj => {
2020-03-28 12:29:08 +02:00
if ( obj === null || obj === undefined ) {
2021-03-23 18:26:54 +02:00
return ` ${ obj } ` ;
2020-03-28 12:29:08 +02:00
}
2019-03-01 18:31:34 +02:00
return { } . toString . call ( obj ) . match ( /\s([a-z]+)/i ) [ 1 ] . toLowerCase ( ) ;
} ;
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Public Util Api
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2021-03-23 18:26:54 +02:00
const getUID = prefix => {
2019-03-01 18:31:34 +02:00
do {
2020-06-13 15:40:28 -07:00
prefix += Math . floor ( Math . random ( ) * MAX _UID ) ;
2019-03-01 18:31:34 +02:00
} while ( document . getElementById ( prefix ) ) ;
return prefix ;
} ;
2021-03-23 18:26:54 +02:00
const getSelector = element => {
let selector = element . getAttribute ( 'data-bs-target' ) ;
2019-03-01 18:31:34 +02:00
if ( ! selector || selector === '#' ) {
2021-03-23 18:26:54 +02:00
let hrefAttr = element . getAttribute ( 'href' ) ; // The only valid content that could double as a selector are IDs or classes,
2021-02-10 18:14:51 +02:00
// so everything starting with `#` or `.`. If a "real" URL is used as the selector,
// `document.querySelector` will rightfully complain it is invalid.
// See https://github.com/twbs/bootstrap/issues/32273
if ( ! hrefAttr || ! hrefAttr . includes ( '#' ) && ! hrefAttr . startsWith ( '.' ) ) {
return null ;
} // Just in case some CMS puts out a full URL with the anchor appended
if ( hrefAttr . includes ( '#' ) && ! hrefAttr . startsWith ( '#' ) ) {
2021-05-05 22:32:12 +03:00
hrefAttr = ` # ${ hrefAttr . split ( '#' ) [ 1 ] } ` ;
2021-02-10 18:14:51 +02:00
}
2019-08-27 16:03:21 +03:00
selector = hrefAttr && hrefAttr !== '#' ? hrefAttr . trim ( ) : null ;
2019-03-01 18:31:34 +02:00
}
2019-08-27 16:03:21 +03:00
return selector ;
} ;
2021-03-23 18:26:54 +02:00
const getSelectorFromElement = element => {
const selector = getSelector ( element ) ;
2019-08-27 16:03:21 +03:00
if ( selector ) {
2019-03-01 18:31:34 +02:00
return document . querySelector ( selector ) ? selector : null ;
}
2019-08-27 16:03:21 +03:00
return null ;
2019-03-01 18:31:34 +02:00
} ;
2021-05-13 19:22:20 +03:00
const isElement = obj => {
if ( ! obj || typeof obj !== 'object' ) {
return false ;
}
if ( typeof obj . jquery !== 'undefined' ) {
obj = obj [ 0 ] ;
}
return typeof obj . nodeType !== 'undefined' ;
} ;
2019-03-01 18:31:34 +02:00
2021-03-23 18:26:54 +02:00
const typeCheckConfig = ( componentName , config , configTypes ) => {
Object . keys ( configTypes ) . forEach ( property => {
const expectedTypes = configTypes [ property ] ;
const value = config [ property ] ;
const valueType = value && isElement ( value ) ? 'element' : toType ( value ) ;
2019-03-01 18:31:34 +02:00
if ( ! new RegExp ( expectedTypes ) . test ( valueType ) ) {
2021-05-05 22:32:12 +03:00
throw new TypeError ( ` ${ componentName . toUpperCase ( ) } : Option " ${ property } " provided type " ${ valueType } " but expected type " ${ expectedTypes } ". ` ) ;
2019-03-01 18:31:34 +02:00
}
} ) ;
} ;
2021-03-23 18:26:54 +02:00
const getjQuery = ( ) => {
const {
jQuery
} = window ;
2019-08-27 16:03:21 +03:00
2020-11-23 15:17:16 +02:00
if ( jQuery && ! document . body . hasAttribute ( 'data-bs-no-jquery' ) ) {
2019-08-27 16:03:21 +03:00
return jQuery ;
}
return null ;
} ;
2021-03-23 18:26:54 +02:00
const onDOMContentLoaded = callback => {
2020-11-11 19:07:37 +02:00
if ( document . readyState === 'loading' ) {
document . addEventListener ( 'DOMContentLoaded' , callback ) ;
} else {
callback ( ) ;
}
} ;
2021-05-13 19:22:20 +03:00
const defineJQueryPlugin = plugin => {
2021-03-23 18:26:54 +02:00
onDOMContentLoaded ( ( ) => {
const $ = getjQuery ( ) ;
2021-02-10 18:14:51 +02:00
/* istanbul ignore if */
2020-12-03 16:18:59 +02:00
2021-02-10 18:14:51 +02:00
if ( $ ) {
2021-05-13 19:22:20 +03:00
const name = plugin . NAME ;
2021-03-23 18:26:54 +02:00
const JQUERY _NO _CONFLICT = $ . fn [ name ] ;
2021-02-10 18:14:51 +02:00
$ . fn [ name ] = plugin . jQueryInterface ;
$ . fn [ name ] . Constructor = plugin ;
2020-12-03 16:18:59 +02:00
2021-03-23 18:26:54 +02:00
$ . fn [ name ] . noConflict = ( ) => {
2021-02-10 18:14:51 +02:00
$ . fn [ name ] = JQUERY _NO _CONFLICT ;
return plugin . jQueryInterface ;
} ;
2020-12-03 16:18:59 +02:00
}
2021-02-10 18:14:51 +02:00
} ) ;
} ;
2020-12-03 16:18:59 +02:00
2021-03-23 18:26:54 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2021-05-13 19:22:20 +03:00
* Bootstrap ( v5 . 0.1 ) : scrollspy . js
2021-03-23 18:26:54 +02:00
* Licensed under MIT ( https : //github.com/twbs/bootstrap/blob/main/LICENSE)
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2020-12-03 16:18:59 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Constants
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2021-03-23 18:26:54 +02:00
const NAME = 'scrollspy' ;
const DATA _KEY = 'bs.scrollspy' ;
const EVENT _KEY = ` . ${ DATA _KEY } ` ;
const DATA _API _KEY = '.data-api' ;
const Default = {
2018-11-13 08:41:12 +02:00
offset : 10 ,
method : 'auto' ,
target : ''
} ;
2021-03-23 18:26:54 +02:00
const DefaultType = {
2018-11-13 08:41:12 +02:00
offset : 'number' ,
method : 'string' ,
target : '(string|element)'
} ;
2021-03-23 18:26:54 +02:00
const EVENT _ACTIVATE = ` activate ${ EVENT _KEY } ` ;
const EVENT _SCROLL = ` scroll ${ EVENT _KEY } ` ;
const EVENT _LOAD _DATA _API = ` load ${ EVENT _KEY } ${ DATA _API _KEY } ` ;
const CLASS _NAME _DROPDOWN _ITEM = 'dropdown-item' ;
const CLASS _NAME _ACTIVE = 'active' ;
const SELECTOR _DATA _SPY = '[data-bs-spy="scroll"]' ;
const SELECTOR _NAV _LIST _GROUP = '.nav, .list-group' ;
const SELECTOR _NAV _LINKS = '.nav-link' ;
const SELECTOR _NAV _ITEMS = '.nav-item' ;
const SELECTOR _LIST _ITEMS = '.list-group-item' ;
const SELECTOR _DROPDOWN = '.dropdown' ;
const SELECTOR _DROPDOWN _TOGGLE = '.dropdown-toggle' ;
const METHOD _OFFSET = 'offset' ;
const METHOD _POSITION = 'position' ;
2019-10-08 09:39:10 +03:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Class Definition
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2018-11-13 08:41:12 +02:00
2021-03-23 18:26:54 +02:00
class ScrollSpy extends BaseComponent _ _default [ 'default' ] {
constructor ( element , config ) {
super ( element ) ;
this . _scrollElement = this . _element . tagName === 'BODY' ? window : this . _element ;
this . _config = this . _getConfig ( config ) ;
this . _selector = ` ${ this . _config . target } ${ SELECTOR _NAV _LINKS } , ${ this . _config . target } ${ SELECTOR _LIST _ITEMS } , ${ this . _config . target } . ${ CLASS _NAME _DROPDOWN _ITEM } ` ;
this . _offsets = [ ] ;
this . _targets = [ ] ;
this . _activeTarget = null ;
this . _scrollHeight = 0 ;
EventHandler _ _default [ 'default' ] . on ( this . _scrollElement , EVENT _SCROLL , ( ) => this . _process ( ) ) ;
this . refresh ( ) ;
2019-03-01 18:31:34 +02:00
2021-03-23 18:26:54 +02:00
this . _process ( ) ;
2018-11-13 08:41:12 +02:00
} // Getters
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
static get Default ( ) {
return Default ;
}
2021-05-13 19:22:20 +03:00
static get NAME ( ) {
return NAME ;
2021-03-23 18:26:54 +02:00
} // Public
2015-05-11 12:05:35 -07:00
2017-09-30 14:28:03 -07:00
2021-03-23 18:26:54 +02:00
refresh ( ) {
const autoMethod = this . _scrollElement === this . _scrollElement . window ? METHOD _OFFSET : METHOD _POSITION ;
const offsetMethod = this . _config . method === 'auto' ? autoMethod : this . _config . method ;
const offsetBase = offsetMethod === METHOD _POSITION ? this . _getScrollTop ( ) : 0 ;
2018-11-13 08:41:12 +02:00
this . _offsets = [ ] ;
this . _targets = [ ] ;
this . _scrollHeight = this . _getScrollHeight ( ) ;
2021-03-23 18:26:54 +02:00
const targets = SelectorEngine _ _default [ 'default' ] . find ( this . _selector ) ;
targets . map ( element => {
const targetSelector = getSelectorFromElement ( element ) ;
const target = targetSelector ? SelectorEngine _ _default [ 'default' ] . findOne ( targetSelector ) : null ;
2015-05-13 12:55:11 -07:00
2018-11-13 08:41:12 +02:00
if ( target ) {
2021-03-23 18:26:54 +02:00
const targetBCR = target . getBoundingClientRect ( ) ;
2015-05-11 12:05:35 -07:00
2018-11-13 08:41:12 +02:00
if ( targetBCR . width || targetBCR . height ) {
2020-09-14 18:12:06 +03:00
return [ Manipulator _ _default [ 'default' ] [ offsetMethod ] ( target ) . top + offsetBase , targetSelector ] ;
2017-09-30 14:28:03 -07:00
}
2018-11-13 08:41:12 +02:00
}
2015-05-11 12:05:35 -07:00
2018-11-13 08:41:12 +02:00
return null ;
2021-03-23 18:26:54 +02:00
} ) . filter ( item => item ) . sort ( ( a , b ) => a [ 0 ] - b [ 0 ] ) . forEach ( item => {
this . _offsets . push ( item [ 0 ] ) ;
2016-10-09 17:26:51 -07:00
2021-03-23 18:26:54 +02:00
this . _targets . push ( item [ 1 ] ) ;
} ) ;
}
2020-12-03 16:18:59 +02:00
2021-03-23 18:26:54 +02:00
dispose ( ) {
2020-09-14 18:12:06 +03:00
EventHandler _ _default [ 'default' ] . off ( this . _scrollElement , EVENT _KEY ) ;
2021-05-13 19:22:20 +03:00
super . dispose ( ) ;
2019-01-04 08:29:45 -08:00
} // Private
2018-11-13 08:41:12 +02:00
2021-03-23 18:26:54 +02:00
_getConfig ( config ) {
config = { ... Default ,
2021-05-05 22:32:12 +03:00
... Manipulator _ _default [ 'default' ] . getDataAttributes ( this . _element ) ,
2021-03-23 18:26:54 +02:00
... ( typeof config === 'object' && config ? config : { } )
} ;
2018-11-13 08:41:12 +02:00
2020-05-13 21:53:43 +03:00
if ( typeof config . target !== 'string' && isElement ( config . target ) ) {
2021-03-23 18:26:54 +02:00
let {
id
} = config . target ;
2018-11-13 08:41:12 +02:00
if ( ! id ) {
2019-03-01 18:31:34 +02:00
id = getUID ( NAME ) ;
config . target . id = id ;
2018-07-23 17:51:14 -07:00
}
2016-01-09 16:40:51 +08:00
2021-03-23 18:26:54 +02:00
config . target = ` # ${ id } ` ;
2018-11-13 08:41:12 +02:00
}
2016-10-09 17:26:51 -07:00
2019-03-01 18:31:34 +02:00
typeCheckConfig ( NAME , config , DefaultType ) ;
2018-11-13 08:41:12 +02:00
return config ;
2021-03-23 18:26:54 +02:00
}
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
_getScrollTop ( ) {
2018-11-13 08:41:12 +02:00
return this . _scrollElement === window ? this . _scrollElement . pageYOffset : this . _scrollElement . scrollTop ;
2021-03-23 18:26:54 +02:00
}
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
_getScrollHeight ( ) {
2018-11-13 08:41:12 +02:00
return this . _scrollElement . scrollHeight || Math . max ( document . body . scrollHeight , document . documentElement . scrollHeight ) ;
2021-03-23 18:26:54 +02:00
}
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
_getOffsetHeight ( ) {
2018-11-13 08:41:12 +02:00
return this . _scrollElement === window ? window . innerHeight : this . _scrollElement . getBoundingClientRect ( ) . height ;
2021-03-23 18:26:54 +02:00
}
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
_process ( ) {
const scrollTop = this . _getScrollTop ( ) + this . _config . offset ;
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
const scrollHeight = this . _getScrollHeight ( ) ;
2017-09-30 14:28:03 -07:00
2021-03-23 18:26:54 +02:00
const maxScroll = this . _config . offset + scrollHeight - this . _getOffsetHeight ( ) ;
2017-09-30 14:28:03 -07:00
2018-11-13 08:41:12 +02:00
if ( this . _scrollHeight !== scrollHeight ) {
this . refresh ( ) ;
}
2017-09-30 14:28:03 -07:00
2018-11-13 08:41:12 +02:00
if ( scrollTop >= maxScroll ) {
2021-03-23 18:26:54 +02:00
const target = this . _targets [ this . _targets . length - 1 ] ;
2015-05-11 12:05:35 -07:00
2018-11-13 08:41:12 +02:00
if ( this . _activeTarget !== target ) {
this . _activate ( target ) ;
2018-07-23 17:51:14 -07:00
}
2015-05-11 12:05:35 -07:00
2018-11-13 08:41:12 +02:00
return ;
}
2018-07-23 17:51:14 -07:00
2018-11-13 08:41:12 +02:00
if ( this . _activeTarget && scrollTop < this . _offsets [ 0 ] && this . _offsets [ 0 ] > 0 ) {
this . _activeTarget = null ;
2017-09-30 14:28:03 -07:00
2018-11-13 08:41:12 +02:00
this . _clear ( ) ;
2018-06-21 22:55:23 -07:00
2018-11-13 08:41:12 +02:00
return ;
}
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
for ( let i = this . _offsets . length ; i -- ; ) {
const isActiveTarget = this . _activeTarget !== this . _targets [ i ] && scrollTop >= this . _offsets [ i ] && ( typeof this . _offsets [ i + 1 ] === 'undefined' || scrollTop < this . _offsets [ i + 1 ] ) ;
2017-09-30 14:28:03 -07:00
2018-11-13 08:41:12 +02:00
if ( isActiveTarget ) {
this . _activate ( this . _targets [ i ] ) ;
}
}
2021-03-23 18:26:54 +02:00
}
2017-09-30 14:28:03 -07:00
2021-03-23 18:26:54 +02:00
_activate ( target ) {
2018-11-13 08:41:12 +02:00
this . _activeTarget = target ;
2017-09-30 14:28:03 -07:00
2018-11-13 08:41:12 +02:00
this . _clear ( ) ;
2017-09-30 14:28:03 -07:00
2021-03-23 18:26:54 +02:00
const queries = this . _selector . split ( ',' ) . map ( selector => ` ${ selector } [data-bs-target=" ${ target } "], ${ selector } [href=" ${ target } "] ` ) ;
2018-11-24 18:22:59 +02:00
2021-03-23 18:26:54 +02:00
const link = SelectorEngine _ _default [ 'default' ] . findOne ( queries . join ( ',' ) ) ;
2017-09-30 14:28:03 -07:00
2020-03-28 12:29:08 +02:00
if ( link . classList . contains ( CLASS _NAME _DROPDOWN _ITEM ) ) {
2020-09-14 18:12:06 +03:00
SelectorEngine _ _default [ 'default' ] . findOne ( SELECTOR _DROPDOWN _TOGGLE , link . closest ( SELECTOR _DROPDOWN ) ) . classList . add ( CLASS _NAME _ACTIVE ) ;
2020-03-28 12:29:08 +02:00
link . classList . add ( CLASS _NAME _ACTIVE ) ;
2018-11-13 08:41:12 +02:00
} else {
// Set triggered link as active
2020-03-28 12:29:08 +02:00
link . classList . add ( CLASS _NAME _ACTIVE ) ;
2021-03-23 18:26:54 +02:00
SelectorEngine _ _default [ 'default' ] . parents ( link , SELECTOR _NAV _LIST _GROUP ) . forEach ( listGroup => {
2019-03-01 18:31:34 +02:00
// Set triggered links parents as active
// With both <ul> and <nav> markup a parent is the previous sibling of any nav ancestor
2021-03-23 18:26:54 +02:00
SelectorEngine _ _default [ 'default' ] . prev ( listGroup , ` ${ SELECTOR _NAV _LINKS } , ${ SELECTOR _LIST _ITEMS } ` ) . forEach ( item => item . classList . add ( CLASS _NAME _ACTIVE ) ) ; // Handle special case when .nav-link is inside .nav-item
SelectorEngine _ _default [ 'default' ] . prev ( listGroup , SELECTOR _NAV _ITEMS ) . forEach ( navItem => {
SelectorEngine _ _default [ 'default' ] . children ( navItem , SELECTOR _NAV _LINKS ) . forEach ( item => item . classList . add ( CLASS _NAME _ACTIVE ) ) ;
2019-03-01 18:31:34 +02:00
} ) ;
} ) ;
2018-11-13 08:41:12 +02:00
}
2016-10-09 17:26:51 -07:00
2020-09-14 18:12:06 +03:00
EventHandler _ _default [ 'default' ] . trigger ( this . _scrollElement , EVENT _ACTIVATE , {
2018-11-13 08:41:12 +02:00
relatedTarget : target
} ) ;
2021-03-23 18:26:54 +02:00
}
2016-10-09 17:26:51 -07:00
2021-03-23 18:26:54 +02:00
_clear ( ) {
SelectorEngine _ _default [ 'default' ] . find ( this . _selector ) . filter ( node => node . classList . contains ( CLASS _NAME _ACTIVE ) ) . forEach ( node => node . classList . remove ( CLASS _NAME _ACTIVE ) ) ;
2019-01-04 08:29:45 -08:00
} // Static
2017-09-30 14:28:03 -07:00
2021-03-23 18:26:54 +02:00
static jQueryInterface ( config ) {
2018-11-13 08:41:12 +02:00
return this . each ( function ( ) {
2021-05-05 22:32:12 +03:00
const data = ScrollSpy . getInstance ( this ) || new ScrollSpy ( this , typeof config === 'object' ? config : { } ) ;
2017-09-30 14:28:03 -07:00
2021-05-05 22:32:12 +03:00
if ( typeof config !== 'string' ) {
return ;
2018-11-13 08:41:12 +02:00
}
2018-07-23 17:51:14 -07:00
2021-05-05 22:32:12 +03:00
if ( typeof data [ config ] === 'undefined' ) {
throw new TypeError ( ` No method named " ${ config } " ` ) ;
2017-09-30 14:28:03 -07:00
}
2021-05-05 22:32:12 +03:00
data [ config ] ( ) ;
2018-11-13 08:41:12 +02:00
} ) ;
2021-03-23 18:26:54 +02:00
}
2015-05-11 12:05:35 -07:00
2021-03-23 18:26:54 +02:00
}
2018-11-13 08:41:12 +02:00
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* Data Api implementation
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* /
2015-05-11 12:05:35 -07:00
2017-09-30 14:28:03 -07:00
2021-03-23 18:26:54 +02:00
EventHandler _ _default [ 'default' ] . on ( window , EVENT _LOAD _DATA _API , ( ) => {
2021-05-05 22:32:12 +03:00
SelectorEngine _ _default [ 'default' ] . find ( SELECTOR _DATA _SPY ) . forEach ( spy => new ScrollSpy ( spy ) ) ;
2018-11-13 08:41:12 +02:00
} ) ;
/ * *
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
* jQuery
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
2020-11-11 19:07:37 +02:00
* add . ScrollSpy to jQuery only if jQuery is present
2018-11-13 08:41:12 +02:00
* /
2015-05-11 12:05:35 -07:00
2021-05-13 19:22:20 +03:00
defineJQueryPlugin ( ScrollSpy ) ;
2015-05-11 12:05:35 -07:00
return ScrollSpy ;
2018-07-23 17:51:14 -07:00
2019-11-08 10:11:23 +02:00
} ) ) ) ;
2018-07-23 17:51:14 -07:00
//# sourceMappingURL=scrollspy.js.map