roykin/adm/themes/default/js/admin-theme.js
Thibault UBUNTU 3d7f60a05e push site
2016-03-03 10:33:17 +01:00

478 lines
14 KiB
JavaScript
Executable File

/*
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-3.0.php
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@prestashop.com so we can send you a copy immediately.
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future. If you wish to customize PrestaShop for your
* needs please refer to http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2015 PrestaShop SA
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
//build confirmation modal
function confirm_modal(heading, question, left_button_txt, right_button_txt, left_button_callback, right_button_callback) {
var confirmModal =
$('<div class="bootstrap modal hide fade">' +
'<div class="modal-dialog">' +
'<div class="modal-content">' +
'<div class="modal-header">' +
'<a class="close" data-dismiss="modal" >&times;</a>' +
'<h3>' + heading + '</h3>' +
'</div>' +
'<div class="modal-body">' +
'<p>' + question + '</p>' +
'</div>' +
'<div class="modal-footer">' +
'<a href="#" id="confirm_modal_left_button" class="btn btn-primary">' +
left_button_txt +
'</a>' +
'<a href="#" id="confirm_modal_right_button" class="btn btn-primary">' +
right_button_txt +
'</a>' +
'</div>' +
'</div>' +
'</div>' +
'</div>');
confirmModal.find('#confirm_modal_left_button').click(function () {
left_button_callback();
confirmModal.modal('hide');
});
confirmModal.find('#confirm_modal_right_button').click(function () {
right_button_callback();
confirmModal.modal('hide');
});
confirmModal.modal('show');
}
//build error modal
/* global error_continue_msg */
function error_modal(heading, msg) {
var errorModal =
$('<div class="bootstrap modal hide fade">' +
'<div class="modal-dialog">' +
'<div class="modal-content">' +
'<div class="modal-header">' +
'<a class="close" data-dismiss="modal" >&times;</a>' +
'<h4>' + heading + '</h4>' +
'</div>' +
'<div class="modal-body">' +
'<p>' + msg + '</p>' +
'</div>' +
'<div class="modal-footer">' +
'<a href="#" id="error_modal_right_button" class="btn btn-default">' +
error_continue_msg +
'</a>' +
'</div>' +
'</div>' +
'</div>' +
'</div>');
errorModal.find('#error_modal_right_button').click(function () {
errorModal.modal('hide');
});
errorModal.modal('show');
}
//move to hash after clicking on anchored links
function scroll_if_anchor(href) {
href = typeof(href) === "string" ? href : $(this).attr("href");
var fromTop = 120;
if(href.indexOf("#") === 0) {
var $target = $(href);
if($target.length) {
$('html, body').animate({ scrollTop: $target.offset().top - fromTop });
if(history && "pushState" in history) {
history.pushState({}, document.title, window.location.href + href);
return false;
}
}
}
}
$(document).ready(function() {
//set main navigation aside
/* global employee_token */
function navSidebar(){
var sidebar = $('#nav-sidebar');
sidebar.off();
$('.expanded').removeClass('expanded');
$('.maintab').not('.active').closest('.submenu').hide();
sidebar.on('click','.submenu_expand', function(){
var $navId = $(this).parent();
$('.submenu-collapse').remove();
if($('.expanded').length ){
$('.expanded > ul').slideUp('fast', function(){
var $target = $('.expanded');
$target.removeClass('expanded');
$($navId).not($target).not('.active').addClass('expanded');
$($navId).not($target).not('.active').children('ul:first').hide().slideDown();
});
}
else {
$($navId).not('.active').addClass('expanded');
$($navId).not('.active').children('ul:first').hide().slideDown();
}
});
//sidebar menu collapse
sidebar.find('.menu-collapse').on('click',function(){
$(this).toggleClass('icon-rotate-90');
if ($(this).hasClass('icon-rotate-90')) {
$(this).css('margin-left', '5px');
$('.page-head .page-title').css('padding-left', '70px');
$('.page-head .breadcrumb').css('left', '70px');
$('.page-head .page-subtitle').css('left', '70px');
} else {
$(this).css('margin-left', '');
$('.page-head .page-title').css('padding-left', '230px');
$('.page-head .breadcrumb').css('left', '230px');
$('.page-head .page-subtitle').css('left', '230px');
}
$('body').toggleClass('page-sidebar-closed');
$('.expanded').removeClass('expanded');
$.ajax({
url: "index.php",
cache: false,
data: "token="+employee_token+'&ajax=1&action=toggleMenu&tab=AdminEmployees&collapse='+Number($('body').hasClass('page-sidebar-closed'))
});
});
var menuCollapse = sidebar.find('.menu-collapse');
if ($('body').hasClass('page-sidebar-closed')) {
menuCollapse.addClass('icon-rotate-90');
menuCollapse.css('margin-left', '5px');
$('.page-head .page-title').css('padding-left', '70px');
$('.page-head .breadcrumb').css('left', '70px');
$('.page-head .page-subtitle').css('left', '70px');
}
}
function navTopbarReset() {
ellipsed = [];
$('#ellipsistab').remove();
$('#nav-topbar ul.menu').find('li.maintab').each(function(){
$(this).removeClass('hide');
});
}
//agregate out of bounds items from top menu into ellipsis dropdown
function navTopbarEllipsis() {
navTopbarReset();
$('#nav-topbar ul.menu').find('li.maintab').each(function(){
if ($(this).position().top > 0) {
ellipsed.push($(this).html());
$(this).addClass('hide');
}
});
if (ellipsed.length > 0) {
$('#nav-topbar ul.menu').append('<li id="ellipsistab" class="subtab has_submenu"><a href="#"><i class="icon-ellipsis-horizontal"></i></a><ul id="ellipsis_submenu" class="submenu"></ul></li>');
for (var i = 0; i < ellipsed.length; i++) {
$('#ellipsis_submenu').append('<li class="subtab has_submenu">' + ellipsed[i] + '</li>');
}
}
}
//set main navigation on top
function navTopbar() {
navTopbarReset();
$('#nav-sidebar').attr('id','nav-topbar');
var topbar = $('#nav-topbar');
topbar.off();
$('span.submenu_expand').remove();
$('.expanded').removeClass('expanded');
// expand elements with submenu
topbar.on('mouseenter', 'li.has_submenu', function(){
$(this).addClass('expanded');
});
topbar.on('mouseleave', 'li.has_submenu', function(){
$(this).removeClass('expanded');
});
// hide element over menu width on load
navTopbarEllipsis();
//hide element over menu width on resize
$(window).on('resize', function() {
navTopbarEllipsis();
});
}
//set main navigation for mobile devices
function mobileNav() {
navTopbarReset();
// clean actual menu type
// get it in navigation whatever type it is
var navigation = $('#nav-sidebar,#nav-topbar');
navigation.find('.menu').hide();
var submenu = "";
// clean trigger
navigation.off().attr('id','nav-mobile');
$('span.menu-collapse').off();
navigation.on('click.collapse','span.menu-collapse',function(){
if ($(this).hasClass('expanded')){
$(this).html('<i class="icon-align-justify"></i>');
navigation.find('ul.menu').hide();
navigation.removeClass('expanded');
$(this).removeClass('expanded');
//remove submenu when closing nav
$('#nav-mobile-submenu').remove();
}
else {
$(this).html('<i class="icon-remove"></i>');
navigation.find('ul.menu').removeClass('menu-close').show();
navigation.addClass('expanded');
$(this).addClass('expanded');
}
});
//get click for item which has submenu
navigation.on('click.submenu','.maintab.has_submenu a.title', function(e){
e.preventDefault();
navigation.find('.menu').addClass('menu-close');
$('#nav-mobile-submenu').remove();
//create submenu
submenu = $('<ul id="nav-mobile-submenu" class="menu"><li><a href="#" id="nav-mobile-submenu-back"><i class="icon-arrow-left"></i>'+ $(this).html() +'</a></li></ul>');
submenu.append($(this).closest('.maintab').find('.submenu').html());
//show submenu
navigation.append(submenu);
submenu.show();
});
navigation.on('click.back','#nav-mobile-submenu-back',function(e){
e.preventDefault();
submenu.remove();
navigation.find('.menu').removeClass('menu-close').show();
});
}
//unset mobile nav
function removeMobileNav(){
var navigation = $('#nav-mobile');
$('#nav-mobile-submenu').remove();
$('span.menu-collapse').html('<i class="icon-align-justify"></i>');
navigation.off();
if ($('body').hasClass('page-sidebar')){
navigation.attr('id',"nav-sidebar");
navSidebar();
} else if ($('body').hasClass('page-topbar')){
navigation.attr('id',"nav-topbar");
navTopbar();
}
navigation.find('.menu').show();
}
//init main navigation
function initNav(){
if ($('body').hasClass('page-sidebar')){
navSidebar();
}
else if ($('body').hasClass('page-topbar')) {
navTopbar();
}
}
//show footer when reach bottom
function animateFooter(){
if($(window).scrollTop() + $(window).height() === $(document).height()) {
$('#footer:hidden').removeClass('hide');
} else {
$('#footer').addClass('hide');
}
}
//scroll top
function animateGoTop() {
if ($(window).scrollTop()) {
$('#go-top:hidden').stop(true, true).fadeIn();
$('#go-top:hidden').removeClass('hide');
} else {
$('#go-top').stop(true, true).fadeOut();
}
}
var ellipsed = [];
initNav();
// prevent mouseout + direct path to submenu on sidebar uncollapsed navigation + avoid out of bounds
var closingMenu, openingMenu;
$('li.maintab.has_submenu').hover(function() {
var submenu = $(this);
if (submenu.is('.active') && submenu.children('ul.submenu').is(':visible')) {
return;
}
clearTimeout(openingMenu);
clearTimeout(closingMenu);
openingMenu = setTimeout(function(){
$('li.maintab').removeClass('hover');
$('ul.submenu.outOfBounds').removeClass('outOfBounds').css('top',0);
submenu.addClass('hover');
var h = $( window ).height();
var x = submenu.find('.submenu li').last().offset();
var l = x.top + submenu.find('.submenu li').last().height();
var f = 25;
if ($('#footer').is(':visible')){
f = $('#footer').height() + f;
}
var s = $(document).scrollTop();
var position = h - l - f + s;
var out = false;
if ( position < 0) {
out = true;
submenu.find('.submenu').addClass('outOfBounds').css('top', position);
}
},50);
}, function() {
var submenu = $(this);
closingMenu = setTimeout(function(){
submenu.removeClass('hover');
},250);
});
$('ul.submenu').on('mouseenter', function(){
clearTimeout(openingMenu);
});
//media queries - depends of enquire.js
/*global enquire*/
enquire.register('screen and (max-width: 1200px)', {
match : function() {
if( $('#main').hasClass('helpOpen')) {
$('.toolbarBox a.btn-help').trigger('click');
}
},
unmatch : function() {
}
});
enquire.register('screen and (max-width: 768px)', {
match : function() {
$('body.page-sidebar').addClass('page-sidebar-closed');
},
unmatch : function() {
$('body.page-sidebar').removeClass('page-sidebar-closed');
}
});
enquire.register('screen and (max-width: 480px)', {
match : function() {
$('body').addClass('mobile-nav');
mobileNav();
},
unmatch : function() {
$('body').removeClass('mobile-nav');
removeMobileNav();
}
});
//bootstrap components init
$('.dropdown-toggle').dropdown();
$('.label-tooltip, .help-tooltip').tooltip();
$('#error-modal').modal('show');
//init footer
animateFooter();
// go on top of the page
$('#go-top').on('click',function() {
$('html, body').animate({ scrollTop: 0 }, 'slow');
return false;
});
var timer;
$(window).scroll(function() {
if(timer) {
window.clearTimeout(timer);
}
timer = window.setTimeout(function() {
animateGoTop();
animateFooter();
}, 100);
});
// search with nav sidebar closed
$(document).on('click', '.page-sidebar-closed .searchtab' ,function() {
$(this).addClass('search-expanded');
$(this).find('#bo_query').focus();
});
$('.page-sidebar-closed').click(function() {
$('.searchtab').removeClass('search-expanded');
});
$('#header_search button').on('click', function(e){
e.stopPropagation();
});
//erase button search input
if ($('#bo_query').val() !== '') {
$('.clear_search').removeClass('hide');
}
$('.clear_search').on('click', function(e){
e.stopPropagation();
e.preventDefault();
var id = $(this).closest('form').attr('id');
$('#'+id+' #bo_query').val('').focus();
$('#'+id+' .clear_search').addClass('hide');
});
$('#bo_query').on('keydown', function(){
if ($('#bo_query').val() !== ''){
$('.clear_search').removeClass('hide');
}
});
//search with nav sidebar opened
$('.page-sidebar').click(function() {
$('#header_search .form-group').removeClass('focus-search');
});
$('#header_search #bo_query').on('click', function(e){
e.stopPropagation();
e.preventDefault();
if($('body').hasClass('mobile-nav')){
return false;
}
$('#header_search .form-group').addClass('focus-search');
});
//select list for search type
$('#header_search_options').on('click','li a', function(e){
e.preventDefault();
$('#header_search_options .search-option').removeClass('active');
$(this).closest('li').addClass('active');
$('#bo_search_type').val($(this).data('value'));
$('#search_type_icon').removeAttr("class").addClass($(this).data('icon'));
$('#bo_query').attr("placeholder",$(this).data('placeholder'));
$('#bo_query').focus();
});
// reset form
/* global header_confirm_reset, body_confirm_reset, left_button_confirm_reset, right_button_confirm_reset */
$(".reset_ready").click(function () {
var href = $(this).attr('href');
confirm_modal( header_confirm_reset, body_confirm_reset, left_button_confirm_reset, right_button_confirm_reset,
function () {
window.location.href = href + '&keep_data=1';
},
function () {
window.location.href = href + '&keep_data=0';
});
return false;
});
//scroll_if_anchor(window.location.hash);
$("body").on("click", "a.anchor", scroll_if_anchor);
}); //end dom ready