jQuery(document).ready(function($){
$('.tag-title-btn').on('click', function(e){
e.preventDefault();
let input_field = $(this).closest('.wrap-tags').prev('input[type="text"], textarea'),
current_value = input_field.val(),
tag = $(this).data('tag');
// We need to add a space if there is some content
if(current_value.length > 0){
tag = ' ' + tag;
}
input_field.val(current_value + tag);
input_field.focus();
});
$('.siteseo-container a').on('click', function(e){
e.preventDefault();
$('.siteseo-container a').removeClass('active');
$(this).addClass('active');
});
$("[id^='siteseo-toggle-meta-']").on('click', function(){
$(this).toggleClass('active');
if($(this).hasClass('active')){
$('#toggle_state_posts').text('Click to hide any SEO metaboxes / columns for this post type');
$(this).closest('.siteseo-toggle-cnt').find('.siteseo-suboption-toggle').val("");
} else{
$('#toggle_state_posts').text(' Click to show any SEO metaboxes / columns for this post type');
$(this).closest('.siteseo-toggle-cnt').find('.siteseo-suboption-toggle').val(true);
}
});
$('#siteseo-dismiss-get-started').on('click', function(e){
e.preventDefault();
$(this).closest('.siteseo-dashbord-intro').slideUp();
$.ajax({
url : siteseoAdminAjax.url,
type : 'POST',
data : {
action : 'siteseo_dismiss_intro',
nonce : siteseoAdminAjax.nonce
}
})
});
// toggle handler function
function handleToggle($toggle, toggleKey, action) {
const $container = $toggle.closest('.siteseo-toggle-cnt');
const $stateText = $container.find(`.toggle_state_${toggleKey}`);
const $input = $(`#${toggleKey}`);
$container.addClass('loading');
$toggle.toggleClass('active');
const newValue = $toggle.hasClass('active') ? '1' : '0';
$input.val(newValue);
$stateText.text($toggle.hasClass('active') ? 'Disable' : 'Enable');
$.ajax({
url: ajaxurl,
type: 'POST',
data: {
action: action,
toggle_value: newValue,
nonce: $toggle.data('nonce')
},
success: function(response) {
if (response.success) {
// Show the custom toast message
showToast('Your settings have been saved.');
} else {
console.error('Failed to save toggle state');
toggleRollback($toggle, $input, $stateText);
showToast(response.data.message || 'Failed to save toggle state', 'error');
}
},
error: function() {
console.error('Ajax request failed');
toggleRollback($toggle, $input, $stateText);
showToast('Unable to save settings', 'error');
},
complete: function() {
$container.removeClass('loading');
}
});
}
// Rollback function in case of AJAX error
function toggleRollback($toggle, $input, $stateText) {
$toggle.toggleClass('active');
$input.val($toggle.hasClass('active') ? '1' : '0');
$stateText.text($toggle.hasClass('active') ? 'Disable' : 'Enable');
}
$('.siteseo-toggle-Sw').on('click', function() {
const $toggle = $(this);
const toggleKey = $toggle.data('toggle-key');
const action = $toggle.data('action');
handleToggle($toggle, toggleKey, action);
});
// toast msg
function showToast(message, type = 'success') {
const toast = $('
')
.addClass('siteseo-toast')
.addClass(type)
.html(`
${message}`);
$('body').append(toast);
// 3 seconds
toast.fadeIn(300).delay(3000).fadeOut(300, function () {
toast.remove();
});
}
// default off
$('.siteseo-suggetion').hide();
$('.tag-select-btn').click(function(e){
e.preventDefault();
e.stopPropagation();
$('.siteseo-suggetion').not($(this).siblings('.siteseo-suggestions-wrapper').find('.siteseo-suggetion')).hide();
$(this).siblings('.siteseo-suggestions-wrapper').find('.siteseo-suggetion').toggle();
});
$('.suggestions-container .section').click(function(e){
e.preventDefault();
e.stopPropagation();
var tag = $(this).find('.tag').text();
var targetField = $(this).closest('.siteseo-suggetion').closest('.wrap-tags').prev('input[type="text"], textarea');
insertAtCursor(targetField, tag);
$(this).closest('.siteseo-suggetion').hide();
});
$(document).click(function(e){
if (!$(e.target).closest('.wrap-tags').length){
$('.siteseo-suggetion').hide();
}
});
$('.search-box').on('input', function(){
var searchText = $(this).val().toLowerCase();
$(this).closest('.siteseo-suggetion').find('.section').each(function() {
var sectionText = $(this).text().toLowerCase();
$(this).toggle(sectionText.indexOf(searchText) > -1);
});
});
function insertAtCursor(field, text){
field = field[0];
var scrollPos = field.scrollTop;
var currentValue = field.value;
//
var newValue = currentValue + text;
field.value = newValue;
//end point
var newPosition = newValue.length;
field.setSelectionRange(newPosition, newPosition);
field.scrollTop = scrollPos;
field.focus();
}
$('.tag-title-btn').click(function(e){
e.preventDefault();
e.stopPropagation();
var tag = '';
var btnId = $(this).attr('id');
if(btnId === 'tag-select-btn'){
tag = '%%sitetitle%%'; // replace
}
if(tag){
var targetField = $(this).closest('.wrap-tags').prev('input[type="text"], textarea');
insertAtCursor(targetField, tag);
}
});
// facebook upload Image
$('#facebook_upload_logo').click(function(e){
var mediaUploader;
e.preventDefault();
if(mediaUploader){
mediaUploader.open();
return;
}
mediaUploader = wp.media.frames.file_frame = wp.media({
title: 'Media',
button:{
text: 'Select'
},
multiple: false
});
mediaUploader.on('select', function(){
var attachment = mediaUploader.state().get('selection').first().toJSON();
$('#facebook_org_image_url').val(attachment.url);
});
mediaUploader.open();
});
//twitter cart image
$('#twitter_logo').click(function(e){
var mediaUploader;
e.preventDefault();
if(mediaUploader){
mediaUploader.open();
return;
}
mediaUploader = wp.media.frames.file_frame = wp.media({
title: 'Media',
button:{
text: 'Select'
},
multiple: false
});
mediaUploader.on('select', function(){
var attachment = mediaUploader.state().get('selection').first().toJSON();
$('#twitter_logo_url').val(attachment.url);
});
mediaUploader.open();
});
//knowledgen org
$('#knowledge_org_logo').on('click', function(e){
var mediaUploader;
e.preventDefault();
if(mediaUploader){
mediaUploader.open();
return;
}
mediaUploader = wp.media.frames.file_frame = wp.media({
title: 'Media',
button:{
text: 'Select'
},
multiple: false
});
mediaUploader.on('select', function(){
var attachment = mediaUploader.state().get('selection').first().toJSON();
$('#knowledge_org_logo_url').val(attachment.url);
});
mediaUploader.open();
});
// get active tab
function getDefaultTab(){
return $('.siteseo-tab.active').attr('id') || 'tab_siteseo_home';
}
function setActiveTab(tabId){
// Hide all first
$('.siteseo-tab').hide();
// remove classes
$('.nav-tab').removeClass('nav-tab-active');
$('.siteseo-tab').removeClass('active');
if($('.nav-tab[data-tab="' + tabId + '"]').length){
$('[data-tab="' + tabId + '"]').addClass('nav-tab-active');
} else{
$('#' + tabId + '-tab').addClass('nav-tab-active');
}
$('#' + tabId).addClass('active').show(); // show active tab
// save ative tab
localStorage.setItem('siteseo_active_tab', tabId);
}
//get from localstorage
var savedTab = localStorage.getItem('siteseo_active_tab');
var defaultTab = getDefaultTab();
// Check if the saved tab exists otherwise use the default tab
if(savedTab && $('#' + savedTab).length){
setActiveTab(savedTab);
} else{
setActiveTab(defaultTab);
}
// Click handler for navigation tabs
$('.nav-tab').on('click', function(e){
e.preventDefault();
var tabId = $(this).data('tab') || $(this).attr('id').replace('-tab', '');
setActiveTab(tabId);
});
$('#siteseo-generate-api-key-btn').on('click', function(){
var button = $(this);
var inputField = $('#bing-api-key');
// Disable button while processing
button.prop('disabled', true);
$.ajax({
url: siteseoAdminAjax.url,
type: 'POST',
data: {
action: 'siteseo_generate_bing_api_key',
nonce: siteseoAdminAjax.nonce
},
success: function(response) {
if (response.success) {
// Insert the generated key into the input field
inputField.val(response.data.api_key);
// Optional: Add a subtle highlight effect
inputField.css('background-color', '#f0f9ff')
.animate({'background-color': '#ffffff'}, 1500);
} else {
alert('Error generating API key. Please try again.');
}
},
error: function() {
alert('Error generating API key. Please try again.');
},
complete: function() {
// Re-enable the button
button.prop('disabled', false);
}
});
});
$('#siteseo-submit-urls-button').on('click', function(e){
e.preventDefault();
var $button = $(this);
var $spinner = $('.spinner');
var $responseDiv = $('#url-submitter-response');
$button.prop('disabled', true);
$spinner.addClass('is-active');
$responseDiv.empty();
//bing responce
function getBingResponseMessage(code){
switch(code){
case 200:
return 'URLs submitted successfully';
case 202:
return 'URL received. IndexNow key validation pending.';
case 400:
return 'Bad request: Invalid format';
case 403:
return 'Forbidden: Key not valid';
case 422:
return 'Unprocessable Entity: URLs don\'t belong to the host';
case 429:
return 'Too Many Requests: Potential Spam';
default:
return 'Something went wrong';
}
}
$.ajax({
url: siteseoAdminAjax.url,
method: 'POST',
data:{
action: 'siteseo_url_submitter_submit',
nonce: siteseoAdminAjax.nonce,
search_engine: $('input[name="siteseo_options[search_engine_google]"]:checked').val() || $('input[name="siteseo_options[search_engine_bing]"]:checked').val(),
urls: $('textarea[name="siteseo_options[instant_indexing_batch]"]').val()
},
success: function(response){
if(response.success){
let failed_svg = '
',
success_svg = '
';
var responseHtml = '';
//Bing
if(response.data.details.bing){
responseHtml += `
`;
}
// Google Response
if(response.data.details.google){
responseHtml += `
`;
}
$responseDiv.html(responseHtml);
} else{
var errorMessage = response.data && response.data.message ? response.data.message : 'An error occurred.';
$responseDiv.html('
');
}
},
error: function (xhr){
console.error(xhr.responseText);
$responseDiv.html('
Request failed: ' + xhr.statusText + '
');
},
complete: function(){
$button.prop('disabled', false);
$spinner.removeClass('is-active');
}
});
});
/** scroll screen**/
$('.siteseo-container a').on('click', function(e){
e.preventDefault();
var $container = $(this).closest('.siteseo-container');
var $table = $(this).closest('table');
$('.siteseo-container a').removeClass('active');
var targetId = $(this).attr('href');
targetId = targetId.replace(/^[#-]/, '');
var $targetSection = $table.find('#' + targetId);
if($targetSection.length){
$('html, body').animate({
scrollTop: $targetSection.offset().top - 100
}, 500);
$(this).addClass('active');
}
});
function isElementInViewport(el){
var rect = el[0].getBoundingClientRect();
var windowHeight = $(window).height();
var elementMiddle = rect.top + (rect.height / 2);
return elementMiddle >= 0 && elementMiddle <= windowHeight;
}
function updateActiveSection(){
$('table').each(function(){
var $table = $(this);
var activeFound = false;
$table.find('.siteseo-container a').each(function(){
var targetId = $(this).attr('href').replace(/^[#-]/, '');
var $targetSection = $table.find('#' + targetId);
if($targetSection.length && isElementInViewport($targetSection)){
$('.siteseo-container a').removeClass('active');
$(this).addClass('active');
activeFound = true;
return false;
}
});
});
}
var scrollTimeout;
$(window).on('scroll', function(){
clearTimeout(scrollTimeout);
scrollTimeout = setTimeout(function(){
updateActiveSection();
}, 100);
});
updateActiveSection();
/*** reset setting***/
$('.siteseo-container a').on('click', function(e){
e.preventDefault();
var $container = $(this).closest('.siteseo-container');
var $table = $(this).closest('table');
$('.siteseo-container a').removeClass('active');
$(this).addClass('active');
var targetId = $(this).attr('href').replace(/^[#-]/, '');
var $targetSection = $table.find('#' + targetId);
if($targetSection.length) {
$('html, body').animate({
scrollTop: $targetSection.offset().top - 100
}, 500);
}
});
function updateActiveSection(){
$('table').each(function(){
var $table = $(this);
var windowTop = $(window).scrollTop();
var windowBottom = windowTop + $(window).height();
var windowCenter = windowTop + ($(window).height() / 2);
var $sections = $table.find('[id]');
var currentSection = null;
$sections.each(function(){
var $section = $(this);
var sectionTop = $section.offset().top;
var sectionBottom = sectionTop + $section.outerHeight();
if(sectionTop <= windowCenter && sectionBottom >= windowCenter){
currentSection = $section;
return false;
}
});
if(currentSection){
var sectionId = currentSection.attr('id');
var $links = $table.find('.siteseo-container a');
$links.removeClass('active');
$links.each(function(){
var href = $(this).attr('href').replace(/^[#-]/, '');
if(href === sectionId){
$(this).addClass('active');
}
});
}
});
}
var scrollTimeout;
$(window).on('scroll', function(){
if(scrollTimeout){
clearTimeout(scrollTimeout);
}
scrollTimeout = setTimeout(function(){
updateActiveSection();
}, 100);
});
updateActiveSection();
$('#siteseo-reset-settings').on('click', function(e){
e.preventDefault();
if(confirm('Are you sure you want to reset all settings?')){
$.ajax({
url: siteseoAdminAjax.url,
type: 'POST',
data:{
action: 'siteseo_reset_settings',
nonce: siteseoAdminAjax.nonce
},
success: function(response){
if(response.success){
alert('Settings reset successfully.');
} else{
alert('Failed to reset settings: ' + response.data.message);
}
},
error: function(xhr, status, error){
alert('An error occurred: ' + error);
}
});
} else{
return false;
}
});
/*** export settings***/
$('#siteseo-export-btn').on('click', function(e){
e.preventDefault();
$.ajax({
url: siteseoAdminAjax.url,
type: 'POST',
data:{
action: 'siteseo_export_settings',
nonce: siteseoAdminAjax.nonce
},
success: function(response){
const blob = new Blob([JSON.stringify(response)], {type: 'application/json'});
const url = window.URL.createObjectURL(blob);
const a = document.createElement('a');
a.style.display = 'none';
a.href = url;
a.download = 'siteseo-settings-export-' + new Date().toLocaleDateString('en-US').replace(/\//g, '-') + '.json';
document.body.appendChild(a);
a.click();
window.URL.revokeObjectURL(url);
document.body.removeChild(a);
},
error: function(xhr, status, error){
console.error('Export failed:', error);
alert('Export failed. Please try again.');
}
});
});
/** import settings**/
$('#siteseo-import-btn').on('click', function (e){
e.preventDefault();
const fileInput = $('#siteseo-import-file')[0];
if(!fileInput.files || !fileInput.files[0]){
alert('Please select a file to import.');
return;
}
const formData = new FormData();
formData.append('action', 'siteseo_import_settings');
formData.append('nonce', siteseoAdminAjax.nonce);
formData.append('import_file', fileInput.files[0]);
$('#siteseo-import-btn').prop('disabled', true);
$.ajax({
url: siteseoAdminAjax.url,
type: 'POST',
data: formData,
processData: false,
contentType: false,
success: function (response){
if(response.success){
alert('Success: ' + response.data.message);
fileInput.value = '';
setTimeout(function(){
location.reload();
}, 1500);
} else{
alert('Error: ' + response.data.message);
}
},
error: function(xhr, status, error){
alert('Error: Import failed. Please try again.');
},
complete: function(){
$('#siteseo-import-btn').prop('disabled', false);
}
});
});
//migration
$(".siteseo-section-tool").hide();
$("#siteseo-plugin-selector").on('change', function(){
var selectedTool = $(this).val();
$(".siteseo-section-tool").hide();
if(selectedTool !== "none"){
$("#" + selectedTool).show();
}
});
// ajax migrate from others
$('button[id^="siteseo-"][id$="-migrate"]').on('click', function(){
const button = $(this);
const plugin = button.attr('id').replace('siteseo-', '').replace('-migrate', '');
const spinner = button.next('.spinner');
const log = button.siblings('.log');
button.prop('disabled', true);
spinner.addClass('is-active');
log.empty();
$.ajax({
url: siteseoAdminAjax.url,
type: 'POST',
data: {
action: 'siteseo_migrate_seo',
plugin: plugin,
nonce: siteseoAdminAjax.nonce
},
success: function(response){
if(response.success){
log.html('
' + response.data.message + '
');
} else{
log.html('
' + response.data.message + '
');
}
},
error: function(){
log.html('
Migration failed. Please try again.
');
},
complete: function(){
button.prop('disabled', false);
spinner.removeClass('is-active');
}
});
});
});