winter/modules/system/assets/ui/js/flashmessage.js

76 lines
1.8 KiB
JavaScript
Raw Normal View History

2015-05-28 20:33:49 +10:00
/*
* The flash message.
2014-05-14 23:24:20 +10:00
*
* Documentation: ../docs/flashmessage.md
2014-05-14 23:24:20 +10:00
*
* Require:
* - bootstrap/transition
2014-05-14 23:24:20 +10:00
*/
+function ($) { "use strict";
var FlashMessage = function (options, el) {
var
2014-05-14 23:24:20 +10:00
options = $.extend({}, FlashMessage.DEFAULTS, options),
$element = $(el)
2014-05-14 23:24:20 +10:00
$('body > p.flash-message').remove()
2016-04-27 04:44:02 +10:00
if ($element.length == 0) {
$element = $('<p />').addClass(options.class).html(options.text)
2016-04-27 04:44:02 +10:00
}
2014-05-14 23:24:20 +10:00
$element.addClass('flash-message fade')
2014-05-14 23:24:20 +10:00
$element.attr('data-control', null)
$element.append('<button type="button" class="close" aria-hidden="true">&times;</button>')
2014-05-14 23:24:20 +10:00
$element.on('click', 'button', remove)
$element.on('click', remove)
2014-05-14 23:24:20 +10:00
$(document.body).append($element)
2016-11-06 17:14:12 +01:00
setTimeout(function() {
$element.addClass('in')
}, 100)
2014-05-14 23:24:20 +10:00
var timer = window.setTimeout(remove, options.interval * 1000)
2014-05-14 23:24:20 +10:00
function removeElement() {
$element.remove()
}
2014-05-14 23:24:20 +10:00
function remove() {
window.clearInterval(timer)
$element.removeClass('in')
$.support.transition && $element.hasClass('fade')
? $element
.one($.support.transition.end, removeElement)
.emulateTransitionEnd(500)
: removeElement()
2014-05-14 23:24:20 +10:00
}
}
FlashMessage.DEFAULTS = {
class: 'success',
text: 'Default text',
interval: 5
2014-05-14 23:24:20 +10:00
}
// FLASH MESSAGE PLUGIN DEFINITION
// ============================
if ($.oc === undefined)
$.oc = {}
$.oc.flashMsg = FlashMessage
2014-05-14 23:24:20 +10:00
// FLASH MESSAGE DATA-API
// ===============
$(document).render(function(){
$('[data-control=flash-message]').each(function(){
$.oc.flashMsg($(this).data(), this)
})
})
}(window.jQuery);