1
0
mirror of https://gitee.com/coder-xiaomo/flashsale synced 2025-01-31 05:30:25 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee

313 lines
11 KiB
JavaScript

/**
Core script to handle the entire theme and core functions
**/
var Layout = function () {
var layoutImgPath = '/public/admin/layout/img/';
var layoutCssPath = '/public/admin/layout/css/';
var resBreakpointMd = App.getResponsiveBreakpoint('md');
//* BEGIN:CORE HANDLERS *//
// this function handles responsive layout on screen size resize or mobile device rotate.
// Handles header
var handleHeader = function () {
// handle search box expand/collapse
$('.page-header').on('click', '.search-form', function (e) {
$(this).addClass("open");
$(this).find('.form-control').focus();
$('.page-header .search-form .form-control').on('blur', function (e) {
$(this).closest('.search-form').removeClass("open");
$(this).unbind("blur");
});
});
// handle hor menu search form on enter press
$('.page-header').on('keypress', '.hor-menu .search-form .form-control', function (e) {
if (e.which == 13) {
$(this).closest('.search-form').submit();
return false;
}
});
// handle header search button click
$('.page-header').on('mousedown', '.search-form.open .submit', function (e) {
e.preventDefault();
e.stopPropagation();
$(this).closest('.search-form').submit();
});
// handle scrolling to top on responsive menu toggler click when header is fixed for mobile view
$('body').on('click', '.page-header-top-fixed .page-header-top .menu-toggler', function(){
App.scrollTop();
});
};
// Handles main menu
var handleMainMenu = function () {
// handle menu toggler icon click
$(".page-header .menu-toggler").on("click", function(event) {
if (App.getViewPort().width < resBreakpointMd) {
var menu = $(".page-header .page-header-menu");
if (menu.is(":visible")) {
menu.slideUp(300);
} else {
menu.slideDown(300);
}
if ($('body').hasClass('page-header-top-fixed')) {
App.scrollTop();
}
}
});
// handle sub dropdown menu click for mobile devices only
$(".hor-menu .menu-dropdown > a, .hor-menu .dropdown-submenu > a").on("click", function(e) {
if (App.getViewPort().width < resBreakpointMd) {
if ($(this).next().hasClass('dropdown-menu')) {
e.stopPropagation();
if ($(this).parent().hasClass("opened")) {
$(this).parent().removeClass("opened");
} else {
$(this).parent().addClass("opened");
}
}
}
});
// handle hover dropdown menu for desktop devices only
if (App.getViewPort().width >= resBreakpointMd) {
$('.hor-menu [data-hover="megamenu-dropdown"]').not('.hover-initialized').each(function() {
$(this).dropdownHover();
$(this).addClass('hover-initialized');
});
}
// handle auto scroll to selected sub menu node on mobile devices
$(document).on('click', '.hor-menu .menu-dropdown > a[data-hover="megamenu-dropdown"]', function() {
if (App.getViewPort().width < resBreakpointMd) {
App.scrollTo($(this));
}
});
// close main menu on final link click for mobile mode
$(".hor-menu li > a").on("click", function(e) {
if (App.getViewPort().width < resBreakpointMd) {
if (!$(this).parent('li').hasClass('classic-menu-dropdown') && !$(this).parent('li').hasClass('mega-menu-dropdown')
&& !$(this).parent('li').hasClass('dropdown-submenu')) {
$(".page-header .page-header-menu").slideUp(300);
App.scrollTop();
}
}
});
// hold mega menu content open on click/tap.
$(document).on('click', '.mega-menu-dropdown .dropdown-menu, .classic-menu-dropdown .dropdown-menu', function (e) {
e.stopPropagation();
});
// handle fixed mega menu(minimized)
$(window).scroll(function() {
var offset = 75;
if ($('body').hasClass('page-header-menu-fixed')) {
if ($(window).scrollTop() > offset){
$(".page-header-menu").addClass("fixed");
} else {
$(".page-header-menu").removeClass("fixed");
}
}
if ($('body').hasClass('page-header-top-fixed')) {
if ($(window).scrollTop() > offset){
$(".page-header-top").addClass("fixed");
} else {
$(".page-header-top").removeClass("fixed");
}
}
});
};
// Handle sidebar menu links
var handleMainMenuActiveLink = function(mode, el) {
var url = location.hash.toLowerCase();
var menu = $('.hor-menu');
if (mode === 'click' || mode === 'set') {
el = $(el);
} else if (mode === 'match') {
menu.find("li > a").each(function() {
var path = $(this).attr("href").toLowerCase();
// url match condition
if (path.length > 1 && url.substr(1, path.length - 1) == path.substr(1)) {
el = $(this);
return;
}
});
}
if (!el || el.size() == 0) {
return;
}
if (el.attr('href').toLowerCase() === 'javascript:;' || el.attr('href').toLowerCase() === '#') {
return;
}
// disable active states
menu.find('li.active').removeClass('active');
menu.find('li > a > .selected').remove();
menu.find('li.open').removeClass('open');
el.parents('li').each(function () {
$(this).addClass('active');
if ($(this).parent('ul.navbar-nav').size() === 1) {
$(this).find('> a').append('<span class="selected"></span>');
}
});
};
// Handles main menu on window resize
var handleMainMenuOnResize = function() {
// handle hover dropdown menu for desktop devices only
var width = App.getViewPort().width;
var menu = $(".page-header-menu");
if (width >= resBreakpointMd && menu.data('breakpoint') !== 'desktop') {
// reset active states
$('.hor-menu [data-toggle="dropdown"].active').removeClass('open');
menu.data('breakpoint', 'desktop');
$('.hor-menu [data-hover="megamenu-dropdown"]').not('.hover-initialized').each(function() {
$(this).dropdownHover();
$(this).addClass('hover-initialized');
});
$('.hor-menu .navbar-nav li.open').removeClass('open');
$(".page-header-menu").css("display", "block");
} else if (width < resBreakpointMd && menu.data('breakpoint') !== 'mobile') {
// set active states as open
$('.hor-menu [data-toggle="dropdown"].active').addClass('open');
menu.data('breakpoint', 'mobile');
// disable hover bootstrap dropdowns plugin
$('.hor-menu [data-hover="megamenu-dropdown"].hover-initialized').each(function() {
$(this).unbind('hover');
$(this).parent().unbind('hover').find('.dropdown-submenu').each(function() {
$(this).unbind('hover');
});
$(this).removeClass('hover-initialized');
});
} else if (width < resBreakpointMd) {
//$(".page-header-menu").css("display", "none");
}
};
var handleContentHeight = function() {
var height;
if ($('body').height() < App.getViewPort().height) {
height = App.getViewPort().height -
$('.page-header').outerHeight() -
($('.page-container').outerHeight() - $('.page-content').outerHeight()) -
$('.page-prefooter').outerHeight() -
$('.page-footer').outerHeight();
$('.page-content').css('min-height', height);
}
};
// Handles the go to top button at the footer
var handleGoTop = function () {
var offset = 100;
var duration = 500;
if (navigator.userAgent.match(/iPhone|iPad|iPod/i)) { // ios supported
$(window).bind("touchend touchcancel touchleave", function(e){
if ($(this).scrollTop() > offset) {
$('.scroll-to-top').fadeIn(duration);
} else {
$('.scroll-to-top').fadeOut(duration);
}
});
} else { // general
$(window).scroll(function() {
if ($(this).scrollTop() > offset) {
$('.scroll-to-top').fadeIn(duration);
} else {
$('.scroll-to-top').fadeOut(duration);
}
});
}
$('.scroll-to-top').click(function(e) {
e.preventDefault();
$('html, body').animate({scrollTop: 0}, duration);
return false;
});
};
//* END:CORE HANDLERS *//
return {
// Main init methods to initialize the layout
// IMPORTANT!!!: Do not modify the core handlers call order.
initHeader: function() {
handleHeader(); // handles horizontal menu
handleMainMenu(); // handles menu toggle for mobile
App.addResizeHandler(handleMainMenuOnResize); // handle main menu on window resize
if (App.isAngularJsApp()) {
handleMainMenuActiveLink('match'); // init sidebar active links
}
},
initContent: function() {
handleContentHeight(); // handles content height
},
initFooter: function() {
handleGoTop(); //handles scroll to top functionality in the footer
},
init: function () {
this.initHeader();
this.initContent();
this.initFooter();
},
setMainMenuActiveLink: function(mode, el) {
handleMainMenuActiveLink(mode, el);
},
closeMainMenu: function() {
$('.hor-menu').find('li.open').removeClass('open');
if (App.getViewPort().width < resBreakpointMd && $('.page-header-menu').is(":visible")) { // close the menu on mobile view while laoding a page
$('.page-header .menu-toggler').click();
}
},
getLayoutImgPath: function() {
return App.getAssetsPath() + layoutImgPath;
},
getLayoutCssPath: function() {
return App.getAssetsPath() + layoutCssPath;
}
};
}();
if (App.isAngularJsApp() === false) {
jQuery(document).ready(function() {
Layout.init(); // init metronic core componets
});
}