mirror of
https://github.com/PacktPublishing/Python-Digital-Forensics-Cookbook.git
synced 2026-02-21 19:27:59 +00:00
182 lines
5.8 KiB
JavaScript
182 lines
5.8 KiB
JavaScript
/*!
|
|
|
|
=========================================================
|
|
* Light Bootstrap Dashboard - v1.3.1.0
|
|
=========================================================
|
|
|
|
* Product Page: http://www.creative-tim.com/product/light-bootstrap-dashboard
|
|
* Copyright 2017 Creative Tim (http://www.creative-tim.com)
|
|
* Licensed under MIT (https://github.com/creativetimofficial/light-bootstrap-dashboard/blob/master/LICENSE.md)
|
|
|
|
=========================================================
|
|
|
|
* The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
|
|
*/
|
|
|
|
var searchVisible = 0;
|
|
var transparent = true;
|
|
|
|
var transparentDemo = true;
|
|
var fixedTop = false;
|
|
|
|
var navbar_initialized = false;
|
|
|
|
$(document).ready(function(){
|
|
window_width = $(window).width();
|
|
|
|
// check if there is an image set for the sidebar's background
|
|
lbd.checkSidebarImage();
|
|
|
|
// Init navigation toggle for small screens
|
|
if(window_width <= 991){
|
|
lbd.initRightMenu();
|
|
}
|
|
|
|
// Activate the tooltips
|
|
$('[rel="tooltip"]').tooltip();
|
|
|
|
// Activate the switches with icons
|
|
if($('.switch').length != 0){
|
|
$('.switch')['bootstrapSwitch']();
|
|
}
|
|
// Activate regular switches
|
|
if($("[data-toggle='switch']").length != 0){
|
|
$("[data-toggle='switch']").wrap('<div class="switch" />').parent().bootstrapSwitch();
|
|
}
|
|
|
|
$('.form-control').on("focus", function(){
|
|
$(this).parent('.input-group').addClass("input-group-focus");
|
|
}).on("blur", function(){
|
|
$(this).parent(".input-group").removeClass("input-group-focus");
|
|
});
|
|
|
|
// Fixes sub-nav not working as expected on IOS
|
|
$('body').on('touchstart.dropdown', '.dropdown-menu', function (e) { e.stopPropagation(); });
|
|
});
|
|
|
|
// activate collapse right menu when the windows is resized
|
|
$(window).resize(function(){
|
|
if($(window).width() <= 991){
|
|
lbd.initRightMenu();
|
|
}
|
|
});
|
|
|
|
lbd = {
|
|
misc:{
|
|
navbar_menu_visible: 0
|
|
},
|
|
|
|
checkSidebarImage: function(){
|
|
$sidebar = $('.sidebar');
|
|
image_src = $sidebar.data('image');
|
|
|
|
if(image_src !== undefined){
|
|
sidebar_container = '<div class="sidebar-background" style="background-image: url(' + image_src + ') "/>'
|
|
$sidebar.append(sidebar_container);
|
|
}
|
|
},
|
|
initRightMenu: function(){
|
|
if(!navbar_initialized){
|
|
$navbar = $('nav').find('.navbar-collapse').first().clone(true);
|
|
|
|
$sidebar = $('.sidebar');
|
|
sidebar_color = $sidebar.data('color');
|
|
|
|
$logo = $sidebar.find('.logo').first();
|
|
logo_content = $logo[0].outerHTML;
|
|
|
|
ul_content = '';
|
|
|
|
$navbar.attr('data-color',sidebar_color);
|
|
|
|
//add the content from the regular header to the right menu
|
|
$navbar.children('ul').each(function(){
|
|
content_buff = $(this).html();
|
|
ul_content = ul_content + content_buff;
|
|
});
|
|
|
|
// add the content from the sidebar to the right menu
|
|
content_buff = $sidebar.find('.nav').html();
|
|
ul_content = ul_content + content_buff;
|
|
|
|
|
|
ul_content = '<div class="sidebar-wrapper">' +
|
|
'<ul class="nav navbar-nav">' +
|
|
ul_content +
|
|
'</ul>' +
|
|
'</div>';
|
|
|
|
navbar_content = logo_content + ul_content;
|
|
|
|
$navbar.html(navbar_content);
|
|
|
|
$('body').append($navbar);
|
|
|
|
background_image = $sidebar.data('image');
|
|
if(background_image != undefined){
|
|
$navbar.css('background',"url('" + background_image + "')")
|
|
.removeAttr('data-nav-image')
|
|
.addClass('has-image');
|
|
}
|
|
|
|
|
|
$toggle = $('.navbar-toggle');
|
|
|
|
$navbar.find('a').removeClass('btn btn-round btn-default');
|
|
$navbar.find('button').removeClass('btn-round btn-fill btn-info btn-primary btn-success btn-danger btn-warning btn-neutral');
|
|
$navbar.find('button').addClass('btn-simple btn-block');
|
|
|
|
$toggle.click(function (){
|
|
if(lbd.misc.navbar_menu_visible == 1) {
|
|
$('html').removeClass('nav-open');
|
|
lbd.misc.navbar_menu_visible = 0;
|
|
$('#bodyClick').remove();
|
|
setTimeout(function(){
|
|
$toggle.removeClass('toggled');
|
|
}, 400);
|
|
|
|
} else {
|
|
setTimeout(function(){
|
|
$toggle.addClass('toggled');
|
|
}, 430);
|
|
|
|
div = '<div id="bodyClick"></div>';
|
|
$(div).appendTo("body").click(function() {
|
|
$('html').removeClass('nav-open');
|
|
lbd.misc.navbar_menu_visible = 0;
|
|
$('#bodyClick').remove();
|
|
setTimeout(function(){
|
|
$toggle.removeClass('toggled');
|
|
}, 400);
|
|
});
|
|
|
|
$('html').addClass('nav-open');
|
|
lbd.misc.navbar_menu_visible = 1;
|
|
|
|
}
|
|
});
|
|
navbar_initialized = true;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
|
|
// Returns a function, that, as long as it continues to be invoked, will not
|
|
// be triggered. The function will be called after it stops being called for
|
|
// N milliseconds. If `immediate` is passed, trigger the function on the
|
|
// leading edge, instead of the trailing.
|
|
|
|
function debounce(func, wait, immediate) {
|
|
var timeout;
|
|
return function() {
|
|
var context = this, args = arguments;
|
|
clearTimeout(timeout);
|
|
timeout = setTimeout(function() {
|
|
timeout = null;
|
|
if (!immediate) func.apply(context, args);
|
|
}, wait);
|
|
if (immediate && !timeout) func.apply(context, args);
|
|
};
|
|
}; |