Created
April 1, 2013 19:40
-
-
Save jalalhejazi/5287170 to your computer and use it in GitHub Desktop.
JavaScript: msgNotify.[info][warning][success][error][bookmark]
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html> | |
<head> | |
<meta charset="utf-8"/> | |
<title>msgNotify examples</title> | |
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> | |
<link href="http://twitter.github.com/bootstrap/assets/css/bootstrap.css" rel="stylesheet"/> | |
<link href="http://twitter.github.com/bootstrap/assets/css/bootstrap-responsive.css" rel="stylesheet"/> | |
<link href="msgNotify.css" rel="stylesheet" type="text/css" /> | |
<style> | |
.row { | |
margin-left: 0; | |
} | |
</style> | |
</head> | |
<body style="padding: 30px" class="container"> | |
<section class="row"> | |
<h1>msgNotify</h1> | |
<a href="https://github.com/Jalalhejazi/msgNotify">//github.com/Jalalhejazi/msgNotify</a> | |
<div class="well row"> | |
<div class="row span11"> | |
<div class="span4"> | |
<div class="control-group"> | |
<div class="controls"> | |
<label class="control-label" for="title">Title</label> | |
<input id="title" type="text" class="input-large" placeholder="Enter a title ..."/> | |
<label class="control-label" for="message">Message</label> | |
<textarea class="input-large" id="message" rows="3" placeholder="Enter a message ..."></textarea> | |
</div> | |
</div> | |
</div> | |
<div class="span2"> | |
<div class="control-group" id="msgNotifyTypeGroup"> | |
<div class="controls"> | |
<label >msgNotify Type</label> | |
<label class="radio"> | |
<input type="radio" name="msgNotifys" value="success" checked/>Success | |
</label> | |
<label class="radio"> | |
<input type="radio" name="msgNotifys" value="info"/> | |
Info | |
</label> | |
<label class="radio"> | |
<input type="radio" name="msgNotifys" value="warning"/> | |
Warning | |
</label> | |
<label class="radio"> | |
<input type="radio" name="msgNotifys" value="error"/> | |
Error | |
</label> | |
<label class="radio"> | |
<input type="radio" name="msgNotifys" value="bookmark"/> | |
bookmark | |
</label> | |
</div> | |
</div> | |
<div class="control-group" id="positionGroup"> | |
<div class="controls"> | |
<label>Position</label> | |
<label class="radio"><input type="radio" name="positions" value="msgNotify-top-right" />Top Right</label> | |
<label class="radio"><input type="radio" name="positions" value="msgNotify-bottom-right"/>Bottom Right</label> | |
<label class="radio"><input type="radio" name="positions" value="msgNotify-bottom-left"/>Bottom Left</label> | |
<label class="radio"><input type="radio" name="positions" value="msgNotify-top-left"/>Top Left</label> | |
<label class="radio"><input type="radio" name="positions" value="msgNotify-top-full-width"/>Top Full Width</label> | |
<label class="radio"><input type="radio" name="positions" value="msgNotify-bottom-full-width" checked/>Bottom Full Width</label> | |
</div> | |
</div> | |
</div> | |
<div class="span2" > | |
<div class="control-group"> | |
<div class="controls"> | |
<label class="control-label" for="">Fade in</label> | |
<input id="fadeIn" type="text" placeholder="ms" class="input-mini" value="300"/> | |
<label class="control-label" for="fadeOut">Fade out</label> | |
<input id="fadeOut" type="text" placeholder="ms" class="input-mini" value="1000"/> | |
<label class="control-label" for="timeOut">Time out</label> | |
<input id="timeOut" type="text" placeholder="ms" class="input-mini" value="5000"/> | |
<label class="control-label" for="timeOut">Extended time out</label> | |
<input id="extendedTimeOut" type="text" placeholder="ms" class="input-mini" value="1000"/> | |
</div> | |
</div> | |
</div> | |
<div class="span2"> | |
<div class="control-group"> | |
<div class="controls"> | |
<label class="checkbox" for="debugInfo"> | |
<input id="debugInfo" type="checkbox" value="checked" class="input-mini"/>Debug | |
</label> | |
</div> | |
<div class="controls"> | |
<label class="checkbox" for="addBehaviorOnmsgNotifyClick"> | |
<input id="addBehaviorOnmsgNotifyClick" type="checkbox" value="checked" class="input-mini"/>Add behavior on msgNotify click | |
</label> | |
</div> | |
</div> | |
</div> | |
</div> | |
<div class="row span11"> | |
<button type="button" class="btn btn-primary" id="showmsgNotify">Show msgNotify</button> | |
<button type="button" class="btn btn-danger" id="clearmsgNotifys">Clear msgNotifys</button> | |
<button type="button" class="btn btn-danger" id="clearlastmsgNotify">Clear Last msgNotify</button> | |
</div> | |
</div> | |
</section> | |
<footer class="row"> | |
</footer> | |
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.3/jquery.min.js"></script> | |
<script src="msgNotify.js"></script> | |
<script type="text/javascript"> | |
$(function () { | |
var | |
i = -1, | |
msgNotifyCount = 0, | |
$msgNotifylast, | |
getMessage = function() { | |
var msgs = ['Please Develop HTML5 WebApps rather than native mobile apps', | |
'<div><input class="input-small" value="textbox"/> <a href="http://SuperMobile.dk" target="_blank">This is a hyperlink</a></div><div><button type="button" id="okBtn" class="btn btn-primary">Close me</button><button type="button" id="surpriseBtn" class="btn" style="margin: 0 8px 0 8px">Dynamic behavior</button></div>', | |
'HTML5 is the future of next generation WebApps !', | |
'Welcome back to the web :-)', | |
'DO not under estimate the power of CSS.3', | |
'Everything you see is FREE !' | |
]; | |
i++; | |
if (i === msgs.length) { | |
i = 0; | |
} | |
return msgs[i]; | |
}; | |
$('#showmsgNotify').click(function() { | |
var shortCutFunction = $("#msgNotifyTypeGroup input:radio:checked").val(), | |
msg = $('#message').val(), | |
title = $('#title').val() || '', | |
$fadeIn = $('#fadeIn'), | |
$fadeOut = $('#fadeOut'), | |
$timeOut = $('#timeOut'), | |
$extendedTimeOut = $('#extendedTimeOut'), | |
msgNotifyIndex = msgNotifyCount++; | |
msgNotify.options = { | |
debug: ($('#debugInfo').attr('checked') === 'checked'), | |
positionClass: $('#positionGroup input:radio:checked').val() || 'msgNotify-top-right', | |
onclick: null | |
}; | |
if (($('#addBehaviorOnmsgNotifyClick').attr('checked') === 'checked')) { | |
msgNotify.options.onclick = function () { | |
alert('You can perform some custom action after a msgNotify goes away'); | |
}; | |
} | |
if ($fadeIn.val().length) { | |
msgNotify.options.fadeIn = + $fadeIn.val(); | |
} | |
if ($fadeOut.val().length) { | |
msgNotify.options.fadeOut = + $fadeOut.val(); | |
} | |
if ($timeOut.val().length) { | |
msgNotify.options.timeOut = + $timeOut.val(); | |
} | |
if ($extendedTimeOut.val().length) { | |
msgNotify.options.extendedTimeOut = + $extendedTimeOut.val(); | |
} | |
if (!msg) { | |
msg = getMessage(); | |
} | |
var $msgNotify = msgNotify[shortCutFunction](msg, title); | |
// Wire up an event handler to a button in the msgNotify, if it exists | |
$msgNotifylast = $msgNotify; | |
if ($msgNotify.find('#okBtn').length) { | |
$msgNotify.delegate('#okBtn', 'click', function () { | |
alert('you clicked me. I was msgNotify #' + msgNotifyIndex + '. goodbye!'); | |
$msgNotify.remove(); | |
}); | |
} | |
if ($msgNotify.find('#surpriseBtn').length) { | |
$msgNotify.delegate('#surpriseBtn', 'click', function () { | |
alert('Surprise! you clicked me. I was msgNotify #' + msgNotifyIndex + '. You could perform an action here.'); | |
}); | |
} | |
$('#clearlastmsgNotify').click(function() { | |
msgNotify.clear($msgNotifylast); | |
}); | |
}); | |
$('#clearmsgNotifys').click(function () { | |
msgNotify.clear(); | |
}); | |
}) | |
</script> | |
<script type="text/javascript"> | |
// to use the library, just call the global msgNotify: | |
msgNotify.success(' https://github.com/Jalalhejazi/msgNotify ', 'download sourceCode'); | |
var Add_to_homescreen_msg = '<p>Bookmark your WebApp and restart from home screen </p> <img src="images/touch-icon-iphone.png" />' ; | |
msgNotify.bookmark(Add_to_homescreen_msg); | |
</script> | |
</body> | |
</html> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
GitHub: https://raw.github.com/Jalalhejazi/msgNotify/master/msgNotify.css | |
Use the Twitter Bootstrap | |
Responsive Design | |
*/ | |
.msgNotify-title { | |
font-weight: bold; | |
} | |
.msgNotify-message { | |
-ms-word-wrap: break-word; | |
word-wrap: break-word; | |
} | |
.msgNotify-message a, | |
.msgNotify-message label { | |
color: #FFF; | |
} | |
.msgNotify-message a:hover { | |
color: #CCC; | |
text-decoration: none; | |
} | |
.msgNotify-top-full-width { | |
top: 0; | |
right: 0; | |
width: 100%; | |
} | |
.msgNotify-bottom-full-width { | |
bottom: 0; | |
right: 0; | |
width: 100%; | |
} | |
.msgNotify-top-left { | |
top: 12px; | |
left: 12px; | |
} | |
.msgNotify-top-right { | |
top: 12px; | |
right: 12px; | |
} | |
.msgNotify-bottom-right { | |
right: 12px; | |
bottom: 12px; | |
} | |
.msgNotify-bottom-left { | |
bottom: 12px; | |
left: 12px; | |
} | |
#msgNotify-container { | |
position: fixed; | |
z-index: 999999; | |
} | |
#msgNotify-container > div { | |
margin: 0 0 6px; | |
padding: 15px 15px 15px 50px; | |
width: 300px; | |
-moz-border-radius: 3px 3px 3px 3px; | |
-webkit-border-radius: 3px 3px 3px 3px; | |
border-radius: 3px 3px 3px 3px; | |
background-position: 15px center; | |
background-repeat: no-repeat; | |
-moz-box-shadow: 0 0 12px #999999; | |
-webkit-box-shadow: 0 0 12px #999999; | |
box-shadow: 0 0 12px #999999; | |
color: #FFFFFF; | |
opacity: 0.8; | |
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)"; | |
filter: alpha(opacity=80); | |
} | |
.msgNotify { | |
background-color: #030303; | |
} | |
.msgNotify-success { | |
background-color: #51A351; | |
} | |
.msgNotify-error { | |
background-color: #BD362F; | |
} | |
.msgNotify-info { | |
background-color: #2F96B4; | |
} | |
.msgNotify-warning { | |
background-color: #F89406; | |
} | |
#msgNotify-container > :hover { | |
-moz-box-shadow: 0 0 12px #000000; | |
-webkit-box-shadow: 0 0 12px #000000; | |
box-shadow: 0 0 12px #000000; | |
opacity: 1; | |
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; | |
filter: alpha(opacity=100); | |
cursor: pointer; | |
} | |
#msgNotify-container > .msgNotify-info { | |
background-image: url("") !important; | |
} | |
#msgNotify-container > .msgNotify-error { | |
background-image: url("") !important; | |
} | |
#msgNotify-container > .msgNotify-success { | |
background-image: url("") !important; | |
} | |
#msgNotify-container > .msgNotify-warning { | |
background-image: url("") !important; | |
} | |
#msgNotify-container > .msgNotify-bookmark { | |
background-image: url("") !important; | |
} | |
/*Responsive Design*/ | |
@media all and (max-width: 240px) { | |
#msgNotify-container > div { | |
padding: 8px 8px 8px 50px; | |
width: 108px; | |
} | |
} | |
@media all and (min-width: 241px) and (max-width: 320px) { | |
#msgNotify-container > div { | |
padding: 8px 8px 8px 50px; | |
width: 128px; | |
} | |
} | |
@media all and (min-width: 321px) and (max-width: 480px) { | |
#msgNotify-container > div { | |
padding: 8px 8px 8px 50px; | |
width: 192px; | |
} | |
} | |
@media all and (min-width: 481px) and (max-width: 768px) { | |
#msgNotify-container > div { | |
padding: 15px 15px 15px 50px; | |
width: 300px; | |
} | |
} | |
/* overrides */ | |
#msgNotify-container.msgNotify-top-full-width > div, | |
#msgNotify-container.msgNotify-bottom-full-width > div { | |
width: 100%; | |
margin: 1px 0 1px 0; | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
GitHub: https://raw.github.com/Jalalhejazi/msgNotify/master/msgNotify.js | |
jQuery plugin: msgNotify.js | |
Usage: | |
msgNotify.info ('Display info message with no title' ); | |
msgNotify.warning ('Display warning message with no title'); | |
msgNotify.success ('Display success message' , 'with a title') | |
msgNotify.error ('Display error message', 'with a title'); | |
msgNotify.bookmark('Bookmark your WebApp and restart from home screen'); | |
msgNotify.bookmark(); | |
msgNotify.clear() ; | |
*/ | |
; (function (define) { | |
define(['jquery'], function ($) { | |
return (function () { | |
var $container, | |
defaults = { | |
tapToDismiss: true, | |
msgNotifyClass: 'msgNotify', | |
containerId: 'msgNotify-container', | |
debug: false, | |
fadeIn: 300, | |
fadeOut: 1000, | |
extendedTimeOut: 1000, | |
iconClasses: { | |
error: 'msgNotify-error', | |
info: 'msgNotify-info', | |
success: 'msgNotify-success', | |
warning: 'msgNotify-warning', | |
bookmark: 'msgNotify-bookmark' | |
}, | |
iconClass: 'msgNotify-info', | |
positionClass: 'msgNotify-top-right', | |
timeOut: 5000, // Set timeOut to 0 to make it sticky | |
titleClass: 'msgNotify-title', | |
messageClass: 'msgNotify-message', | |
target: 'body' | |
}, | |
error = function (message, title, optionsOverride) { | |
return notify({ | |
iconClass: getOptions().iconClasses.error, | |
message: message, | |
optionsOverride: optionsOverride, | |
title: title | |
}); | |
}, | |
info = function (message, title, optionsOverride) { | |
return notify({ | |
iconClass: getOptions().iconClasses.info, | |
message: message, | |
optionsOverride: optionsOverride, | |
title: title | |
}); | |
}, | |
notify = function (map) { | |
var | |
options = getOptions(), | |
iconClass = map.iconClass || options.iconClass; | |
if (typeof (map.optionsOverride) !== 'undefined') { | |
options = $.extend(options, map.optionsOverride); | |
iconClass = map.optionsOverride.iconClass || iconClass; | |
} | |
var | |
intervalId = null, | |
$container = getContainer(options), | |
$msgNotifyElement = $('<div/>'), | |
$titleElement = $('<div/>'), | |
$messageElement = $('<div/>'), | |
response = { options: options, map: map }; | |
if (map.iconClass) { | |
$msgNotifyElement.addClass(options.msgNotifyClass).addClass(iconClass); | |
} | |
if (map.title) { | |
$titleElement.append(map.title).addClass(options.titleClass); | |
$msgNotifyElement.append($titleElement); | |
} | |
if (map.message) { | |
$messageElement.append(map.message).addClass(options.messageClass); | |
$msgNotifyElement.append($messageElement); | |
} | |
$msgNotifyElement.hide(); | |
$container.prepend($msgNotifyElement); | |
$msgNotifyElement.fadeIn(options.fadeIn); | |
if (options.timeOut > 0) { | |
intervalId = setTimeout(fadeAway, options.timeOut); | |
} | |
$msgNotifyElement.hover(stickAround, delayedFadeAway); | |
if (!options.onclick && options.tapToDismiss) { | |
$msgNotifyElement.click(fadeAway); | |
} | |
if (options.onclick) { | |
$msgNotifyElement.click(function () { | |
options.onclick() && fadeAway(); | |
}); | |
} | |
if (options.debug && console) { | |
console.log(response); | |
} | |
return $msgNotifyElement; | |
function fadeAway() { | |
if ($(':focus', $msgNotifyElement).length > 0) { | |
return; | |
} | |
return $msgNotifyElement.fadeOut(options.fadeOut, function () { | |
removemsgNotify($msgNotifyElement); | |
}); | |
} | |
function delayedFadeAway() { | |
if (options.timeOut > 0 || options.extendedTimeOut > 0) { | |
intervalId = setTimeout(fadeAway, options.extendedTimeOut); | |
} | |
} | |
function stickAround() { | |
clearTimeout(intervalId); | |
$msgNotifyElement.stop(true, true).fadeIn(options.fadeIn); | |
} | |
}, | |
success = function (message, title, optionsOverride) { | |
return notify({ | |
iconClass: getOptions().iconClasses.success, | |
message: message, | |
optionsOverride: optionsOverride, | |
title: title | |
}); | |
}, | |
warning = function (message, title, optionsOverride) { | |
return notify({ | |
iconClass: getOptions().iconClasses.warning, | |
message: message, | |
optionsOverride: optionsOverride, | |
title: title | |
}); | |
}, | |
bookmark = function (message, title, optionsOverride) { | |
return notify({ | |
iconClass: getOptions().iconClasses.info, | |
message: (message ? message : "Bookmark your WebApp and restart from home screen") , | |
optionsOverride: optionsOverride, | |
title: (title ? title : "Add to home screen") | |
}); | |
}, | |
clear = function ($msgNotifyElement) { | |
var options = getOptions(); | |
if (!$container) | |
{ | |
getContainer(options) | |
} | |
if ($msgNotifyElement && $(':focus', $msgNotifyElement).length === 0) { | |
$msgNotifyElement.fadeOut(options.fadeOut, function () { | |
removemsgNotify($msgNotifyElement); | |
}); | |
return; | |
} | |
if ($container.children().length) { | |
$container.fadeOut(options.fadeOut, function () { | |
$container.remove(); | |
}); | |
} | |
}; | |
var msgNotify = { | |
getContainer: getContainer, | |
clear: clear, | |
info: info, | |
options: {}, | |
error: error, | |
success: success, | |
warning: warning, | |
bookmark: bookmark, | |
version: '1.2.3' | |
}; | |
return msgNotify; | |
//#region Internal Methods | |
function getContainer(options) { | |
if (!options) { options = getOptions(); } | |
container = $('#' + options.containerId); | |
if (container.children().length) { | |
return container; | |
} | |
container = $('<div/>') | |
.attr('id', options.containerId) | |
.addClass(options.positionClass); | |
container.appendTo($(options.target)); | |
$container = container; | |
return container; | |
} | |
function getOptions() { | |
return $.extend({}, defaults, msgNotify.options); | |
} | |
function removemsgNotify($msgNotifyElement) { | |
if (!$container) { $container = getContainer(); } | |
if ($msgNotifyElement.is(':visible')) { | |
return; | |
} | |
$msgNotifyElement.remove(); | |
$msgNotifyElement = null; | |
if ($container.children().length === 0) { | |
$container.remove(); | |
} | |
} | |
//#endregion | |
})(); | |
}); | |
}(typeof define === 'function' && define.amd ? define : function (deps, factory) { | |
if (typeof module !== 'undefined' && module.exports) { //Node | |
module.exports = factory(require(deps[0])); | |
} else { | |
window['msgNotify'] = factory(window['jQuery']); | |
} | |
})); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment