jQuery(document).ready(function($) { // Function to show notification function showNotification(message, isError = false) { // Remove any existing notification $('.wp-status').remove(); // Create and append the new notification var $notification = $('' + message + ''); $('.wp-allstars-header h1').after($notification); // Remove the notification after 2 seconds setTimeout(function() { $notification.fadeOut(300, function() { $(this).remove(); }); }, 2000); } // Handle all settings changes function updateOption(option, value) { return $.post(wpAllstars.ajaxurl, { action: 'wp_allstars_update_option', option: option, value: value, nonce: wpAllstars.nonce }).then(function(response) { if (!response.success) { throw new Error(response.data || 'Error saving setting'); } return response; }); } // Handle toggle switch clicks $('.wp-toggle-switch').on('click', function(e) { e.stopPropagation(); }); // Handle checkbox changes $('.wp-toggle-switch input[type="checkbox"]').on('change', function(e) { e.stopPropagation(); }); // Handle panel toggle $('.wp-allstars-toggle-header').on('click', function(e) { if (!$(e.target).closest('.wp-toggle-switch').length) { var $settings = $(this).closest('.wp-allstars-toggle').find('.wp-allstars-toggle-settings'); var isExpanded = $(this).attr('aria-expanded') === 'true'; $(this).attr('aria-expanded', !isExpanded); $settings.slideToggle(); } }); // Set initial state $('.wp-allstars-toggle-header').each(function() { var $settings = $(this).closest('.wp-allstars-toggle').find('.wp-allstars-toggle-settings'); var isExpanded = $(this).attr('aria-expanded') === 'true'; if (!isExpanded) { $settings.hide(); } }); // Handle text, number, and textarea inputs $('.wp-allstars-setting-row input[type="text"], .wp-allstars-setting-row input[type="number"], .wp-allstars-setting-row textarea').on('change', function() { var $input = $(this); var option = $input.attr('name'); var value = $input.val(); updateOption(option, value) .then(function() { showNotification('Setting saved'); }) .catch(function(error) { console.error('Error:', error); showNotification('Error saving setting', true); }); }); // Handle form submission $('form').on('submit', function() { showNotification('Saved'); }); // Load plugins on page load if ($('#wpa-plugin-list').length) { var urlParams = new URLSearchParams(window.location.search); var currentCategory = urlParams.get('category') || 'minimal'; loadPlugins(currentCategory); // Handle category filter clicks $('.wpa-plugin-filters a').on('click', function(e) { e.preventDefault(); var category = new URLSearchParams($(this).attr('href').split('?')[1]).get('category'); loadPlugins(category); // Update URL without page reload var newUrl = $(this).attr('href'); history.pushState({}, '', newUrl); // Update active state $('.wpa-plugin-filters a').removeClass('button-primary'); $(this).addClass('button-primary'); }); } // Function to load plugins function loadPlugins(category) { // Show loading overlay $('.wpa-loading-overlay').fadeIn(); $.ajax({ url: ajaxurl, type: 'POST', data: { action: 'wp_allstars_get_plugins', category: category || 'minimal', _wpnonce: wpAllstars.nonce }, success: function(response) { if (response.success) { $('#wpa-plugin-list').html(response.data); } else { console.error('Server returned error:', response); $('#wpa-plugin-list').html('
Failed to load plugins: ' + (response.data || 'Unknown error') + '
Failed to load plugins. Please try again. Error: ' + error + '
Failed to load theme: ' + (response.data || 'Unknown error') + '
Failed to load theme. Please try again. Error: ' + error + '