update to latest toastr
This commit is contained in:
		| @@ -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; | ||||
| 	} | ||||
| } | ||||
| @@ -1,109 +1,174 @@ | ||||
| .toast-title { | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| .toast-message { | ||||
| } | ||||
|  | ||||
|     .toast-message a, | ||||
|     .toast-message label { | ||||
|         color: #FFF; | ||||
|     } | ||||
|  | ||||
|         .toast-message a:hover { | ||||
|             color: #CCC; | ||||
|             text-decoration: none; | ||||
|         } | ||||
|  | ||||
| .toast-top-left { | ||||
|     top: 12px; | ||||
|     left: 12px; | ||||
| } | ||||
|  | ||||
| .toast-bottom-right { | ||||
|     right: 12px; | ||||
|     bottom: 12px; | ||||
| } | ||||
|  | ||||
| .toast-bottom-left { | ||||
|     left: 12px; | ||||
|     bottom: 12px; | ||||
| } | ||||
|  | ||||
| #toast-container { | ||||
|     position: fixed; | ||||
|     z-index: 9999; | ||||
| } | ||||
|  | ||||
|     #toast-container > div { | ||||
|         background-position: 15px center; | ||||
|         background-repeat: no-repeat; | ||||
|         -moz-border-radius: 3px 3px 3px 3px; | ||||
|         -webkit-border-radius: 3px 3px 3px 3px; | ||||
|         border-radius: 3px 3px 3px 3px; | ||||
|         -moz-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; | ||||
|         color: #FFFFFF; | ||||
|         margin: 0 0 6px; | ||||
|         -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)"; | ||||
|         filter: alpha(opacity=80); | ||||
|         -moz-opacity: 0.8; | ||||
|         opacity: 0.8; | ||||
|         padding: 15px 15px 15px 50px; | ||||
|         width: 300px; | ||||
|     } | ||||
|  | ||||
| .toast { | ||||
|     background-color: #030303; | ||||
| } | ||||
|  | ||||
| .toast-success { | ||||
|     background-color: #51A351; | ||||
| } | ||||
|  | ||||
| .toast-error { | ||||
|     background-color: #BD362F; | ||||
| } | ||||
|  | ||||
| .toast-info { | ||||
|     background-color: #2F96B4; | ||||
| } | ||||
|  | ||||
| .toast-warning { | ||||
|     background-color: #F89406; | ||||
| } | ||||
|  | ||||
| .toast-top-right { | ||||
|     top: 12px; | ||||
|     right: 12px; | ||||
| } | ||||
|  | ||||
| #toast-container > :hover { | ||||
|     -moz-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; | ||||
|     -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; | ||||
|     filter: alpha(opacity=100); | ||||
|     -moz-opacity: 1; | ||||
|     opacity: 1; | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| #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; | ||||
| } | ||||
| .toast-title | ||||
| { | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| .toast-message | ||||
| { | ||||
|     -ms-word-wrap: break-word; | ||||
|     word-wrap: break-word; | ||||
| } | ||||
|  | ||||
|     .toast-message a, | ||||
|     .toast-message label | ||||
|     { | ||||
|         color: #FFF; | ||||
|     } | ||||
|  | ||||
|         .toast-message a:hover | ||||
|         { | ||||
|             color: #CCC; | ||||
|             text-decoration: none; | ||||
|         } | ||||
|  | ||||
| .toast-top-left | ||||
| { | ||||
|     left: 12px; | ||||
|     top: 12px; | ||||
| } | ||||
|  | ||||
| .toast-bottom-right | ||||
| { | ||||
|     bottom: 12px; | ||||
|     right: 12px; | ||||
| } | ||||
|  | ||||
| .toast-bottom-left | ||||
| { | ||||
|     bottom: 12px; | ||||
|     left: 12px; | ||||
| } | ||||
|  | ||||
| #toast-container | ||||
| { | ||||
|     position: fixed; | ||||
|     z-index: 9999; | ||||
| } | ||||
|  | ||||
|     #toast-container > div | ||||
|     { | ||||
|         background-position: 15px center; | ||||
|         background-repeat: no-repeat; | ||||
|         -moz-border-radius: 3px 3px 3px 3px; | ||||
|         -webkit-border-radius: 3px 3px 3px 3px; | ||||
|         border-radius: 3px 3px 3px 3px; | ||||
|         -moz-box-shadow: 0 0 12px #999999; | ||||
|         -webkit-box-shadow: 0 0 12px #999999; | ||||
|         box-shadow: 0 0 12px #999999; | ||||
|         color: #FFFFFF; | ||||
|         -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)"; | ||||
|         filter: alpha(opacity=80); | ||||
|         margin: 0 0 6px; | ||||
|         opacity: 0.8; | ||||
|         padding: 15px 15px 15px 50px; | ||||
|         width: 300px; | ||||
|     } | ||||
|  | ||||
| .toast | ||||
| { | ||||
|     background-color: #030303; | ||||
| } | ||||
|  | ||||
| .toast-success | ||||
| { | ||||
|     background-color: #51A351; | ||||
| } | ||||
|  | ||||
| .toast-error | ||||
| { | ||||
|     background-color: #BD362F; | ||||
| } | ||||
|  | ||||
| .toast-info | ||||
| { | ||||
|     background-color: #2F96B4; | ||||
| } | ||||
|  | ||||
| .toast-warning | ||||
| { | ||||
|     background-color: #F89406; | ||||
| } | ||||
|  | ||||
| .toast-top-right | ||||
| { | ||||
|     right: 12px; | ||||
|     top: 12px; | ||||
| } | ||||
|  | ||||
| #toast-container > :hover | ||||
| { | ||||
|     -moz-box-shadow: 0 0 12px #000000; | ||||
|     -webkit-box-shadow: 0 0 12px #000000; | ||||
|     box-shadow: 0 0 12px #000000; | ||||
|     cursor: pointer; | ||||
|     -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; | ||||
|     filter: alpha(opacity=100); | ||||
|     opacity: 1; | ||||
| } | ||||
|  | ||||
| #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; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,173 +1,195 @@ | ||||
| // By: Hans Fjällemark and John Papa | ||||
| // https://github.com/CodeSeven/toastr | ||||
| //  | ||||
| // Modified to support css styling instead of inline styling | ||||
| // Inspired by https://github.com/Srirangan/notifer.js/ | ||||
|  | ||||
| ;(function(window, $) { | ||||
|     window.toastr = (function() { | ||||
|         var  | ||||
|             defaults = { | ||||
|                 tapToDismiss: true, | ||||
|                 toastClass: 'toast', | ||||
|                 containerId: 'toast-container', | ||||
|                 debug: false, | ||||
|                 fadeIn: 300, | ||||
|                 fadeOut: 1000, | ||||
|                 extendedTimeOut: 1000, | ||||
|                 iconClasses: { | ||||
|                     error: 'toast-error', | ||||
|                     info: 'toast-info', | ||||
|                     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' | ||||
|             }, | ||||
|  | ||||
|  | ||||
|             error = function(message, title) { | ||||
|                 return notify({ | ||||
|                     iconClass: getOptions().iconClasses.error, | ||||
|                     message: message, | ||||
|                     title: title | ||||
|                 }) | ||||
|             }, | ||||
|  | ||||
|             getContainer = function(options) { | ||||
|                 var $container = $('#' + options.containerId) | ||||
|  | ||||
|                 if ($container.length) | ||||
|                     return $container | ||||
|  | ||||
|                 $container = $('<div/>') | ||||
|                     .attr('id', options.containerId) | ||||
|                     .addClass(options.positionClass) | ||||
|  | ||||
|                 $container.appendTo($('body')) | ||||
|  | ||||
|                 return $container | ||||
|             }, | ||||
|  | ||||
|             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() { | ||||
|                         if ($toastElement.is(':visible')) { | ||||
|                             return | ||||
|                         } | ||||
|                         $toastElement.remove() | ||||
|                         if ($container.children().length === 0) | ||||
|                             $container.remove() | ||||
|                     }) | ||||
|                 } | ||||
|  | ||||
|                 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.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)); | ||||
| // By: Hans Fjällemark and John Papa | ||||
| // https://github.com/CodeSeven/toastr | ||||
| //  | ||||
| // Modified to support css styling instead of inline styling | ||||
| // Inspired by https://github.com/Srirangan/notifer.js/ | ||||
|  | ||||
| ; (function (define) { | ||||
|     define(['jquery'], function ($) { | ||||
|         var toastr = (function () { | ||||
|             var | ||||
|                 defaults = { | ||||
|                     tapToDismiss: true, | ||||
|                     toastClass: 'toast', | ||||
|                     containerId: 'toast-container', | ||||
|                     debug: false, | ||||
|                     fadeIn: 300, | ||||
|                     fadeOut: 1000, | ||||
|                     extendedTimeOut: 1000, | ||||
|                     iconClasses: { | ||||
|                         error: 'toast-error', | ||||
|                         info: 'toast-info', | ||||
|                         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' | ||||
|                 }, | ||||
|  | ||||
|                 error = function (message, title, optionsOverride) { | ||||
|                     return notify({ | ||||
|                         iconClass: getOptions().iconClasses.error, | ||||
|                         message: message, | ||||
|                         optionsOverride: optionsOverride, | ||||
|                         title: title | ||||
|                     }); | ||||
|                 }, | ||||
|  | ||||
|                 getContainer = function (options) { | ||||
|                     var $container = $('#' + options.containerId); | ||||
|                     if ($container.length) { | ||||
|                         return $container; | ||||
|                     } | ||||
|                     $container = $('<div/>') | ||||
|                         .attr('id', options.containerId) | ||||
|                         .addClass(options.positionClass); | ||||
|                     $container.appendTo($('body')); | ||||
|                     return $container; | ||||
|                 }, | ||||
|  | ||||
|                 getOptions = function () { | ||||
|                     return $.extend({}, defaults, toastr.options); | ||||
|                 }, | ||||
|  | ||||
|                 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), | ||||
|                         $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 (callback) { | ||||
|                             return $toastElement.fadeOut(options.fadeOut, callback); | ||||
|                         }; | ||||
|                         var removeToast = function () { | ||||
|                             if ($toastElement.is(':visible')) { | ||||
|                                 return; | ||||
|                             } | ||||
|                             $toastElement.remove(); | ||||
|                             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(); | ||||
|                     }); | ||||
|                 } | ||||
|             }; | ||||
|             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']); | ||||
|     } | ||||
| })); | ||||
| @@ -28,7 +28,6 @@ | ||||
|   <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-responsive.css"/> | ||||
|   [% END %] | ||||
|  | ||||
|   <link rel="stylesheet" href="[% uri_base %]/css/bootstrap.min.css"/> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user