update to latest toastr

This commit is contained in:
Oliver Gorwits
2012-12-03 20:00:50 +00:00
parent 8b13e1bdfa
commit 21fbe2a061
4 changed files with 369 additions and 313 deletions

View File

@@ -1,30 +0,0 @@
@media all and (max-width: 240px) {
#toast-container > div {
padding: 8px 8px 8px 50px;
width: 108px;
}
}
@media all and (min-width: 241px) and (max-width: 320px) {
#toast-container > div {
padding: 8px 8px 8px 50px;
width: 128px;
}
}
@media all and (min-width: 321px) and (max-width: 480px) {
#toast-container > div {
padding: 8px 8px 8px 50px;
width: 192px;
}
}
@media all and (min-width: 481px) and (max-width: 768px) {
#toast-container > div {
padding: 15px 15px 15px 50px;
width: 300px;
}
}
@media all and (min-width: 769px) {
#toast-container > div {
padding: 15px 15px 15px 50px;
width: 300px;
}
}

View File

@@ -1,41 +1,52 @@
.toast-title { .toast-title
{
font-weight: bold; font-weight: bold;
} }
.toast-message { .toast-message
{
-ms-word-wrap: break-word;
word-wrap: break-word;
} }
.toast-message a, .toast-message a,
.toast-message label { .toast-message label
{
color: #FFF; color: #FFF;
} }
.toast-message a:hover { .toast-message a:hover
{
color: #CCC; color: #CCC;
text-decoration: none; text-decoration: none;
} }
.toast-top-left { .toast-top-left
{
left: 12px;
top: 12px; top: 12px;
left: 12px;
} }
.toast-bottom-right { .toast-bottom-right
{
bottom: 12px;
right: 12px; right: 12px;
bottom: 12px;
} }
.toast-bottom-left { .toast-bottom-left
{
bottom: 12px;
left: 12px; left: 12px;
bottom: 12px;
} }
#toast-container { #toast-container
{
position: fixed; position: fixed;
z-index: 9999; z-index: 9999;
} }
#toast-container > div { #toast-container > div
{
background-position: 15px center; background-position: 15px center;
background-repeat: no-repeat; background-repeat: no-repeat;
-moz-border-radius: 3px 3px 3px 3px; -moz-border-radius: 3px 3px 3px 3px;
@@ -43,67 +54,121 @@
border-radius: 3px 3px 3px 3px; border-radius: 3px 3px 3px 3px;
-moz-box-shadow: 0 0 12px #999999; -moz-box-shadow: 0 0 12px #999999;
-webkit-box-shadow: 0 0 12px #999999; -webkit-box-shadow: 0 0 12px #999999;
-o-box-shadow: 0 0 12px #999999;
box-shadow: 0 0 12px #999999; box-shadow: 0 0 12px #999999;
color: #FFFFFF; color: #FFFFFF;
margin: 0 0 6px;
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)"; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
filter: alpha(opacity=80); filter: alpha(opacity=80);
-moz-opacity: 0.8; margin: 0 0 6px;
opacity: 0.8; opacity: 0.8;
padding: 15px 15px 15px 50px; padding: 15px 15px 15px 50px;
width: 300px; width: 300px;
} }
.toast { .toast
{
background-color: #030303; background-color: #030303;
} }
.toast-success { .toast-success
{
background-color: #51A351; background-color: #51A351;
} }
.toast-error { .toast-error
{
background-color: #BD362F; background-color: #BD362F;
} }
.toast-info { .toast-info
{
background-color: #2F96B4; background-color: #2F96B4;
} }
.toast-warning { .toast-warning
{
background-color: #F89406; background-color: #F89406;
} }
.toast-top-right { .toast-top-right
top: 12px; {
right: 12px; right: 12px;
top: 12px;
} }
#toast-container > :hover { #toast-container > :hover
{
-moz-box-shadow: 0 0 12px #000000; -moz-box-shadow: 0 0 12px #000000;
-webkit-box-shadow: 0 0 12px #000000; -webkit-box-shadow: 0 0 12px #000000;
-o-box-shadow: 0 0 12px #000000;
box-shadow: 0 0 12px #000000; box-shadow: 0 0 12px #000000;
cursor: pointer;
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
filter: alpha(opacity=100); filter: alpha(opacity=100);
-moz-opacity: 1;
opacity: 1; opacity: 1;
cursor: pointer;
} }
#toast-container > .toast-info { #toast-container > .toast-info
{
background-image: url("") !important; background-image: url("") !important;
} }
#toast-container > .toast-error { #toast-container > .toast-error
{
background-image: url("") !important; background-image: url("") !important;
} }
#toast-container > .toast-success { #toast-container > .toast-success
{
background-image: url("") !important; background-image: url("") !important;
} }
#toast-container > .toast-warning { #toast-container > .toast-warning
{
background-image: url("") !important; background-image: url("") !important;
} }
/*Responsive Design*/
@media all and (max-width: 240px)
{
#toast-container > div
{
padding: 8px 8px 8px 50px;
width: 108px;
}
}
@media all and (min-width: 241px) and (max-width: 320px)
{
#toast-container > div
{
padding: 8px 8px 8px 50px;
width: 128px;
}
}
@media all and (min-width: 321px) and (max-width: 480px)
{
#toast-container > div
{
padding: 8px 8px 8px 50px;
width: 192px;
}
}
@media all and (min-width: 481px) and (max-width: 768px)
{
#toast-container > div
{
padding: 15px 15px 15px 50px;
width: 300px;
}
}
@media all and (min-width: 769px)
{
#toast-container > div
{
padding: 15px 15px 15px 50px;
width: 300px;
}
}

