🏨 Hotel Booking Enhancements: - Implemented Eagle Booking Advanced Pricing add-on - Added Booking.com-style rate management system - Created professional calendar interface for pricing - Integrated deals and discounts functionality 💰 Advanced Pricing Features: - Dynamic pricing models (per room, per person, per adult) - Base rates, adult rates, and child rates management - Length of stay discounts and early bird deals - Mobile rates and secret deals implementation - Seasonal promotions and flash sales 📅 Availability Management: - Real-time availability tracking - Stop sell and restriction controls - Closed to arrival/departure functionality - Minimum/maximum stay requirements - Automatic sold-out management 💳 Payment Integration: - Maintained Redsys payment gateway integration - Seamless integration with existing Eagle Booking - No modifications to core Eagle Booking plugin 🛠️ Technical Implementation: - Custom database tables for advanced pricing - WordPress hooks and filters integration - AJAX-powered admin interface - Data migration from existing Eagle Booking - Professional calendar view for revenue management 📊 Admin Interface: - Booking.com-style management dashboard - Visual rate and availability calendar - Bulk operations for date ranges - Statistics and analytics dashboard - Modal dialogs for quick editing 🔧 Code Quality: - WordPress coding standards compliance - Secure database operations with prepared statements - Proper input validation and sanitization - Error handling and logging - Responsive admin interface 🤖 Generated with Claude Code (https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
50 lines
1.7 KiB
JavaScript
50 lines
1.7 KiB
JavaScript
var __webpack_exports__ = {};
|
|
/* wp:polyfill */
|
|
let formSettings;
|
|
try {
|
|
formSettings = JSON.parse(document.getElementById('wp-script-module-data-@wordpress/block-library/form/view')?.textContent);
|
|
} catch {}
|
|
|
|
// eslint-disable-next-line eslint-comments/disable-enable-pair
|
|
/* eslint-disable no-undef */
|
|
document.querySelectorAll('form.wp-block-form').forEach(function (form) {
|
|
// Bail If the form settings not provided or the form is not using the mailto: action.
|
|
if (!formSettings || !form.action || !form.action.startsWith('mailto:')) {
|
|
return;
|
|
}
|
|
const redirectNotification = status => {
|
|
const urlParams = new URLSearchParams(window.location.search);
|
|
urlParams.append('wp-form-result', status);
|
|
window.location.search = urlParams.toString();
|
|
};
|
|
|
|
// Add an event listener for the form submission.
|
|
form.addEventListener('submit', async function (event) {
|
|
event.preventDefault();
|
|
// Get the form data and merge it with the form action and nonce.
|
|
const formData = Object.fromEntries(new FormData(form).entries());
|
|
formData.formAction = form.action;
|
|
formData._ajax_nonce = formSettings.nonce;
|
|
formData.action = formSettings.action;
|
|
formData._wp_http_referer = window.location.href;
|
|
formData.formAction = form.action;
|
|
try {
|
|
const response = await fetch(formSettings.ajaxUrl, {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/x-www-form-urlencoded'
|
|
},
|
|
body: new URLSearchParams(formData).toString()
|
|
});
|
|
if (response.ok) {
|
|
redirectNotification('success');
|
|
} else {
|
|
redirectNotification('error');
|
|
}
|
|
} catch (error) {
|
|
redirectNotification('error');
|
|
}
|
|
});
|
|
});
|
|
|