Я пытаюсь интегрировать шаблон администратора с реагировать, все работает, кроме меню, которое вызывает перезагрузку страницы.
У меня есть такое меню:
<ul className="navigation navigation-main">
<li ><Link to="/reception/dashboard"></Link></li>
<li><Link to="/reception/register">Registration</span></Link></li>
</ul>
с навигацией main класс в элементе ul страница перезагружается, я хочу, чтобы класс navaidation-main не перезагружал страницу, класс определяется в app-menu. js file.
здесь app-menu . js полный код: https://hastebin.com/uhusapukus.js
/*=========================================================================================
File Name: app-menu.js
Description: Menu navigation, custom scrollbar, hover scroll bar, multilevel menu
initialization and manipulations
----------------------------------------------------------------------------------------
Item Name: Frest HTML Admin Template
Version: 1.0
Author: Pixinvent
Author URL: hhttp://www.themeforest.net/user/pixinvent
==========================================================================================*/
(function (window, document, $) {
'use strict';
$.app = $.app || {};
var $body = $('body');
var $window = $(window);
var menuWrapper_el = $('div[data-menu="menu-wrapper"]').html();
var menuWrapperClasses = $('div[data-menu="menu-wrapper"]').attr('class');
// Main menu
$.app.menu = {
expanded: null,
collapsed: null,
hidden: null,
container: null,
horizontalMenu: false,
manualScroller: {
obj: null,
init: function () {
var scroll_theme = ($('.main-menu').hasClass('menu-dark')) ? 'light' : 'dark';
this.obj = new PerfectScrollbar(".main-menu-content", {
suppressScrollX: true,
wheelPropagation: false
});
},
update: function () {
if (this.obj) {
// Scroll to currently active menu on page load if data-scroll-to-active is true
if ($('.main-menu').data('scroll-to-active') === true) {
var activeEl, menu;
activeEl = document.querySelector('.main-menu-content li.active');
if ($body.hasClass('menu-collapsed')) {
if ($('.main-menu-content li.sidebar-group-active').length) {
activeEl = document.querySelector('.main-menu-content li.sidebar-group-active');
}
} else {
menu = document.querySelector('.main-menu-content');
activeEl = activeEl.getBoundingClientRect().top + menu.scrollTop;
// If active element's top position is less than 2/3 (66%) of menu height than do not scroll
if (activeEl > parseInt((menu.clientHeight * 2) / 3)) {
var start = menu.scrollTop,
change = activeEl - start - parseInt(menu.clientHeight / 2);
}
}
setTimeout(function () {
$.app.menu.container.stop().animate({ scrollTop: change }, 300);
$('.main-menu').data('scroll-to-active', 'false');
}, 300);
}
this.obj.update();
}
},
enable: function () {
if (!$('.main-menu-content').hasClass('ps')) {
this.init();
}
},
disable: function () {
if (this.obj) {
this.obj.destroy();
}
},
updateHeight: function () {
if (($body.data('menu') == 'vertical-menu' || $body.data('menu') == 'vertical-menu-modern' || $body.data('menu') == 'vertical-overlay-menu') && $('.main-menu').hasClass('menu-fixed')) {
$('.main-menu-content').css('height', $(window).height() - $('.header-navbar').height() - $('.main-menu-header').outerHeight() - $('.main-menu-footer').outerHeight());
this.update();
}
}
},
init: function (compactMenu) {
if ($('.main-menu-content').length > 0) {
this.container = $('.main-menu-content');
var menuObj = this;
var defMenu = '';
if (compactMenu === true) {
defMenu = 'collapsed';
}
if ($body.data('menu') == 'vertical-menu-modern') {
var menuToggle = '';
if (menuToggle === "false") {
this.change('collapsed');
}
else {
this.change(defMenu);
}
}
else {
this.change(defMenu);
}
}
},
drillDownMenu: function (screenSize) {
if ($('.drilldown-menu').length) {
if (screenSize == 'sm' || screenSize == 'xs') {
if ($('#navbar-mobile').attr('aria-expanded') == 'true') {
$('.drilldown-menu').slidingMenu({
backLabel: true
});
}
}
else {
$('.drilldown-menu').slidingMenu({
backLabel: true
});
}
}
},
change: function (defMenu, menuIconColorsObj) {
var currentBreakpoint = Unison.fetch.now(); // Current Breakpoint
this.reset();
var menuType = $body.data('menu');
if (currentBreakpoint) {
switch (currentBreakpoint.name) {
case 'xl':
if (menuType === 'vertical-overlay-menu') {
this.hide();
}
else {
if (defMenu === 'collapsed')
this.collapse(defMenu);
else
this.expand();
}
break;
case 'lg':
if (menuType === 'vertical-overlay-menu' || menuType === 'vertical-menu-modern' || menuType === 'horizontal-menu') {
this.hide();
}
else {
this.collapse();
}
break;
case 'md':
case 'sm':
this.hide();
break;
case 'xs':
this.hide();
break;
}
}
// On the small and extra small screen make them overlay menu
if (menuType === 'vertical-menu' || menuType === 'vertical-menu-modern') {
this.toOverlayMenu(currentBreakpoint.name, menuType);
}
if ($body.is('.horizontal-layout') && !$body.hasClass('.horizontal-menu-demo')) {
this.changeMenu(currentBreakpoint.name);
$('.menu-toggle').removeClass('is-active');
}
// Initialize drill down menu for vertical layouts, for horizontal layouts drilldown menu is intitialized in changemenu function
if (menuType != 'horizontal-menu') {
// Drill down menu
// ------------------------------
this.drillDownMenu(currentBreakpoint.name);
}
// Dropdown submenu on large screen on hover For Large screen only
// ---------------------------------------------------------------
if (currentBreakpoint.name == 'xl') {
$('body[data-open="hover"] .dropdown').on('mouseenter', function () {
if (!($(this).hasClass('show'))) {
$(this).addClass('show');
} else {
$(this).removeClass('show');
}
}).on('mouseleave', function (event) {
$(this).removeClass('show');
});
$('body[data-open="hover"] .dropdown a').on('click', function (e) {
if (menuType == 'horizontal-menu') {
var $this = $(this);
if ($this.hasClass('dropdown-toggle')) {
return false;
}
}
});
}
// Added data attribute brand-center for navbar-brand-center
// TODO:AJ: Shift this feature in JADE.
if ($('.header-navbar').hasClass('navbar-brand-center')) {
$('.header-navbar').attr('data-nav', 'brand-center');
}
if (currentBreakpoint.name == 'sm' || currentBreakpoint.name == 'xs') {
$('.header-navbar[data-nav=brand-center]').removeClass('navbar-brand-center');
} else {
$('.header-navbar[data-nav=brand-center]').addClass('navbar-brand-center');
}
// Dropdown submenu on small screen on click
// --------------------------------------------------
$('ul.dropdown-menu [data-toggle=dropdown]').on('click', function (event) {
if ($(this).siblings('ul.dropdown-menu').length > 0) {
event.preventDefault();
}
event.stopPropagation();
$(this).parent().siblings().removeClass('show');
$(this).parent().toggleClass('show');
});
// Horizontal layout submenu drawer scrollbar
if (menuType == 'horizontal-menu') {
$('li.dropdown-submenu').on('mouseenter', function () {
if (!$(this).parent('.dropdown').hasClass('show')) {
$(this).removeClass('openLeft');
}
var dd = $(this).find('.dropdown-menu');
if (dd) {
var pageHeight = $(window).height(),
ddTop = dd.offset().top,
ddLeft = dd.offset().left,
ddWidth = dd.width(),
ddHeight = dd.height();
if (((pageHeight - ddTop) - ddHeight - 28) < 1) {
var maxHeight = (pageHeight - ddTop - 25);
$(this).find('.dropdown-menu').css({ 'max-height': maxHeight + 'px', 'overflow-y': 'auto', 'overflow-x': 'hidden' });
var menu_content = new PerfectScrollbar('li.dropdown-submenu.show .dropdown-menu', {
wheelPropagation: false
});
}
// Add class to horizontal sub menu if screen width is small
if (ddLeft + ddWidth - (window.innerWidth - 16) >= 0) {
$(this).addClass('openLeft');
}
}
});
}
/********************************************
* Searchable Menu *
********************************************/
function searchMenu(list) {
var input = $(".menu-search");
$(input)
.change(function () {
var filter = $(this).val();
if (filter) {
// Hide Main Navigation Headers
$('.navigation-header').hide();
// this finds all links in a list that contain the input,
// and hide the ones not containing the input while showing the ones that do
$(list).find("li a:not(:Contains(" + filter + "))").hide().parent().hide();
// $(list).find("li a:Contains(" + filter + ")").show().parents('li').show().addClass('open').closest('li').children('a').show();
var searchFilter = $(list).find("li a:Contains(" + filter + ")");
if (searchFilter.parent().hasClass('has-sub')) {
searchFilter.show()
.parents('li').show()
.addClass('open')
.closest('li')
.children('a').show()
.children('li').show();
// searchFilter.parents('li').find('li').show().children('a').show();
if (searchFilter.siblings('ul').length > 0) {
searchFilter.siblings('ul').children('li').show().children('a').show();
}
}
else {
searchFilter.show().parents('li').show().addClass('open').closest('li').children('a').show();
}
} else {
// return to default
$('.navigation-header').show();
$(list).find("li a").show().parent().show().removeClass('open');
}
$.app.menu.manualScroller.update();
return false;
})
.keyup(function () {
// fire the above change event after every letter
$(this).change();
});
}
if (menuType === 'vertical-menu' || menuType === 'vertical-overlay-menu') {
// custom css expression for a case-insensitive contains()
jQuery.expr[':'].Contains = function (a, i, m) {
return (a.textContent || a.innerText || "").toUpperCase().indexOf(m[3].toUpperCase()) >= 0;
};
searchMenu($("#main-menu-navigation"));
}
},
transit: function (callback1, callback2) {
var menuObj = this;
$body.addClass('changing-menu');
callback1.call(menuObj);
if ($body.hasClass('vertical-layout')) {
if ($body.hasClass('menu-open') || $body.hasClass('menu-expanded')) {
$('.menu-toggle').addClass('is-active');
// Show menu header search when menu is normally visible
if ($body.data('menu') === 'vertical-menu') {
if ($('.main-menu-header')) {
$('.main-menu-header').show();
}
}
}
else {
$('.menu-toggle').removeClass('is-active');
// Hide menu header search when only menu icons are visible
if ($body.data('menu') === 'vertical-menu') {
if ($('.main-menu-header')) {
$('.main-menu-header').hide();
}
}
}
}
setTimeout(function () {
callback2.call(menuObj);
$body.removeClass('changing-menu');
menuObj.update();
}, 500);
},
open: function () {
this.transit(function () {
$body.removeClass('menu-hide menu-collapsed').addClass('menu-open');
this.hidden = false;
this.expanded = true;
if ($body.hasClass('vertical-overlay-menu')) {
$('.sidenav-overlay').removeClass('d-none').addClass('d-block');
$('body').css('overflow', 'hidden');
}
}, function () {
if (!$('.main-menu').hasClass('menu-native-scroll') && $('.main-menu').hasClass('menu-fixed')) {
this.manualScroller.enable();
$('.main-menu-content').css('height', $(window).height() - $('.header-navbar').height() - $('.main-menu-header').outerHeight() - $('.main-menu-footer').outerHeight());
// this.manualScroller.update();
}
if (!$body.hasClass('vertical-overlay-menu')) {
$('.sidenav-overlay').removeClass('d-block d-none');
$('body').css('overflow', 'auto');
}
});
},
hide: function () {
this.transit(function () {
$body.removeClass('menu-open menu-expanded').addClass('menu-hide');
this.hidden = true;
this.expanded = false;
if ($body.hasClass('vertical-overlay-menu')) {
$('.sidenav-overlay').removeClass('d-block').addClass('d-none');
$('body').css('overflow', 'auto');
}
}, function () {
if (!$('.main-menu').hasClass('menu-native-scroll') && $('.main-menu').hasClass('menu-fixed')) {
this.manualScroller.enable();
}
if (!$body.hasClass('vertical-overlay-menu')) {
$('.sidenav-overlay').removeClass('d-block d-none');
$('body').css('overflow', 'auto');
}
});
},
expand: function () {
if (this.expanded === false) {
if ($body.data('menu') == 'vertical-menu-modern') {
$('.modern-nav-toggle').find('.toggle-icon')
.removeClass('bx bx-circle').addClass('bx bx-disc');
}
this.transit(function () {
$body.removeClass('menu-collapsed').addClass('menu-expanded');
this.collapsed = false;
this.expanded = true;
$('.sidenav-overlay').removeClass('d-block d-none');
}, function () {
if (($('.main-menu').hasClass('menu-native-scroll') || $body.data('menu') == 'horizontal-menu')) {
this.manualScroller.disable();
}
else {
if ($('.main-menu').hasClass('menu-fixed'))
this.manualScroller.enable();
}
if (($body.data('menu') == 'vertical-menu' || $body.data('menu') == 'vertical-menu-modern') && $('.main-menu').hasClass('menu-fixed')) {
$('.main-menu-content').css('height', $(window).height() - $('.header-navbar').height() - $('.main-menu-header').outerHeight() - $('.main-menu-footer').outerHeight());
// this.manualScroller.update();
}
});
}
},
collapse: function (defMenu) {
if (this.collapsed === false) {
if ($body.data('menu') == 'vertical-menu-modern') {
$('.modern-nav-toggle').find('.toggle-icon')
.removeClass('bx bx-disc').addClass('bx bx-circle');
}
this.transit(function () {
$body.removeClass('menu-expanded').addClass('menu-collapsed');
this.collapsed = true;
this.expanded = false;
$('.content-overlay').removeClass('d-block d-none');
}, function () {
if (($body.data('menu') == 'horizontal-menu') && $body.hasClass('vertical-overlay-menu')) {
if ($('.main-menu').hasClass('menu-fixed'))
this.manualScroller.enable();
}
if (($body.data('menu') == 'vertical-menu' || $body.data('menu') == 'vertical-menu-modern') && $('.main-menu').hasClass('menu-fixed')) {
$('.main-menu-content').css('height', $(window).height() - $('.header-navbar').height());
// this.manualScroller.update();
}
if ($body.data('menu') == 'vertical-menu-modern') {
if ($('.main-menu').hasClass('menu-fixed'))
this.manualScroller.enable();
}
});
}
},
toOverlayMenu: function (screen, menuType) {
var menu = $body.data('menu');
if (menuType == 'vertical-menu-modern') {
if (screen == 'lg' || screen == 'md' || screen == 'sm' || screen == 'xs') {
if ($body.hasClass(menu)) {
$body.removeClass(menu).addClass('vertical-overlay-menu');
}
}
else {
if ($body.hasClass('vertical-overlay-menu')) {
$body.removeClass('vertical-overlay-menu').addClass(menu);
}
}
}
else {
if (screen == 'sm' || screen == 'xs') {
if ($body.hasClass(menu)) {
$body.removeClass(menu).addClass('vertical-overlay-menu');
}
}
else {
if ($body.hasClass('vertical-overlay-menu')) {
$body.removeClass('vertical-overlay-menu').addClass(menu);
}
}
}
},
changeMenu: function (screen) {
// Replace menu html
$('div[data-menu="menu-wrapper"]').html('');
$('div[data-menu="menu-wrapper"]').html(menuWrapper_el);
// Destroy Icons when screen size changes
$('.menu-livicon').removeLiviconEvo();
// Initialize Menu Icons with configs
$.each($('.menu-livicon'), function (i) {
var $this = $(this),
icon = $this.data('icon'),
iconStyle = $('#main-menu-navigation').data("icon-style");
$this.addLiviconEvo({
name: icon,
style: iconStyle,
duration: 0.85,
strokeWidth: '1.3px',
eventOn: 'parent',
strokeColor: menuIconColorsObj.iconStrokeColor,
solidColor: menuIconColorsObj.iconSolidColor,
fillColor: menuIconColorsObj.iconFillColor,
strokeColorAlt: menuIconColorsObj.iconStrokeColorAlt,
afterAdd: function () {
if (i === $(".main-menu-content .menu-livicon").length - 1) {
// When hover over any menu item, start animation and stop all other animation
$(".main-menu-content .nav-item a").on("mouseenter", function () {
if ($(".main-menu-content .menu-livicon").length) {
$(".main-menu-content .menu-livicon").stopLiviconEvo()
$(this)
.find(".menu-livicon")
.playLiviconEvo()
}
})
}
}
});
});
var menuWrapper = $('div[data-menu="menu-wrapper"]'),
menuContainer = $('div[data-menu="menu-container"]'),
menuNavigation = $('ul[data-menu="menu-navigation"]'),
/*megaMenu = $('li[data-menu="megamenu"]'),
megaMenuCol = $('li[data-mega-col]'),*/
dropdownMenu = $('li[data-menu="dropdown"]'),
dropdownSubMenu = $('li[data-menu="dropdown-submenu"]');
if (screen === 'xl') {
// Change body classes
$body.removeClass('vertical-layout vertical-overlay-menu fixed-navbar').addClass($body.data('menu'));
// Remove navbar-fix-top class on large screens
$('nav.header-navbar').removeClass('fixed-top');
// Change menu wrapper, menu container, menu navigation classes
menuWrapper.removeClass().addClass(menuWrapperClasses);
// Intitialize drill down menu for horizontal layouts
// --------------------------------------------------
this.drillDownMenu(screen);
$('a.dropdown-item.nav-has-children').on('click', function () {
event.preventDefault();
event.stopPropagation();
});
$('a.dropdown-item.nav-has-parent').on('click', function () {
event.preventDefault();
event.stopPropagation();
});
}
else {
// Change body classes
$body.removeClass($body.data('menu')).addClass('vertical-layout vertical-overlay-menu fixed-navbar');
// Add navbar-fix-top class on small screens
$('nav.header-navbar').addClass('fixed-top');
// Change menu wrapper, menu container, menu navigation classes
menuWrapper.removeClass().addClass('main-menu menu-fixed menu-shadow');
if ($body.data('layout') === "dark-layout" || $body.data('layout') === "semi-dark-layout") {
menuWrapper.addClass('menu-dark');
}
else {
menuWrapper.addClass('menu-light');
}
// menuContainer.removeClass().addClass('main-menu-content');
menuNavigation.removeClass().addClass('navigation navigation-main');
// If Dropdown Menu
dropdownMenu.removeClass('dropdown').addClass('has-sub');
dropdownMenu.find('a').removeClass('dropdown-toggle nav-link');
dropdownMenu.children('ul').find('a').removeClass('dropdown-item');
dropdownMenu.find('ul').removeClass('dropdown-menu');
dropdownSubMenu.removeClass().addClass('has-sub');
$.app.nav.init();
// Dropdown submenu on small screen on click
// --------------------------------------------------
$('ul.dropdown-menu [data-toggle=dropdown]').on('click', function (event) {
event.preventDefault();
event.stopPropagation();
$(this).parent().siblings().removeClass('open');
$(this).parent().toggleClass('open');
});
// $('.shadow-bottom').css('display', 'block');
}
$(".main-menu-content").find('li.active').parents('li').addClass('sidebar-group-active');
function updateLivicon(el) {
el.updateLiviconEvo({
strokeColor: menuActiveIconColorsObj.iconStrokeColor,
solidColor: menuActiveIconColorsObj.iconSolidColor,
fillColor: menuActiveIconColorsObj.iconFillColor,
strokeColorAlt: menuActiveIconColorsObj.iconStrokeColorAlt
})
}
// Update Active Menu item Icon with active color
if ($('.nav-item.active .menu-livicon').length) {
updateLivicon($('.nav-item.active .menu-livicon'))
}
// Update Active sidebar group menu icon with active ccolor
if ($(".main-menu-content li.sidebar-group-active .menu-livicon").length) {
updateLivicon($(".main-menu-content li.sidebar-group-active .menu-livicon"))
}
},
toggle: function () {
var currentBreakpoint = Unison.fetch.now(); // Current Breakpoint
var collapsed = this.collapsed;
var expanded = this.expanded;
var hidden = this.hidden;
var menu = $body.data('menu');
switch (currentBreakpoint.name) {
case 'xl':
if (expanded === true) {
if (menu == 'vertical-overlay-menu') {
this.hide();
}
else {
this.collapse();
}
}
else {
if (menu == 'vertical-overlay-menu') {
this.open();
}
else {
this.expand();
}
}
break;
case 'lg':
if (expanded === true) {
if (menu == 'vertical-overlay-menu' || menu == 'vertical-menu-modern' || menu == 'horizontal-menu') {
this.hide();
}
else {
this.collapse();
}
}
else {
if (menu == 'vertical-overlay-menu' || menu == 'vertical-menu-modern' || menu == 'horizontal-menu') {
this.open();
}
else {
this.expand();
}
}
break;
case 'md':
case 'sm':
if (hidden === true) {
this.open();
} else {
this.hide();
}
break;
case 'xs':
if (hidden === true) {
this.open();
} else {
this.hide();
}
break;
}
// Re-init sliding menu to update width
this.drillDownMenu(currentBreakpoint.name);
},
update: function () {
this.manualScroller.update();
},
reset: function () {
this.expanded = false;
this.collapsed = false;
this.hidden = false;
$body.removeClass('menu-hide menu-open menu-collapsed menu-expanded');
},
};
// Navigation Menu
$.app.nav = {
container: $('.navigation-main'),
initialized: false,
navItem: $('.navigation-main').find('li').not('.navigation-category'),
config: {
speed: 300,
},
init: function (config) {
this.initialized = true; // Set to true when initialized
$.extend(this.config, config);
this.bind_events();
},
bind_events: function () {
var menuObj = this;
$('.navigation-main').on('mouseenter.app.menu', 'li', function () {
var $this = $(this);
$('.hover', '.navigation-main').removeClass('hover');
if ($body.hasClass('menu-collapsed') && $body.data('menu') != 'vertical-menu-modern') {
$('.main-menu-content').children('span.menu-title').remove();
$('.main-menu-content').children('a.menu-title').remove();
$('.main-menu-content').children('ul.menu-content').remove();
// Title
var menuTitle = $this.find('span.menu-title').clone(),
tempTitle,
tempLink;
if (!$this.hasClass('has-sub')) {
tempTitle = $this.find('span.menu-title').text();
tempLink = $this.children('a').attr('href');
if (tempTitle !== '') {
menuTitle = $("<a>");
menuTitle.attr("href", tempLink);
menuTitle.attr("title", tempTitle);
menuTitle.text(tempTitle);
menuTitle.addClass("menu-title");
}
}
// menu_header_height = ($('.main-menu-header').length) ? $('.main-menu-header').height() : 0,
// fromTop = menu_header_height + $this.position().top + parseInt($this.css( "border-top" ),10);
var fromTop;
if ($this.css("border-top")) {
fromTop = $this.position().top + parseInt($this.css("border-top"), 10);
}
else {
fromTop = $this.position().top;
}
if ($body.data('menu') !== 'vertical-compact-menu') {
menuTitle.appendTo('.main-menu-content').css({
position: 'fixed',
top: fromTop,
});
}
// Content
if ($this.hasClass('has-sub') && $this.hasClass('nav-item')) {
var menuContent = $this.children('ul:first');
menuObj.adjustSubmenu($this);
}
}
$this.addClass('hover');
}).on('mouseleave.app.menu', 'li', function () {
// $(this).removeClass('hover');
}).on('active.app.menu', 'li', function (e) {
$(this).addClass('active');
e.stopPropagation();
}).on('deactive.app.menu', 'li.active', function (e) {
$(this).removeClass('active');
e.stopPropagation();
}).on('open.app.menu', 'li', function (e) {
var $listItem = $(this);
$listItem.addClass('open');
menuObj.expand($listItem);
// If menu collapsible then do not take any action
if ($('.main-menu').hasClass('menu-collapsible')) {
return false;
}
// If menu accordion then close all except clicked once
else {
$listItem.siblings('.open').find('li.open').trigger('close.app.menu');
$listItem.siblings('.open').trigger('close.app.menu');
}
e.stopPropagation();
}).on('close.app.menu', 'li.open', function (e) {
var $listItem = $(this);
$listItem.removeClass('open');
menuObj.collapse($listItem);
})(window, document, jQuery);
Как предотвратить перезагрузку страницы классом navaigation-main