bootstrap/js/src/base-component.js

69 lines
1.6 KiB
JavaScript
Raw Normal View History

2019-09-04 22:58:29 +08:00
/**
* --------------------------------------------------------------------------
* Bootstrap (v5.0.0): base-component.js
2019-09-04 22:58:29 +08:00
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
* --------------------------------------------------------------------------
*/
import Data from './dom/data'
import {
emulateTransitionEnd,
execute,
getTransitionDurationFromElement
} from './util/index'
import EventHandler from './dom/event-handler'
2019-09-04 22:58:29 +08:00
/**
* ------------------------------------------------------------------------
* Constants
* ------------------------------------------------------------------------
*/
const VERSION = '5.0.0'
2019-09-04 22:58:29 +08:00
class BaseComponent {
constructor(element) {
element = typeof element === 'string' ? document.querySelector(element) : element
2019-09-04 22:58:29 +08:00
if (!element) {
return
}
this._element = element
Data.set(this._element, this.constructor.DATA_KEY, this)
2019-09-04 22:58:29 +08:00
}
2020-11-20 18:13:11 +08:00
dispose() {
Data.remove(this._element, this.constructor.DATA_KEY)
EventHandler.off(this._element, `.${this.constructor.DATA_KEY}`)
Object.getOwnPropertyNames(this).forEach(propertyName => {
this[propertyName] = null
})
2020-11-20 18:13:11 +08:00
}
_queueCallback(callback, element, isAnimated = true) {
if (!isAnimated) {
execute(callback)
return
}
const transitionDuration = getTransitionDurationFromElement(element)
EventHandler.one(element, 'transitionend', () => execute(callback))
emulateTransitionEnd(element, transitionDuration)
}
2019-09-04 22:58:29 +08:00
/** Static */
static getInstance(element) {
return Data.get(element, this.DATA_KEY)
2019-09-04 22:58:29 +08:00
}
static get VERSION() {
return VERSION
}
2019-09-04 22:58:29 +08:00
}
export default BaseComponent