Hotel Raxa Dev 5b1e2453c7 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>
2025-07-11 07:43:22 +02:00

88 lines
2.1 KiB
PHP

<?php
namespace Elementor\Modules\SiteNavigation\Data\Endpoints;
use Elementor\Data\V2\Base\Endpoint;
use Elementor\Plugin;
use Elementor\User;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
class Add_New_Post extends Endpoint {
protected function register() {
$args = [
'post_type' => [
'description' => 'Post type to create',
'type' => 'string',
'required' => false,
'default' => 'post',
'sanitize_callback' => function ( $value ) {
return sanitize_text_field( $value );
},
'validate_callback' => 'rest_validate_request_arg',
],
];
$this->register_items_route( \WP_REST_Server::CREATABLE, $args );
}
public function get_name() {
return 'add-new-post';
}
public function get_format() {
return 'site-navigation/add-new-post';
}
public function create_items( $request ) {
$post_type = $request->get_param( 'post_type' );
if ( ! $this->validate_post_type( $post_type ) ) {
return new \WP_Error( 400, sprintf( 'Post type %s does not exist.', $post_type ), [ 'status' => 400 ] );
}
if ( ! User::is_current_user_can_edit_post_type( $post_type ) ) {
return new \WP_Error( 401, sprintf( 'User dont have capability to create page of type - %s.', $post_type ), [ 'status' => 401 ] );
}
// Temporary solution for the fact that documents creation not using the actual registered post types.
$post_type = $this->map_post_type( $post_type );
$document = Plugin::$instance->documents->create( $post_type );
if ( is_wp_error( $document ) ) {
return new \WP_Error( 500, sprintf( 'Error while creating %s.', $post_type ) );
}
return [
'id' => $document->get_main_id(),
'edit_url' => $document->get_edit_url(),
];
}
private function validate_post_type( $post_type ): bool {
$post_types = get_post_types();
return in_array( $post_type, $post_types );
}
/**
* Map post type to Elementor document type.
*
* @param $post_type
*
* @return string
*/
private function map_post_type( $post_type ): string {
$post_type_map = [
'page' => 'wp-page',
'post' => 'wp-post',
];
return $post_type_map[ $post_type ] ?? $post_type;
}
}