2026-01-31 13:15:13 +01:00
|
|
|
/**
|
|
|
|
|
* WP BnB Admin JavaScript
|
|
|
|
|
*
|
|
|
|
|
* @package Magdev\WpBnb
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
(function($) {
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Initialize license management functionality.
|
|
|
|
|
*/
|
|
|
|
|
function initLicenseManagement() {
|
|
|
|
|
var $validateBtn = $('#wp-bnb-validate-license');
|
|
|
|
|
var $activateBtn = $('#wp-bnb-activate-license');
|
|
|
|
|
var $spinner = $('#wp-bnb-license-spinner');
|
|
|
|
|
var $message = $('#wp-bnb-license-message');
|
|
|
|
|
|
|
|
|
|
if (!$validateBtn.length) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Validate license button click.
|
|
|
|
|
$validateBtn.on('click', function(e) {
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
performLicenseAction('wp_bnb_validate_license', wpBnbAdmin.i18n.validating);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Activate license button click.
|
|
|
|
|
$activateBtn.on('click', function(e) {
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
performLicenseAction('wp_bnb_activate_license', wpBnbAdmin.i18n.activating);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Perform a license AJAX action.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} action AJAX action name.
|
|
|
|
|
* @param {string} loadingText Loading text to display.
|
|
|
|
|
*/
|
|
|
|
|
function performLicenseAction(action, loadingText) {
|
|
|
|
|
// Disable buttons and show spinner.
|
|
|
|
|
$validateBtn.prop('disabled', true);
|
|
|
|
|
$activateBtn.prop('disabled', true);
|
|
|
|
|
$spinner.addClass('is-active');
|
|
|
|
|
$message.hide();
|
|
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
|
url: wpBnbAdmin.ajaxUrl,
|
|
|
|
|
type: 'POST',
|
|
|
|
|
data: {
|
|
|
|
|
action: action,
|
|
|
|
|
nonce: wpBnbAdmin.nonce
|
|
|
|
|
},
|
|
|
|
|
success: function(response) {
|
|
|
|
|
$spinner.removeClass('is-active');
|
|
|
|
|
$validateBtn.prop('disabled', false);
|
|
|
|
|
$activateBtn.prop('disabled', false);
|
|
|
|
|
|
|
|
|
|
if (response.success) {
|
|
|
|
|
showMessage('success', response.data.message);
|
|
|
|
|
// Reload page after short delay to show updated status.
|
|
|
|
|
setTimeout(function() {
|
|
|
|
|
window.location.reload();
|
|
|
|
|
}, 1500);
|
|
|
|
|
} else {
|
|
|
|
|
showMessage('error', response.data.message || wpBnbAdmin.i18n.error);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
error: function() {
|
|
|
|
|
$spinner.removeClass('is-active');
|
|
|
|
|
$validateBtn.prop('disabled', false);
|
|
|
|
|
$activateBtn.prop('disabled', false);
|
|
|
|
|
showMessage('error', wpBnbAdmin.i18n.error);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Show a message.
|
|
|
|
|
*
|
|
|
|
|
* @param {string} type Message type (success or error).
|
|
|
|
|
* @param {string} message Message text.
|
|
|
|
|
*/
|
|
|
|
|
function showMessage(type, message) {
|
|
|
|
|
$message
|
|
|
|
|
.removeClass('success error')
|
|
|
|
|
.addClass(type)
|
|
|
|
|
.text(message)
|
|
|
|
|
.fadeIn();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-01-31 13:45:06 +01:00
|
|
|
/**
|
|
|
|
|
* Initialize room gallery functionality.
|
|
|
|
|
*/
|
|
|
|
|
function initRoomGallery() {
|
|
|
|
|
var $container = $('#bnb-room-gallery');
|
|
|
|
|
var $addButton = $('#bnb-add-gallery-images');
|
|
|
|
|
var $input = $('#bnb_room_gallery');
|
|
|
|
|
var $imagesContainer = $container.find('.bnb-gallery-images');
|
|
|
|
|
|
|
|
|
|
if (!$addButton.length) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Media frame for selecting images.
|
|
|
|
|
var mediaFrame;
|
|
|
|
|
|
|
|
|
|
// Add images button click.
|
|
|
|
|
$addButton.on('click', function(e) {
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
|
|
// If frame exists, reopen it.
|
|
|
|
|
if (mediaFrame) {
|
|
|
|
|
mediaFrame.open();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Create media frame.
|
|
|
|
|
mediaFrame = wp.media({
|
|
|
|
|
title: wpBnbAdmin.i18n.selectImages,
|
|
|
|
|
button: {
|
|
|
|
|
text: wpBnbAdmin.i18n.addToGallery
|
|
|
|
|
},
|
|
|
|
|
multiple: true,
|
|
|
|
|
library: {
|
|
|
|
|
type: 'image'
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Handle selection.
|
|
|
|
|
mediaFrame.on('select', function() {
|
|
|
|
|
var selection = mediaFrame.state().get('selection');
|
|
|
|
|
selection.each(function(attachment) {
|
|
|
|
|
var data = attachment.toJSON();
|
|
|
|
|
var thumbnail = data.sizes.thumbnail ? data.sizes.thumbnail.url : data.url;
|
|
|
|
|
|
|
|
|
|
// Check if already in gallery.
|
|
|
|
|
if ($imagesContainer.find('[data-id="' + data.id + '"]').length) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add image to gallery.
|
|
|
|
|
var $image = $('<div class="bnb-gallery-image" data-id="' + data.id + '">' +
|
|
|
|
|
'<img src="' + thumbnail + '" alt="">' +
|
|
|
|
|
'<button type="button" class="bnb-remove-image">×</button>' +
|
|
|
|
|
'</div>');
|
|
|
|
|
$imagesContainer.append($image);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
updateGalleryInput();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
mediaFrame.open();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Remove image button click.
|
|
|
|
|
$imagesContainer.on('click', '.bnb-remove-image', function(e) {
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
$(this).closest('.bnb-gallery-image').remove();
|
|
|
|
|
updateGalleryInput();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Make gallery sortable.
|
|
|
|
|
$imagesContainer.sortable({
|
|
|
|
|
items: '.bnb-gallery-image',
|
|
|
|
|
cursor: 'move',
|
|
|
|
|
update: function() {
|
|
|
|
|
updateGalleryInput();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Update the hidden input with gallery image IDs.
|
|
|
|
|
*/
|
|
|
|
|
function updateGalleryInput() {
|
|
|
|
|
var ids = [];
|
|
|
|
|
$imagesContainer.find('.bnb-gallery-image').each(function() {
|
|
|
|
|
ids.push($(this).data('id'));
|
|
|
|
|
});
|
|
|
|
|
$input.val(ids.join(','));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-01-31 13:15:13 +01:00
|
|
|
// Initialize on document ready.
|
|
|
|
|
$(document).ready(function() {
|
|
|
|
|
initLicenseManagement();
|
2026-01-31 13:45:06 +01:00
|
|
|
initRoomGallery();
|
2026-01-31 13:15:13 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
})(jQuery);
|