- Fixed critical security vulnerability with incorrect capability checks - Fixed hardcoded redirect path from /community-login/ to /training-login/ - Moved dashboard shortcode registration to centralized location - Fixed duplicate class loading with proper singleton checks - Fixed incorrect edit URLs in dashboard - Removed debug HTML comments from production templates - Moved inline CSS to external stylesheets for better maintainability - Added caching mechanism for dashboard statistics queries (1 hour cache) - Implemented pagination JavaScript handlers for AJAX navigation - Added comprehensive error handling and logging throughout - Fixed role-based access control (checking roles not capabilities) - Improved performance with cached database queries
		
			
				
	
	
		
			169 lines
		
	
	
		
			No EOL
		
	
	
		
			6.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			No EOL
		
	
	
		
			6.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * HVAC Navigation - Robust & Simple
 | |
|  * Ensures navigation dropdowns work reliably for all users
 | |
|  * 
 | |
|  * @version 1.0.1
 | |
|  * @since 2025-08-21
 | |
|  */
 | |
| 
 | |
| // CRITICAL: Disable the original menu system IMMEDIATELY to prevent conflicts
 | |
| // This must be set OUTSIDE of jQuery ready to ensure it's available first
 | |
| window.hvacRobustNavigationActive = true;
 | |
| 
 | |
