• Здравствуйте, подскажите пожалуйста где находится код, который выводит поля <input>? Мне нужно установить функцию esc_attr() в поле для редактирования, чтобы не было такого.

Просмотр 3 ответов — с 1 по 3 (всего 3)
  • Это зависит от плагина или темы, которая выводит всю эту форму.

    Вот форма в functions.php

    //////////////////////////////////////////////////////////////////
    // Register custom meta box for reviews
    //////////////////////////////////////////////////////////////////
    $prefix = 'leetpress_';
    
    $meta_box = array(
        'id' => 'rating-meta-box',
        'title' => 'Информация игры',
        'page' => 'reviews',
        'context' => 'normal',
        'priority' => 'high',
        'fields' => array(
    		array(
                'name' => 'Миниатюра игры',
                'desc' => 'Только вставить эскиз вашей игры здесь, если вы показываете игры на главной странице (миниатюра должна быть не менее 600x300px).',
                'id' => $prefix . 'review_thumb',
                'type' => 'text',
                'std' => ''
            ),
            array(
                'name' => 'Общий балл',
                'desc' => 'Выберите число от 1-10 (напр. 9.7)',
                'id' => $prefix . 'overallscore',
                'type' => 'text',
                'std' => ''
            ),
    		array(
                'name' => 'Критерия 1',
                'desc' => 'Введите критерию (напр. Графика)',
                'id' => $prefix . 'criteria1',
                'type' => 'text',
                'std' => ''
            ),
            array(
                'name' => 'Рейтинг критерии',
                'id' => $prefix . 'crit1_rating',
                'type' => 'select',
                'options' => array('1', '2', '3', '4', '5', '6', '7', '8', '9', '10')
            ),
    		array(
                'name' => 'Критерия 2',
                'desc' => 'Введите критерию (напр. Звук)',
                'id' => $prefix . 'criteria2',
                'type' => 'text',
                'std' => ''
            ),
            array(
                'name' => 'Рейтинг критерии',
                'id' => $prefix . 'crit2_rating',
                'type' => 'select',
                'options' => array('1', '2', '3', '4', '5', '6', '7', '8', '9', '10')
            ),
    		array(
                'name' => 'Критерия 3',
                'desc' => 'Введите критерию (напр. Геймплей)',
                'id' => $prefix . 'criteria3',
                'type' => 'text',
                'std' => ''
            ),
            array(
                'name' => 'Рейтинг критерии',
                'id' => $prefix . 'crit3_rating',
                'type' => 'select',
                'options' => array('1', '2', '3', '4', '5', '6', '7', '8', '9', '10')
            ),
    		array(
                'name' => 'Плюсы игры',
                'desc' => 'Введите плюсы игры и разделите их "|". (напр. Великая история | Выдающийся саундтрек)',
                'id' => $prefix . 'good',
                'type' => 'text',
                'std' => ''
            ),
    		array(
                'name' => 'Минусы игры',
                'desc' => 'Введите минусы игры и разделите их "|". (напр. Багги Мультиплеера | Очень короткая кампания)',
                'id' => $prefix . 'bad',
                'type' => 'text',
                'std' => ''
            ),
    		array(
                'name' => 'Кнопка',
                'desc' => 'Ссылка на игру',
                'id' => $prefix . 'button',
                'type' => 'text',
                'std' => ''
            )
        )
    );
    
    add_action('admin_menu', 'mytheme_add_box');
    
    // Add meta box
    function mytheme_add_box() {
    	global $meta_box;
    
    	add_meta_box($meta_box['id'], $meta_box['title'], 'mytheme_show_box', $meta_box['page'], $meta_box['context'], $meta_box['priority']);
    }
    
    // Callback function to show fields in meta box
    function mytheme_show_box() {
    	global $meta_box, $post;
    
    	// Use nonce for verification
    	echo '<input type="hidden" name="mytheme_meta_box_nonce" value="', wp_create_nonce(basename(__FILE__)), '" />';
    
    	echo '<table class="form-table">';
    
    	foreach ($meta_box['fields'] as $field) {
    		// get current post meta data
    		$meta = get_post_meta($post->ID, $field['id'], true);
    
    		echo '<tr>',
    				'<th style="width:20%"><label for="', $field['id'], '"><strong>', $field['name'], ':</strong></label></th>',
    				'<td>';
    		switch ($field['type']) {
    			case 'text':
    				echo '<input type="text" name="', $field['id'], '" id="', $field['id'], '" value="', $meta ? $meta : $field['std'], '" size="30" style="width:97%" />',
    					'<br /><small>', $field['desc'],'</small>';
    				break;
    			case 'textarea':
    				echo '<textarea name="', $field['id'], '" id="', $field['id'], '" cols="60" rows="4" style="width:97%">', $meta ? $meta : $field['std'], '</textarea>',
    					'<br />', $field['desc'];
    				break;
    			case 'select':
    				echo '<select name="', $field['id'], '" id="', $field['id'], '">';
    				foreach ($field['options'] as $option) {
    					echo '<option', $meta == $option ? ' selected="selected"' : '', '>', $option, '</option>';
    				}
    				echo '</select>';
    				break;
    			case 'radio':
    				foreach ($field['options'] as $option) {
    					echo '<input type="radio" name="', $field['id'], '" value="', $option['value'], '"', $meta == $option['value'] ? ' checked="checked"' : '', ' />', $option['name'];
    				}
    				break;
    			case 'checkbox':
    				echo '<input type="checkbox" name="', $field['id'], '" id="', $field['id'], '"', $meta ? ' checked="checked"' : '', ' />';
    				break;
    		}
    		echo 	'<td>',
    			'</tr>';
    	}
    
    	echo '</table>';
    }
    
    add_action('save_post', 'mytheme_save_data');
    
    // Save data from meta box
    function mytheme_save_data($post_id) {
    	global $meta_box;
    
    	// verify nonce
    	if (!wp_verify_nonce($_POST['mytheme_meta_box_nonce'], basename(__FILE__))) {
    		return $post_id;
    	}
    
    	// check autosave
    	if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
    		return $post_id;
    	}
    
    	// check permissions
    	if ('page' == $_POST['post_type']) {
    		if (!current_user_can('edit_page', $post_id)) {
    			return $post_id;
    		}
    	} elseif (!current_user_can('edit_post', $post_id)) {
    		return $post_id;
    	}
    
    	foreach ($meta_box['fields'] as $field) {
    		$old = get_post_meta($post_id, $field['id'], true);
    		$new = $_POST[$field['id']];
    
    		if ($new && $new != $old) {
    			update_post_meta($post_id, $field['id'], $new);
    		} elseif ('' == $new && $old) {
    			delete_post_meta($post_id, $field['id'], $old);
    		}
    	}
    }

    Модератор Sergey Biryukov

    (@sergeybiryukov)

    Live and Learn

    Ответил в теме «Новый тип записи». Эту закрываю как дубль.

Просмотр 3 ответов — с 1 по 3 (всего 3)
  • Тема «Где находится код, выводящий» закрыта для новых ответов.