/** * 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(); } } /** * 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 = $(''); $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(',')); } } // Initialize on document ready. $(document).ready(function() { initLicenseManagement(); initRoomGallery(); }); })(jQuery);