Вопрос

В 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>'),
        )
    ));
});

Редактировать: исправлена опечатка в коде.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top