forked from YOURLS/YOURLS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjquery.notifybar.js
97 lines (82 loc) · 2.53 KB
/
jquery.notifybar.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*
* Notify Bar - jQuery plugin
*
* Copyright (c) 2009-2010 Dmitri Smirnov
*
* Licensed under the MIT license:
* http://www.opensource.org/licenses/mit-license.php
*
* Version: 1.2.2
*
* Project home:
* http://www.dmitri.me/blog/notify-bar
*/
/**
* param Object
*/
jQuery.notifyBar = function(settings) {
(function($) {
var bar = notifyBarNS = {};
notifyBarNS.shown = false;
if( !settings) {
settings = {};
}
// HTML inside bar
notifyBarNS.html = settings.html || "Your message here";
//How long bar will be delayed, doesn't count animation time.
notifyBarNS.delay = settings.delay || 2000;
//How long notifyBarNS bar will be slided up and down
notifyBarNS.animationSpeed = settings.animationSpeed || 200;
//Use own jquery object usually DIV, or use default
notifyBarNS.jqObject = settings.jqObject;
//Set up own class
notifyBarNS.cls = settings.cls || "";
//close button
notifyBarNS.close = settings.close || false;
if( notifyBarNS.jqObject) {
bar = notifyBarNS.jqObject;
notifyBarNS.html = bar.html();
} else {
bar = jQuery("<div></div>")
.addClass("jquery-notify-bar")
.addClass(notifyBarNS.cls)
.attr("id", "__notifyBar");
}
bar.html(notifyBarNS.html).hide();
var id = bar.attr("id");
switch (notifyBarNS.animationSpeed) {
case "slow":
asTime = 600;
break;
case "normal":
asTime = 400;
break;
case "fast":
asTime = 200;
break;
default:
asTime = notifyBarNS.animationSpeed;
}
if( bar != 'object'); {
jQuery("body").prepend(bar);
}
// Style close button in CSS file
if( notifyBarNS.close) {
bar.append(jQuery("<a href='#' class='notify-bar-close'>Close [X]</a>"));
jQuery(".notify-bar-close").click(function() {
if( bar.attr("id") == "__notifyBar") {
jQuery("#" + id).slideUp(asTime, function() { jQuery("#" + id).remove() });
} else {
jQuery("#" + id).slideUp(asTime);
}
return false;
});
}
bar.slideDown(asTime);
// If taken from DOM dot not remove just hide
if( bar.attr("id") == "__notifyBar") {
setTimeout("jQuery('#" + id + "').slideUp(" + asTime +", function() {jQuery('#" + id + "').remove()});", notifyBarNS.delay + asTime);
} else {
setTimeout("jQuery('#" + id + "').slideUp(" + asTime +", function() {jQuery('#" + id + "')});", notifyBarNS.delay + asTime);
}
})(jQuery) };