晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。   林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。   见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝)   既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。   南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。 .
Prv8 Shell
Server : Apache
System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64
User : rainic ( 1014)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/rainic/www/oldTZh/wp-content/plugins/persian-elementor/widget/form-fields/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/rainic/www/oldTZh/wp-content/plugins/persian-elementor/widget/form-fields/persian-date.php
<?php

namespace Persian_Elementor\Form_Fields;

use Elementor\Controls_Manager;
use ElementorPro\Modules\Forms\Fields\Field_Base;

if (!defined('ABSPATH')) {
    exit; // Exit if accessed directly
}

class Persian_Date_Field extends Field_Base {
    
    public function __construct() {
        parent::__construct();
        add_action('elementor/preview/init', [$this, 'editor_preview_footer']);
        add_action('wp_enqueue_scripts', [$this, 'register_assets']);
        add_action('elementor/editor/after_enqueue_scripts', [$this, 'register_assets']);
        add_action('elementor/preview/enqueue_styles', [$this, 'register_assets']);
    }
    
    /**
     * Register necessary assets for Persian date field.
     * 
     * @return void
     */
    public function register_assets() {
        // Use a fixed version number
        $version = '1.2.0';
        
        wp_register_style(
            'persian-elementor-datepicker-custom',
            PERSIAN_ELEMENTOR_URL . 'assets/css/datepicker-custom.css',
            [],
            $version
        );
        
        wp_register_script(
            'persian-elementor-datepicker',
            PERSIAN_ELEMENTOR_URL . 'assets/js/jalalidatepicker.min.js',
            ['jquery'],
            $version,
            true
        );
        
        wp_register_script(
            'persian-elementor-datepicker-init',
            PERSIAN_ELEMENTOR_URL . 'assets/js/datepicker-init.js',
            ['jquery', 'persian-elementor-datepicker'],
            $version,
            true
        );
        
        // Enqueue the assets
        wp_enqueue_style('persian-elementor-datepicker-custom');
        wp_enqueue_script('persian-elementor-datepicker');
        wp_enqueue_script('persian-elementor-datepicker-init');
    }
    
    public function editor_preview_footer(): void {
        add_action('wp_footer', [$this, 'content_template_script']);
    }
    
