mirror of
https://github.com/twbs/bootstrap.git
synced 2024-12-12 00:08:59 +01:00
169 lines
3.4 KiB
JavaScript
169 lines
3.4 KiB
JavaScript
|
/**
|
||
|
* --------------------------------------------------------------------------
|
||
|
* Bootstrap (v4.0.0): alert.js
|
||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||
|
* --------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
import Util from 'util'
|
||
|
|
||
|
|
||
|
/**
|
||
|
* --------------------------------------------------------------------------
|
||
|
* Constants
|
||
|
* --------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
const NAME = 'alert'
|
||
|
const VERSION = '4.0.0'
|
||
|
const DATA_KEY = 'bs.alert'
|
||
|
const JQUERY_NO_CONFLICT = $.fn[NAME]
|
||
|
const TRANSITION_DURATION = 150
|
||
|
|
||
|
const Selector = {
|
||
|
DISMISS : '[data-dismiss="alert"]'
|
||
|
}
|
||
|
|
||
|
const Event = {
|
||
|
CLOSE : 'close.bs.alert',
|
||
|
CLOSED : 'closed.bs.alert',
|
||
|
CLICK : 'click.bs.alert.data-api'
|
||
|
}
|
||
|
|
||
|
const ClassName = {
|
||
|
ALERT : 'alert',
|
||
|
FADE : 'fade',
|
||
|
IN : 'in'
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* --------------------------------------------------------------------------
|
||
|
* Class Definition
|
||
|
* --------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
export class Alert {
|
||
|
|
||
|
constructor(element) {
|
||
|
if (element) {
|
||
|
this.element = element
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
// public
|
||
|
|
||
|
close(element) {
|
||
|
let rootElement = this._getRootElement(element)
|
||
|
let customEvent = this._triggerCloseEvent(rootElement)
|
||
|
|
||
|
if (customEvent.isDefaultPrevented()) {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
this._removeElement(rootElement)
|
||
|
}
|
||
|
|
||
|
|
||
|
// private
|
||
|
|
||
|
_getRootElement(element) {
|
||
|
let parent = false
|
||
|
let selector = Util.getSelectorFromElement(element)
|
||
|
|
||
|
if (selector) {
|
||
|
parent = $(selector)[0]
|
||
|
}
|
||
|
|
||
|
if (!parent) {
|
||
|
parent = $(element).closest('.' + ClassName.ALERT)[0]
|
||
|
}
|
||
|
|
||
|
return parent
|
||
|
}
|
||
|
|
||
|
_triggerCloseEvent(element) {
|
||
|
var closeEvent = $.Event(Event.CLOSE)
|
||
|
$(element).trigger(closeEvent)
|
||
|
return closeEvent
|
||
|
}
|
||
|
|
||
|
_removeElement(element) {
|
||
|
$(element).removeClass(ClassName.IN)
|
||
|
|
||
|
if (!Util.supportsTransitionEnd() || !$(element).hasClass(ClassName.FADE)) {
|
||
|
this._destroyElement(element)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
$(element)
|
||
|
.one(Util.TRANSITION_END, this._destroyElement.bind(this, element))
|
||
|
.emulateTransitionEnd(TRANSITION_DURATION)
|
||
|
}
|
||
|
|
||
|
_destroyElement(element) {
|
||
|
$(element)
|
||
|
.detach()
|
||
|
.trigger(Event.CLOSED)
|
||
|
.remove()
|
||
|
}
|
||
|
|
||
|
|
||
|
// static
|
||
|
|
||
|
static _jQueryInterface(config) {
|
||
|
return this.each(function () {
|
||
|
let $element = $(this)
|
||
|
let data = $element.data(DATA_KEY)
|
||
|
|
||
|
if (!data) {
|
||
|
data = new Alert(this)
|
||
|
$element.data(DATA_KEY, data)
|
||
|
}
|
||
|
|
||
|
if (config === 'close') {
|
||
|
data[config](this)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
|
||
|
static _handleDismiss(alertInstance) {
|
||
|
return function (event) {
|
||
|
if (event) {
|
||
|
event.preventDefault()
|
||
|
}
|
||
|
|
||
|
alertInstance.close(this)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* --------------------------------------------------------------------------
|
||
|
* Data Api implementation
|
||
|
* --------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
$(document).on(
|
||
|
Event.CLICK,
|
||
|
Selector.DISMISS,
|
||
|
Alert._handleDismiss(new Alert())
|
||
|
)
|
||
|
|
||
|
|
||
|
/**
|
||
|
* --------------------------------------------------------------------------
|
||
|
* jQuery
|
||
|
* --------------------------------------------------------------------------
|
||
|
*/
|
||
|
|
||
|
$.fn[NAME] = Alert._jQueryInterface
|
||
|
$.fn[NAME].Constructor = Alert
|
||
|
$.fn[NAME].noConflict = function () {
|
||
|
$.fn[NAME] = Alert._JQUERY_NO_CONFLICT
|
||
|
return Alert._jQueryInterface
|
||
|
}
|