| jQuery(document).ready(function($) {
 | |
|     'use strict';
 | |
|     
 | |
|     console.log('HVAC Navigation: Robust navigation loading...');
 | |
|     
 | |
|     // Ensure the menu system works even if other JavaScript fails
 | |
|     function initRobustNavigation() {
 | |
|         // Find all menu toggle elements
 | |
|         const $menuToggles = $('.hvac-trainer-menu .menu-toggle');
 | |
|         
 | |
|         console.log('HVAC Navigation: Found', $menuToggles.length, 'menu toggles');
 | |
|         
 | |
|         // AGGRESSIVE: Remove ALL competing handlers first
 | |
|         $menuToggles.off(); // Remove all handlers
 | |
|         $menuToggles.unbind(); // jQuery < 3.0 compatibility
 | |
|         
 | |
|         // Add click handlers to dropdown toggles
 | |
|         $menuToggles.on('click.hvacRobust', function(e) {
 | |
|             e.preventDefault();
 | |
|             e.stopPropagation();
 | |
|             
 | |
|             const $this = $(this);
 | |
|             const $menuItem = $this.closest('.menu-item');
 | |
|             const $submenu = $menuItem.find('> .sub-menu');
 | |
|             
 | |
|             console.log('HVAC Navigation: Toggle clicked for', $this.text().trim());
 | |
|             
 | |
|             // Close other open menus at the same level
 | |
|             $this.closest('ul').find('> .menu-item.open').not($menuItem).removeClass('open');
 | |
|             
 | |
|             // Toggle this menu - FORCE the class change
 | |
|             if ($menuItem.hasClass('open')) {
 | |
|                 $menuItem.removeClass('open');
 | |
|                 console.log('HVAC Navigation: Menu closed');
 | |
|             } else {
 | |
|                 $menuItem.addClass('open');
 | |
|                 console.log('HVAC Navigation: Menu opened');
 | |
|             }
 | |
|             
 | |
|             // Double-check the state
 | |
|             console.log('HVAC Navigation: Final state:', $menuItem.hasClass('open') ? 'open' : 'closed');
 | |
|         });
 | |
|         
 | |
|         // Ensure hamburger menu works
 | |
|         const $hamburger = $('#hvac-hamburger-menu, .hvac-hamburger-menu');
 | |
|         const $menu = $('#hvac-trainer-menu, .hvac-trainer-menu');
 | |
|         
 | |
|         if ($hamburger.length && $menu.length) {
 | |
|             console.log('HVAC Navigation: Setting up hamburger menu');
 | |
|             
 | |
|             // CRITICAL: Aggressively remove all existing handlers to prevent conflicts
 | |
|             // This ensures only our handler runs
 | |
|             $hamburger.off(); // Remove ALL handlers
 | |
|             $hamburger.unbind(); // jQuery < 3.0 compatibility
 | |
|             $hamburger.removeClass('active'); // Reset state
 | |
|             
 | |
|             // Add only our handler with immediate effect
 | |
|             $hamburger.on('click.hvacRobust', function(e) {
 | |
|                 e.preventDefault();
 | |
|                 e.stopPropagation();
 | |
|                 
 | |
|                 console.log('HVAC Navigation: Hamburger clicked');
 | |
|                 
 | |
|                 $hamburger.toggleClass('active');
 | |
|                 $menu.toggleClass('active');
 | |
|                 
 | |
|                 // Update aria attributes
 | |
|                 const isOpen = $menu.hasClass('active');
 | |
|                 $hamburger.attr('aria-expanded', isOpen);
 | |
|                 
 | |
|                 console.log('HVAC Navigation: Menu is now', isOpen ? 'active' : 'inactive');
 | |
|             });
 | |
|             
 | |
|             // AGGRESSIVE: Monitor and remove conflicting handlers continuously
 | |
|             setInterval(function() {
 | |
|                 const events = $._data($hamburger[0], 'events');
 | |
|                 if (events && events.click && events.click.length > 1) {
 | |
|                     console.log('HVAC Navigation: Removing conflicting handlers');
 | |
|                     // Keep only our namespaced handler
 | |
|                     $hamburger.off('click');
 | |
|                     $hamburger.on('click.hvacRobust', function(e) {
 | |
|                         e.preventDefault();
 | |
|                         e.stopPropagation();
 | |
|                         console.log('HVAC Navigation: Hamburger clicked (monitored)');
 | |
|                         $hamburger.toggleClass('active');
 | |
|                         $menu.toggleClass('active');
 | |
|                         const isOpen = $menu.hasClass('active');
 | |
|                         $hamburger.attr('aria-expanded', isOpen);
 | |
|                         console.log('HVAC Navigation: Menu is now', isOpen ? 'active' : 'inactive');
 | |
|                     });
 | |
|                 }
 | |
|             }, 1000);
 | |
|         }
 | |
|         
 | |
|         // Close menu when clicking outside (on mobile)
 | |
|         $(document).off('click.hvacRobustOutside').on('click.hvacRobustOutside', function(e) {
 | |
|             if (!$(e.target).closest('.hvac-trainer-nav').length) {
 | |
|                 if (window.innerWidth <= 992) {
 | |
|                     $menu.removeClass('active');
 | |
|                     $hamburger.removeClass('active');
 | |
|                     $hamburger.attr('aria-expanded', 'false');
 | |
|                 }
 | |
|                 
 | |
|                 // Close all open dropdowns
 | |
|                 $('.hvac-trainer-menu .menu-item.open').removeClass('open');
 | |
|             }
 | |
|         });
 | |
|         
 | |
|         // Handle window resize
 | |
|         $(window).off('resize.hvacRobust').on('resize.hvacRobust', function() {
 | |
|             if (window.innerWidth > 992) {
 | |
|                 // Reset mobile menu state on desktop
 | |
|                 $menu.removeClass('active');
 | |
|                 $hamburger.removeClass('active');
 | |
|                 $hamburger.attr('aria-expanded', 'false');
 | |
|             }
 | |
|         });
 | |
|         
 | |
|         console.log('HVAC Navigation: Robust navigation initialized successfully');
 | |
|     }
 | |
|     
 | |
|     // Initialize immediately
 | |
|     initRobustNavigation();
 | |
|     
 | |
|     // Reinitialize after AJAX or dynamic content changes
 | |
|     $(document).on('hvac-content-updated', initRobustNavigation);
 | |
|     
 | |
|     // Fallback initialization after a delay
 | |
|     setTimeout(function() {
 | |
|         // Check if dropdowns are working
 | |
|         const $firstToggle = $('.hvac-trainer-menu .menu-toggle').first();
 | |
|         if ($firstToggle.length) {
 | |
|             // Simulate a click to test functionality
 | |
|             const events = $._data($firstToggle[0], 'events');
 | |
|             if (!events || !events.click || events.click.length === 0) {
 | |
|                 console.log('HVAC Navigation: No click handlers found, reinitializing...');
 | |
|                 initRobustNavigation();
 | |
|             }
 | |
|         }
 | |
|     }, 1000);
 | |
|     
 | |
|     // Extra safety net - ensure menu visibility
 | |
|     function ensureMenuVisibility() {
 | |
|         const $activeMenu = $('.hvac-trainer-menu.active');
 | |
|         if ($activeMenu.length && $activeMenu.is(':hidden')) {
 | |
|             console.log('HVAC Navigation: Forcing menu visibility');
 | |
|             $activeMenu.css({
 | |
|                 'display': 'block',
 | |
|                 'visibility': 'visible',
 | |
|                 'opacity': '1'
 | |
|             });
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     // Check menu visibility periodically
 | |
|     setInterval(ensureMenuVisibility, 2000);
 | |
| }); |