繁体   English   中英

如何动态分配作者在WordPress中发布?

[英]How to dynamically assign author to post in WordPress?

我正在创建一个WordPress插件,它有一个自定义元框,列出了作者和贡献者的复选框。 选中后,列表会显示在帖子末尾的前端。 我需要做的是:当用户单击贡献者的名称时,它将恢复到存档页面,但该帖子未列在该贡献者的名称下。

如何在多个贡献者下更新和保存帖子,以便在作者的档案页面下显示?

这是自定义元框回调函数和保存帖子时调用的函数:

function cd_meta_box_cb($post)
{
    global $post;
    echo'<b> Select the contributors that have contributed to this post: </b>';
    echo '<br><br>';
    wp_nonce_field('my_meta_box_nonce', 'meta_box_nonce');
    global $wpdb;

    $authors=$wpdb->get_results("SELECT wp_users.ID, wp_users.user_nicename 
    FROM wp_users INNER JOIN wp_usermeta 
    ON wp_users.ID = wp_usermeta.user_id 
    WHERE wp_usermeta.meta_key = 'wp_capabilities' 
    AND wp_usermeta.meta_value LIKE '%author%' OR wp_usermeta.meta_value LIKE '%editor%'  
    ORDER BY wp_users.user_nicename");

    $current_user = wp_get_current_user();
    foreach ($authors as $author) {
        $author_info=get_userdata($author->ID);
        //$author_role=$author_info->roles;
        $author_first_name=$author_info->first_name;
        $author_last_name=$author_info->last_name;
        if(strcmp($current_user->user_nicename,$author->user_nicename)==0)
        {       
            echo"<input type='checkbox' id='my_meta_box_check' name='my_meta_box_check[]'";
            echo"value=";
            the_author_meta('user_nicename', $author->ID);
            echo" checked disabled>";

            echo"<input type='hidden' id='my_meta_box_check' name='my_meta_box_check[]'";
            echo"value=";
            the_author_meta('user_nicename', $author->ID);
            echo">";
        }
        else
        {
            echo"<input type='checkbox' id='my_meta_box_check' name='my_meta_box_check[]'";
            echo"value=";
            the_author_meta('user_nicename', $author->ID);
            echo">";    
        }
        echo $author_first_name ." ". $author_last_name ." ";
        echo"(";
        echo"<label id='labelid' for='author'>";
        the_author_meta('user_nicename', $author->ID);
        echo"</label>";
        echo")";
        echo "<br />";
    }
}
//save custom data when our post is saved
function save_custom_data($post_id)
{
    global $post,$wpdb;

    $contributor=get_post_meta($post->ID, 'my_meta_box_check', true);
    if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) return;
    if (!isset($_POST['meta_box_nonce']) || !wp_verify_nonce($_POST['meta_box_nonce'], 'my_meta_box_nonce')) return;
    if (!current_user_can('edit_post')) return;
    if (isset($_POST['my_meta_box_check'])) 
    {
        update_post_meta($post_id, 'my_meta_box_check', $_POST['my_meta_box_check']);
        $tablename = $wpdb->prefix.'authorlist';
        $wpdb->insert($tablename,array('authorname'=>$post_id,'authorpost'=>$contributor));
    }
    else 
    {
        delete_post_meta($post_id, 'my_meta_box_check');
    }
}

add_action('save_post', 'save_custom_data');

将其添加到主题的'functions.php'或插件中。

add_action( 'pre_get_posts', 'modify_author_query' );

function modify_author_query( $query ) {
    // check if on front-end and author query is modified
    if ( ! is_admin() && is_main_query() && $query->is_author() ) {
        $author_name =  $query->query_vars['author_name'];
        //$userdata = get_user_by('slug',$author_name);
        //$userid = $user->ID;

        $meta_query = array(  
            array(
                'key' => 'my_meta_box_check',
                'value' => $author_name,
                'compare' => 'LIKE'
            )
        );
        $query->set( 'meta_query', $meta_query );

        // unset the default author since we are using custom meta
        unset( $query->query_vars['author_name'] );
    }
}

请注意,如果用户名的一部分与另一个匹配,上面可能会显示错误的结果 - 尝试将数据保存为逗号分隔的字符串 (应以逗号开头和结尾)并将'value' => $author_name'value' => ','.$author_name.','

好吧,首先,Wordpress打算在帖子中有一位作者。 所以我们需要从那里开始。

我的方法是使用Wordpress作者字段作为主要作者,并为“次要”作者拥有自己的字段。

通过这种方式,您可以直接连接到作者页面查询,并添加除了用户是作者的帖子之外,还可以在meta下保存用户的保存位置。

没有引用任何代码,因为你的问题似乎比不知道代码更错误。

add_filter('posts_where', function($where){
      if(!is_admin() && is_author() && is_main_query() ){
            $where = "AND ((dev_posts.post_author = ".get_queried_object_id().") OR ( ( dev_postmeta.meta_key = 'auth_id' AND dev_postmeta.meta_value LIKE '%:\"'.get_queried_object_id().'\"\;%' ) )) AND dev_posts.post_type = 'post' AND (dev_posts.post_status = 'publish' OR dev_posts.post_status = 'private')";
    }
    return $where;
});

add_action('pre_get_posts', function($query){
    if(!is_admin() && is_author() && is_main_query() ){
        $query->set('relation', 'or');
        $query->set('meta_query', array(array(
            'key' => 'auth_id',
            'value' => ':'.get_queried_object_id().';',
            'compare' => 'LIKE'
        )));
    }
}); 

“dev”是我的数据库前缀,因此您需要使用$ wpdb-> prefix替换

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM