Настройка экрана быстрого редактирования
Возможный дубликат: Как показать пользовательское мета-поле на экране "Быстрое редактирование"?
Я пытаюсь настроить экран быстрого редактирования для своего пользовательского типа записи "visitor", чтобы добавить дополнительные опции для конечных пользователей. Моему типу записи не требуются/не нужны: дата публикации, пароль для просмотра, статус публикации или большие блоки таксономий для пользовательских категорий посетителей.
Я уже добавил пользовательское мета-поле на страницу редактирования, но хотел бы добавить поддержку быстрого редактирования этих мета-полей, одновременно убрав текущие опции быстрого редактирования.
Также я нашел пост (ссылка в возможном дубликате) на форумах wordpress.org, но не совсем понимаю, что именно он делает.
Я использую этот код для добавления полей формы в режим быстрого редактирования. В WordPress это не самая простая задача (пока что), и найти информацию о том, как это сделать, может быть очень сложно. Приходится буквально копаться в исходном коде, чтобы разобраться.
Добавление полей формы в быстрое редактирование
<?php
add_action('quick_edit_custom_box', 'quickedit_posts_custom_box', 10, 2);
add_action('admin_head-edit.php', 'quick_add_script');
function quickedit_posts_custom_box( $col, $type ) {
if( $col != 'COLUMN_NAME' || $type != 'post' ) {
return;
} ?>
<fieldset class="inline-edit-col-right"><div class="inline-edit-col">
<div class="inline-edit-group">
<label class="alignleft">
<input type="checkbox" name="yourformfield" id="yourformfield_check">
<span class="checkbox-title">У этой записи есть торт</span>
</label>
</div>
</fieldset>
<?php
}
function quick_add_script() { ?>
<script type="text/javascript">
jQuery(document).ready(function() {
jQuery('a.editinline').live('click', function() {
var id = inlineEditPost.getId(this);
var val = parseInt(jQuery('#inline_' + id + '_yourformfield').text());
jQuery('#yourformfield_check').attr('checked', !!val);
});
});
</script>
<?php
}

Я прочитал это, но не понимаю: как можно установить флажок, если метаданные записи находятся в базе данных; get_meta_data() доступен только в php; возможно, у вас есть подсказка или решение для меня. В текущем виде ваш пример хорош, но я не понимаю ID #inline_' + id + '_yourformfield; где это находится; и является ли этот ID глобальным в WP. Я добавил много флажков, и сохранение данных работает нормально, но не могу найти решение для отображения отмеченных флажков. Большое спасибо!

Позволю себе немного похвастаться, но чтобы упростить редактирование пользовательских метаполей в WordPress, я написал плагин под названием Custom Bulk/Quick Edit.
Этот плагин не только добавляет пользовательские метаполя на экраны массового и быстрого редактирования, но и выводит их в виде колонок в списке записей.
Если тема или используемый плагин еще не добавили пользовательские метаполя в колонки типа записи, вы можете использовать фильтр для добавления своих колонок.
В файл functions.php
вашей темы добавьте код, аналогичный приведенному ниже.
add_filter( 'manage_post_posts_columns', 'my_manage_post_posts_columns' );
function my_manage_post_posts_columns( $columns ) {
$columns['custom_stuff'] = esc_html__( 'Кастомное поле' );
return $columns;
}
В качестве примера работы с пользовательским типом записи news-room
используйте следующий код.
add_filter( 'manage_news-room_posts_columns', 'my_manage_newsroom_posts_columns' );
function my_manage_newsroom_posts_columns( $columns ) {
$columns['wpcf-publication-author'] = esc_html__( 'Автор публикации');
$columns['wpcf-newsroom-type'] = esc_html__( 'Тип новостной ленты');
$columns['_views_template'] = esc_html__( 'Шаблон контента');
return $columns;
}
Это основано на фильтре manage_${post_type}_posts_columns для типа записи post
.
Обратите внимание, что для поддержки дальнейшей разработки бесплатная версия плагина ограничена встроенными типами записей WordPress. Если вы работаете с пользовательскими типами записей, вы можете приобрести версию Custom Bulk/Quick Edit Premium.
Также вы можете извлечь код из плагина через https://github.com/michael-cannon/custom-bulkquick-edit.

