Hotel Raxa - Advanced Booking System Implementation
🏨 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>
This commit is contained in:
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@@ -0,0 +1,81 @@
|
||||
(function($) {
|
||||
'use strict';
|
||||
|
||||
$('.iconselectfa').each(function(){
|
||||
$(this).fontIconPicker({
|
||||
theme: 'fip-grey'
|
||||
})
|
||||
})
|
||||
|
||||
|
||||
|
||||
// Before a new group row is added, destroy Select2. We'll reinitialise after the row is added
|
||||
$('.cmb-repeatable-group').on('cmb2_add_group_row_start', function (event, instance) {
|
||||
var $table = $(document.getElementById($(instance).data('selector')));
|
||||
var $oldRow = $table.find('.cmb-repeatable-grouping').last();
|
||||
|
||||
$oldRow.find('.iconselectfa').each(function () {
|
||||
$(this).fontIconPicker().destroyPicker();
|
||||
});
|
||||
});
|
||||
|
||||
// When a new group row is added, clear selection and initialise Select2
|
||||
$('.cmb-repeatable-group').on('cmb2_add_row', function (event, newRow) {
|
||||
$(newRow).find('.iconselectfa').each(function () {
|
||||
$('option:selected', this).removeAttr("selected");
|
||||
$(this).fontIconPicker().refreshPicker({
|
||||
theme: 'fip-grey'
|
||||
});
|
||||
});
|
||||
|
||||
// Reinitialise the field we previously destroyed
|
||||
$(newRow).prev().find('.iconselectfa').each(function () {
|
||||
$(this).fontIconPicker().refreshPicker({
|
||||
theme: 'fip-grey'
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
// Before a group row is shifted, destroy Select2. We'll reinitialise after the row shift
|
||||
$('.cmb-repeatable-group').on('cmb2_shift_rows_start', function (event, instance) {
|
||||
var groupWrap = $(instance).closest('.cmb-repeatable-group');
|
||||
groupWrap.find('.iconselectfa').each(function () {
|
||||
$(this).fontIconPicker().destroyPicker();
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
// When a group row is shifted, reinitialise Select2
|
||||
$('.cmb-repeatable-group').on('cmb2_shift_rows_complete', function (event, instance) {
|
||||
var groupWrap = $(instance).closest('.cmb-repeatable-group');
|
||||
groupWrap.find('.iconselectfa').each(function () {
|
||||
$(this).fontIconPicker().refreshPicker({
|
||||
theme: 'fip-grey'
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
// Before a new repeatable field row is added, destroy Select2. We'll reinitialise after the row is added
|
||||
$('.cmb-add-row-button').on('click', function (event) {
|
||||
var $table = $(document.getElementById($(event.target).data('selector')));
|
||||
var $oldRow = $table.find('.cmb-row').last();
|
||||
|
||||
$oldRow.find('.iconselectfa').each(function () {
|
||||
$(this).fontIconPicker().destroyPicker();
|
||||
});
|
||||
});
|
||||
|
||||
// When a new repeatable field row is added, clear selection and initialise Select2
|
||||
$('.cmb-repeat-table').on('cmb2_add_row', function (event, newRow) {
|
||||
|
||||
// Reinitialise the field we previously destroyed
|
||||
$(newRow).prev().find('.iconselectfa').each(function () {
|
||||
$('option:selected', this).removeAttr("selected");
|
||||
$(this).fontIconPicker().refreshPicker({
|
||||
theme: 'fip-grey'
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
})(jQuery);
|
||||
Reference in New Issue
Block a user