web-dev-qa-db-ja.com

WordPressのユーザープロファイルを使用するのに対して、「staff」のカスタムの投稿タイプはありますか。

私が出くわしているシナリオは、私が何らかのリストと伝記情報を持つ単一のプロフィールページを持ちたい組織のために何人かのスタッフがいるかもしれないところです。

通常、スタッフ用にカスタム投稿タイプを作成し、必要に応じてカスタム分類法を作成します。

しかし今、私はそれがWordpressの組み込みの "ユーザー"投稿タイプを使うのが最適でないかもしれないかどうか疑問に思います。私は、ユーザープロファイルフィールドをカスタマイズしたり、ユーザーリストを表示したり、単一のプロファイルなどを表示したりできることに気付きました。カスタム分類も可能です。

ここにベストプラクティスはありますか?

私は今、すべてのスタッフが自分の名前でブログ記事を書いていますので、とにかくユーザーアカウントを持っています。カスタム投稿タイプの「staff」を使用します。

今のところ私はCPTを使い、Posts 2 Postsプラグインを使って彼らの "staff"投稿を彼らの "user"アカウントに関連付け、それによって彼らの単一のstaffページにブログ投稿のリストを作成しています。

ワードプレスでこれを実装する最善の方法についての任意の考えは高く評価されています。

11
bongoman

サイトに公開したい人がsersの場合、つまりアカウントを持ち、投稿を書く場合、WordPressユーザー機能を使用する方がはるかに良いと思います:すべての情報CPTに入れることはユーザーメタデータにも入れることができ、ユーザーの作成は必須(ログインする必要があります)ですが、CPTの作成は回避でき、私にとっては冗長です。

ただし、CPTを使用するとsimplerになる可能性があることは、いくつかの理由でわかっています。

  1. WP adminのデフォルトのプロファイルページにはほとんど情報がありません。
  2. WPにはパブリックプロフィールページがまったくありません:author.phpはプロフィールページではありません。
  3. プロフィールページに加えて、おそらくloop staffを使用し、もちろんWP_User_Queryを使用してこれを行うことができますが、hiddenは少し難しい場合があります。ユーザー分類法がなく、ユーザーロールを使用すると、公開してはいけないユーザーにpublicロールを割り当てたい場合に問題が発生する可能性があります。

幸いなことに、これらの問題は現実的ではありません問題であり、簡単に解決できます。私が提案するワークフローは次のとおりです。

  1. 新しいユーザー役割を作成します。標準の役割から機能を複製できますが、役割を作成し、スタッフを他のユーザーから分離するのは非常に簡単です。
  2. ユーザープロファイルのカスタムフィールドを追加し、必要な情報をすべて入力します。
  3. ユーザーループとユーザープロファイルを処理するページテンプレートを作成します。どうやって?ポイント4を見てください。
  4. 書き換えエンドポイントを作成します。この方法では、example.com/staffのようなURLはページ(3で作成したテンプレートを割り当てたもの)を呼び出し、example.com/staff/user/nicknameのようなURLは同じページを呼び出しますが、クエリvar usernicknameで、ユーザープロファイルを表示するためにページで使用できます。

1.、2。、および4.は、プラグインで簡単に実行できます。このプラグインのbonesを提供しますが、改善する必要があります。

<?php
/**
 * Plugin Name: Staff Plugin
 * Description: Test
 * Author: G.M.
*/

/**
* Add a new role cloning capabilities from editor and flush rewrite rules
*/
function install_staff_plugin() {
    $editor = get_role( 'editor' );
    add_role( 'staff', 'Staff', $editor->capabilities );
    staff_plugin_endpoint();
    flush_rewrite_rules();
}

/**
* Remove the role and flush rewrite rules
*/
function unistall_staff_plugin() {
    remove_role( 'staff' );
    flush_rewrite_rules();
}

/**
* Add the endpoint
*/
function staff_plugin_endpoint() {
    add_rewrite_endpoint( 'user', EP_PAGES );
}

/**
* Add custom field to profile page
*/
function staff_plugin_profile_fields( $user ) {
    $fields = array(
        'facebook' => __('Facebook'),
        'Twitter'  => __('Twitter'),
        'photo_id' => __('Photo ID (use attachment id)')
    );
    echo '<h3>' . __('Staff Information') . '</h3>';
    echo '<table class="form-table">';
    foreach ( $fields as $field => $label ) {
        $now = get_user_meta( $user->ID, $field, true ) ? : "";
        printf( '<tr><th><label for="%s">%s</label></th>',
            esc_attr($field), esc_html($label) );
        printf( '<td><input type="text" name="%s" id="%s" value="%s" class="regular-text" /><br /></td></tr>', 
            esc_attr($field), esc_attr($field), esc_attr($now) );
    }
    echo '</table>';
}

/**
* Save the custom fields
*/
function staff_plugin_profile_fields_save( $user_id ) {
    if ( ! current_user_can( 'edit_user', $user_id ) ) return;
    $fields = array( 'facebook', 'Twitter', 'photo_id' );
    foreach ( $fields as $field ) {
        if ( isset( $_POST[$field] ) ) 
            update_user_meta( $user_id, $field, $_POST[$field] );
    }
}

