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:
113
wp-content/plugins/elementor/includes/managers/skins.php
Normal file
113
wp-content/plugins/elementor/includes/managers/skins.php
Normal file
@@ -0,0 +1,113 @@
|
||||
<?php
|
||||
namespace Elementor;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor skins manager.
|
||||
*
|
||||
* Elementor skins manager handler class is responsible for registering and
|
||||
* initializing all the supported skins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class Skins_Manager {
|
||||
|
||||
/**
|
||||
* Registered Skins.
|
||||
*
|
||||
* Holds the list of all the registered skins for all the widgets.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
*
|
||||
* @var array Registered skins.
|
||||
*/
|
||||
private $_skins = [];
|
||||
|
||||
/**
|
||||
* Add new skin.
|
||||
*
|
||||
* Register a single new skin for a widget.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @param Widget_Base $widget Elementor widget.
|
||||
* @param Skin_Base $skin Elementor skin.
|
||||
*
|
||||
* @return true True if skin added.
|
||||
*/
|
||||
public function add_skin( Widget_Base $widget, Skin_Base $skin ) {
|
||||
$widget_name = $widget->get_name();
|
||||
|
||||
if ( ! isset( $this->_skins[ $widget_name ] ) ) {
|
||||
$this->_skins[ $widget_name ] = [];
|
||||
}
|
||||
|
||||
$this->_skins[ $widget_name ][ $skin->get_id() ] = $skin;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove a skin.
|
||||
*
|
||||
* Unregister an existing skin from a widget.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @param Widget_Base $widget Elementor widget.
|
||||
* @param string $skin_id Elementor skin ID.
|
||||
*
|
||||
* @return true|\WP_Error True if skin removed, `WP_Error` otherwise.
|
||||
*/
|
||||
public function remove_skin( Widget_Base $widget, $skin_id ) {
|
||||
$widget_name = $widget->get_name();
|
||||
|
||||
if ( ! isset( $this->_skins[ $widget_name ][ $skin_id ] ) ) {
|
||||
return new \WP_Error( 'Cannot remove not-exists skin.' );
|
||||
}
|
||||
|
||||
unset( $this->_skins[ $widget_name ][ $skin_id ] );
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get skins.
|
||||
*
|
||||
* Retrieve all the skins assigned for a specific widget.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @param Widget_Base $widget Elementor widget.
|
||||
*
|
||||
* @return false|array Skins if the widget has skins, False otherwise.
|
||||
*/
|
||||
public function get_skins( Widget_Base $widget ) {
|
||||
$widget_name = $widget->get_name();
|
||||
|
||||
if ( ! isset( $this->_skins[ $widget_name ] ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $this->_skins[ $widget_name ];
|
||||
}
|
||||
|
||||
/**
|
||||
* Skins manager constructor.
|
||||
*
|
||||
* Initializing Elementor skins manager by requiring the skin base class.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*/
|
||||
public function __construct() {
|
||||
require ELEMENTOR_PATH . 'includes/base/skin-base.php';
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user