| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481 |
- /*jslint browser: true, white: true, this: true */
- /*global console,jQuery,megamenu,window,navigator*/
- /*! Max Mega Menu jQuery Plugin */
- (function($) {
- "use strict";
- $.maxmegamenu = function(menu, options) {
- var plugin = this;
- var $menu = $(menu);
- var defaults = {
- event: $menu.attr("data-event"),
- effect: $menu.attr("data-effect"),
- effect_speed: parseInt($menu.attr("data-effect-speed")),
- effect_mobile: $menu.attr("data-effect-mobile"),
- effect_speed_mobile: parseInt($menu.attr("data-effect-speed-mobile")),
- panel_width: $menu.attr("data-panel-width"),
- panel_inner_width: $menu.attr("data-panel-inner-width"),
- mobile_force_width: $menu.attr("data-mobile-force-width"),
- second_click: $menu.attr("data-second-click"),
- vertical_behaviour: $menu.attr("data-vertical-behaviour"),
- document_click: $menu.attr("data-document-click"),
- breakpoint: $menu.attr("data-breakpoint"),
- unbind_events: $menu.attr("data-unbind")
- };
- plugin.settings = {};
- var items_with_submenus = $("li.mega-menu-megamenu.mega-menu-item-has-children," +
- "li.mega-menu-flyout.mega-menu-item-has-children," +
- "li.mega-menu-tabbed > ul.mega-sub-menu > li.mega-menu-item-has-children," +
- "li.mega-menu-flyout li.mega-menu-item-has-children", menu);
- plugin.hidePanel = function(anchor, immediate) {
- anchor.parent().triggerHandler("before_close_panel");
- if ( (!immediate && plugin.settings.effect == 'slide') || (plugin.isMobileView() && plugin.settings.effect_mobile == 'slide') ) {
- var speed = plugin.isMobileView() ? plugin.settings.effect_speed_mobile : plugin.settings.effect_speed;
- anchor.siblings(".mega-sub-menu").animate({'height':'hide', 'paddingTop':'hide', 'paddingBottom':'hide', 'minHeight':'hide'}, speed, function() {
- anchor.siblings(".mega-sub-menu").css("display", "");
- anchor.parent().removeClass("mega-toggle-on").triggerHandler("close_panel");
- });
- return;
- }
- if (immediate) {
- anchor.siblings(".mega-sub-menu").css("display", "none").delay(plugin.settings.effect_speed).queue(function(){
- $(this).css("display", "").dequeue();
- });
- }
- // pause video widget videos
- anchor.siblings(".mega-sub-menu").find('.widget_media_video video').each(function() {
- this.player.pause();
- });
- anchor.parent().removeClass("mega-toggle-on").triggerHandler("close_panel");
- plugin.addAnimatingClass(anchor.parent());
- };
- plugin.addAnimatingClass = function(element) {
- if (plugin.settings.effect === "disabled") {
- return;
- }
- $(".mega-animating").removeClass("mega-animating");
- var timeout = plugin.settings.effect_speed + parseInt(megamenu.timeout, 10);
- element.addClass("mega-animating");
- setTimeout(function() {
- element.removeClass("mega-animating");
- }, timeout );
- };
- plugin.hideAllPanels = function() {
- $(".mega-toggle-on > a.mega-menu-link", $menu).each(function() {
- plugin.hidePanel($(this), false);
- });
- };
- plugin.hideSiblingPanels = function(anchor, immediate) {
- anchor.parent().parent().find(".mega-toggle-on").children("a.mega-menu-link").each(function() { // all open children of open siblings
- plugin.hidePanel($(this), immediate);
- });
- };
- plugin.isDesktopView = function() {
- return Math.max(window.outerWidth, $(window).width()) > plugin.settings.breakpoint; // account for scrollbars
- };
- plugin.isMobileView = function() {
- return !plugin.isDesktopView();
- };
- plugin.showPanel = function(anchor) {
- anchor.parent().triggerHandler("before_open_panel");
- $(".mega-animating").removeClass("mega-animating");
- if (plugin.isMobileView() && anchor.parent().hasClass("mega-hide-sub-menu-on-mobile")) {
- return;
- }
- if (plugin.isDesktopView() && ($menu.hasClass("mega-menu-horizontal") || $menu.hasClass("mega-menu-vertical"))) {
- plugin.hideSiblingPanels(anchor, true);
- }
- if ((plugin.isMobileView() && $menu.hasClass("mega-keyboard-navigation")) || plugin.settings.vertical_behaviour === "accordion") {
- plugin.hideSiblingPanels(anchor, false);
- }
- plugin.calculateDynamicSubmenuWidths(anchor);
- // apply jQuery transition (only if the effect is set to "slide", other transitions are CSS based)
- if ( plugin.settings.effect == "slide" || plugin.isMobileView() && plugin.settings.effect_mobile == 'slide') {
- var speed = plugin.isMobileView() ? plugin.settings.effect_speed_mobile : plugin.settings.effect_speed;
- anchor.siblings(".mega-sub-menu").css("display", "none").animate({'height':'show', 'paddingTop':'show', 'paddingBottom':'show', 'minHeight':'show'}, speed, function() {
- $(this).css("display", "");
- });
- }
- anchor.parent().addClass("mega-toggle-on").triggerHandler("open_panel");
- };
- plugin.calculateDynamicSubmenuWidths = function(anchor) {
- // apply dynamic width and sub menu position (only to top level mega menus)
- if (anchor.parent().hasClass("mega-menu-megamenu") && anchor.parent().parent().hasClass('mega-menu') && plugin.settings.panel_width && $(plugin.settings.panel_width).length > 0) {
- if (plugin.isDesktopView()) {
- var submenu_offset = $menu.offset();
- var target_offset = $(plugin.settings.panel_width).offset();
- anchor.siblings(".mega-sub-menu").css({
- width: $(plugin.settings.panel_width).outerWidth(),
- left: (target_offset.left - submenu_offset.left) + "px"
- });
- } else {
- anchor.siblings(".mega-sub-menu").css({
- width: "",
- left: ""
- });
- }
- }
- // apply inner width to sub menu by adding padding to the left and right of the mega menu
- if (anchor.parent().hasClass("mega-menu-megamenu") && anchor.parent().parent().hasClass('mega-menu') && plugin.settings.panel_inner_width && $(plugin.settings.panel_inner_width).length > 0) {
- var target_width = 0;
- if ($(plugin.settings.panel_inner_width).length) {
- // jQuery selector
- target_width = parseInt($(plugin.settings.panel_inner_width).width(), 10);
- } else {
- // we"re using a pixel width
- target_width = parseInt(plugin.settings.panel_inner_width, 10);
- }
- var submenu_width = parseInt(anchor.siblings(".mega-sub-menu").innerWidth(), 10);
- if (plugin.isDesktopView() && target_width > 0 && target_width < submenu_width) {
- anchor.siblings(".mega-sub-menu").css({
- "paddingLeft": (submenu_width - target_width) / 2 + "px",
- "paddingRight": (submenu_width - target_width) / 2 + "px"
- });
- } else {
- anchor.siblings(".mega-sub-menu").css({
- "paddingLeft": "",
- "paddingRight": ""
- });
- }
- }
- }
- var bindClickEvents = function() {
- var dragging = false;
- $(document).on({
- "touchmove": function(e) { dragging = true; },
- "touchstart": function(e) { dragging = false; }
- });
- $(document).on("click touchend", function(e) { // hide menu when clicked away from
- if (!dragging && plugin.settings.document_click === "collapse" && ! $(e.target).closest(".max-mega-menu li").length && ! $(e.target).closest(".mega-menu-toggle").length ) {
- plugin.hideAllPanels();
- }
- dragging = false;
- });
- $("> a.mega-menu-link", items_with_submenus).on("click.megamenu touchend.megamenu", function(e) {
- if (e.type === 'touchend') {
- // prevent mouseenter events once touch has been detected
- plugin.unbindHoverEvents();
- plugin.unbindHoverIntentEvents();
- }
- if (plugin.isDesktopView() && $(this).parent().hasClass("mega-toggle-on") && $(this).parent().parent().parent().hasClass("mega-menu-tabbed") ) {
- if (plugin.settings.second_click === "go") {
- return;
- } else {
- e.preventDefault();
- return;
- }
- }
- if (dragging) {
- return;
- }
- if (plugin.isMobileView() && $(this).parent().hasClass("mega-hide-sub-menu-on-mobile")) {
- return; // allow all clicks on parent items when sub menu is hidden on mobile
- }
- if ((plugin.settings.second_click === "go" || $(this).parent().hasClass("mega-click-click-go")) && $(this).attr('href') !== undefined) { // check for second click
- if (!$(this).parent().hasClass("mega-toggle-on")) {
- e.preventDefault();
- plugin.showPanel($(this));
- }
- } else {
- e.preventDefault();
- if ($(this).parent().hasClass("mega-toggle-on")) {
- plugin.hidePanel($(this), false);
- } else {
- plugin.showPanel($(this));
- }
- }
- });
- };
- var bindHoverEvents = function() {
- items_with_submenus.on({
- "mouseenter.megamenu" : function() {
- plugin.unbindClickEvents();
- if (! $(this).hasClass("mega-toggle-on")) {
- plugin.showPanel($(this).children("a.mega-menu-link"));
- }
- },
- "mouseleave.megamenu" : function() {
- if ($(this).hasClass("mega-toggle-on") && ! $(this).hasClass("mega-disable-collapse") && ! $(this).parent().parent().hasClass("mega-menu-tabbed")) {
- plugin.hidePanel($(this).children("a.mega-menu-link"), false);
- }
- }
- });
- };
- var bindHoverIntentEvents = function() {
- items_with_submenus.hoverIntent({
- over: function () {
- plugin.unbindClickEvents();
- if (! $(this).hasClass("mega-toggle-on")) {
- plugin.showPanel($(this).children("a.mega-menu-link"));
- }
- },
- out: function () {
- if ($(this).hasClass("mega-toggle-on") && ! $(this).hasClass("mega-disable-collapse") && ! $(this).parent().parent().hasClass("mega-menu-tabbed")) {
- plugin.hidePanel($(this).children("a.mega-menu-link"), false);
- }
- },
- timeout: megamenu.timeout,
- interval: megamenu.interval
- });
- };
- var bindKeyboardEvents = function() {
- var tab_key = 9;
- var escape_key = 27;
- $("body").on("keyup", function(e) {
- var keyCode = e.keyCode || e.which;
- if (keyCode === escape_key) {
- $menu.parent().removeClass("mega-keyboard-navigation");
- plugin.hideAllPanels();
- }
- if ( $menu.parent().hasClass("mega-keyboard-navigation") && ! ( $(e.target).closest(".max-mega-menu li").length || $(e.target).closest(".mega-menu-toggle").length ) ) {
- $menu.parent().removeClass("mega-keyboard-navigation");
- plugin.hideAllPanels();
- if ( plugin.isMobileView() ) {
- $menu.siblings('.mega-menu-toggle').removeClass('mega-menu-open');
- }
- }
- });
- $menu.parent().on("keyup", function(e) {
- var keyCode = e.keyCode || e.which;
- var active_link = $(e.target);
- if (keyCode === tab_key) {
- $menu.parent().addClass("mega-keyboard-navigation");
- if ( active_link.parent().is(items_with_submenus) ) {
- plugin.showPanel(active_link);
- } else {
- plugin.hideSiblingPanels(active_link);
- }
- if ( active_link.hasClass("mega-menu-toggle") ) {
- active_link.addClass("mega-menu-open");
- }
- }
- });
- };
- plugin.unbindAllEvents = function() {
- $("ul.mega-sub-menu, li.mega-menu-item, li.mega-menu-row, li.mega-menu-column, a.mega-menu-link, span.mega-indicator", menu).off().unbind();
- };
- plugin.unbindClickEvents = function() {
- $("> a.mega-menu-link", items_with_submenus).off("click.megamenu touchend.megamenu");
- };
- plugin.unbindHoverEvents = function() {
- items_with_submenus.unbind("mouseenter.megamenu mouseleave.megamenu");
- };
- plugin.unbindHoverIntentEvents = function() {
- items_with_submenus.unbind("mouseenter mouseleave").removeProp('hoverIntent_t').removeProp('hoverIntent_s'); // hoverintent does not allow namespaced events
- };
- plugin.unbindMegaMenuEvents = function() {
- if (plugin.settings.event === "hover_intent") {
- plugin.unbindHoverIntentEvents();
- }
- if (plugin.settings.event === "hover") {
- plugin.unbindHoverEvents();
- }
- plugin.unbindClickEvents();
- }
- plugin.bindMegaMenuEvents = function() {
- if (plugin.isDesktopView() && plugin.settings.event === "hover_intent") {
- bindHoverIntentEvents();
- }
- if (plugin.isDesktopView() && plugin.settings.event === "hover") {
- bindHoverEvents();
- }
- bindClickEvents(); // always bind click events for touch screen devices
- bindKeyboardEvents();
- };
- plugin.monitorView = function() {
- if (plugin.isDesktopView()) {
- $menu.data("view", "desktop");
- } else {
- $menu.data("view", "mobile");
- plugin.switchToMobile();
- }
- plugin.checkWidth();
- $(window).resize(function() {
- plugin.checkWidth();
- });
- };
- plugin.checkWidth = function() {
- if ( plugin.isMobileView() && $menu.data("view") === "desktop" ) {
- $menu.data("view", "mobile");
- plugin.switchToMobile();
- }
- if ( plugin.isDesktopView() && $menu.data("view") === "mobile" ) {
- $menu.data("view", "desktop");
- plugin.switchToDesktop();
- }
- plugin.calculateDynamicSubmenuWidths($("li.mega-menu-megamenu.mega-toggle-on > a.mega-menu-link", $menu));
- };
- plugin.reverseRightAlignedItems = function() {
- if ( ! $('body').hasClass('rtl') ) {
- $menu.append($menu.children("li.mega-item-align-right").get().reverse());
- }
- };
- plugin.addClearClassesToMobileItems = function() {
- $(".mega-menu-row", $menu).each(function() {
- $("> .mega-sub-menu > .mega-menu-column:not(.mega-hide-on-mobile)", $(this)).filter(":even").addClass('mega-menu-clear'); // :even is 0 based
- });
- }
- plugin.switchToMobile = function() {
- plugin.unbindMegaMenuEvents();
- plugin.bindMegaMenuEvents();
- plugin.reverseRightAlignedItems();
- plugin.addClearClassesToMobileItems();
- plugin.hideAllPanels();
- };
- plugin.switchToDesktop = function() {
- plugin.unbindMegaMenuEvents();
- plugin.bindMegaMenuEvents();
- plugin.reverseRightAlignedItems();
- plugin.hideAllPanels();
- $menu.css({
- width: '',
- left: '',
- display: ''
- });
- $menu.siblings(".mega-menu-toggle").removeClass('mega-menu-open');
- };
- plugin.init = function() {
- $menu.triggerHandler("before_mega_menu_init");
- plugin.settings = $.extend({}, defaults, options);
- $menu.removeClass("mega-no-js");
- // mobile menu
- $menu.siblings(".mega-menu-toggle").on("click", function(e) {
- var toggle_bar = $(this);
- if ( $(e.target).is(".mega-menu-toggle-block, .mega-toggle-blocks-left, .mega-toggle-blocks-center, .mega-toggle-blocks-right, .mega-toggle-label, .mega-toggle-label span") ) {
- if ($(plugin.settings.mobile_force_width).length) {
- var submenu_offset = toggle_bar.offset();
- var target_offset = $(plugin.settings.mobile_force_width).offset();
- $menu.css({
- width: $(plugin.settings.mobile_force_width).outerWidth(),
- left: (target_offset.left - submenu_offset.left) + "px"
- });
- }
- if (plugin.settings.effect_mobile == 'slide') {
- if ($(this).hasClass("mega-menu-open")) {
- $menu.animate({'height':'hide'}, plugin.settings.effect_speed_mobile, function() {
- $menu.css({
- width: '',
- left: '',
- display: ''
- });
- });
- } else {
- $menu.animate({'height':'show'}, plugin.settings.effect_speed_mobile);
- }
- }
- $(this).toggleClass("mega-menu-open");
- }
- });
-
- if (plugin.settings.unbind_events == 'true') {
- plugin.unbindAllEvents();
- }
- $("span.mega-indicator", $menu).on('click', function(e) {
- e.preventDefault();
- e.stopPropagation();
- plugin.hidePanel($(this).parent(), false);
- });
- plugin.bindMegaMenuEvents();
- plugin.monitorView();
- $menu.triggerHandler("after_mega_menu_init");
- };
- plugin.init();
- };
- $.fn.maxmegamenu = function(options) {
- return this.each(function() {
- if (undefined === $(this).data("maxmegamenu")) {
- var plugin = new $.maxmegamenu(this, options);
- $(this).data("maxmegamenu", plugin);
- }
- });
- };
- $(function() {
- $('.max-mega-menu').maxmegamenu();
- });
- })(jQuery);
|