add_action( 'init', 'staff_plugin_endpoint' );
add_action( 'show_user_profile', 'staff_plugin_profile_fields' );
add_action( 'edit_user_profile', 'staff_plugin_profile_fields' );
add_action( 'personal_options_update', 'staff_plugin_profile_fields_save' );
add_action( 'edit_user_profile_update', 'staff_plugin_profile_fields_save' );
register_activation_hook( __FILE__, 'install_staff_plugin' );
register_deactivation_hook( __FILE__, 'unistall_staff_plugin' );

プラグインはまさに私が言ったことを行います。ユーザープロファイルのカスタムフィールドの追加に関して、例として、3つのフィールドのみを追加しました。そのうちの1つは、ユーザーイメージに使用するためのもので、添付ファイルのIDを受け入れます。もちろん、現実の世界では、メディアアップローダーを呼び出してユーザーに画像のアップロードを選択させる方が良いですが、これはこの答えの範囲ではありません...

プラグインを保存してアクティブにしたら、ページテンプレートを作成し、ページを作成して、そのテンプレートを割り当てる必要があります。繰り返しますが、テンプレートの概念実証をここに投稿します。

<?php
/**
 * Template Name: Staff Page
*
*/

get_header(); ?>

<div id="primary" class="content-area">
<div id="content" class="site-content" role="main">

<?php
/* The page content */
while ( have_posts() ) : the_post();
    $page_link = get_permalink();
    the_content();
endwhile;

$required_user = get_query_var( 'user' );

$wanted_meta = array(
    'first_name', // This is a standard meta
    'facebook',   // This is an example of custom meta
    'Twitter'     // This is another example of custom meta
);

if ( empty( $required_user ) ) {

    /* The Users Loop */

    // Customize the args as you need
    $args = array (
        'role'    => 'Staff',
        'orderby' => 'post_count',
        'order'   => 'DESC',
        'fields'  => 'all'
    );
    $user_query = new WP_User_Query( $args );
    if ( ! empty( $user_query->results ) ) { 
        foreach ( $user_query->results as $user ) {
            $profile_url = trailingslashit($page_link) . 'user/' . $user->user_nicename;
            // This gets ALL the meta fields as a 2 dimensional array (array of arrays)
            $meta_fields = get_user_meta( $user->ID ); 
            ?>
            <div id="user-<?php echo $user->ID ?>">
            <?php
            // An example of custom meta where to save the id of an attachment
            if ( isset($meta_fields['photo_id'][0]) && ! empty($meta_fields['photo_id'][0]) ) {
                echo '<a href="' . esc_url($profile_url) . '/">';
                echo wp_get_attachment_image( $meta_fields['photo_id'][0], 'medium' );
                echo '</a>';
            }
            ?>
            <h2><?php echo '<p><a href="' .esc_url( $profile_url ) . '/">' . 
                $user->display_name . '</a></p>';?></h2>
            <p><?php echo $meta_fields['description'][0]; ?></p>
            <ul>
            <?php
            foreach ( $wanted_meta as $key ) { 
                if ( isset($meta_fields[$key][0]) && ! empty($meta_fields[$key][0]) ) {
                    ?>
                    <li><?php echo $meta_fields[$key][0]; ?></li>
                <?php } 
            } ?>
            </ul>
            </div>
            <?php
        }
    }

} else {

    /* One User Requested */

    $user = get_user_by( 'slug', $required_user );
    if ( $user ) {
        ?>
        <div id="user-<?php echo $user->ID ?>">
        <?php
        $meta_fields = get_user_meta( $user->ID );
        if ( isset( $meta_fields['photo_id'][0] ) && ! empty( $meta_fields['photo_id'][0] ) ) {
            echo wp_get_attachment_image( $meta_fields['photo_id'][0], 'full' );
        }
        ?>
        <h1><?php echo '<p>' . $user->display_name . '</p>';?></h1>
        <p><?php echo $meta_fields['description'][0]; ?></p>
        <p>
            <a href="<?php echo get_author_posts_url($user->ID); ?>"><?php 
                printf(__('See all posts by %s'), $user->display_name); ?></a> | 
            <a href="<?php echo $page_link; ?>"><?php _e('Back to Staff'); ?></a>
        </p>
        <ul>
        <?php
        foreach ( $wanted_meta as $key ) {
            if ( isset( $meta_fields[$key][0] ) && ! empty( $meta_fields[$key][0] ) ) {
                ?>
                <li><?php echo $meta_fields[$key][0]; ?></li>
                <?php 
            } 
        } ?>
        </ul>
        </div>
        <?php
    }
}
?>

</div><!-- #content -->
</div><!-- #primary -->

<?php get_footer(); ?>

次に、ページを作成し、このテンプレートを割り当てます。次に、ユーザーロール「スタッフ」をスタッフに割り当て、プロファイルを入力します。

最後の仕上げとして、author.phpに、おそらくヘッダーに次のようなものを追加できます。

<div class="author-info">
    <?php
    $curauth = ( get_query_var( 'author_name' ) ) ? 
        get_user_by( 'slug', get_query_var( 'author_name' ) ) : 
        get_userdata( get_query_var( 'author' ) );
    $photo = get_user_meta( $curauth->ID, 'photo_id', true );
    if ( $photo ) echo wp_get_attachment_image( $photo, 'medium' );
    ?>
    <h2><?php echo $curauth->display_name; ?></h2>
    <h3><em><?php echo $curauth->user_description; ?></em></h3>
</div>

それで全部です。それをテストし、改善し、楽しんでください。

16
gmazzap