Browse Source

Updated toastr to 2.1.0

pull/156/head
Simon Eisenmann 11 years ago
parent
commit
5a3ac20110
  1. 44
      src/styles/libs/toastr/toastr.scss
  2. 68
      static/js/libs/toastr.js

44
src/styles/libs/toastr/toastr.scss

@ -1,12 +1,13 @@ @@ -1,12 +1,13 @@
/*
* Toastr
* Version 2.0.1
* Copyright 2012 John Papa and Hans Fjällemark.
* Copyright 2012-2014
* Authors: John Papa, Hans Fjällemark, and Tim Ferrell.
* All Rights Reserved.
* Use, reproduction, distribution, and modification of this code is subject to the terms and
* conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php
*
* Author: John Papa and Hans Fjällemark
* ARIA Support: Greta Krafsig
*
* Project: https://github.com/CodeSeven/toastr
*/
.toast-title {
@ -24,7 +25,6 @@ @@ -24,7 +25,6 @@
color: #cccccc;
text-decoration: none;
}
.toast-close-button {
position: relative;
right: -0.3em;
@ -48,7 +48,6 @@ @@ -48,7 +48,6 @@
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40);
filter: alpha(opacity=40);
}
/*Additional properties for button version
iOS requires the button element instead of an anchor tag.
If you want the anchor version, it requires `href="#"`.*/
@ -59,6 +58,16 @@ button.toast-close-button { @@ -59,6 +58,16 @@ button.toast-close-button {
border: 0;
-webkit-appearance: none;
}
.toast-top-center {
top: 0;
right: 0;
width: 100%;
}
.toast-bottom-center {
bottom: 0;
right: 0;
width: 100%;
}
.toast-top-full-width {
top: 0;
right: 0;
@ -97,6 +106,8 @@ button.toast-close-button { @@ -97,6 +106,8 @@ button.toast-close-button {
box-sizing: border-box;
}
#toast-container > div {
position: relative;
overflow: hidden;
margin: 0 0 6px;
padding: 15px 15px 15px 50px;
width: 300px;
@ -134,6 +145,11 @@ button.toast-close-button { @@ -134,6 +145,11 @@ button.toast-close-button {
#toast-container > .toast-warning {
background-image: url("") !important;
}
#toast-container.toast-top-center > div,
#toast-container.toast-bottom-center > div {
width: 300px;
margin: auto;
}
#toast-container.toast-top-full-width > div,
#toast-container.toast-bottom-full-width > div {
width: 96%;
@ -154,8 +170,20 @@ button.toast-close-button { @@ -154,8 +170,20 @@ button.toast-close-button {
.toast-warning {
background-color: #f89406;
}
.toast-progress {
position: absolute;
left: 0;
bottom: 0;
height: 4px;
background-color: #000000;
opacity: 0.4;
-ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=40);
filter: alpha(opacity=40);
}
/*Responsive Design*/
@media all and (max-width: 239px) {
@media all and (max-width: 240px) {
#toast-container > div {
padding: 8px 8px 8px 50px;
width: 11em;
@ -165,7 +193,7 @@ button.toast-close-button { @@ -165,7 +193,7 @@ button.toast-close-button {
top: -0.2em;
}
}
@media all and (min-width: 240px) and (max-width: 479px) {
@media all and (min-width: 241px) and (max-width: 480px) {
#toast-container > div {
padding: 8px 8px 8px 50px;
width: 18em;
@ -175,7 +203,7 @@ button.toast-close-button { @@ -175,7 +203,7 @@ button.toast-close-button {
top: -0.2em;
}
}
@media all and (min-width: 480px) and (max-width: 767px) {
@media all and (min-width: 481px) and (max-width: 768px) {
#toast-container > div {
padding: 15px 15px 15px 50px;
width: 25em;

68
static/js/libs/toastr.js

@ -1,12 +1,13 @@ @@ -1,12 +1,13 @@
/*
* Toastr
* Copyright 2012-2014 John Papa and Hans Fjällemark.
* Copyright 2012-2014
* Authors: John Papa, Hans Fjällemark, and Tim Ferrell.
* All Rights Reserved.
* Use, reproduction, distribution, and modification of this code is subject to the terms and
* conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php
*
* Author: John Papa and Hans Fjällemark
* ARIA Support: Greta Krafsig
*
* Project: https://github.com/CodeSeven/toastr
*/
; (function (define) {
@ -31,10 +32,12 @@ @@ -31,10 +32,12 @@
options: {},
subscribe: subscribe,
success: success,
version: '2.0.3',
version: '2.1.0',
warning: warning
};
var previousToast;
return toastr;
//#region Accessible Methods
@ -54,7 +57,7 @@ @@ -54,7 +57,7 @@
if ($container.length) {
return $container;
}
if(create) {
if (create) {
$container = createContainer(options);
}
return $container;
@ -117,14 +120,14 @@ @@ -117,14 +120,14 @@
//#region Internal Methods
function clearContainer(options){
function clearContainer (options) {
var toastsToClear = $container.children();
for (var i = toastsToClear.length - 1; i >= 0; i--) {
clearToast($(toastsToClear[i]), options);
};
}
}
function clearToast($toastElement, options){
function clearToast ($toastElement, options) {
if ($toastElement && $(':focus', $toastElement).length === 0) {
$toastElement[options.hideMethod]({
duration: options.hideDuration,
@ -172,12 +175,14 @@ @@ -172,12 +175,14 @@
},
iconClass: 'toast-info',
positionClass: 'toast-top-right',
timeOut: 5000, // Set timeOut and extendedTimeout to 0 to make it sticky
timeOut: 5000, // Set timeOut and extendedTimeOut to 0 to make it sticky
titleClass: 'toast-title',
messageClass: 'toast-message',
target: 'body',
closeHtml: '<button>&times;</button>',
newestOnTop: true
newestOnTop: true,
preventDuplicates: false,
progressBar: false
};
}
@ -190,6 +195,14 @@ @@ -190,6 +195,14 @@
var options = getOptions(),
iconClass = map.iconClass || options.iconClass;
if (options.preventDuplicates) {
if (map.message === previousToast) {
return;
} else {
previousToast = map.message;
}
}
if (typeof (map.optionsOverride) !== 'undefined') {
options = $.extend(options, map.optionsOverride);
iconClass = map.optionsOverride.iconClass || iconClass;
@ -202,7 +215,13 @@ @@ -202,7 +215,13 @@
$toastElement = $('<div/>'),
$titleElement = $('<div/>'),
$messageElement = $('<div/>'),
$progressElement = $('<div/>'),
$closeElement = $(options.closeHtml),
progressBar = {
intervalId: null,
hideEta: null,
maxHideTime: null
},
response = {
toastId: toastId,
state: 'visible',
@ -226,24 +245,32 @@ @@ -226,24 +245,32 @@
}
if (options.closeButton) {
$closeElement.addClass('toast-close-button').attr("role", "button");
$closeElement.addClass('toast-close-button').attr('role', 'button');
$toastElement.prepend($closeElement);
}
if (options.progressBar) {
$progressElement.addClass('toast-progress');
$toastElement.prepend($progressElement);
}
$toastElement.hide();
if (options.newestOnTop) {
$container.prepend($toastElement);
} else {
$container.append($toastElement);
}
$toastElement[options.showMethod](
{ duration: options.showDuration, easing: options.showEasing, complete: options.onShown }
{duration: options.showDuration, easing: options.showEasing, complete: options.onShown}
);
if (options.timeOut > 0) {
intervalId = setTimeout(hideToast, options.timeOut);
progressBar.maxHideTime = parseFloat(options.timeOut);
progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;
if (options.progressBar) {
progressBar.intervalId = setInterval(updateProgress, 10);
}
}
$toastElement.hover(stickAround, delayedHideToast);
@ -253,9 +280,9 @@ @@ -253,9 +280,9 @@
if (options.closeButton && $closeElement) {
$closeElement.click(function (event) {
if( event.stopPropagation ) {
if (event.stopPropagation) {
event.stopPropagation();
} else if( event.cancelBubble !== undefined && event.cancelBubble !== true ) {
} else if (event.cancelBubble !== undefined && event.cancelBubble !== true) {
event.cancelBubble = true;
}
hideToast(true);
@ -281,6 +308,7 @@ @@ -281,6 +308,7 @@
if ($(':focus', $toastElement).length && !override) {
return;
}
clearTimeout(progressBar.intervalId);
return $toastElement[options.hideMethod]({
duration: options.hideDuration,
easing: options.hideEasing,
@ -299,16 +327,24 @@ @@ -299,16 +327,24 @@
function delayedHideToast() {
if (options.timeOut > 0 || options.extendedTimeOut > 0) {
intervalId = setTimeout(hideToast, options.extendedTimeOut);
progressBar.maxHideTime = parseFloat(options.extendedTimeOut);
progressBar.hideEta = new Date().getTime() + progressBar.maxHideTime;
}
}
function stickAround() {
clearTimeout(intervalId);
progressBar.hideEta = 0;
/* Disabled to support custom jQuery without animations.
$toastElement.stop(true, true)[options.showMethod](
{ duration: options.showDuration, easing: options.showEasing }
{duration: options.showDuration, easing: options.showEasing}
);*/
}
function updateProgress() {
var percentage = ((progressBar.hideEta - (new Date().getTime())) / progressBar.maxHideTime) * 100;
$progressElement.width(percentage + '%');
}
}
function getOptions() {

Loading…
Cancel
Save