🏨 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>
70 lines
2.4 KiB
PHP
70 lines
2.4 KiB
PHP
<?php
|
|
/**
|
|
* The template for the panel footer area.
|
|
* Override this template by specifying the path where it is stored (templates_path) in your Redux config.
|
|
*
|
|
* @author Redux Framework
|
|
* @package ReduxFramework/Templates
|
|
* @version: 4.4.2
|
|
*/
|
|
|
|
// Exit if accessed directly.
|
|
defined( 'ABSPATH' ) || exit;
|
|
|
|
?>
|
|
<div id="redux-sticky-padder" style="display: none;"> </div>
|
|
<div id="redux-footer-sticky">
|
|
<div id="redux-footer">
|
|
<?php
|
|
if ( isset( $this->parent->args['share_icons'] ) ) {
|
|
$skip_icons = false;
|
|
|
|
if ( ! $this->parent->args['dev_mode'] && $this->parent->args_class->omit_icons ) {
|
|
$skip_icons = true;
|
|
}
|
|
?>
|
|
<div id="redux-share">
|
|
<?php
|
|
foreach ( $this->parent->args['share_icons'] as $links ) {
|
|
if ( $skip_icons ) {
|
|
continue;
|
|
}
|
|
// SHIM, use URL now.
|
|
if ( isset( $links['link'] ) && ! empty( $links['link'] ) ) {
|
|
$links['url'] = $links['link'];
|
|
unset( $links['link'] );
|
|
}
|
|
if ( isset( $links['icon'] ) && ! empty( $links['icon'] ) ) {
|
|
if ( strpos( $links['icon'], 'el-icon' ) !== false && strpos( $links['icon'], 'el ' ) === false ) {
|
|
$links['icon'] = 'el ' . $links['icon'];
|
|
}
|
|
}
|
|
?>
|
|
<a href="<?php echo esc_url( $links['url'] ); ?>" title="<?php echo esc_attr( $links['title'] ); ?>" target="_blank">
|
|
<?php if ( isset( $links['icon'] ) && ! empty( $links['icon'] ) ) { ?>
|
|
<i class="<?php echo esc_attr( $links['icon'] ); ?>"></i>
|
|
<?php } else { ?>
|
|
<img alt="<?php echo esc_url( $links['img'] ); ?>" src="<?php echo esc_url( $links['img'] ); ?>"/>
|
|
<?php } ?>
|
|
</a>
|
|
<?php } ?>
|
|
</div>
|
|
<?php } ?>
|
|
|
|
<div class="redux-action_bar">
|
|
<span class="spinner"></span>
|
|
<?php
|
|
if ( false === $this->parent->args['hide_save'] ) {
|
|
submit_button( esc_html__( 'Save Changes', 'redux-framework' ), 'primary', 'redux_save', false, array( 'id' => 'redux_bottom_save' ) );
|
|
}
|
|
|
|
if ( false === $this->parent->args['hide_reset'] ) {
|
|
submit_button( esc_html__( 'Reset Section', 'redux-framework' ), 'secondary', $this->parent->args['opt_name'] . '[defaults-section]', false, array( 'id' => 'redux-defaults-section-bottom' ) );
|
|
submit_button( esc_html__( 'Reset All', 'redux-framework' ), 'secondary', $this->parent->args['opt_name'] . '[defaults]', false, array( 'id' => 'redux-defaults-bottom' ) );
|
|
}
|
|
?>
|
|
</div>
|
|
<div class="clear"></div>
|
|
</div>
|
|
</div>
|