Wordpress создает новый статус записи?[закрыто]
Вопрос
В Wordpress вы получаете статусы записей по умолчанию:Опубликовано, черновик и находится на рассмотрении.Можно ли добавить еще несколько типов сообщений, зарегистрировав их через function.php файл активной темы?
Также возможно ли отредактировать метки в метабоксе Публикации?То, что я отправляю, на самом деле не является Публикацией...
Также хотел бы добавить, что я хочу, чтобы эти изменения вносились только тогда, когда я внесу их в свой пользовательский тип записи.
С наилучшими пожеланиями
Скотт
Решение
Со времени WP 3.0 вы можете использовать функцию Register_post_status () http://hitchhackerguide.com/2011/02/12/register_post_status/ ) добавить новые статусы в тип поста.
Сам WP использует Register_post_status () для регистрации по умолчанию «Опубликовано», «Проект» и т. Д. Статусы на init с использованием функции create_initial_post_types () в wp-includes/post.php ( http://hitchhackerguide.com/2011/02/11/create_initial_post_types/ ).
Посмотрите на код в этих ссылках, и вы можете получить представление о том, как использовать функцию.
Я надеюсь, что это поможет вам начать!
Другие советы
Вы можете написать плагин, если знаете, как. Вы должны покопаться в документации или подобных плагинах, подобных этой http://wordpress.org/extend/plugins/edit-flow/ или этот http://wordpress.org/extend/plugins/custom-post-type-ui/
С «крючками, действиями и фильтрами» вы можете изменить интерфейс администратора, см. Здесь http://codex.wordpress.org/plugin_api
До сих пор я пишу только один простой плагин, и я не знаю точных шагов, которые вы должны выполнить, чтобы выполнить это ...
Удачи!
Вы можете добавить пользовательскую статус Post 'с помощью функции Register_post_status. Обратитесь к create_initial_post_types () в http://core.trac.wordpress.org/browser/tags/3.2.1/wp-includes/post.php
Однако будьте осторожны, что это не интегрировано в бэкэнд WordPress.
/**
* PostStatusExtender
*
* @author Hyyan Abo Fakher<hyyanaf@gmail.com>
*/
class PostStatusExtender
{
/**
* Extend
*
* Extend the current status list for the given post type
*
* @global \WP_POST $post
*
* @param string $postType the post type name , ex: product
* @param array $states array of states where key is the id(state id) and value
* is the state array
*/
public static function extend($postType, $states)
{
foreach ($states as $id => $state) {
register_post_status($id, $state);
}
add_action('admin_footer-post.php', function() use($postType, $states) {
global $post;
if (!$post || $post->post_type !== $postType) {
return false;
}
foreach ($states as $id => $state) {
printf(
'<script>'
. 'jQuery(document).ready(function($){'
. ' $("select#post_status").append("<option value=\"%s\" %s>%s</option>");'
. ' $("a.save-post-status").on("click",function(e){'
. ' e.preventDefault();'
. ' var value = $("select#post_status").val();'
. ' $("select#post_status").value = value;'
. ' $("select#post_status option").removeAttr("selected", true);'
. ' $("select#post_status option[value=\'"+value+"\']").attr("selected", true)'
. ' });'
. '});'
. '</script>'
, $id
, $post->post_status !== $id ? '' : 'selected=\"selected\"'
, $state['label']
);
if ($post->post_status === $id) {
printf(
'<script>'
. 'jQuery(document).ready(function($){'
. ' $(".misc-pub-section #post-status-display").text("%s");'
. '});'
. '</script>'
, $state['label']
);
}
}
});
add_action('admin_footer-edit.php', function() use($states, $postType) {
global $post;
if (!$post || $post->post_type !== $postType) {
return false;
}
foreach ($states as $id => $state) {
printf(
'<script>'
. 'jQuery(document).ready(function($){'
. " $('select[name=\"_status\"]' ).append( '<option value=\"%s\">%s</option>' );"
. '});'
. '</script>'
, $id
, $state['label']
);
}
});
add_filter('display_post_states', function($states, $post) use($states, $postType) {
foreach ($states as $id => $state) {
if ($post->post_type == $postType && $post->post_status === $id) {
return array($state['label']);
} else {
if (array_key_exists($id, $states)) {
unset($states[$id]);
}
}
}
return $states;
}, 10, 2);
}
}
И здесь как использовать IT
add_action('init', function() {
PostStatusExtender::extend(self::NAME, array(
'sold' => array(
'label' => __('Sold', 'viasit'),
'public' => true,
'exclude_from_search' => true,
'show_in_admin_all_list' => true,
'show_in_admin_status_list' => true,
'label_count' => _n_noop('Sold <span class="count">(%s)</span>', 'Sold <span class="count">(%s)</span>'),
)
));
});
Редактировать: исправлена опечатка в коде.