diff --git a/Netdisco/public/css/toastr-responsive.css b/Netdisco/public/css/toastr-responsive.css deleted file mode 100644 index c27ed9fe..00000000 --- a/Netdisco/public/css/toastr-responsive.css +++ /dev/null @@ -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; - } -} \ No newline at end of file diff --git a/Netdisco/public/css/toastr.css b/Netdisco/public/css/toastr.css index 74e59e5a..94244a97 100644 --- a/Netdisco/public/css/toastr.css +++ b/Netdisco/public/css/toastr.css @@ -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; + } +} diff --git a/Netdisco/public/javascripts/toastr.js b/Netdisco/public/javascripts/toastr.js index 5ec9a854..e254135c 100644 --- a/Netdisco/public/javascripts/toastr.js +++ b/Netdisco/public/javascripts/toastr.js @@ -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 = $('
') - .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 = $('
'), - $titleElement = $('
'), - $messageElement = $('
'), - 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)); \ No newline at end of file +// 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 = $('
') + .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 = $('
'), + $titleElement = $('
'), + $messageElement = $('
'), + 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']); + } +})); \ No newline at end of file diff --git a/Netdisco/views/layouts/main.tt b/Netdisco/views/layouts/main.tt index 75407fd5..8d33e4d6 100644 --- a/Netdisco/views/layouts/main.tt +++ b/Netdisco/views/layouts/main.tt @@ -28,7 +28,6 @@ - [% END %]