    public function content_template_script(): void {
        ?>
        <script>
        jQuery(document).ready(() => {
            elementor.hooks.addFilter(
                'elementor_pro/forms/content_template/field/<?php echo esc_js($this->get_type()); ?>',
                function(inputField, item, i) {
                    const fieldType = 'text';
                    const fieldId = `form_field_${i}`;
                    // Sanitize CSS classes to prevent XSS
                    const baseCssClasses = 'elementor-field-textual elementor-field persian-date-input';
                    const additionalClasses = (item.css_classes || '').replace(/[<>"']/g, '');
                    const fieldClass = `${baseCssClasses} ${additionalClasses}`.trim();
                    // Sanitize placeholder to prevent XSS
                    const placeholder = (item['persian-date-placeholder'] || '').replace(/[<>"']/g, '');
                    
                    // Initialize datepicker after element is added to DOM with multiple attempts
                    setTimeout(function() {
                        const initAttempts = function(attempts) {
                            if (attempts > 5) return;
                            
                            const element = document.getElementById(fieldId);
                            if (element && typeof window.jalaliDatepicker !== "undefined") {
                                try {
                                    window.jalaliDatepicker.attachDatepicker(element);
                                    element.setAttribute('data-jdp-initialized', 'true');
                                } catch (e) {
                                    console.log('Persian Elementor: Retry datepicker init attempt ' + attempts);
                                    setTimeout(() => initAttempts(attempts + 1), 200);
                                }
                            } else {
                                setTimeout(() => initAttempts(attempts + 1), 200);
                            }
                        };
                        initAttempts(1);
                    }, 300);
                    
                    // Create input element safely
                    const input = document.createElement('input');
                    input.type = fieldType;
                    input.id = fieldId;
                    input.className = fieldClass;
                    input.setAttribute('data-jdp', '');
                    input.readOnly = true;
                    input.placeholder = placeholder;
                    
                    return input.outerHTML;
                }, 10, 3
            );
        });
        </script>
        <?php
    }
    
    public function get_type() {
        return 'persian_date';
    }
    
    public function get_name() {
        return esc_html__('تاریخ شمسی', 'persian-elementor');
    }
    
    /**
     * Renders the Persian Date field on the frontend
     */
    public function render($item, $item_index, $form) {
        // Sanitize placeholder value
        $placeholder = isset($item['persian-date-placeholder']) ? 
            sanitize_text_field($item['persian-date-placeholder']) : 
            esc_attr__('تاریخ را انتخاب کنید', 'persian-elementor');
        
        // Set required attributes
        $form->add_render_attribute(
            'input' . $item_index,
            [
                'class' => 'elementor-field-textual persian-date-input',
                'name' => $form->get_attribute_name($item),
                'type' => 'text',
                'data-jdp' => '',
                'readonly' => 'readonly',
                'placeholder' => $placeholder,
            ]
        );
        
        // Output the field safely
        echo '<input ' . $form->get_render_attribute_string('input' . $item_index) . '>';
    }
    
    /**
     * Update the field controls in Elementor editor
     */
    public function update_controls($widget) {
        $elementor = $widget->get_controls('field_type');
        $elementor['options']['persian_date'] = esc_html__('تاریخ شمسی', 'persian-elementor');
        $widget->update_control('field_type', $elementor);
        
        $control_data = \ElementorPro\Plugin::elementor()->controls_manager->get_control_from_stack($widget->get_unique_name(), 'form_fields');
        
        if (is_wp_error($control_data)) {
            return;
        }
        
        $field_controls = [
            'persian-date-placeholder' => [
                'name' => 'persian-date-placeholder',
                'label' => esc_html__('Placeholder', 'persian-elementor'),
                'type' => Controls_Manager::TEXT,
                'default' => esc_html__('تاریخ را انتخاب کنید', 'persian-elementor'),
                'dynamic' => [
                    'active' => true,
                ],
                'condition' => [
                    'field_type' => $this->get_type(),
                ],
                'tab' => 'content',
                'inner_tab' => 'form_fields_content_tab',
                'tabs_wrapper' => 'form_fields_tabs',
            ],
        ];
        
        $control_data['fields'] = $this->inject_field_controls($control_data['fields'], $field_controls);
        $widget->update_control('form_fields', $control_data);
    }
    
    /**
     * Field validation
     */
    public function validation($field, $record, $ajax_handler) {
        // Check if field is required and empty
        if (empty($field['value']) && $field['required']) {
            $ajax_handler->add_error(
                $field['id'],
                esc_html__('تاریخ را وارد کنید.', 'persian-elementor')
            );
            return;
        }
        
        // If field has value, validate Persian date format
        if (!empty($field['value'])) {
            $date_value = sanitize_text_field($field['value']);
            
            // Basic Persian date format validation (YYYY/MM/DD)
            if (!preg_match('/^\d{4}\/\d{1,2}\/\d{1,2}$/', $date_value)) {
                $ajax_handler->add_error(
                    $field['id'],
                    esc_html__('فرمت تاریخ صحیح نیست. لطفاً تاریخ را از تقویم انتخاب کنید.', 'persian-elementor')
                );
                return;
            }
            
            // Additional validation: check if date parts are in valid range
            $date_parts = explode('/', $date_value);
            if (count($date_parts) === 3) {
                $year = (int) $date_parts[0];
                $month = (int) $date_parts[1];
                $day = (int) $date_parts[2];
                
                // Basic range validation for Persian calendar
                if ($year < 1300 || $year > 1500 || $month < 1 || $month > 12 || $day < 1 || $day > 31) {
                    $ajax_handler->add_error(
                        $field['id'],
                        esc_html__('تاریخ وارد شده معتبر نیست.', 'persian-elementor')
                    );
                }
            }
        }
    }
}

haha - 2025