88 lines
2.1 KiB
PHP
Raw Normal View History

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
<?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;
}
}