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,109 +1,174 @@
.toast-title { .toast-title
font-weight: bold; {
} font-weight: bold;
}
.toast-message {
} .toast-message
{
.toast-message a, -ms-word-wrap: break-word;
.toast-message label { word-wrap: break-word;
color: #FFF; }
}
.toast-message a,
.toast-message a:hover { .toast-message label
color: #CCC; {
text-decoration: none; color: #FFF;
} }
.toast-top-left { .toast-message a:hover
top: 12px; {
left: 12px; color: #CCC;
} text-decoration: none;
}
.toast-bottom-right {
right: 12px; .toast-top-left
bottom: 12px; {
} left: 12px;
top: 12px;
.toast-bottom-left { }
left: 12px;
bottom: 12px; .toast-bottom-right
} {
bottom: 12px;
#toast-container { right: 12px;
position: fixed; }
z-index: 9999;
} .toast-bottom-left
{
#toast-container > div { bottom: 12px;
background-position: 15px center; left: 12px;
background-repeat: no-repeat; }
-moz-border-radius: 3px 3px 3px 3px;
-webkit-border-radius: 3px 3px 3px 3px; #toast-container
border-radius: 3px 3px 3px 3px; {
-moz-box-shadow: 0 0 12px #999999; position: fixed;
-webkit-box-shadow: 0 0 12px #999999; z-index: 9999;
-o-box-shadow: 0 0 12px #999999; }
box-shadow: 0 0 12px #999999;
color: #FFFFFF; #toast-container > div
margin: 0 0 6px; {
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)"; background-position: 15px center;
filter: alpha(opacity=80); background-repeat: no-repeat;
-moz-opacity: 0.8; -moz-border-radius: 3px 3px 3px 3px;
opacity: 0.8; -webkit-border-radius: 3px 3px 3px 3px;
padding: 15px 15px 15px 50px; border-radius: 3px 3px 3px 3px;
width: 300px; -moz-box-shadow: 0 0 12px #999999;
} -webkit-box-shadow: 0 0 12px #999999;
box-shadow: 0 0 12px #999999;
.toast { color: #FFFFFF;
background-color: #030303; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
} filter: alpha(opacity=80);
margin: 0 0 6px;
.toast-success { opacity: 0.8;
background-color: #51A351; padding: 15px 15px 15px 50px;
} width: 300px;
}
.toast-error {
background-color: #BD362F; .toast
} {
background-color: #030303;
.toast-info { }
background-color: #2F96B4;
} .toast-success
{
.toast-warning { background-color: #51A351;
background-color: #F89406; }
}
.toast-error
.toast-top-right { {
top: 12px; background-color: #BD362F;
right: 12px; }
}
.toast-info
#toast-container > :hover { {
-moz-box-shadow: 0 0 12px #000000; background-color: #2F96B4;
-webkit-box-shadow: 0 0 12px #000000; }
-o-box-shadow: 0 0 12px #000000;
box-shadow: 0 0 12px #000000; .toast-warning
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; {
filter: alpha(opacity=100); background-color: #F89406;
-moz-opacity: 1; }
opacity: 1;
cursor: pointer; .toast-top-right
} {
right: 12px;
#toast-container > .toast-info { top: 12px;
background-image: url("") !important; }
}
#toast-container > :hover
#toast-container > .toast-error { {
background-image: url("") !important; -moz-box-shadow: 0 0 12px #000000;
} -webkit-box-shadow: 0 0 12px #000000;
box-shadow: 0 0 12px #000000;
#toast-container > .toast-success { cursor: pointer;
background-image: url("") !important; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
} filter: alpha(opacity=100);
opacity: 1;
#toast-container > .toast-warning { }
background-image: url("") !important;
} #toast-container > .toast-info
{
background-image: url("") !important;
}
#toast-container > .toast-error
{
background-image: url("") !important;
}
#toast-container > .toast-success
{
background-image: url("") !important;
}
#toast-container > .toast-warning
{
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

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