diff --git a/src/styles/libs/toastr/toastr.scss b/src/styles/libs/toastr/toastr.scss index 71f017ba..e4a7bc2f 100644 --- a/src/styles/libs/toastr/toastr.scss +++ b/src/styles/libs/toastr/toastr.scss @@ -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 @@ color: #cccccc; text-decoration: none; } - .toast-close-button { position: relative; right: -0.3em; @@ -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 { 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 { 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 { #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 { .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 { 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 { 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; diff --git a/static/js/libs/toastr.js b/static/js/libs/toastr.js index 7c4e1b5b..d0c6df7a 100644 --- a/static/js/libs/toastr.js +++ b/static/js/libs/toastr.js @@ -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 @@ 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 @@ if ($container.length) { return $container; } - if(create) { + if (create) { $container = createContainer(options); } return $container; @@ -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 @@ }, 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: '', - newestOnTop: true + newestOnTop: true, + preventDuplicates: false, + progressBar: false }; } @@ -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 @@ $toastElement = $('
'), $titleElement = $('
'), $messageElement = $('
'), + $progressElement = $('
'), $closeElement = $(options.closeHtml), + progressBar = { + intervalId: null, + hideEta: null, + maxHideTime: null + }, response = { toastId: toastId, state: 'visible', @@ -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 @@ 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 @@ if ($(':focus', $toastElement).length && !override) { return; } + clearTimeout(progressBar.intervalId); return $toastElement[options.hideMethod]({ duration: options.hideDuration, easing: options.hideEasing, @@ -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() {