Wordpress создает новый статус сообщения?
В Wordpress вы получаете статусы сообщений по умолчанию: опубликованные, черновики и ожидающие рассмотрения. Можно ли добавить еще несколько типов сообщений, зарегистрировав их через файл function.php активной темы?
Также возможно отредактировать таблицы в метатеге публикации? То, что я представляю, действительно не является публикацией...
Также хотел бы добавить, что я хочу, чтобы эти изменения были сделаны, когда в моем настраиваемом типе сообщений я сделал.
С уважением
Скотт
Ответы
Ответ 1
Начиная с WP 3.0, вы можете использовать функцию register_post_status() (http://hitchhackerguide.com/2011/02/12/register_post_status/), чтобы добавить новые статусы в тип сообщения.
Сам WP использует register_post_status() для регистрации статусов "опубликованных", "черновиков" и т.д. по умолчанию с помощью функции create_initial_post_types() в wp-includes/post.php(http://hitchhackerguide.com/2011/02/11/create_initial_post_types/).
Посмотрите на код в этих ссылках, и вы можете получить представление о том, как использовать эту функцию.
Я надеюсь, что это поможет вам начать работу.
Ответ 2
Вы можете написать плагин, если знаете, как это сделать. Вы должны вникнуть в документацию или подобные плагины, подобные этой http://wordpress.org/extend/plugins/edit-flow/ или этой http://wordpress.org/extend/plugins/custom-post-type-ui/
С помощью "Крюков, действий и фильтров" вы можете изменить интерфейс администратора, см. здесь http://codex.wordpress.org/Plugin_API
Пока я пишу только один простой плагин, и я не знаю, какие именно шаги вам нужно выполнить, чтобы выполнить это...
Удачи!
Ответ 3
Вы можете добавить пользовательский статус сообщения ', используя функцию register_post_status. Обратитесь к create_initial_post_types() в http://core.trac.wordpress.org/browser/tags/3.2.1/wp-includes/post.php
Следует предупредить, что это не интегрировано в пользовательский интерфейс Wordpress.
Ответ 4
/**
* PostStatusExtender
*
* @author Hyyan Abo Fakher<[email protected]>
*/
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>'),
)
));
});
Изменить: фиксированная опечатка в коде.