View File

@@ -4,170 +4,192 @@
// Modified to support css styling instead of inline styling // Modified to support css styling instead of inline styling
// Inspired by https://github.com/Srirangan/notifer.js/ // Inspired by https://github.com/Srirangan/notifer.js/
;(function(window, $) { ; (function (define) {
window.toastr = (function() { define(['jquery'], function ($) {
var var toastr = (function () {
defaults = { var
tapToDismiss: true, defaults = {
toastClass: 'toast', tapToDismiss: true,
containerId: 'toast-container', toastClass: 'toast',
debug: false, containerId: 'toast-container',
fadeIn: 300, debug: false,
fadeOut: 1000, fadeIn: 300,
extendedTimeOut: 1000, fadeOut: 1000,
iconClasses: { extendedTimeOut: 1000,
error: 'toast-error', iconClasses: {
info: 'toast-info', error: 'toast-error',
success: 'toast-success', info: 'toast-info',
warning: 'toast-warning' success: 'toast-success',
warning: 'toast-warning'
},
iconClass: 'toast-info',
positionClass: 'toast-top-right',
timeOut: 5000, // Set timeOut to 0 to make it sticky
titleClass: 'toast-title',
messageClass: 'toast-message'
}, },
iconClass: 'toast-info',
positionClass: 'toast-top-right',
timeOut: 5000, // Set timeOut to 0 to make it sticky
titleClass: 'toast-title',
messageClass: 'toast-message'
},
error = function (message, title, optionsOverride) {
return notify({
iconClass: getOptions().iconClasses.error,
message: message,
optionsOverride: optionsOverride,
title: title
});
},
error = function(message, title) { getContainer = function (options) {
return notify({ var $container = $('#' + options.containerId);
iconClass: getOptions().iconClasses.error, if ($container.length) {
message: message, return $container;
title: title }
}) $container = $('<div/>')
}, .attr('id', options.containerId)
.addClass(options.positionClass);
$container.appendTo($('body'));
return $container;
},
getContainer = function(options) { getOptions = function () {
var $container = $('#' + options.containerId) return $.extend({}, defaults, toastr.options);
},
if ($container.length) info = function (message, title, optionsOverride) {
return $container return notify({
iconClass: getOptions().iconClasses.info,
message: message,
optionsOverride: optionsOverride,
title: title
});
},
$container = $('<div/>') notify = function (map) {
.attr('id', options.containerId) var
.addClass(options.positionClass) options = getOptions(),
iconClass = map.iconClass || options.iconClass;
$container.appendTo($('body')) if (typeof (map.optionsOverride) !== 'undefined') {
options = $.extend(options, map.optionsOverride);
return $container iconClass = map.optionsOverride.iconClass || iconClass;
},
getOptions = function() {
return $.extend({}, defaults, toastr.options)
},
info = function(message, title) {
return notify({
iconClass: getOptions().iconClasses.info,
message: message,
title: title
})
},
notify = function(map) {
var
options = getOptions(),
iconClass = map.iconClass || options.iconClass,
intervalId = null,
$container = getContainer(options),
$toastElement = $('<div/>'),
$titleElement = $('<div/>'),
$messageElement = $('<div/>'),
response = { options: options, map: map }
if (map.iconClass) {
$toastElement.addClass(options.toastClass).addClass(iconClass)
}
if (map.title) {
$titleElement.append(map.title).addClass(options.titleClass)
$toastElement.append($titleElement)
}
if (map.message) {
$messageElement.append(map.message).addClass(options.messageClass)
$toastElement.append($messageElement)
}
var fadeAway = function() {
if ($(':focus', $toastElement).length > 0)
return
var fade = function() {
return $toastElement.fadeOut(options.fadeOut)
} }
$.when(fade()).done(function() { var
if ($toastElement.is(':visible')) { intervalId = null,
return $container = getContainer(options),
$toastElement = $('<div/>'),
$titleElement = $('<div/>'),
$messageElement = $('<div/>'),
response = { options: options, map: map };
if (map.iconClass) {
$toastElement.addClass(options.toastClass).addClass(iconClass);
}
if (map.title) {
$titleElement.append(map.title).addClass(options.titleClass);
$toastElement.append($titleElement);
}
if (map.message) {
$messageElement.append(map.message).addClass(options.messageClass);
$toastElement.append($messageElement);
}
var fadeAway = function () {
if ($(':focus', $toastElement).length > 0) {
return;
} }
$toastElement.remove() var fade = function (callback) {
if ($container.children().length === 0) return $toastElement.fadeOut(options.fadeOut, callback);
$container.remove() };
}) var removeToast = function () {
} if ($toastElement.is(':visible')) {
return;
var delayedFadeAway = function() { }
if (options.timeOut > 0 || options.extendedTimeOut > 0) { $toastElement.remove();
intervalId = setTimeout(fadeAway, options.extendedTimeOut) if ($container.children().length === 0) {
$container.remove();
}
};
fade(removeToast);
};
var delayedFadeAway = function () {
if (options.timeOut > 0 || options.extendedTimeOut > 0) {
intervalId = setTimeout(fadeAway, options.extendedTimeOut);
}
};
var stickAround = function () {
clearTimeout(intervalId);
$toastElement.stop(true, true).fadeIn(options.fadeIn);
};
$toastElement.hide();
$container.prepend($toastElement);
$toastElement.fadeIn(options.fadeIn);
if (options.timeOut > 0) {
intervalId = setTimeout(fadeAway, options.timeOut);
} }
$toastElement.hover(stickAround, delayedFadeAway);
if (!options.onclick && options.tapToDismiss) {
$toastElement.click(fadeAway);
}
if (options.onclick) {
$toastElement.click(function () {
options.onclick() && fadeAway();
});
}
if (options.debug && console) {
console.log(response);
}
return $toastElement;
},
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
});
},
clear = function () {
var options = getOptions();
var $container = $('#' + options.containerId);
if ($container.length) {
$container.fadeOut(options.fadeOut, function () {
$container.remove();
});
} }
};
var stickAround = function() { return {
clearTimeout(intervalId) clear: clear,
$toastElement.stop(true, true) error: error,
.fadeIn(options.fadeIn) info: info,
} options: {},
success: success,
$toastElement.hide() version: '1.1.1',
$container.prepend($toastElement) warning: warning
$toastElement.fadeIn(options.fadeIn) };
})();
if (options.timeOut > 0) { return toastr;
intervalId = setTimeout(fadeAway, options.timeOut) });
} }(typeof define === 'function' && define.amd ? define : function (deps, factory) {
if (typeof module !== 'undefined' && module.exports) { //Node
$toastElement.hover(stickAround, delayedFadeAway) module.exports = factory(require(deps[0]));
} else {
if (!options.onclick && options.tapToDismiss) { window['toastr'] = factory(window['jQuery']);
$toastElement.click(fadeAway) }
} }));
if (options.onclick) {
$toastElement.click(function() {
options.onclick() && fadeAway()
})
}
if (options.debug) {
console.log(response)
}
return $toastElement
},
success = function(message, title) {
return notify({
iconClass: getOptions().iconClasses.success,
message: message,
title: title
})
},
warning = function(message, title) {
return notify({
iconClass: getOptions().iconClasses.warning,
message: message,
title: title
})
}
return {
error: error,
info: info,
options: {},
success: success,
warning: warning
}
})()
} (window, jQuery));

View File

@@ -28,7 +28,6 @@
<script type="text/javascript" src="[% uri_base %]/javascripts/netdisco_portcontrol.js"></script> <script type="text/javascript" src="[% uri_base %]/javascripts/netdisco_portcontrol.js"></script>
<link rel="stylesheet" href="[% uri_base %]/css/toastr.css"/> <link rel="stylesheet" href="[% uri_base %]/css/toastr.css"/>
<link rel="stylesheet" href="[% uri_base %]/css/toastr-responsive.css"/>
[% END %] [% END %]
<link rel="stylesheet" href="[% uri_base %]/css/bootstrap.min.css"/> <link rel="stylesheet" href="[% uri_base %]/css/bootstrap.min.css"/>