Добавьте этот код в ваш файл functions.php
. Этот код используется для пользовательского типа записи "расписание". Измените тип записи в соответствии с вашими потребностями.
// Добавляем в нашу функцию admin_init
add_filter('manage_schedule_posts_columns', 'myown_add_post_columns');
function myown_add_post_columns($columns) {
$columns['stime'] = 'Время начала';
$columns['etime'] = 'Время окончания';
return $columns;
}
// Добавляем в нашу функцию admin_init
add_action('manage_schedule_posts_custom_column', 'myown_render_post_columns', 10, 2);
function myown_render_post_columns($column_name, $id) {
switch ($column_name) {
case 'stime':
// показываем мое поле
echo get_post_meta( $id, 'stime', TRUE);
case 'etime':
// показываем мое поле
$my_fieldvalue1 = get_post_meta( $id, 'etime', TRUE);
echo $my_fieldvalue1;
}
}
// Добавляем в нашу функцию admin_init
add_action('quick_edit_custom_box', 'myown_add_quick_edit', 10, 2);
function myown_add_quick_edit($column_name, $post_type) {
if ($column_name != 'stime') return;
?>
<fieldset class="inline-edit-col-left">
<div class="inline-edit-col">
<span class="title">Время начала</span>
<input id="myfield_noncename" type="hidden" name="myfield_noncename" value="" />
<input id="myfield" type="text" name="stime" value=""/></br>
<span class="title">Время окончания</span>
<input id="myfield1" type="text" name="etime" value=""/></br>
<div id="main">
<span class="title">Добавить новую дату сессии</span></br>
<a href="#" class="aclick">Добавить</a></br></div>
</div>
</fieldset>
<?php
}
// Добавляем в нашу функцию admin_init
add_action('save_post', 'myown_save_quick_edit_data');
function myown_save_quick_edit_data($post_id) {
// проверяем, не является ли это автосохранением
if ( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE )
return $post_id;
// Проверяем права
if ( 'stime' == $_POST['post_type'] ) {
if ( !current_user_can( 'edit_page', $post_id ) )
return $post_id;
}
if ( 'etime' == $_POST['post_type'] ) {
if ( !current_user_can( 'edit_page', $post_id ) )
return $post_id;
}
else {
if ( !current_user_can( 'edit_post', $post_id ) )
return $post_id;
}
if(isset($_POST['tag-name']))
{
if ( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE ) return;
$post = get_post($post_id);
if ( $post->post_type == 'schedule') { // меняем 'post' на любой нужный вам CPT
$term = get_term_by('slug', $post->post_name, 'schedule_category');
if ( empty($term) ) {
$add = wp_insert_term( $_POST['tag-name'], 'schedule_category', array('slug'=> $_POST['tag-name']) );
if ( is_array($add) && isset($add['term_id']) ) {
wp_set_object_terms($post_id, $add['term_id'], 'schedule_category', true );
}
}
}
}
// Аутентификация пройдена, теперь сохраняем данные
if (isset($_POST['stime']) && ($post->post_type != 'revision')) {
$my_fieldvalue = esc_attr($_POST['stime']);
if ($my_fieldvalue)
update_post_meta( $post_id, 'stime', $my_fieldvalue);
else
delete_post_meta( $post_id, 'stime');
}
return $my_fieldvalue;
if (isset($_POST['etime']) && ($post->post_type != 'revision')) {
$my_fieldvalue1 = esc_attr($_POST['etime']);
if ($my_fieldvalue1)
update_post_meta( $post_id, 'etime', $my_fieldvalue1);
else
delete_post_meta( $post_id, 'etime');
}
return $my_fieldvalue1;
}
// Добавляем в нашу функцию admin_init
add_action('admin_footer', 'myown_quick_edit_javascript');
function myown_quick_edit_javascript() {
global $current_screen;
if (($current_screen->post_type != 'schedule')) return;
?>
<script type="text/javascript">
jQuery(document).ready(function(){
jQuery(".aclick").one("click", function(){
jQuery("#main").append('<input type="text" name="tag-name" />');
});
});
function set_myfield_value(fieldValue,fieldValue1, nonce) {
// правильно обновляем быстрое меню
inlineEditPost.revert();
console.log(fieldValue);
console.log(fieldValue1);
jQuery('#myfield').val(fieldValue);
jQuery('#myfield1').val(fieldValue1);
}
</script>
<?php
}
// Добавляем в нашу функцию admin_init
add_filter('post_row_actions', 'myown_expand_quick_edit_link', 10, 2);
function myown_expand_quick_edit_link($actions, $post) {
global $current_screen;
if (($current_screen->post_type != 'schedule'))
return $actions;
$nonce = wp_create_nonce( 'myfield_'.$post->ID);
$myfielvalue = get_post_meta( $post->ID, 'stime', TRUE);
$myfielvalue1 = get_post_meta( $post->ID, 'etime', TRUE);
$actions['inline hide-if-no-js'] = '<a href="#" class="editinline" title="';
$actions['inline hide-if-no-js'] .= esc_attr( __( 'Редактировать этот элемент' ) ) . '"';
$actions['inline hide-if-no-js'] .= " onclick=\"set_myfield_value('{$myfielvalue}','{$myfielvalue1}')\" >";
$actions['inline hide-if-no-js'] .= __( 'Быстрое редактирование' );
$actions['inline hide-if-no-js'] .= '</a>';
return $actions;
}

Также, пожалуйста, прочитайте мои комментарии к вашему вопросу о редактировании ваших сообщений. Ваш код представляет собой нечитаемую кашу, и не задача другого человека разбирать за вами, это ваша ответственность — правильно редактировать свои сообщения
