From 1b47423a683ff0011137aae988b76b0c1ea45fd5 Mon Sep 17 00:00:00 2001 From: Marcus Quinn Date: Mon, 17 Mar 2025 01:10:11 +0000 Subject: [PATCH] Fix theme installation and activation with AJAX-based approach --- admin/js/wp-allstars-admin.js | 45 ++++++++++++++++++++++++++++++---- admin/partials/theme-panel.php | 14 +++-------- wp-allstars-plugin.php | 1 + 3 files changed, 45 insertions(+), 15 deletions(-) diff --git a/admin/js/wp-allstars-admin.js b/admin/js/wp-allstars-admin.js index a9ef4fc..ff5bd32 100644 --- a/admin/js/wp-allstars-admin.js +++ b/admin/js/wp-allstars-admin.js @@ -301,15 +301,50 @@ jQuery(document).ready(function($) { $('.theme-actions .install-now').off('click'); $('.theme-actions .activate-now').off('click'); - // Install theme - use standard WordPress behavior + // Install theme - use WordPress AJAX-based installation $('.theme-actions .install-now').on('click', function(e) { - // We're not preventing default here - let the standard WordPress installer handle it - // Just add the updating message + e.preventDefault(); var $button = $(this); var slug = $button.data('slug'); + var themeName = $button.data('name') || slug; + + console.log('Installing theme via AJAX:', slug); $button.addClass('updating-message').text('Installing...'); - console.log('Installing theme using standard WordPress URL:', $button.attr('href')); - // The rest will be handled by WordPress core + + // Use the WordPress core updates API for AJAX installation + wp.updates.installTheme({ + slug: slug, + success: function(response) { + console.log('Theme installed successfully:', response); + $button.removeClass('updating-message').addClass('updated-message').text('Installed!'); + + setTimeout(function() { + // Replace the button with an activate button + var $parent = $button.closest('.theme-actions'); + $button.remove(); + + // Create a proper activation link + var activateUrl = response.activateUrl || + 'themes.php?action=activate&stylesheet=' + slug + + '&_wpnonce=' + wp.updates.data.activateNonce; + + var adminUrl = wpAllstars.adminUrl || ajaxurl.replace('/admin-ajax.php', '/'); + var $activateButton = $('Activate'); + $activateButton.attr('data-slug', slug); + $activateButton.attr('data-name', themeName); + + $parent.prepend($activateButton); + + // Re-initialize the event handlers + initThemeHandlers(); + }, 1000); + }, + error: function(response) { + console.error('Theme installation failed:', response); + $button.removeClass('updating-message').text('Install'); + alert(response.errorMessage || 'Failed to install theme. Please try again.'); + } + }); }); // Activate theme - use standard WordPress behavior diff --git a/admin/partials/theme-panel.php b/admin/partials/theme-panel.php index b4d03f3..acc63ca 100644 --- a/admin/partials/theme-panel.php +++ b/admin/partials/theme-panel.php @@ -39,19 +39,13 @@ if (!defined('ABSPATH')) { - - + data-name="Kadence" + aria-label=""> - +